var xp = { post: true, version: "2.0-beta", openFileHandler: (path) => {}, applications: { apps: {}, add: function(name, func) { xp.applications.apps[name] = func; }, remove: function(name) { delete xp.applications.apps[name]; } }, themes: ['reborn', 'classic', 'luna', 'silver', 'vista'], theme: { name: 'luna', set: function(name) { xp.theme.name = name; if (xp.theme.name !== 'default') { $('#theme').attr('href', 'system/themes/' + xp.theme.name + '.css'); } else { $('#theme').attr('href', ''); } if (saveConfig) saveConfig(); } }, wallpaper: { href: "", set: function(name) { if (name === undefined) { xp.wallpaper.set(xp.wallpaper.href); } else if (name === "") { $("._ui_wallpaper_image").attr("src", ""); xp.wallpaper.href = ""; } else { $("._ui_wallpaper_image").attr("src", name); xp.wallpaper.href = name; } if (saveConfig) saveConfig(); }, setLocal: function(path) { xp.filesystem.toURL(path, (url) => { xp.wallpaper.set(url); }); } }, icons: { error: '', warning: '', info: '' }, dialog: function(title, text, callback, isyesno, type, nocallback) { if (type === undefined) type = 'info'; var icon = undefined; if (type === 'info') icon = xp.icons.info; if (type === 'warning') icon = xp.icons.warning; if (type === 'error') icon = xp.icons.error; if (type === 'info') xp.audio.playURL('https://cdn.glitch.com/01d2e04f-e49d-4304-aa9e-55b9849b4cce%2FWindows%20XP%20Ding.wav?1522624603096'); if (type === 'warning') xp.audio.playURL('https://cdn.glitch.com/01d2e04f-e49d-4304-aa9e-55b9849b4cce%2FWindows%20XP%20Error.wav?1522624607974'); if (type === 'error') xp.audio.playURL('https://cdn.glitch.com/01d2e04f-e49d-4304-aa9e-55b9849b4cce%2FWindows%20XP%20Critical%20Stop.wav?1522624592867'); var win = new Window({ width: 340, height: 154, title: title, canResize: false, canMinimize: false }); if (isyesno) { win.content(`

` + text + `

`); } else { win.content(`

` + text + `

`); } if (isyesno) { win.el.find('.no').on('click', function() { win.close(); if (nocallback !== undefined) nocallback(); }); win.el.find('.yes').on('click', function() { win.close(); if (callback !== undefined) callback(); }).focus(); } else { win.el.find('.ok').on('click', function() { win.close(); if (callback !== undefined) callback(); }).focus(); } }, alert: function(msg, callback, nocallback) { xp.dialog('Alert', msg, callback, false, 'info', nocallback); }, error: function(msg, callback, nocallback) { xp.dialog('Error', msg, callback, false, 'error', nocallback); }, prompt: function(title, text, callback, defaulttext, nocallback) { xp.audio.playURL('https://cdn.glitch.com/01d2e04f-e49d-4304-aa9e-55b9849b4cce%2FWindows%20XP%20Ding.wav?1522624603096'); var guid = generate_guid(); var temp = document.createElement('div'); if (defaulttext === undefined) defaulttext = ""; var win = new Window({ width: 340, height: 154, title: title, canResize: false, canMinimize: false }); win.content(`

` + text + `

`); win.el.find('.prompttext').val(defaulttext); win.el.find('.cancel').on('click', function() { win.close(); if (nocallback !== undefined) nocallback(); }); win.el.find('.ok').on('click', function() { win.close(); callback(win.el.find('.prompttext').val()); }); }, chooser: function(title, text, options, callback, nocallback) { xp.audio.playURL('https://cdn.glitch.com/01d2e04f-e49d-4304-aa9e-55b9849b4cce%2FWindows%20XP%20Ding.wav?1522624603096'); var guid = generate_guid(); var optionstext = ''; for (var i = 0; i < options.length; i ++) { optionstext += ''; } var win = new Window({ width: 340, height: 154, title: title, canResize: false, canMinimize: false }); win.content(`

` + text + `

`); win.el.find('.cancel').on('click', function() { win.close(); if (nocallback !== undefined) nocallback(); }); win.el.find('.ok').on('click', function() { win.close(); callback(win.el.find('.select').val()); }); } }; $.fn.closeWindow = function() { closeWindow($(this).attr('guid')); } $.fn.setTitle = function(title) { var guid = $(this).attr('guid'); if (title === '') title = ' '; title = title.replace(/&/g,'&').replace(//g,'>'); $('window[guid=' + guid + ']').attr('title', title); $('window[guid=' + guid + ']').find('.windowTitle').html(title.replace(/ /g,' ')); $('windowbutton[guid=' + guid + '] div').html(title); }; function maximizeWindow(guid, force) { var el = $('window[guid=' + guid + ']'); if (el.attr('maximized') === 'true' && force !== true) { el.attr('maximized', 'false'); el.attr('width', el.attr('prevwidth')); el.attr('height', el.attr('prevheight')); el.css('left', el.attr('prevleft')); el.css('top', el.attr('prevtop')); } else { el.attr('maximized', 'true'); if (!force) { el.attr('prevwidth', el.attr('width')); el.attr('prevheight', el.attr('height')); el.attr('prevleft', el.css('left')); el.attr('prevtop', el.css('top')); } el.attr('width', $(window).width()); el.attr('height', $(window).height() - (el.find('.windowTitle').closest('table').height() + $('taskbar').height()) + parseInt(el.find('.windowBody').css("border-bottom-width"))); el.css('left', -parseInt(el.find('.windowBody').css("border-left-width"))); el.css('top', -parseInt(el.find('.windowBody').css("border-right-width"))); } el.updateWindow(); var event = new Event('resize'); el[0].dispatchEvent(event); } // Generate GUID function generate_guid() { function s4() { return Math.floor((1 + Math.random()) * 0x10000) .toString(16) .substring(1); } return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4(); } // Window control function closeWindow(guid) { var el = $('[guid=' + guid + ']'); $('window[guid=' + guid + ']')[0].dispatchEvent(new Event('close')); setTimeout(function() { el.remove(); }, 50); } function minimizeWindow(guid) { var el = $('[guid=' + guid + ']'); el.attr("minimized", "true"); el.attr("inactive", "true"); updateAllWindows(); } function sortProperties(obj) { // convert object into array var sortable=[]; for(var key in obj) if(obj.hasOwnProperty(key)) sortable.push([key, obj[key]]); // each item is an array in format [key, value] // sort items by value sortable.sort(function(a, b) { return a[1]-b[1]; // compare numbers }); return sortable; // array in format [ [ key1, val1 ], [ key2, val2 ], ... ] } var createdIndexes = 0; function updateIndexes(topGuid) { var newIndexes = {}; var maxIndex = 0; $("window").each(function(index) { var el = $(this); var index = parseInt(el.attr("index")); var guid = el.attr("guid"); newIndexes[guid] = index; if (index > maxIndex) maxIndex = index; }); if (topGuid === undefined) { topGuid = Object.keys(newIndexes).find(key => newIndexes[key] === maxIndex); } newIndexes[topGuid] = maxIndex + 1; newIndexes = sortProperties(newIndexes); var index = 0; for (var i = 0, len = newIndexes.length; i < len; i++) { var guid = newIndexes[i][0]; var inactive = i === len - 1 ? "false" : "true" index ++; $("window[guid=" + guid + "]").attr("index", index); $("window[guid=" + guid + "]").attr("inactive", inactive); } createdIndexes = index; } $.fn.updateWindow = function() { updateWindow(this, true); updateIndexes(); updateAllWindows(); } function hideMenu(name, guid) { $("#" + name.replace(/ /g,"_") + "_menu_" + guid).css("display", "none"); $("#" + name.replace(/ /g,"_") + "_menubutton_" + guid).removeClass('_ui_menu_item_active'); } $.fn.addMenu = function(name, items) { var guid = generate_guid(); var el = `
` + name + `