From 752b78f3006b4990152e73104e269574bdb523ec Mon Sep 17 00:00:00 2001 From: khaybarkhaybaryayahud <156494330+khaybarkhaybaryayahud@users.noreply.github.com> Date: Sun, 21 Jan 2024 20:52:31 -0500 Subject: [PATCH] Add files via upload --- xp/boot/assets/logo.png | Bin 0 -> 6515 bytes xp/boot/assets/progress.gif | Bin 0 -> 1427 bytes xp/boot/boot.css | 29 + xp/boot/load.js | 150 ++++++ xp/index.html | 24 + xp/program/browser.js | 102 ++++ xp/program/imageviewer.js | 18 + xp/program/mediaplayer.js | 23 + xp/program/minesweeper.js | 30 ++ xp/program/notepad.js | 56 ++ xp/program/paint.js | 30 ++ xp/program/terminal.js | 94 ++++ xp/system/audio.js | 38 ++ xp/system/config.js | 34 ++ xp/system/contextmenus.css | 19 + xp/system/contextmenus.js | 196 +++++++ xp/system/controlpanel.js | 254 +++++++++ xp/system/core.js | 620 +++++++++++++++++++++ xp/system/cursors.css | 19 + xp/system/desktop.css | 79 +++ xp/system/explorer.css | 97 ++++ xp/system/explorer.js | 690 ++++++++++++++++++++++++ xp/system/filesystem.js | 227 ++++++++ xp/system/fonts.css | 49 ++ xp/system/help.js | 29 + xp/system/icons.css | 71 +++ xp/system/jquery.terminal-2.0.0.min.css | 28 + xp/system/jquery.terminal-2.0.0.min.js | 41 ++ xp/system/lambda.js | 639 ++++++++++++++++++++++ xp/system/script.js | 44 ++ xp/system/startmenu.css | 136 +++++ xp/system/uac.js | 396 ++++++++++++++ xp/system/uac_app.js | 396 ++++++++++++++ xp/system/unix_formatting.js | 613 +++++++++++++++++++++ xp/system/widgets.css | 108 ++++ xp/system/window-api.js | 88 +++ xp/system/window.css | 305 +++++++++++ xp/system/xp.css | 369 +++++++++++++ xp/system/xp.js | 482 +++++++++++++++++ 39 files changed, 6623 insertions(+) create mode 100644 xp/boot/assets/logo.png create mode 100644 xp/boot/assets/progress.gif create mode 100644 xp/boot/boot.css create mode 100644 xp/boot/load.js create mode 100644 xp/index.html create mode 100644 xp/program/browser.js create mode 100644 xp/program/imageviewer.js create mode 100644 xp/program/mediaplayer.js create mode 100644 xp/program/minesweeper.js create mode 100644 xp/program/notepad.js create mode 100644 xp/program/paint.js create mode 100644 xp/program/terminal.js create mode 100644 xp/system/audio.js create mode 100644 xp/system/config.js create mode 100644 xp/system/contextmenus.css create mode 100644 xp/system/contextmenus.js create mode 100644 xp/system/controlpanel.js create mode 100644 xp/system/core.js create mode 100644 xp/system/cursors.css create mode 100644 xp/system/desktop.css create mode 100644 xp/system/explorer.css create mode 100644 xp/system/explorer.js create mode 100644 xp/system/filesystem.js create mode 100644 xp/system/fonts.css create mode 100644 xp/system/help.js create mode 100644 xp/system/icons.css create mode 100644 xp/system/jquery.terminal-2.0.0.min.css create mode 100644 xp/system/jquery.terminal-2.0.0.min.js create mode 100644 xp/system/lambda.js create mode 100644 xp/system/script.js create mode 100644 xp/system/startmenu.css create mode 100644 xp/system/uac.js create mode 100644 xp/system/uac_app.js create mode 100644 xp/system/unix_formatting.js create mode 100644 xp/system/widgets.css create mode 100644 xp/system/window-api.js create mode 100644 xp/system/window.css create mode 100644 xp/system/xp.css create mode 100644 xp/system/xp.js diff --git a/xp/boot/assets/logo.png b/xp/boot/assets/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..21f3cacc1ac6b590a147db709c42c06dd3dd90be GIT binary patch literal 6515 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 literal 0 HcmV?d00001 diff --git a/xp/boot/boot.css b/xp/boot/boot.css new file mode 100644 index 00000000..bf0d970a --- /dev/null +++ b/xp/boot/boot.css @@ -0,0 +1,29 @@ +body { + padding: 0; + margin: 0; +} +._ui_boot { + background: #000000; + width: 100%; + height: 100%; +} +._ui_boot_logo { + height: 150px; + width: 126px; + position: absolute; + top: 50%; + left: 50%; + margin: -75px 0 0 -63px; +} +._ui_boot_winlogo { + background-image: url("assets/logo.png"); + width: 118px; + height: 104px; +} +._ui_boot_progress { + background-image: url("assets/progress.gif"); + width: 126px; + height: 15px; + position: absolute; + bottom: 0; +} diff --git a/xp/boot/load.js b/xp/boot/load.js new file mode 100644 index 00000000..86ffbdd9 --- /dev/null +++ b/xp/boot/load.js @@ -0,0 +1,150 @@ +var scripts = [ + 'system/core.js', + 'system/window-api.js', + 'system/contextmenus.js', + 'system/filesystem.js', + 'system/xp.js', + 'system/jquery.terminal-2.0.0.min.js', + 'system/unix_formatting.js', + 'program/terminal.js', + 'system/script.js', + 'system/explorer.js', + 'system/help.js', + 'program/browser.js', + 'program/notepad.js', + 'program/imageviewer.js', + 'program/mediaplayer.js', + 'system/config.js', + 'system/controlpanel.js', + 'system/uac.js', + 'system/uac_app.js', + 'system/audio.js', + 'system/lambda.js', + 'program/minesweeper.js', + 'program/paint.js', + '//xpstore.glitch.me/appstore.js', + 'boot/boot.js' +]; +var stylesheets = [ + 'system/fonts.css', + 'system/xp.css', + 'system/icons.css', + 'system/widgets.css', + 'system/window.css', + 'system/contextmenus.css', + 'system/cursors.css', + 'system/desktop.css', + 'system/startmenu.css', + 'system/explorer.css', + 'system/jquery.terminal-2.0.0.min.css' +]; +var requiredDirectories = []; + +$(function() { + $('windows').html(` +
+ + + +
`); + console.log('Loading scripts and stylesheets...'); + $('', {rel: 'stylesheet', href: 'boot/boot.css'}).appendTo('head'); + var scriptsindex = 0; + var stylesindex = 0; + + function loadStylesheets() { + $.ajax({ + url: stylesheets[stylesindex], + dataType: "script", + success: function(data){ + $("head").append(""); + stylesindex ++; + if (stylesindex < stylesheets.length) { + loadStylesheets(); + } else { + loadScripts(); + } + } + }); + } + + function loadScripts() { + $.ajax({ + url: scripts[scriptsindex], + dataType: "script", + success: function(data){ + scriptsindex ++; + if (scriptsindex < scripts.length) { + loadScripts(); + } else { + console.log('Finished loading'); + console.log('Checking for necessary directories'); + + function checkDir(path, callback) { + var times = 0; + xp.filesystem.listDir(path, (e) => { + if (times === 0) + callback(typeof e === 'string'); + times ++; + }); + } + + var i = 0; + function checkNextDir(t) { + var dirToCreate = requiredDirectories[i]; + if (dirToCreate !== undefined) { + xp.filesystem.createDir(dirToCreate, (e) => { + i ++; + checkNextDir(); + }); + } else { + xp.audio.init(); + var event = new Event('xpboot'); + window.dispatchEvent(event); + console.log('Dispatched boot event'); + $('windows').html('
'); + $.getScript('system/login.js'); + xp.audio.playURL('boot/assets/startup.wav'); + } + } + + xp.filesystem.create(512*1024*1024, () => { + xp.filesystem.fs.root.getDirectory('/', {create: false}, function(dirEntry) { + var dirReader = dirEntry.createReader(); + var entries = []; + + function readEntries() { + dirReader.readEntries (function(results) { + if (results.length === 0) { + $('._ui_boot').remove(); + $('windows').html('
'); + $.getScript('setup/setup.js'); + } else { + xp.filesystem.createDir('/WINDOWS', (e) => { + requiredDirectories = [ + '/WINDOWS', + '/WINDOWS/system32', + '/WINDOWS/startup', + '/Program Files', + '/Documents and Settings' + ]; + checkNextDir(); + }); + } + }, console.error); + }; + + readEntries(); + }, console.error); + }); + } + } + }); + } + + loadStylesheets(); +}); diff --git a/xp/index.html b/xp/index.html new file mode 100644 index 00000000..d43f93dd --- /dev/null +++ b/xp/index.html @@ -0,0 +1,24 @@ + + + RebornXP + + + + + + + + + + + + + + + + + + diff --git a/xp/program/browser.js b/xp/program/browser.js new file mode 100644 index 00000000..e5412e65 --- /dev/null +++ b/xp/program/browser.js @@ -0,0 +1,102 @@ +function browserGo(loc, guid) { + if(!loc){ + loc = document.getElementById('url_' + guid).value; + } + if (loc.indexOf('http://') == -1 && loc.indexOf('https://') == -1) { + loc = location.protocol + '//' + loc; + } + document.getElementById('webPage_' + guid).src = loc; + document.getElementById('url_' + guid).value = loc; + document.getElementById('loading_' + guid).style.display = 'block'; + document.getElementById('webPage_' + guid).style.display = 'none'; +} +function iframeContentUnload(guid) { + document.getElementById('loading_' + guid).style.display = 'block'; + document.getElementById('webPage_' + guid).style.display = 'none'; +} +function iframeContentLoaded(guid) { + document.getElementById('loading_' + guid).style.display = 'none'; + document.getElementById('webPage_' + guid).style.display = 'block'; +} + +$(window).on('xpboot', function() { + xp.applications.add('browser', (args) => { + var guid = generate_guid(); + var el = $.parseHTML(` + + + + + +
+ + + + + + +
+
+ + +
+
+
`); + document.body.appendChild(el[0]); + $(el).updateWindow(); + var widthOffset = 30; + var heightOffset = 80; + window.iFrameChanges = -1; + }); + + xp.applications.add('html', (args) => { + var el = $.parseHTML(` + +
+ +
+
`); + document.body.appendChild(el[0]); + $(el).updateWindow(); + }); + + xp.startmenu.add('browser', 'Idiot Explorer 6', 'program/assets/ie.webp'); +}); diff --git a/xp/program/imageviewer.js b/xp/program/imageviewer.js new file mode 100644 index 00000000..9183d264 --- /dev/null +++ b/xp/program/imageviewer.js @@ -0,0 +1,18 @@ +$(window).on('xpboot', () => { + xp.applications.add('image-viewer', (args) => { + var image = args.length > 1 ? xp.filesystem.addPaths(args[0], args[1]) : ''; + var imagename = xp.filesystem.basename(image); + var win = new Window({ + width: 640, + height: 480, + title: image === '' ? 'Image Viewer' : (imagename + ' - Image Viewer') + }); + xp.filesystem.toURL(image, (url) => { + win.content('
'); + }); + }); + explorer.fileHandlers.add('png', (f) => openApp('image-viewer', ['', f])); + explorer.fileHandlers.add('jpg', (f) => openApp('image-viewer', ['', f])); + explorer.fileHandlers.add('jpeg', (f) => openApp('image-viewer', ['', f])); + explorer.fileHandlers.add('gif', (f) => openApp('image-viewer', ['', f])); +}); \ No newline at end of file diff --git a/xp/program/mediaplayer.js b/xp/program/mediaplayer.js new file mode 100644 index 00000000..0a079d2b --- /dev/null +++ b/xp/program/mediaplayer.js @@ -0,0 +1,23 @@ +$(window).on('xpboot', () => { + xp.applications.add('media-player', (args) => { + var video = args.length > 1 ? xp.filesystem.addPaths(args[0], args[1]) : ''; + var videoname = xp.filesystem.basename(video); + var win = new Window({ + width: 480, + height: 360, + title: video === '' ? 'Media Player' : (videoname + ' - Media Player') + }); + xp.filesystem.toURL(video, (url) => { + win.content(``); + }); + }); + explorer.fileHandlers.add('webm', (f) => openApp('media-player', ['', f])); + explorer.fileHandlers.add('wav', (f) => openApp('media-player', ['', f])); + explorer.fileHandlers.add('ogg', (f) => openApp('media-player', ['', f])); + explorer.fileHandlers.add('ogv', (f) => openApp('media-player', ['', f])); + explorer.fileHandlers.add('mp3', (f) => openApp('media-player', ['', f])); + explorer.fileHandlers.add('mp4', (f) => openApp('media-player', ['', f])); + explorer.fileHandlers.add('flac', (f) => openApp('media-player', ['', f])); +}); \ No newline at end of file diff --git a/xp/program/minesweeper.js b/xp/program/minesweeper.js new file mode 100644 index 00000000..bae4a8c9 --- /dev/null +++ b/xp/program/minesweeper.js @@ -0,0 +1,30 @@ +$(window).on('xpboot', () => { + xp.applications.add('minesweeper', () => { + var el = $.parseHTML(` + + +
+ + +
+
`); + document.body.appendChild(el[0]); + $(el).updateWindow(); + }); + xp.startmenu.add('minesweeper', 'Minesweeper', 'https://w7.pngwing.com/pngs/337/559/png-transparent-minesweeper-computer-icons-bing-maps-video-game-mines-miscellaneous-game-angle.png'); +}); diff --git a/xp/program/notepad.js b/xp/program/notepad.js new file mode 100644 index 00000000..d5dd927a --- /dev/null +++ b/xp/program/notepad.js @@ -0,0 +1,56 @@ +$(window).on('xpboot', () => { + xp.applications.add('notepad', (args) => { + var guid = generate_guid(); + var el = $.parseHTML(` + +`); + document.body.appendChild(el[0]); + $(el).updateWindow(); + $(el).addMenu("File", [ + ["New", function() { + $("#notepad_" + guid).val(""); + $("#notepad_" + guid).attr('filename', ''); + }], + ["Open", function() { + xp.filesystem.openFileDialog((filename) => { + xp.filesystem.readFile(filename, function(e) { + //e = e.split("\0")[0]; + $("#notepad_" + guid).val(e); + $("#notepad_" + guid).attr("filename", filename); + }); + }); + }], + ["Save", function() { + var filename = $("#notepad_" + guid).attr("filename"); + if (filename === "") { + xp.filesystem.saveFileDialog((filename) => { + xp.filesystem.writeFile(filename, new Blob([$("#notepad_" + guid).val()], {type: 'text/plain'}), (e) => { + if (e) xp.dialog('Error', e); + }); + }); + } else { + xp.filesystem.writeFile(filename, new Blob([$("#notepad_" + guid).val()], {type: 'text/plain'}), (e) => { + if (e) xp.dialog('Error', e); + }); + } + }], + ["Save As", function() { + xp.filesystem.saveFileDialog((filename) => { + xp.filesystem.writeFile(filename, new Blob([$("#notepad_" + guid).val()], {type: 'text/plain'}), (e) => { + if (e) xp.dialog('Error', e); + }); + }); + }] + ]); + + if (args !== undefined && args[1] !== undefined) { + var filename = xp.filesystem.addPaths(args[0], args[1]); + xp.filesystem.readFile(filename, function(e) { + //e = e.split("\0")[0]; + $("#notepad_" + guid).val(e); + $("#notepad_" + guid).attr("filename", filename); + }); + } + }); + xp.startmenu.add('notepad', 'Notepad', '//cdn.glitch.com/01d2e04f-e49d-4304-aa9e-55b9849b4cce%2Fnotepad.png?1521328884236'); +}); \ No newline at end of file diff --git a/xp/program/paint.js b/xp/program/paint.js new file mode 100644 index 00000000..88e6e05b --- /dev/null +++ b/xp/program/paint.js @@ -0,0 +1,30 @@ +$(window).on('xpboot', () => { + xp.applications.add('paint', () => { + var el = $.parseHTML(` + + +
+ + +
+
`); + document.body.appendChild(el[0]); + $(el).updateWindow(); + }); + xp.startmenu.add('paint', 'Paint', 'https://raw.githubusercontent.com/1j01/jspaint/master/images/icons/512x512.png'); +}); diff --git a/xp/program/terminal.js b/xp/program/terminal.js new file mode 100644 index 00000000..43618d48 --- /dev/null +++ b/xp/program/terminal.js @@ -0,0 +1,94 @@ +var terminalicon = ''; + +$(window).on('xpboot', () => { + xp.applications.add("terminal", () => { + var guid = generate_guid(); + var el = $.parseHTML(` +
+
`); + document.body.appendChild(el[0]); + el = $(el); + el.updateWindow(); + $("#terminal_" + guid).terminal(function(command) { + var term = this; + if (command !== '') { + try { + var args = command.split(" "); + if (this.dir === undefined) + this.dir = [""]; + if (args[0] === "ls") { + xp.filesystem.listDir(xp.filesystem.getDir(this.dir), function(e){if(e){term.echo(e)}}); + } else if (args[0] === "cd") { + if (args[1] === undefined) { + this.error("Not enough arguments"); + } else { + let input = args.slice(1).join(' '); + if (input !== ".") { + if (input.charAt(0) === "/") { + this.dir = input.split("/"); + } else { + var foo = input.split("/"); + var _this = this; + foo.forEach(function(val, i) { + if (val === "..") { + _this.dir.splice(-1,1) + } else { + _this.dir = _this.dir.concat(val); + } + }); + } + } + } + } else if (args[0] === "pwd") { + this.echo(xp.filesystem.getDir(this.dir)); + } else if (args[0] === "touch") { + xp.filesystem.createFile(xp.filesystem.addPaths(xp.filesystem.getDir(this.dir), args[1]), function(e){if(e){term.echo(e)}}); + } else if (args[0] === "rm") { + xp.filesystem.deleteFile(xp.filesystem.addPaths(xp.filesystem.getDir(this.dir), args[1]), function(e){if(e){term.echo(e)}}); + } else if (args[0] === "mkdir") { + xp.filesystem.createDir(xp.filesystem.addPaths(xp.filesystem.getDir(this.dir), args[1]), function(e){if(e){term.echo(e)}}); + } else if (args[0] === "rmdir") { + xp.filesystem.deleteDir(xp.filesystem.addPaths(xp.filesystem.getDir(this.dir), args[1]), function(e){if(e){term.echo(e)}}); + } else if (args[0] === "cat") { + xp.filesystem.readFile(xp.filesystem.addPaths(xp.filesystem.getDir(this.dir), args[1]), function(e){if(e){term.echo(e)}}); + } else if (args[0] === "help") { + this.echo("DE: XPerience"); + this.echo("Kernel: RXP vOS.2023"); + this.echo("Shell: JQuery Terminal"); + this.echo("GitHub: github.com/shoaib-jamal/RebornXP"); + this.echo("\nInstalled applications:"); + var foo = ""; + for (var name in xp.applications.apps) { + foo += name + ", "; + } + foo = foo.slice(0, -2); + this.echo(foo); + this.echo("\nSystem commands:"); + this.echo("ls, cd, pwd, touch, rm, mkdir, rmdir, cat, help"); + } else if (xp.applications.apps[args[0]] !== undefined) { + xp.applications.apps[args[0]]([xp.filesystem.getDir(this.dir)].concat(args.slice(1))); + } else { + var result = window.eval(command); + if (result !== undefined) { + this.echo(new String(result)); + } + } + } catch(e) { + this.error(new String(e)); + } + } else { + this.echo(''); + } + }, { + greetings: ` + RebornXP [vOS.2023] + (c) RebornXP Open-Source Project. All rights reserved. +`, + name: 'xpjs_terminal', + width: '100%', + height: '100%', + prompt: '> ' + }); + }); + xp.startmenu.add("terminal", "Terminal", terminalicon); +}); diff --git a/xp/system/audio.js b/xp/system/audio.js new file mode 100644 index 00000000..63b91c1b --- /dev/null +++ b/xp/system/audio.js @@ -0,0 +1,38 @@ +xp.audio = { + context: null, + cache: {}, + init: function() { + try { + window.AudioContext = window.AudioContext || window.webkitAudioContext; + xp.audio.context = new AudioContext(); + } + catch(e) { + console.error('Web Audio API is not supported in this browser'); + } + }, + playURL: function(url) { + if (xp.audio.cache[url] !== undefined) { + var source = xp.audio.context.createBufferSource(); + source.buffer = xp.audio.cache[url]; + source.connect(xp.audio.context.destination); + source.start(0); + } else { + var request = new XMLHttpRequest(); + request.open('GET', url, true); + request.responseType = 'arraybuffer'; + request.onload = function() { + if (xp.audio.context === null) { + xp.audio.init(); + } + xp.audio.context.decodeAudioData(request.response, function(buffer) { + var source = xp.audio.context.createBufferSource(); + source.buffer = buffer; + xp.audio.cache[url] = buffer; + source.connect(xp.audio.context.destination); + source.start(0); + }, console.error); + } + request.send(); + } + } +}; \ No newline at end of file diff --git a/xp/system/config.js b/xp/system/config.js new file mode 100644 index 00000000..a71602b3 --- /dev/null +++ b/xp/system/config.js @@ -0,0 +1,34 @@ +var configFile = ''; +var config = {}; +var loadingconfig = false; + +function saveConfig(callback) { + if (!loadingconfig) { + config.wallpaper = xp.wallpaper.href; + config.profile = xp.profile; + config.theme = xp.theme.name; + xp.filesystem.writeFile(configFile, new Blob([JSON.stringify(config)], {type: 'text/plain'}), (e) => { + if (e) xp.error(e); + else if (callback !== undefined) callback() + }); + } +} + +function loadConfig(callback) { + loadingconfig = true; + xp.filesystem.readFile(configFile, (text) => { + try { + config = JSON.parse(text); + console.log(config); + xp.wallpaper.set('https://rebornxp.js.org/system/themes/XP.jpg'); + xp.profile = config.profile; + xp.theme.set('reborn'); + } catch(e) { + xp.wallpaper.set('https://rebornxp.js.org/system/themes/XP.jpg'); + loadingconfig = false; + saveConfig(); + } + loadingconfig = false; + if (callback !== undefined) callback(); + }); +} diff --git a/xp/system/contextmenus.css b/xp/system/contextmenus.css new file mode 100644 index 00000000..22093e85 --- /dev/null +++ b/xp/system/contextmenus.css @@ -0,0 +1,19 @@ +.contextMenu { + box-shadow: 0px 0px 20px -5px #000; + clip-path: inset(0 -20px -20px 0); +} + +.contextMenuItem { + color: #000000; + background-color: transparent; + font-size: 11px; +} + +.contextMenuItem:hover { + color: #ffffff; + background-color: #0A246A; +} + +.contextMenuItem.hr { + border-top: 1px solid #979797; +} \ No newline at end of file diff --git a/xp/system/contextmenus.js b/xp/system/contextmenus.js new file mode 100644 index 00000000..9513b75f --- /dev/null +++ b/xp/system/contextmenus.js @@ -0,0 +1,196 @@ +var vContextMenu = Array(); +var isContextMenu = false; +var CurX; +var CurY; +var tContextMenu; + +function fMouseDown(event) { + try { + if(window.event) event = window.event; + CurX = event.clientX; + CurY = event.clientY; + if (document.getElementById('lContextMenu').style.visibility === 'hidden') + tContextMenu = event.target; + } catch(e) {} +} + +function rcContextMenu() { + try { + if (vContextMenu.length != 0) { + + drawContextMenu(); + + var targX = CurX; //0; //event.clientX; + var targY = CurY; //0; //event.clientY; + + //alert + + var testW = document.getElementById('lContextMenu').offsetWidth; + var testH = document.getElementById('lContextMenu').offsetHeight; + + var testX = targX + document.getElementById('lContextMenu').offsetWidth; + var testY = targY + document.getElementById('lContextMenu').offsetHeight; + + var sW = document.body.clientWidth;//document.body.clientWidth; + var sH = document.body.clientHeight;//document.body.clientHeight; + + if (testX >= sW) { targX = targX - testW; } + if (testY >= sH) { targY = targY - testH; } + + document.getElementById('lContextMenu').style.left = targX; + document.getElementById('lContextMenu').style.top = targY; + document.getElementById('lContextMenu').style.visibility = 'visible'; + + } + } catch (e) {} +} + +function rcCloseContext() { + try { + document.getElementById('lContextMenu').style.left = 0; + document.getElementById('lContextMenu').style.top = 0; + document.getElementById('lContextMenu').style.visibility = 'hidden'; + } catch (e) {} +} + +function drawContextMenu() { + try { + var outMsg = '
'; + + var len = vContextMenu.length - 1; + + var inMsg = vContextMenu[0]; + var inCmd = vContextMenu[1]; + if (typeof inCmd !== 'string') { + outMsg = outMsg + ''; + } else { + outMsg = outMsg + ''; + } + + for (var i = 2; i <= len; i ++) { + inMsg = vContextMenu[i]; + inCmd = vContextMenu[i+1]; + + if (inMsg != '-HR-') { + if (typeof inCmd !== 'string') { + var outMsg = outMsg + ''; + } else { + var outMsg = outMsg + ''; + } + i ++; + } else { + i ++; + inMsg = vContextMenu[i]; + inCmd = vContextMenu[i+1]; + if (typeof inCmd !== 'string') { + outMsg = outMsg + ''; + } else { + outMsg = outMsg + ''; + } + i ++; + } + } + + outMsg = outMsg + '
' + inMsg + '
' + inMsg + '
' + inMsg + '
' + inMsg + '
' + inMsg + '
' + inMsg + '
'; + + document.getElementById('lContextMenu').innerHTML = outMsg; + + // JQuery magic + $('#lContextMenu').find('td[commandindex]').each(function() { + $(this).on('click', function() { + rcCloseContext(); + vContextMenu[parseInt($(this).attr('commandindex'))](); + }); + }); + } catch(e) {} +} + +function desktopContextMenu(e) { + var el = $(e.target); + if (el.closest('windowbutton').length > 0) { + var guid = el.closest('windowbutton').attr('guid'); + vContextMenu = Array(); + if ($('window[guid=' + guid + ']').attr('maximized') === 'true') { + vContextMenu.push('Restore'); + vContextMenu.push('maximizeWindow(\'' + guid + '\')'); + } else if ($('window[guid=' + guid + ']').find('.maximize').length > 0 || $('window[guid=' + guid + ']').find('.restore').length > 0) { + vContextMenu.push('Maximize'); + vContextMenu.push('maximizeWindow(\'' + guid + '\')'); + } + if ($('window[guid=' + guid + ']').attr('minimized') === 'true') { + vContextMenu.push('Restore'); + vContextMenu.push('moveWindowToTop(\'' + guid + '\')'); + } else if ($('window[guid=' + guid + ']').find('.minimize').length > 0) { + vContextMenu.push('Minimize'); + vContextMenu.push('minimizeWindow(\'' + guid + '\')'); + } + if ($('window[guid=' + guid + ']').find('.close').length > 0) { + vContextMenu.push('Close'); + vContextMenu.push('closeWindow(\'' + guid + '\')'); + } + rcContextMenu(); + } else if (el.closest('.ui_icon').length > 0) { + el = el.closest('.ui_icon'); + vContextMenu = Array('Open', () => eval(el.data('exe')), 'Explore', () => openLocation(el.data('target')), '-HR-', 'Create Shortcut', '', 'Delete',() => el.remove(), 'Rename', () => xp.prompt('Rename', 'Enter the new name:', (t) => {el.find('span').html(t)}), '-HR-'); + rcContextMenu(); + } +} + +function getSelectionText() { + var text = ""; + var activeEl = document.activeElement; + var activeElTagName = activeEl ? activeEl.tagName.toLowerCase() : null; + if ( + (activeElTagName == "textarea") || (activeElTagName == "input" && + /^(?:text|search|password|tel|url)$/i.test(activeEl.type)) && + (typeof activeEl.selectionStart == "number") + ) { + text = activeEl.value.slice(activeEl.selectionStart, activeEl.selectionEnd); + } else if (window.getSelection) { + text = window.getSelection().toString(); + } + return text; +} + +function windowContextMenu(e, guid) { + var el = $('window[guid=' + guid + ']'); + var t = e.target.nodeName; + console.log(t); + vContextMenu = Array(); + var type = ($(e.target).attr('type') || '').toLowerCase(); + if (t === 'TEXTAREA' || (t === 'INPUT' && (type === 'text' || type === 'number'))) { + vContextMenu.push('Copy'); + vContextMenu.push('document.execCommand(\'copy\')'); + vContextMenu.push('Paste'); + vContextMenu.push('document.execCommand(\'paste\')'); + vContextMenu.push('-HR-'); + } + if (el.attr('maximized') === 'true') { + vContextMenu.push('Restore'); + vContextMenu.push('maximizeWindow(\'' + guid + '\')'); + } else if (el.find('.maximize').length > 0) { + vContextMenu.push('Maximize'); + vContextMenu.push('maximizeWindow(\'' + guid + '\')'); + } + if (el.attr('minimized') === 'true') { + vContextMenu.push('Restore'); + vContextMenu.push('moveWindowToTop(\'' + guid + '\')'); + } else if (el.find('.minimize').length > 0) { + vContextMenu.push('Minimize'); + vContextMenu.push('minimizeWindow(\'' + guid + '\')'); + } + if (el.find('.close').length > 0) { + vContextMenu.push('Close'); + vContextMenu.push('closeWindow(\'' + guid + '\')'); + } + rcContextMenu(); +} + +function startContextMenu(e) { + var el = $(e.target); + if (!(el.is('li.startmenuitem') || el.is('li.startmenuitem>img') || el.is('li.startmenuitem>div') || el.is('li.startmenuitem>div>div') || el.is('li.startmenuitem>div>div>b'))) return; + if (!el.is('li.startmenuitem')) + el = el.closest('li'); + vContextMenu = Array('Open', el.attr('onclick'), 'Explore', el.attr('onclick'), '-HR-', 'Create Shortcut', '', 'Delete',() => el.remove(), 'Rename', () => xp.prompt('Rename', 'Enter the new name:', (t) => {el.find('div>div>b').html(t)}), '-HR-'); + rcContextMenu(); +} \ No newline at end of file diff --git a/xp/system/controlpanel.js b/xp/system/controlpanel.js new file mode 100644 index 00000000..d8ff8c62 --- /dev/null +++ b/xp/system/controlpanel.js @@ -0,0 +1,254 @@ +var configFile = 'config.json'; + +// Load the config on startup +$(window).on('xpboot', function() { + loadConfig(); +}); + +function saveConfig(callback) { + if (!loadingconfig) { + config.wallpaper = xp.wallpaper.href; + config.profile = xp.profile; + config.theme = xp.theme.name; + xp.filesystem.writeFile(configFile, new Blob([JSON.stringify(config)], {type: 'text/plain'}), (e) => { + if (e) xp.error(e); + else if (callback !== undefined) callback(); + }); + } +} + +function loadConfig(callback) { + loadingconfig = true; + xp.filesystem.readFile(configFile, (text) => { + try { + config = JSON.parse(text); + xp.wallpaper.set(config.wallpaper || 'https://rebornxp.js.org/system/themes/XP.jpg'); + xp.profile = config.profile; + xp.theme.set(config.theme || 'reborn'); + } catch (e) { + xp.wallpaper.set('https://rebornxp.js.org/system/themes/XP.jpg'); + loadingconfig = false; + saveConfig(); + } + loadingconfig = false; + if (callback !== undefined) callback(); + }); +} + +// Add theme chooser to Control Panel +xp.controlpanel.add('Themes', () => { + var win = new Window({ + width: 400, + height: 200, // Increased height to accommodate the wallpaper change option + title: 'Change Theme', + canResize: false, + }); + + win.content(` +
+

Theme Chooser

+

Choose a new theme to apply:

+ +

+ + +
+ `); + + win.el.find('#applyThemeBtn').on('click', function() { + const selectedTheme = win.el.find('#themeSelect').val(); + xp.theme.set(selectedTheme); + saveConfig(); + win.close(); + }); + + win.el.find('#changeWallpaperBtn').on('click', function() { + const wallpaperDialog = new Window({ + width: 400, + height: 250, + title: 'Change Wallpaper', + canResize: false, + }); + + wallpaperDialog.content(` +
+

Wallpaper Chooser

+

Select a wallpaper:

+
+ +
+
+ + +
+ `); + + const thumbnailsContainer = wallpaperDialog.el.find('.wallpaper-thumbnails'); + + // Add your wallpaper thumbnails here using the following format + const wallpaperThumbnails = [ + 'system/themes/XP.jpg', + 'system/themes/wallpapers/anniversary.png', + 'system/themes/wallpapers/3.jpg', + 'system/themes/wallpapers/4.jpg', + 'system/themes/wallpapers/5.jpg', + 'system/themes/wallpapers/6.jpg', + ]; + + wallpaperThumbnails.forEach(thumbnail => { + const thumbnailElement = $('') + .attr('src', thumbnail) + .addClass('wallpaper-thumbnail') + .attr('width', "100px") + .attr('height', "60px") + + + .on('click', function() { + const selectedWallpaper = $(this).attr('src'); + xp.wallpaper.set(selectedWallpaper); + saveConfig(); + }); + thumbnailsContainer.append(thumbnailElement); + }); + + wallpaperDialog.el.find('#applyWallpaperBtn').on('click', function() { + const wallpaperLink = wallpaperDialog.el.find('#wallpaperLink').val(); + if (wallpaperLink) { + xp.wallpaper.set(wallpaperLink); + saveConfig(); + } + wallpaperDialog.close(); + }); + + + }); + + // Calculate window position to center it on the screen + const screenWidth = $(window).width(); + const screenHeight = $(window).height(); + const windowWidth = win.el.outerWidth(); + const windowHeight = win.el.outerHeight(); + const left = (screenWidth - windowWidth) / 2; + const top = (screenHeight - windowHeight) / 2; + + win.el.css({ + position: 'absolute', + left: left + 'px', + top: top + 'px', + }); + + win.el.find('.content').css({ + padding: '20px', // Adjust the padding value as needed + }); +}); + +// Add theme chooser as an application +xp.applications.add('themes', () => { + var win = new Window({ + width: 400, + height: 200, // Increased height to accommodate the wallpaper change option + title: 'Change Theme', + canResize: false, + }); + + win.content(` +
+

Theme Chooser

+

Choose a new theme to apply:

+ +

+ + +
+ `); + + win.el.find('#applyThemeBtn').on('click', function() { + const selectedTheme = win.el.find('#themeSelect').val(); + xp.theme.set(selectedTheme); + saveConfig(); + win.close(); + }); + + win.el.find('#changeWallpaperBtn').on('click', function() { + const wallpaperDialog = new Window({ + width: 400, + height: 250, + title: 'Change Wallpaper', + canResize: false, + }); + + wallpaperDialog.content(` +
+

Wallpaper Chooser

+

Select a wallpaper:

+
+ +
+
+ + +
+ `); + + const thumbnailsContainer = wallpaperDialog.el.find('.wallpaper-thumbnails'); + + // Add your wallpaper thumbnails here using the following format + const wallpaperThumbnails = [ + 'system/themes/XP.jpg', + 'system/themes/wallpapers/anniversary.png', + 'system/themes/wallpapers/3.jpg', + 'system/themes/wallpapers/4.jpg', + 'system/themes/wallpapers/5.jpg', + 'system/themes/wallpapers/6.jpg', + ]; + + wallpaperThumbnails.forEach(thumbnail => { + const thumbnailElement = $('') + .attr('src', thumbnail) + .addClass('wallpaper-thumbnail') + .attr('width', "100px") + .attr('height', "60px") + + + .on('click', function() { + const selectedWallpaper = $(this).attr('src'); + xp.wallpaper.set(selectedWallpaper); + saveConfig(); + }); + thumbnailsContainer.append(thumbnailElement); + }); + + wallpaperDialog.el.find('#applyWallpaperBtn').on('click', function() { + const wallpaperLink = wallpaperDialog.el.find('#wallpaperLink').val(); + if (wallpaperLink) { + xp.wallpaper.set(wallpaperLink); + saveConfig(); + } + wallpaperDialog.close(); + }); + + + }); + + // Calculate window position to center it on the screen + const screenWidth = $(window).width(); + const screenHeight = $(window).height(); + const windowWidth = win.el.outerWidth(); + const windowHeight = win.el.outerHeight(); + const left = (screenWidth - windowWidth) / 2; + const top = (screenHeight - windowHeight) / 2; + + win.el.css({ + position: 'absolute', + left: left + 'px', + top: top + 'px', + }); + + win.el.find('.content').css({ + padding: '20px', // Adjust the padding value as needed + }); +}); diff --git a/xp/system/core.js b/xp/system/core.js new file mode 100644 index 00000000..f9c96498 --- /dev/null +++ b/xp/system/core.js @@ -0,0 +1,620 @@ +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 + ` +