GitHub
Tests: 12 • Commercial: 2 • Pet projects: 4 • Legacy: 4
Total: 22

.NET Framework

Test
2021

Project Request

ASP.NET MVC • C# • SQL Server
Idea of the project: if someone wants to order a project development, here you can send an application.
Test
2020

ProjectC

ASP.NET MVC • C# • JSON • jQuery
JSON data processing.
Test
2020

Vehicle Maintenance

ASP.NET MVC • VB.NET • JSON
Idea of the project: if someone wants to order a project development, here you can send an application.
Test
2019

Movie Navigator

ASP.NET MVC • VB.NET
Request information about movie from IMDB.
Test
2018

Customers Exchange

ASP.NET MVC • C# • SQL Server
Automated teller machine emulation.
Test
2016

ATM

ASP.NET MVC • C#
Automated teller machine emulation.

.NET Core

Pet project
2022

Mail Daemon

.NET 8 • Console • JSON
Utility to send mails with customizable settings.

Custom

Code
2024

Buns of code

.NET Framework • C# • JavaScript
Code snippets from my projects, ready to use; tiny tests; code examples.

PHP

Test
2024

Mediabox

PHP 8 • Laravel 11 • Vue.js • Composer • SQLite
Test project for media files management.
Test
2020

Loan Castle

PHP • MariaDB
Jums jāizstrādā kāda lielāk projekta prototips. Izstrādājot prototipu, paturiet prātā, ka projektam attīstoties, šo prototipu varētu vajadzēt pilnveidot.
Test
2020

Content Management

PHP • MySQL • AJAX
Создать простой сайт, где будет страница с формой для авторизации и страница для авторизованного пользователя.
Test
2019

Laravel

PHP • Laravel • Vue.js • Composer • SQLite
Izveidot aplikāciju, kura ik pēc noteikta intervāla (60 sekundes) veic ierakstu datubāzē izmantojot Laravel freimworka iebūvēto funkcionalitāti.
Test
2019

Phone Check

PHP • JavaScript • JSON • Docker
Implement application to detect country by phone number.

Frontend

Test
2021

Forex Wall

npm • React
For this exercise, what we need is a simple live wall for tracking currencies.

Business projects

Commercial
2008

Certification Center

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • SQL Server • ADO.NET • Dapper • JavaScript • jQuery • Git
Transport registration and certification services in Latvia, Customer Relationship Management.
Commercial
2000

Amerikas Auto

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • SQL Server • ADO.NET • Entity Framework • JavaScript • jQuery • Git
Car service and spare parts for all USA and European car models, Customer Relationship Management.

Pet projects

Pet project
2023

Geolocation Assistant

.NET 8 • ASP.NET Core • C# • Web API • JSON • Git
Website for determining geolocation by IP or geotagged photo.
Pet project
2008

Web Dynamics

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • Web API • JSON • SQL Server • Dapper • JavaScript • jQuery • SVG • Git
Software development blog. Articles, books, videos, content management.
Pet project
2000

Blackball

.NET Framework 4.8 • ASP.NET Web Forms • C# • LINQ • Web API • JSON • XML • SQL Server • Dapper • JavaScript • jQuery • SVG • Git
My entertainment portal created from scratch.

Good old times

Legacy
2000

DOS Clock

Turbo Pascal • Assembler
Digital clock.
Legacy
2000

BrainOut

Turbo Pascal • Assembler
Tank battle game.
Legacy
1999

Airport Administrator

Turbo Pascal
Курсовая работа в институте.
Legacy
1998

Atomizer

Turbo Pascal • Assembler
Atomizer, aka «Studio2D». Graphic raster editor. AGI is my own «Atomizer Generated Image» file format.

ATM

2016 Test

Automated teller machine emulation.

ASP.NET MVC C#
Information
Source code
  ATM
  Home
Root / SergeyDrozdovATM.Web / Scripts / respond.js
/* NUGET: BEGIN LICENSE TEXT * * Microsoft grants you the right to use these script files for the sole * purpose of either: (i) interacting through your browser with the Microsoft * website or online service, subject to the applicable licensing or use * terms; or (ii) using the files as included with a Microsoft product subject * to that product's license terms. Microsoft reserves all other rights to the * files not expressly granted by Microsoft, whether by implication, estoppel * or otherwise. Insofar as a script file is dual licensed under GPL, * Microsoft neither took the code under GPL nor distributes it thereunder but * under the terms set out in this paragraph. All notices and licenses * below are for informational purposes only. * * NUGET: END LICENSE TEXT */ /*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas. Dual MIT/BSD license */ /*! NOTE: If you're already including a window.matchMedia polyfill via Modernizr or otherwise, you don't need this part */ window.matchMedia = window.matchMedia || (function(doc, undefined){ var bool, docElem = doc.documentElement, refNode = docElem.firstElementChild || docElem.firstChild, // fakeBody required for <FF4 when executed in <head> fakeBody = doc.createElement('body'), div = doc.createElement('div'); div.id = 'mq-test-1'; div.style.cssText = "position:absolute;top:-100em"; fakeBody.style.background = "none"; fakeBody.appendChild(div); return function(q){ div.innerHTML = '&shy;<style media="'+q+'"> #mq-test-1 { width: 42px; }</style>'; docElem.insertBefore(fakeBody, refNode); bool = div.offsetWidth == 42; docElem.removeChild(fakeBody); return { matches: bool, media: q }; }; })(document); /*! Respond.js v1.2.0: min/max-width media query polyfill. (c) Scott Jehl. MIT/GPLv2 Lic. j.mp/respondjs */ (function( win ){     //exposed namespace     win.respond        = {};          //define update even in native-mq-supporting browsers, to avoid errors     respond.update    = function(){};          //expose media query support flag for external use     respond.mediaQueriesSupported    = win.matchMedia && win.matchMedia( "only all" ).matches;          //if media queries are supported, exit here     if( respond.mediaQueriesSupported ){ return; }          //define vars     var doc             = win.document,         docElem         = doc.documentElement,         mediastyles        = [],         rules            = [],         appendedEls     = [],         parsedSheets     = {},         resizeThrottle    = 30,         head             = doc.getElementsByTagName( "head" )[0] || docElem,         base            = doc.getElementsByTagName( "base" )[0],         links            = head.getElementsByTagName( "link" ),         requestQueue    = [],                  //loop stylesheets, send text content to translate         ripCSS            = function(){             var sheets     = links,                 sl         = sheets.length,                 i        = 0,                 //vars for loop:                 sheet, href, media, isCSS;             for( ; i < sl; i++ ){                 sheet    = sheets[ i ],                 href    = sheet.href,                 media    = sheet.media,                 isCSS    = sheet.rel && sheet.rel.toLowerCase() === "stylesheet";                 //only links plz and prevent re-parsing                 if( !!href && isCSS && !parsedSheets[ href ] ){                     // selectivizr exposes css through the rawCssText expando                     if (sheet.styleSheet && sheet.styleSheet.rawCssText) {                         translate( sheet.styleSheet.rawCssText, href, media );                         parsedSheets[ href ] = true;                     } else {                         if( (!/^([a-zA-Z:]*\/\/)/.test( href ) && !base)                             || href.replace( RegExp.$1, "" ).split( "/" )[0] === win.location.host ){                             requestQueue.push( {                                 href: href,                                 media: media                             } );                         }                     }                 }             }             makeRequests();         },                  //recurse through request queue, get css text         makeRequests    = function(){             if( requestQueue.length ){                 var thisRequest = requestQueue.shift();                                  ajax( thisRequest.href, function( styles ){                     translate( styles, thisRequest.href, thisRequest.media );                     parsedSheets[ thisRequest.href ] = true;                     makeRequests();                 } );             }         },                  //find media blocks in css text, convert to style blocks         translate            = function( styles, href, media ){             var qs            = styles.match( /@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi ),                 ql            = qs && qs.length || 0,                 //try to get CSS path                 href        = href.substring( 0, href.lastIndexOf( "/" )),                 repUrls        = function( css ){                     return css.replace( /(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g, "$1" + href + "$2$3" );                 },                 useMedia    = !ql && media,                 //vars used in loop                 i            = 0,                 j, fullq, thisq, eachq, eql;             //if path exists, tack on trailing slash             if( href.length ){ href += "/"; }                                  //if no internal queries exist, but media attr does, use that                 //note: this currently lacks support for situations where a media attr is specified on a link AND                 //its associated stylesheet has internal CSS media queries.                 //In those cases, the media attribute will currently be ignored.             if( useMedia ){                 ql = 1;             }                          for( ; i < ql; i++ ){                 j    = 0;                                  //media attr                 if( useMedia ){                     fullq = media;                     rules.push( repUrls( styles ) );                 }                 //parse for styles                 else{                     fullq    = qs[ i ].match( /@media *([^\{]+)\{([\S\s]+?)$/ ) && RegExp.$1;                     rules.push( RegExp.$2 && repUrls( RegExp.$2 ) );                 }                                  eachq    = fullq.split( "," );                 eql        = eachq.length;                                      for( ; j < eql; j++ ){                     thisq    = eachq[ j ];                     mediastyles.push( {                         media    : thisq.split( "(" )[ 0 ].match( /(only\s+)?([a-zA-Z]+)\s?/ ) && RegExp.$2 || "all",                         rules    : rules.length - 1,                         hasquery: thisq.indexOf("(") > -1,                         minw    : thisq.match( /\(min\-width:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/ ) && parseFloat( RegExp.$1 ) + ( RegExp.$2 || "" ),                         maxw    : thisq.match( /\(max\-width:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/ ) && parseFloat( RegExp.$1 ) + ( RegExp.$2 || "" )                     } );                 }                 }             applyMedia();         },              lastCall,                  resizeDefer,                  // returns the value of 1em in pixels         getEmValue        = function() {             var ret,                 div = doc.createElement('div'),                 body = doc.body,                 fakeUsed = false;                                                  div.style.cssText = "position:absolute;font-size:1em;width:1em";                                  if( !body ){                 body = fakeUsed = doc.createElement( "body" );                 body.style.background = "none";             }                                  body.appendChild( div );                                              docElem.insertBefore( body, docElem.firstChild );                                              ret = div.offsetWidth;                                              if( fakeUsed ){                 docElem.removeChild( body );             }             else {                 body.removeChild( div );             }                          //also update eminpx before returning             ret = eminpx = parseFloat(ret);                                              return ret;         },                  //cached container for 1em value, populated the first time it's needed         eminpx,                  //enable/disable styles         applyMedia            = function( fromResize ){             var name        = "clientWidth",                 docElemProp    = docElem[ name ],                 currWidth     = doc.compatMode === "CSS1Compat" && docElemProp || doc.body[ name ] || docElemProp,                 styleBlocks    = {},                 lastLink    = links[ links.length-1 ],                 now         = (new Date()).getTime();             //throttle resize calls                 if( fromResize && lastCall && now - lastCall < resizeThrottle ){                 clearTimeout( resizeDefer );                 resizeDefer = setTimeout( applyMedia, resizeThrottle );                 return;             }             else {                 lastCall    = now;             }                                                      for( var i in mediastyles ){                 var thisstyle = mediastyles[ i ],                     min = thisstyle.minw,                     max = thisstyle.maxw,                     minnull = min === null,                     maxnull = max === null,                     em = "em";                                  if( !!min ){                     min = parseFloat( min ) * ( min.indexOf( em ) > -1 ? ( eminpx || getEmValue() ) : 1 );                 }                 if( !!max ){                     max = parseFloat( max ) * ( max.indexOf( em ) > -1 ? ( eminpx || getEmValue() ) : 1 );                 }                                  // if there's no media query at all (the () part), or min or max is not null, and if either is present, they're true                 if( !thisstyle.hasquery || ( !minnull || !maxnull ) && ( minnull || currWidth >= min ) && ( maxnull || currWidth <= max ) ){                         if( !styleBlocks[ thisstyle.media ] ){                             styleBlocks[ thisstyle.media ] = [];                         }                         styleBlocks[ thisstyle.media ].push( rules[ thisstyle.rules ] );                 }             }                          //remove any existing respond style element(s)             for( var i in appendedEls ){                 if( appendedEls[ i ] && appendedEls[ i ].parentNode === head ){                     head.removeChild( appendedEls[ i ] );                 }             }                          //inject active styles, grouped by media type             for( var i in styleBlocks ){                 var ss        = doc.createElement( "style" ),                     css        = styleBlocks[ i ].join( "\n" );                                  ss.type = "text/css";                     ss.media    = i;                                  //originally, ss was appended to a documentFragment and sheets were appended in bulk.                 //this caused crashes in IE in a number of circumstances, such as when the HTML element had a bg image set, so appending beforehand seems best. Thanks to @dvelyk for the initial research on this one!                 head.insertBefore( ss, lastLink.nextSibling );                                  if ( ss.styleSheet ){              ss.styleSheet.cssText = css;          }          else {                     ss.appendChild( doc.createTextNode( css ) );          }                          //push to appendedEls to track for later removal                 appendedEls.push( ss );             }         },         //tweaked Ajax functions from Quirksmode         ajax = function( url, callback ) {             var req = xmlHttp();             if (!req){                 return;             }                 req.open( "GET", url, true );             req.onreadystatechange = function () {                 if ( req.readyState != 4 || req.status != 200 && req.status != 304 ){                     return;                 }                 callback( req.responseText );             }             if ( req.readyState == 4 ){                 return;             }             req.send( null );         },         //define ajax obj         xmlHttp = (function() {             var xmlhttpmethod = false;                 try {                 xmlhttpmethod = new XMLHttpRequest();             }             catch( e ){                 xmlhttpmethod = new ActiveXObject( "Microsoft.XMLHTTP" );             }             return function(){                 return xmlhttpmethod;             };         })();          //translate CSS     ripCSS();          //expose update for re-running respond later on     respond.update = ripCSS;          //adjust on resize     function callMedia(){         applyMedia( true );     }     if( win.addEventListener ){         win.addEventListener( "resize", callMedia, false );     }     else if( win.attachEvent ){         win.attachEvent( "onresize", callMedia );     } })(this);