├── img
├── screenshot.png
└── animated-demo.gif
├── src
├── icons
│ ├── icon.ico
│ ├── icon-16.png
│ ├── icon-32.png
│ ├── icon-64.png
│ ├── icon-128.png
│ ├── icon-256.png
│ ├── icon-512.png
│ └── loading-logo.png
├── Markdown Editor.c3p
├── fonts
│ ├── lato-bold.ttf
│ ├── lato-italic.ttf
│ └── lato-regular.ttf
├── scripts
│ ├── register-sw.js
│ ├── offlineClient.js
│ ├── supportCheck.js
│ ├── jobWorker.js
│ ├── dispatchWorker.js
│ └── main.js
├── offline.json
├── arcade.json
├── appmanifest.json
├── style.css
├── index.html
├── converter.js
├── markstyle.css
├── menucss.css
├── sw.js
└── data.json
├── .github
└── FUNDING.yml
├── README.md
├── index.js
├── LICENSE
├── .gitignore
└── package.json
/img/screenshot.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/img/screenshot.png
--------------------------------------------------------------------------------
/src/icons/icon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon.ico
--------------------------------------------------------------------------------
/img/animated-demo.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/img/animated-demo.gif
--------------------------------------------------------------------------------
/src/icons/icon-16.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon-16.png
--------------------------------------------------------------------------------
/src/icons/icon-32.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon-32.png
--------------------------------------------------------------------------------
/src/icons/icon-64.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon-64.png
--------------------------------------------------------------------------------
/src/Markdown Editor.c3p:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/Markdown Editor.c3p
--------------------------------------------------------------------------------
/src/fonts/lato-bold.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/fonts/lato-bold.ttf
--------------------------------------------------------------------------------
/src/icons/icon-128.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon-128.png
--------------------------------------------------------------------------------
/src/icons/icon-256.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon-256.png
--------------------------------------------------------------------------------
/src/icons/icon-512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/icon-512.png
--------------------------------------------------------------------------------
/src/fonts/lato-italic.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/fonts/lato-italic.ttf
--------------------------------------------------------------------------------
/src/fonts/lato-regular.ttf:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/fonts/lato-regular.ttf
--------------------------------------------------------------------------------
/src/icons/loading-logo.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/el3um4s/markdown-c3/HEAD/src/icons/loading-logo.png
--------------------------------------------------------------------------------
/src/scripts/register-sw.js:
--------------------------------------------------------------------------------
1 | "use strict";window.C3_RegisterSW=async function(){if(navigator.serviceWorker)try{const a=await navigator.serviceWorker.register("sw.js",{scope:"./"});console.info("Registered service worker on "+a.scope)}catch(a){console.warn("Failed to register service worker: ",a)}};
--------------------------------------------------------------------------------
/src/offline.json:
--------------------------------------------------------------------------------
1 | {"version":1542836585821,"fileList":["showdown.js","scripts/c3runtime.js","data.json","style.css","scripts/offlineClient.js","scripts/main.js","scripts/dispatchWorker.js","scripts/jobWorker.js","scripts/supportCheck.js","fonts/lato-regular.ttf","fonts/lato-bold.ttf","fonts/lato-italic.ttf","converter.js","markstyle.css","menucss.css","icons/icon-16.png","icons/icon-32.png","icons/icon-64.png","icons/loading-logo.png","icons/icon-128.png","icons/icon-256.png","icons/icon-512.png","arcade.json","scripts/register-sw.js"]}
--------------------------------------------------------------------------------
/src/arcade.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "Markdown Editor",
3 | "version": "1.0.0.0",
4 | "description": "",
5 | "id": "",
6 | "viewport-width": 854,
7 | "viewport-height": 480,
8 | "author": "",
9 | "email": "",
10 | "website": "",
11 | "orientations": "landscape",
12 | "c2version": "244",
13 | "c3version": "r125",
14 | "used-plugins": [
15 | "StraniAnelli_InjectCSS",
16 | "StraniAnelli_HTMLElement",
17 | "Function",
18 | "Browser",
19 | "PlatformInfo",
20 | "StraniAnelli_Showdown"
21 | ],
22 | "used-behaviors": [
23 | "Pin",
24 | "DragnDrop",
25 | "Tween",
26 | "Anchor"
27 | ]
28 | }
--------------------------------------------------------------------------------
/src/scripts/offlineClient.js:
--------------------------------------------------------------------------------
1 | "use strict";{window.OfflineClientInfo=new class{constructor(){if(this._broadcastChannel="undefined"==typeof BroadcastChannel?null:new BroadcastChannel("offline"),this._queuedMessages=[],this._onMessageCallback=null,this._broadcastChannel){var a=this;this._broadcastChannel.onmessage=function(b){a._OnBroadcastChannelMessage(b)}}}_OnBroadcastChannelMessage(a){return this._onMessageCallback?void this._onMessageCallback(a):void this._queuedMessages.push(a)}SetMessageCallback(a){this._onMessageCallback=a;for(let b of this._queuedMessages)this._onMessageCallback(b);this._queuedMessages.length=0}}}
--------------------------------------------------------------------------------
/.github/FUNDING.yml:
--------------------------------------------------------------------------------
1 | # These are supported funding model platforms
2 |
3 | github: [el3um4s]
4 | patreon: el3um4s
5 | open_collective: # Replace with a single Open Collective username
6 | ko_fi: # Replace with a single Ko-fi username
7 | tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
8 | community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
9 | liberapay: # Replace with a single Liberapay username
10 | issuehunt: # Replace with a single IssueHunt username
11 | otechie: # Replace with a single Otechie username
12 | custom: ["https://www.paypal.me/el3um4s"]
13 |
--------------------------------------------------------------------------------
/src/scripts/supportCheck.js:
--------------------------------------------------------------------------------
1 | "use strict";(function(){var a=document.createElement("canvas"),b=!!(a.getContext("webgl")||a.getContext("experimental-webgl")),c=[];if(b||c.push("WebGL"),"undefined"==typeof WebAssembly&&c.push("WebAssembly"),0===c.length)window["C3_IsSupported"]=!0;else{var d=document.createElement("div");d.id="notSupportedWrap",document.body.appendChild(d);var e=document.createElement("h2");e.id="notSupportedTitle",e.textContent="Software update needed",d.appendChild(e);var f=document.createElement("p");f.id="notSupportedMessage",f.innerHTML="This content is not supported because your device's software is out-of-date. Try installing any available software updates. Alternatively try on a different device.
Missing features: "+c.join(", ")+"",d.appendChild(f)}})();
--------------------------------------------------------------------------------
/src/appmanifest.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "Markdown Editor",
3 | "short_name": "Markdown Editor",
4 | "description": "",
5 | "start_url": "index.html",
6 | "display": "fullscreen",
7 | "orientation": "landscape",
8 | "background_color": "#ffffff",
9 | "icons": [
10 | {
11 | "src": "icons/icon-16.png",
12 | "sizes": "16x16",
13 | "type": "image/png"
14 | },
15 | {
16 | "src": "icons/icon-32.png",
17 | "sizes": "32x32",
18 | "type": "image/png"
19 | },
20 | {
21 | "src": "icons/icon-64.png",
22 | "sizes": "64x64",
23 | "type": "image/png"
24 | },
25 | {
26 | "src": "icons/icon-128.png",
27 | "sizes": "128x128",
28 | "type": "image/png"
29 | },
30 | {
31 | "src": "icons/icon-256.png",
32 | "sizes": "256x256",
33 | "type": "image/png"
34 | },
35 | {
36 | "src": "icons/icon-512.png",
37 | "sizes": "512x512",
38 | "type": "image/png"
39 | }
40 | ]
41 | }
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Markdown C3
2 | _A Markdown Editor and Previewer built with Construct 3 and ElectronJs_
3 |
4 | **Link**
5 | * [Releases](https://github.com/el3um4s/markdown-c3/releases)
6 | * [Portable Windows 64bit](https://github.com/el3um4s/markdown-c3/releases/download/v.1.0.0/Markdown.C3.1.0.0.exe)
7 | * [C3P file](https://github.com/el3um4s/markdown-c3/raw/master/src/Markdown%20Editor.c3p)
8 |
9 | 
10 |
11 | **Version** 1.0.0
12 |
13 | **License** MIT © 2018 - Samuele de Tomasi
14 |
15 | **GitHub** el3um4s/markdown-c3
16 |
17 | 
18 |
19 | **Created with:**
20 | * [Construct 3](https://www.construct.net/en)
21 | * [ElectronJs](https://electronjs.org/)
22 | * [HTMLElement](https://el3um4s.github.io/construct-html-element-plugin/)
23 | * [Showdownjs](http://showdownjs.com/)
24 | * Google Font Lato
25 |
--------------------------------------------------------------------------------
/index.js:
--------------------------------------------------------------------------------
1 | const electron = require('electron');
2 | const path = require('path');
3 | const url = require('url');
4 | require('electron-debug')();
5 |
6 | const {
7 | app,
8 | BrowserWindow
9 | } = electron;
10 |
11 | let mainWindow;
12 |
13 | // 854 x 480
14 | app.on('ready', () => {
15 | mainWindow = new BrowserWindow({
16 | width: 854,
17 | height: 480,
18 | useContentSize: true,
19 | center:true,
20 | show: false,
21 | backgroundColor: '#420024',
22 | title: "Markdown C3",
23 | icon: path.join(__dirname, '/src/icons/icon-256.png')
24 | });
25 |
26 | mainWindow.loadURL(url.format({
27 | pathname: path.join(__dirname, 'src', 'index.html'),
28 | protocol: 'file:',
29 | slashes: true
30 | }))
31 |
32 |
33 | mainWindow.once('ready-to-show', () => {
34 | mainWindow.show();
35 | })
36 |
37 | mainWindow.on('closed', () => {
38 | mainWindow = null;
39 | })
40 | });
41 |
42 | app.on('window-all-closed', () => {
43 | if (process.platform !== 'darwin') {
44 | app.quit()
45 | }
46 | })
--------------------------------------------------------------------------------
/src/style.css:
--------------------------------------------------------------------------------
1 | html, body {
2 | padding: 0;
3 | margin: 0;
4 | overflow: hidden;
5 |
6 | background: #ffffff;
7 | color: white;
8 | }
9 |
10 | html, body, canvas {
11 | touch-action: none;
12 | touch-action-delay: none;
13 | }
14 |
15 | #notSupportedWrap {
16 | margin: 2em auto 1em auto;
17 | width: 75%;
18 | max-width: 45em;
19 | border: 2px solid #aaa;
20 | border-radius: 1em;
21 | padding: 2em;
22 | background-color: #f0f0f0;
23 | font-family: "Segoe UI", Frutiger, "Frutiger Linotype", "Dejavu Sans", "Helvetica Neue", Arial, sans-serif;
24 | color: black;
25 | }
26 |
27 | #notSupportedTitle {
28 | font-size: 1.8em;
29 | }
30 |
31 | #notSupportedMessage {
32 | font-size: 1.2em;
33 | }
34 |
35 | @font-face {
36 | font-family: 'lato-regular';
37 | src: url('fonts/lato-regular.ttf') format('truetype');
38 | }
39 |
40 | @font-face {
41 | font-family: 'lato-bold';
42 | src: url('fonts/lato-bold.ttf') format('truetype');
43 | }
44 |
45 | @font-face {
46 | font-family: 'lato-italic';
47 | src: url('fonts/lato-italic.ttf') format('truetype');
48 | }
49 |
50 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2018 Samuele de Tomasi
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # Logs
2 | logs
3 | *.log
4 | npm-debug.log*
5 | yarn-debug.log*
6 | yarn-error.log*
7 |
8 | # Runtime data
9 | pids
10 | *.pid
11 | *.seed
12 | *.pid.lock
13 |
14 | # Directory for instrumented libs generated by jscoverage/JSCover
15 | lib-cov
16 |
17 | # Coverage directory used by tools like istanbul
18 | coverage
19 |
20 | # nyc test coverage
21 | .nyc_output
22 |
23 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
24 | .grunt
25 |
26 | # Bower dependency directory (https://bower.io/)
27 | bower_components
28 |
29 | # node-waf configuration
30 | .lock-wscript
31 |
32 | # Compiled binary addons (https://nodejs.org/api/addons.html)
33 | build/Release
34 |
35 | # Dependency directories
36 | node_modules/
37 | jspm_packages/
38 | build/
39 |
40 | # TypeScript v1 declaration files
41 | typings/
42 |
43 | # Optional npm cache directory
44 | .npm
45 |
46 | # Optional eslint cache
47 | .eslintcache
48 |
49 | # Optional REPL history
50 | .node_repl_history
51 |
52 | # Output of 'npm pack'
53 | *.tgz
54 |
55 | # Yarn Integrity file
56 | .yarn-integrity
57 |
58 | # dotenv environment variables file
59 | .env
60 |
61 | # next.js build output
62 | .next
63 |
--------------------------------------------------------------------------------
/src/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | Markdown Editor
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
27 |
28 |
29 |
30 |
31 |
32 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "markdownc3",
3 | "version": "1.0.0",
4 | "description": "Markdown Editor and Previewer",
5 | "main": "index.js",
6 | "scripts": {
7 | "test": "echo \"Error: no test specified\" && exit 1",
8 | "start": "electron .",
9 | "build": "electron-builder",
10 | "pack": "electron-builder --dir",
11 | "dist": "electron-builder",
12 | "dist:32win": "build --win --ia32 ",
13 | "dist:64win": "build --win --x64",
14 | "postinstall": "electron-builder install-app-deps"
15 | },
16 | "repository": {
17 | "type": "git",
18 | "url": "git+https://github.com/el3um4s/markdown-c3.git"
19 | },
20 | "keywords": [
21 | "markdown",
22 | "construct3",
23 | "electronjs"
24 | ],
25 | "author": "Samuele de Tomasi",
26 | "license": "ISC",
27 | "bugs": {
28 | "url": "https://github.com/el3um4s/markdown-c3/issues"
29 | },
30 | "homepage": "https://github.com/el3um4s/markdown-c3#readme",
31 | "dependencies": {
32 | "electron-debug": "^2.0.0",
33 | "npm": ">=6.14.6",
34 | "showdown": "^1.9.1"
35 | },
36 | "devDependencies": {
37 | "electron": "^3.0.10",
38 | "electron-builder": "^20.36.2"
39 | },
40 | "build": {
41 | "productName": "Markdown C3",
42 | "appId": "com.stranianelli.markdown-c3",
43 | "directories": {
44 | "output": "build"
45 | },
46 | "win": {
47 | "target": "portable",
48 | "icon": "src/icons/icon.ico"
49 | }
50 | }
51 | }
52 |
--------------------------------------------------------------------------------
/src/converter.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | function convert() {
4 | const text = document.getElementById('editor').value;
5 | const converter = new showdown.Converter();
6 | return converter.makeHtml(text);
7 | };
8 |
9 | function handleFiles(file) {
10 | const fileToLoad = document.getElementById("upload-file").files[0];
11 | let fileReader = new FileReader();
12 | fileReader.onload = function(fileLoadedEvent){
13 | const textFromFileLoaded = fileLoadedEvent.target.result;
14 | document.getElementById("editor").value = textFromFileLoaded;
15 | document.getElementById('preview').innerHTML = '';
16 | document.getElementById('upload-file').value = null;
17 | // const text = document.getElementById('editor').value;
18 | /*
19 | const converter = new showdown.Converter();
20 | const html = converter.makeHtml(textFromFileLoaded);
21 | let target = document.getElementById('preview');
22 | target.innerHTML = html;*/
23 |
24 | };
25 |
26 | fileReader.readAsText(fileToLoad, "UTF-8");
27 | }
28 |
29 |
30 | // https://www.javascripture.com/FileReader
31 | // https://stackoverflow.com/questions/31746837/reading-uploaded-text-file-contents-in-html
32 | function loadFileAsText(){
33 | var fileToLoad = document.getElementById("fileToLoad").files[0];
34 |
35 | var fileReader = new FileReader();
36 | fileReader.onload = function(fileLoadedEvent){
37 | var textFromFileLoaded = fileLoadedEvent.target.result;
38 | document.getElementById("inputTextToSave").value = textFromFileLoaded;
39 | };
40 |
41 | fileReader.readAsText(fileToLoad, "UTF-8");
42 | }
--------------------------------------------------------------------------------
/src/markstyle.css:
--------------------------------------------------------------------------------
1 | html, body, canvas {
2 | touch-action: manipulation;
3 | }
4 |
5 | #backgroundpatternd {
6 | background-color: #eeedee;
7 | background-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23bbbbbb' fill-opacity='0.4' fill-rule='evenodd'/%3E%3C/svg%3E");
8 | }
9 |
10 | .onSelect {
11 | z-index: 10;
12 | }
13 |
14 | .onDrag {
15 | box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22) !important;
16 | }
17 |
18 | .resizer-dx, .resizer-sx {
19 | cursor: ew-resize;
20 | z-index: 20;
21 | min-width: 8px;
22 | max-width: 8px;
23 | }
24 |
25 | .resizer-bottom, .resizer-up {
26 | cursor: ns-resize;
27 | z-index: 20;
28 | min-height: 8px;
29 | max-height: 8px;
30 | }
31 |
32 | .resizer-bassodestra, .resizer-altosinistra {
33 | cursor: nwse-resize;
34 | z-index: 25;
35 | min-height: 8px;
36 | max-height: 8px;
37 | min-width: 8px;
38 | max-width: 8px;
39 | }
40 |
41 | .noTextSelectable {
42 | user-select: none;
43 | }
--------------------------------------------------------------------------------
/src/scripts/jobWorker.js:
--------------------------------------------------------------------------------
1 | "use strict";self.dispatchPort=null,self.outputPort=null,self.workerNumber=-1,self.activeJobId=null,self.sentBlobs=new Map,self.JobHandlers={};function FlipImageData(a,b,c){const d=4*b,e=new Uint8Array(d),f=a.buffer;for(let g=0,h=Math.floor(c/2);g{const b=a.data,c=b["type"];return"init"===c?(self.workerNumber=b["number"],self.dispatchPort=b["dispatch-port"],self.dispatchPort.onmessage=OnDispatchWorkerMessage,void(self.outputPort=b["output-port"])):"terminate"===c?void self.close():void console.error("unknown message '"+c+"'")});function SendReady(){self.dispatchPort.postMessage({"type":"ready"}),self.outputPort.postMessage({"type":"ready"})}function SendError(a,b){a||self.outputPort.postMessage({"type":"error","jobId":self.activeJobId,"error":b.toString()}),SendDone()}function SendResult(a,b){if(!a){const a=b.transferables||[];self.outputPort.postMessage({"type":"result","jobId":self.activeJobId,"result":b.result},a)}SendDone()}function SendDone(){self.activeJobId=null,self.dispatchPort.postMessage({"type":"done"})}function SendProgress(a){self.outputPort.postMessage({"type":"progress","jobId":self.activeJobId,"progress":a})}function OnDispatchWorkerMessage(a){const b=a.data,c=b["type"];if("_import_scripts"===c)return void importScripts(...b["scripts"]);if("_send_blob"===c)return void self.sentBlobs.set(b["id"],b["blob"]);if("_testMessageChannel"===c)return void self.outputPort.postMessage({"type":"_testMessageChannelOk"});if("_ready"===c)return void SendReady();const d=b["jobId"],f=b["isBroadcast"],e=b["params"];let g;if(self.activeJobId=d,!self.JobHandlers.hasOwnProperty(c))return void console.error(`no handler for message type '${c}'`);try{g=self.JobHandlers[c](e)}catch(a){return void SendError(f,"Exception in job handler: "+a)}g&&g.then?g.then((a)=>SendResult(f,a)).catch((a)=>SendError(f,"Rejection in job handler: "+a)):SendResult(f,g)}
--------------------------------------------------------------------------------
/src/scripts/dispatchWorker.js:
--------------------------------------------------------------------------------
1 | "use strict";self.inputPort=null,self.jobQueue=[],self.jobWorkers=[],self.sentBlobs=[],self.importedScripts=[],self.lastBroadcasts=new Map;class JobWorker{constructor(a,b){this._port=a,this._number=b,this._isReady=!1,this._isBusy=!1,this._port.onmessage=(a)=>this._OnMessage(a.data)}ImportScripts(a){this._port.postMessage({"type":"_import_scripts","scripts":a})}SendBlob(a,b){this._port.postMessage({"type":"_send_blob","blob":a,"id":b})}SendJob(a){if(this._isBusy||!this._isReady)throw new Error("cannot take job");this._isBusy=!0,this._port.postMessage(a,a["transferables"])}_InitBroadcast(a){this._port.postMessage(a,a["transferables"])}SendReady(){this._port.postMessage({"type":"_ready"})}IsReady(){return this._isReady}_OnReady(){this._isReady=!0,this.MaybeStartNextJob()}IsBusy(){return this._isBusy}GetNumber(){return this._number}_OnMessage(a){const b=a["type"];return"ready"===b?void this._OnReady():"done"===b?void this._OnJobDone():void console.error("unknown message from worker '"+b+"'")}_OnJobDone(){this._isBusy=!1,this.MaybeStartNextJob()}MaybeStartNextJob(){if(!this._isBusy&&this._isReady){const a=this._FindAvailableJob();if(-1!==a){const b=self.jobQueue[a],c=b["isBroadcast"];c?(b["doneFlags"][this._number]=!0,b["doneFlags"].every((a)=>a)&&self.jobQueue.splice(a,1)):self.jobQueue.splice(a,1),this.SendJob(b)}}}_FindAvailableJob(){for(let a=0,b=self.jobQueue.length;a{const b=a.data,c=b["type"];"_init"===c?(self.inputPort=b["in-port"],self.inputPort.onmessage=OnInputPortMessage):"_addJobWorker"===c&&AddJobWorker(b["port"])});function OnInputPortMessage(a){const b=a.data,c=b["type"];if("_cancel"===c)return void CancelJob(b.jobId);if("_import_scripts"===c){const a=b["scripts"];for(const b of self.jobWorkers)b.ImportScripts(a);return void self.importedScripts.push(a)}if("_send_blob"===c){const a=b["blob"],c=b["id"];for(const b of self.jobWorkers)b.SendBlob(a,c);return void self.sentBlobs.push([a,c])}if("_no_more_workers"===c)return self.sentBlobs.length=0,self.importedScripts.length=0,void self.lastBroadcasts.clear();if("_testMessageChannel"===c)return void self.jobWorkers[0].TestMessageChannel();self.jobQueue.push(b),b["isBroadcast"]&&(b["doneFlags"]=Array(self.jobWorkers.length).fill(!1),b["transferables"]=[],self.lastBroadcasts.set(b["type"],b));for(const b of self.jobWorkers)b.MaybeStartNextJob()}
--------------------------------------------------------------------------------
/src/menucss.css:
--------------------------------------------------------------------------------
1 | /*https://codepen.io/JFarrow/pen/fFrpg*/
2 |
3 | .fa-2x {
4 | font-size: 2em;
5 | }
6 |
7 | .fas, .fa, .fab {
8 | position: relative;
9 | display: table-cell;
10 | width: 60px;
11 | height: 36px;
12 | text-align: center;
13 | vertical-align: middle;
14 | font-size:20px;
15 | }
16 |
17 | /*
18 | .fa {
19 | position: relative;
20 | display: table-cell;
21 | width: 60px;
22 | height: 36px;
23 | text-align: center;
24 | vertical-align: middle;
25 | font-size:20px;
26 | }*/
27 |
28 |
29 | .main-menu:hover,nav.main-menu.expanded {
30 | width:250px;
31 | overflow:visible;
32 | }
33 |
34 | .main-menu {
35 | background:#212121;
36 | border-right:1px solid #e5e5e5;
37 | position:absolute;
38 | top:0;
39 | bottom:0;
40 | height:100%;
41 | left:0;
42 | width:60px;
43 | overflow:hidden;
44 | -webkit-transition:width .05s linear;
45 | transition:width .05s linear;
46 | -webkit-transform:translateZ(0) scale(1,1);
47 | z-index:100;
48 | }
49 |
50 | .main-menu>ul {
51 | margin:7px 0;
52 | }
53 |
54 | .main-menu li {
55 | position:relative;
56 | display:block;
57 | width:250px;
58 | }
59 |
60 | .main-menu li>a {
61 | position:relative;
62 | display:table;
63 | border-collapse:collapse;
64 | border-spacing:0;
65 | color:#999;
66 | font-family: arial;
67 | font-size: 14px;
68 | text-decoration:none;
69 | -webkit-transform:translateZ(0) scale(1,1);
70 | -webkit-transition:all .1s linear;
71 | transition:all .1s linear;
72 |
73 | }
74 |
75 | .main-menu .nav-icon {
76 | position:relative;
77 | display:table-cell;
78 | width:60px;
79 | height:36px;
80 | text-align:center;
81 | vertical-align:middle;
82 | font-size:18px;
83 | }
84 |
85 | .main-menu .nav-text {
86 | position:relative;
87 | display:table-cell;
88 | vertical-align:middle;
89 | width:190px;
90 | font-family: 'Titillium Web', sans-serif;
91 | }
92 |
93 | .main-menu>ul.logout {
94 | position:absolute;
95 | left:0;
96 | bottom:0;
97 | }
98 |
99 | .no-touch .scrollable.hover {
100 | overflow-y:hidden;
101 | }
102 |
103 | .no-touch .scrollable.hover:hover {
104 | overflow-y:auto;
105 | overflow:visible;
106 | }
107 |
108 | a:hover,a:focus {
109 | text-decoration:none;
110 | }
111 |
112 | nav {
113 | -webkit-user-select:none;
114 | -moz-user-select:none;
115 | -ms-user-select:none;
116 | -o-user-select:none;
117 | user-select:none;
118 | }
119 |
120 | nav ul,nav li {
121 | outline:0;
122 | margin:0;
123 | padding:0;
124 | }
125 | .main-menu li:hover>a,nav.main-menu li.active>a,.dropdown-menu>li>a:hover,.dropdown-menu>li>a:focus,.dropdown-menu>.active>a,.dropdown-menu>.active>a:hover,.dropdown-menu>.active>a:focus,.no-touch .dashboard-page nav.dashboard-menu ul li:hover a,.dashboard-page nav.dashboard-menu ul li.active a {
126 | color:#fff;
127 | background-color:#5fa2db;
128 | }
129 | .area {
130 | float: left;
131 | background: #e2e2e2;
132 | width: 100%;
133 | height: 100%;
134 | }
135 | @font-face {
136 | font-family: 'Titillium Web';
137 | font-style: normal;
138 | font-weight: 300;
139 | src: local('Titillium WebLight'), local('TitilliumWeb-Light'), url(https://themes.googleusercontent.com/static/fonts/titilliumweb/v2/anMUvcNT0H1YN4FII8wpr24bNCNEoFTpS2BTjF6FB5E.woff) format('woff');
140 | }
141 |
--------------------------------------------------------------------------------
/src/sw.js:
--------------------------------------------------------------------------------
1 | "use strict";const OFFLINE_DATA_FILE="offline.json",CACHE_NAME_PREFIX="c3offline",BROADCASTCHANNEL_NAME="offline",CONSOLE_PREFIX="[SW] ",LAZYLOAD_KEYNAME="",broadcastChannel="undefined"==typeof BroadcastChannel?null:new BroadcastChannel("offline");function PostBroadcastMessage(a){broadcastChannel&&setTimeout(()=>broadcastChannel.postMessage(a),3e3)}function Broadcast(a){PostBroadcastMessage({"type":a})}function BroadcastDownloadingUpdate(a){PostBroadcastMessage({"type":"downloading-update","version":a})}function BroadcastUpdateReady(a){PostBroadcastMessage({"type":"update-ready","version":a})}function IsUrlInLazyLoadList(a,b){if(!b)return!1;try{for(const c of b)if(new RegExp(c).test(a))return!0}catch(a){console.error("[SW] Error matching in lazy-load list: ",a)}return!1}function WriteLazyLoadListToStorage(a){return"undefined"==typeof localforage?Promise.resolve():localforage.setItem(LAZYLOAD_KEYNAME,a)}function ReadLazyLoadListFromStorage(){return"undefined"==typeof localforage?Promise.resolve([]):localforage.getItem(LAZYLOAD_KEYNAME)}function GetCacheBaseName(){return"c3offline-"+self.registration.scope}function GetCacheVersionName(a){return GetCacheBaseName()+"-v"+a}async function GetAvailableCacheNames(){const a=await caches.keys(),b=GetCacheBaseName();return a.filter((a)=>a.startsWith(b))}async function IsUpdatePending(){const a=await GetAvailableCacheNames();return 2<=a.length}async function GetMainPageUrl(){const a=await clients.matchAll({includeUncontrolled:!0,type:"window"});for(const b of a){let a=b.url;if(a.startsWith(self.registration.scope)&&(a=a.substring(self.registration.scope.length)),a&&"/"!==a)return a.startsWith("?")&&(a="/"+a),a}return""}function fetchWithBypass(a,b){if("string"==typeof a&&(a=new Request(a)),b){const b=new URL(a.url);return b.search+=Math.floor(1e6*Math.random()),fetch(b,{headers:a.headers,mode:a.mode,credentials:a.credentials,redirect:a.redirect,cache:"no-store"})}return fetch(a)}async function CreateCacheFromFileList(a,b,c){const d=await Promise.all(b.map((a)=>fetchWithBypass(a,c)));let e=!0;for(const f of d)f.ok||(e=!1,console.error("[SW] Error fetching '"+f.url+"' ("+f.status+" "+f.statusText+")"));if(!e)throw new Error("not all resources were fetched successfully");const f=await caches.open(a);try{return await Promise.all(d.map((a,c)=>f.put(b[c],a)))}catch(b){throw console.error("[SW] Error writing cache entries: ",b),caches.delete(a),b}}async function UpdateCheck(a){try{const b=await fetchWithBypass(OFFLINE_DATA_FILE,!0);if(!b.ok)throw new Error("offline.json responded with "+b.status+" "+b.statusText);const c=await b.json(),d=c.version,e=c.fileList,f=c.lazyLoad,g=GetCacheVersionName(d),h=await caches.has(g);if(h){const a=await IsUpdatePending();return void(a?(console.log("[SW] Update pending"),Broadcast("update-pending")):(console.log("[SW] Up to date"),Broadcast("up-to-date")))}const i=await GetMainPageUrl();e.unshift("./"),i&&-1===e.indexOf(i)&&e.unshift(i),console.log("[SW] Caching "+e.length+" files for offline use"),a?Broadcast("downloading"):BroadcastDownloadingUpdate(d),f&&(await WriteLazyLoadListToStorage(f)),await CreateCacheFromFileList(g,e,!a);const j=await IsUpdatePending();j?(console.log("[SW] All resources saved, update ready"),BroadcastUpdateReady(d)):(console.log("[SW] All resources saved, offline support ready"),Broadcast("offline-ready"))}catch(a){console.warn("[SW] Update check failed: ",a)}}self.addEventListener("install",(a)=>{a.waitUntil(UpdateCheck(!0).catch(()=>null))});async function GetCacheNameToUse(a,b){if(1===a.length||!b)return a[0];const c=await clients.matchAll();if(1caches.delete(a))),d}async function HandleFetch(a,b){const c=await GetAvailableCacheNames();if(!c.length)return fetch(a.request);const d=await GetCacheNameToUse(c,b),e=await caches.open(d),f=await e.match(a.request);if(f)return f;const g=await Promise.all([fetch(a.request),ReadLazyLoadListFromStorage()]),h=g[0],i=g[1];if(IsUrlInLazyLoadList(a.request.url,i))try{await e.put(a.request,h.clone())}catch(b){console.warn("[SW] Error caching '"+a.request.url+"': ",b)}return h}self.addEventListener("fetch",(a)=>{if(new URL(a.request.url).origin===location.origin){const b="navigate"===a.request.mode,c=HandleFetch(a,b);b&&a.waitUntil(c.then(()=>UpdateCheck(!1))),a.respondWith(c)}});
--------------------------------------------------------------------------------
/src/scripts/main.js:
--------------------------------------------------------------------------------
1 | "use strict";window.DOMHandler=class{constructor(a,b){this._iRuntime=a,this._componentId=b,this._hasTickCallback=!1,this._tickCallback=()=>this.Tick()}Attach(){}PostToRuntime(a,b,c,d){this._iRuntime.PostToRuntimeComponent(this._componentId,a,b,!!c,d)}PostToRuntimeAsync(a,b,c,d){return this._iRuntime.PostToRuntimeComponentAsync(this._componentId,a,b,!!c,d)}_PostToRuntimeMaybeSync(a,b,c){this._iRuntime.UsesWorker()?this.PostToRuntime(a,b,c):this._iRuntime._GetLocalRuntime()["_OnMessageFromDOM"]({"type":"event","component":this._componentId,"handler":a,"dispatchRuntimeEvent":c,"data":b,"responseId":null})}AddRuntimeMessageHandler(a,b){this._iRuntime.AddRuntimeComponentMessageHandler(this._componentId,a,b)}AddRuntimeMessageHandlers(a){for(const[b,c]of a)this.AddRuntimeMessageHandler(b,c)}GetRuntimeInterface(){return this._iRuntime}GetComponentID(){return this._componentId}_StartTicking(){this._hasTickCallback||(this._iRuntime._AddRAFCallback(this._tickCallback),this._hasTickCallback=!0)}_StopTicking(){this._hasTickCallback&&(this._iRuntime._RemoveRAFCallback(this._tickCallback),this._hasTickCallback=!1)}Tick(){}};
2 |
3 | "use strict";window.DOMElementHandler=class extends DOMHandler{constructor(a,b){super(a,b),this._elementMap=new Map,this._autoAttach=!0,this.AddRuntimeMessageHandler("create",(a)=>this._OnCreate(a)),this.AddRuntimeMessageHandler("destroy",(a)=>this._OnDestroy(a)),this.AddRuntimeMessageHandler("set-visible",(a)=>this._OnSetVisible(a)),this.AddRuntimeMessageHandler("update-position",(a)=>this._OnUpdatePosition(a)),this.AddRuntimeMessageHandler("update-state",(a)=>this._OnUpdateState(a)),this.AddRuntimeMessageHandler("focus",(a)=>this._OnSetFocus(a)),this.AddRuntimeMessageHandler("set-css-style",(a)=>this._OnSetCssStyle(a))}SetAutoAttach(a){this._autoAttach=!!a}AddDOMElementMessageHandler(a,b){this.AddRuntimeMessageHandler(a,(a)=>{const c=a["elementId"],d=this._elementMap.get(c);return b(d,a)})}_OnCreate(a){const b=a["elementId"],c=this.CreateElement(b,a);this._elementMap.set(b,c),this._autoAttach&&document.body.appendChild(c)}CreateElement(){throw new Error("required override")}DestroyElement(){}_OnDestroy(a){const b=a["elementId"],c=this._elementMap.get(b);this.DestroyElement(c),this._autoAttach&&c.parentElement.removeChild(c),this._elementMap.delete(b)}PostToRuntimeElement(a,b,c){c||(c={}),c["elementId"]=b,this.PostToRuntime(a,c)}_PostToRuntimeElementMaybeSync(a,b,c){c||(c={}),c["elementId"]=b,this._PostToRuntimeMaybeSync(a,c)}_OnSetVisible(a){if(this._autoAttach){const b=this._elementMap.get(a["elementId"]);b.style.display=a["isVisible"]?"":"none"}}_OnUpdatePosition(a){if(this._autoAttach){const b=this._elementMap.get(a["elementId"]);b.style.left=a["left"]+"px",b.style.top=a["top"]+"px",b.style.width=a["width"]+"px",b.style.height=a["height"]+"px";const c=a["fontSize"];null!==c&&(b.style.fontSize=c+"em")}}_OnUpdateState(a){const b=this._elementMap.get(a["elementId"]);this.UpdateState(b,a)}UpdateState(){throw new Error("required override")}_OnSetFocus(a){const b=this._elementMap.get(a["elementId"]);a["focus"]?b.focus():b.blur()}_OnSetCssStyle(a){const b=this._elementMap.get(a["elementId"]);b.style[a["prop"]]=a["val"]}GetElementById(a){return this._elementMap.get(a)}};
4 |
5 | "use strict";{function a(a){return new Promise((b,c)=>{const d=document.createElement("script");d.onload=b,d.onerror=c,d.async=!1,d.src=a,document.head.appendChild(d)})}function b(a){return new Promise((b,c)=>{const d=new FileReader;d.onload=(a)=>b(a.target.result),d.onerror=(a)=>c(a),d.readAsText(a)})}function c(a){return new Promise((b,c)=>{const d=new FileReader;d.onload=(a)=>b(a.target.result),d.onerror=(a)=>c(a),d.readAsArrayBuffer(a)})}function d(a){if(!a)return"";const b=a.split(".");if(2>b.length)return"";const c=b[b.length-1].toLowerCase();return k.get(c)||""}const e=/(iphone|ipod|ipad)/i.test(navigator.userAgent);let f=new Audio;const g={"audio/webm; codecs=opus":!!f.canPlayType("audio/webm; codecs=opus"),"audio/ogg; codecs=opus":!!f.canPlayType("audio/ogg; codecs=opus"),"audio/webm; codecs=vorbis":!!f.canPlayType("audio/webm; codecs=vorbis"),"audio/ogg; codecs=vorbis":!!f.canPlayType("audio/ogg; codecs=vorbis"),"audio/mp4":!!f.canPlayType("audio/mp4"),"audio/mpeg":!!f.canPlayType("audio/mpeg")};f=null;const h=[];let i=0;const j=Math.max(navigator.hardwareConcurrency||0,8),k=new Map([["mp4","video/mp4"],["webm","video/webm"],["m4a","audio/mp4"],["mp3","audio/mpeg"],["js","application/javascript"],["wasm","application/wasm"]]),l=[],m=new Map,n=new Map;let o=0;window.RuntimeInterface=class f{constructor(a){this._useWorker=a.useWorker,this._messageChannelPort=null,this._baseUrl="",this._workerScriptBlobURLs={},this._worker=null,this._localRuntime=null,this._domHandlers=[],this._runtimeDomHandler=null,this._canvas=null,this._jobScheduler=null,this._rafId=-1,this._rafFunc=()=>this._OnRAFCallback(),this._rafCallbacks=[],this._exportType=a.exportType,this._transferablesBroken=!1,"html5"===this._exportType&&"file"===location.protocol.substr(0,4)&&alert("Exported games won't work until you upload them. (When running on the file: protocol, browsers block many features from working for security reasons.)"),this.AddRuntimeComponentMessageHandler("runtime","cordova-fetch-local-file",(a)=>this._OnCordovaFetchLocalFile(a)),this.AddRuntimeComponentMessageHandler("runtime","create-job-worker",(a)=>this._OnCreateJobWorker(a)),"cordova"===this._exportType?document.addEventListener("deviceready",()=>this._Init(a)):this._Init(a)}Release(){this._CancelAnimationFrame(),this._messageChannelPort&&(this._messageChannelPort.onmessage=null,this._messageChannelPort=null),this._worker&&(this._worker.terminate(),this._worker=null),this._localRuntime&&(this._localRuntime.Release(),this._localRuntime=null),this._canvas&&(this._canvas.parentElement.removeChild(this._canvas),this._canvas=null)}GetCanvas(){return this._canvas}GetBaseURL(){return this._baseUrl}UsesWorker(){return this._useWorker}GetExportType(){return this._exportType}IsWKWebView(){return"cordova"===this._exportType&&e}IsiPhoneX(){if(!this.IsWKWebView())return!1;const a=window["devicePixelRatio"],b=window["screen"]["width"]*a,c=window["screen"]["height"]*a;return 1125==b&&2436==c}async _Init(a){if(a.baseUrl)this._baseUrl=a.baseUrl;else{this._baseUrl=location.origin+location.pathname;const a=this._baseUrl.lastIndexOf("/");-1!==a&&(this._baseUrl=this._baseUrl.substr(0,a+1))}if(a.workerScripts)for(const[b,c]of Object.entries(a.workerScripts))this._workerScriptBlobURLs[b]=URL.createObjectURL(c);const b=new MessageChannel;this._messageChannelPort=b.port1,this._messageChannelPort.onmessage=(a)=>this["_OnMessageFromRuntime"](a.data),window["c3_addPortMessageHandler"]&&window["c3_addPortMessageHandler"]((a)=>this._OnMessageFromDebugger(a)),this._jobScheduler=new self.JobSchedulerDOM(this),await this._jobScheduler.Init(),this.MaybeForceBodySize(),"object"==typeof window["StatusBar"]&&window["StatusBar"]["hide"](),await this._TestTransferablesWork(),this._useWorker?await this._InitWorker(a,b.port2):await this._InitDOM(a,b.port2)}_GetWorkerURL(a){return this._workerScriptBlobURLs.hasOwnProperty(a)?this._workerScriptBlobURLs[a]:a}async CreateWorker(a,b,c){if(a.startsWith("blob:"))return new Worker(a,c);if(this.IsWKWebView()){const b=await this.CordovaFetchLocalFileAsBlob("scripts/"+a);return new Worker(URL.createObjectURL(b),c)}const d=new URL(a,b),e=location.origin!==d.origin;if(e){const a=await fetch(d);if(!a.ok)throw new Error("failed to fetch worker script");const b=await a.blob();return new Worker(URL.createObjectURL(b),c)}return new Worker(d,c)}MaybeForceBodySize(){if(this.IsiPhoneX()){const a=window.innerWidth>window.innerHeight,b=document["documentElement"].style,c=document["body"].style;a?(c["height"]=b["height"]="375px",c["width"]=b["width"]="812px"):(c["width"]=b["width"]="375px",c["height"]=b["height"]="812px")}}_GetCommonRuntimeOptions(a){return{"baseUrl":this._baseUrl,"windowInnerWidth":window.innerWidth,"windowInnerHeight":window.innerHeight,"devicePixelRatio":window.devicePixelRatio,"isFullscreen":f.IsDocumentFullscreen(),"projectData":a.projectData,"previewImageBlobs":window["cr_previewImageBlobs"],"previewProjectFileBlobs":window["cr_previewProjectFileBlobs"],"shaders":self["C3_Shaders"],"exportType":a.exportType,"isDebug":-1new a(this)),this._FindRuntimeDOMHandler()}async _InitDOM(b,c){this._canvas=document.createElement("canvas"),this._canvas.style.display="none",document.body.appendChild(this._canvas),this._domHandlers=l.map((a)=>new a(this)),this._FindRuntimeDOMHandler();const d=b.engineScripts.map((a)=>new URL(a,this._baseUrl).toString());await Promise.all(d.map((b)=>a(b)));const e=Object.assign(this._GetCommonRuntimeOptions(b),{"isInWorker":!1,"messagePort":c,"canvas":this._canvas});this._localRuntime=self["C3_CreateRuntime"](e),await self["C3_InitRuntime"](this._localRuntime,e)}async _OnCreateJobWorker(){const a=await this._jobScheduler._CreateJobWorker();return{"outputPort":a,"transferables":[a]}}_GetLocalRuntime(){if(this._useWorker)throw new Error("not available in worker mode");return this._localRuntime}PostToRuntimeComponent(a,b,c,d,e){this._messageChannelPort.postMessage({"type":"event","component":a,"handler":b,"dispatchRuntimeEvent":d,"data":c,"responseId":null},this._transferablesBroken?void 0:e)}PostToRuntimeComponentAsync(a,b,c,d,e){const f=o++,g=new Promise((a,b)=>{n.set(f,{resolve:a,reject:b})});return this._messageChannelPort.postMessage({"type":"event","component":a,"handler":b,"dispatchRuntimeEvent":d,"data":c,"responseId":f},this._transferablesBroken?void 0:e),g}["_OnMessageFromRuntime"](a){const b=a["type"];if("event"===b)this._OnEventFromRuntime(a);else if("result"===b)this._OnResultFromRuntime(a);else if("runtime-ready"===b)this._OnRuntimeReady();else throw new Error(`unknown message '${b}'`)}_OnEventFromRuntime(a){const b=a["component"],c=a["handler"],d=a["data"],e=a["responseId"],f=m.get(b);if(!f)return void console.warn(`[DOM] No event handlers for component '${b}'`);const g=f.get(c);if(!g)return void console.warn(`[DOM] No handler '${c}' for component '${b}'`);let h=null;try{h=g(d)}catch(a){return console.error(`Exception in '${b}' handler '${c}':`,a),void(null!==e&&this._PostResultToRuntime(e,!1,a.toString()))}null!==e&&(h&&h.then?h.then((a)=>this._PostResultToRuntime(e,!0,a)).catch((a)=>{console.error(`Rejection from '${b}' handler '${c}':`,a),this._PostResultToRuntime(e,!1,a.toString())}):this._PostResultToRuntime(e,!0,h))}_PostResultToRuntime(a,b,c){let d;c&&c["transferables"]&&(d=c["transferables"]),this._messageChannelPort.postMessage({"type":"result","responseId":a,"isOk":b,"result":c},d)}_OnResultFromRuntime(a){const b=a["responseId"],c=a["isOk"],d=a["result"],e=n.get(b);c?e.resolve(d):e.reject(d),n.delete(b)}AddRuntimeComponentMessageHandler(a,b,c){let d=m.get(a);if(d||(d=new Map,m.set(a,d)),d.has(b))throw new Error(`[DOM] Component '${a}' already has handler '${b}'`);d.set(b,c)}static AddDOMHandlerClass(a){if(l.includes(a))throw new Error("DOM handler already added");l.push(a)}_FindRuntimeDOMHandler(){for(const a of this._domHandlers)if("runtime"===a.GetComponentID())return void(this._runtimeDomHandler=a);throw new Error("cannot find runtime DOM handler")}_OnMessageFromDebugger(a){this.PostToRuntimeComponent("debugger","message",a)}_OnRuntimeReady(){for(const a of this._domHandlers)a.Attach()}static IsDocumentFullscreen(){return!!(document["fullscreenElement"]||document["webkitFullscreenElement"]||document["mozFullScreenElement"])}_AddRAFCallback(a){this._rafCallbacks.push(a),this._RequestAnimationFrame()}_RemoveRAFCallback(a){const b=this._rafCallbacks.indexOf(a);if(-1===b)throw new Error("invalid callback");this._rafCallbacks.splice(b,1),this._rafCallbacks.length||this._CancelAnimationFrame()}_RequestAnimationFrame(){-1===this._rafId&&this._rafCallbacks.length&&(this._rafId=requestAnimationFrame(this._rafFunc))}_CancelAnimationFrame(){-1!==this._rafId&&(cancelAnimationFrame(this._rafId),this._rafId=-1)}_OnRAFCallback(){this._rafId=-1;for(const a of this._rafCallbacks)a();this._RequestAnimationFrame()}TryPlayMedia(a,b){this._runtimeDomHandler.TryPlayMedia(a,b)}RemovePendingPlay(a){this._runtimeDomHandler.RemovePendingPlay(a)}_PlayPendingMedia(){this._runtimeDomHandler._PlayPendingMedia()}SetSilent(a){this._runtimeDomHandler.SetSilent(a)}IsAudioFormatSupported(a){return!!g[a]}async _WasmDecodeWebMOpus(a){const b=await this.PostToRuntimeComponentAsync("runtime","opus-decode",{"arrayBuffer":a},!1,[a]);return new Float32Array(b)}IsAbsoluteURL(a){return /^(?:[a-z]+:)?\/\//.test(a)||"data:"===a.substr(0,5)||"blob:"===a.substr(0,5)}IsRelativeURL(a){return!this.IsAbsoluteURL(a)}async _OnCordovaFetchLocalFile(a){const b=a["filename"];switch(a["as"]){case"text":return await this.CordovaFetchLocalFileAsText(b);case"blob":return await this.CordovaFetchLocalFileAsBlob(b);case"blob-url":return await this.CordovaFetchLocalFileAsURL(b);default:throw new Error("unsupported type");}}CordovaFetchLocalFile(a){const b=window["cordova"]["file"]["applicationDirectory"]+"www/"+a;return new Promise((a,c)=>{window["resolveLocalFileSystemURL"](b,(b)=>{b["file"](a,c)},c)})}async CordovaFetchLocalFileAsText(a){const c=await this.CordovaFetchLocalFile(a);return await b(c)}_CordovaMaybeStartNextArrayBufferRead(){if(h.length&&!(i>=j)){i++;const a=h.shift();this._CordovaDoFetchLocalFileAsAsArrayBuffer(a.filename,a.successCallback,a.errorCallback)}}CordovaFetchLocalFileAsArrayBuffer(a){return new Promise((b,c)=>{h.push({filename:a,successCallback:(a)=>{i--,this._CordovaMaybeStartNextArrayBufferRead(),b(a)},errorCallback:(a)=>{i--,this._CordovaMaybeStartNextArrayBufferRead(),c(a)}}),this._CordovaMaybeStartNextArrayBufferRead()})}async _CordovaDoFetchLocalFileAsAsArrayBuffer(a,b,d){try{const d=await this.CordovaFetchLocalFile(a),e=await c(d);b(e)}catch(a){d(a)}}async CordovaFetchLocalFileAsBlob(a,b){b||(b=d(a));const c=await this.CordovaFetchLocalFileAsArrayBuffer(a);return new Blob([c],{type:b})}async CordovaFetchLocalFileAsURL(a){const b=await this.CordovaFetchLocalFileAsBlob(a);return URL.createObjectURL(b)}_TestTransferablesWork(){let a=null;const b=new Promise((b)=>a=b),c=new ArrayBuffer(1),d=new MessageChannel;return d.port2.onmessage=(b)=>{b.data&&b.data["arrayBuffer"]||(this._transferablesBroken=!0,console.warn("MessageChannel transfers determined to be broken. Disabling transferables.")),a()},d.port1.postMessage({"arrayBuffer":c},[c]),b}}}
6 |
7 | "use strict";{function a(a){return a["sourceCapabilities"]&&a["sourceCapabilities"]["firesTouchEvents"]||a["originalEvent"]&&a["originalEvent"]["sourceCapabilities"]&&a["originalEvent"]["sourceCapabilities"]["firesTouchEvents"]}function b(a){return new Promise((b,c)=>{const d=new Image;d.onload=()=>b(d),d.onerror=(a)=>c(a),d.src=a})}async function c(a){const c=URL.createObjectURL(a);try{return await b(c)}finally{URL.revokeObjectURL(c)}}function d(){return window.parent&&window.parent.document.hasFocus()}self["C3_RasterSvgImage"]=async function(a,b,c){const d=document.createElement("canvas");d.width=b,d.height=c;const e=d.getContext("2d");return e.drawImage(a,0,0,b,c),d};let e=!1;document.addEventListener("pause",()=>e=!0),document.addEventListener("resume",()=>e=!1);const f=class extends DOMHandler{constructor(a){super(a,"runtime"),this._isFirstSizeUpdate=!0,this._targetOrientation="any",this._debugHighlightElem=null,a.AddRuntimeComponentMessageHandler("canvas","update-size",(a)=>this._OnUpdateCanvasSize(a)),a.AddRuntimeComponentMessageHandler("runtime","invoke-download",(a)=>this._OnInvokeDownload(a)),a.AddRuntimeComponentMessageHandler("runtime","raster-svg-image",(a)=>this._OnRasterSvgImage(a)),a.AddRuntimeComponentMessageHandler("runtime","set-target-orientation",(a)=>this._OnSetTargetOrientation(a)),a.AddRuntimeComponentMessageHandler("runtime","register-sw",()=>this._OnRegisterSW()),a.AddRuntimeComponentMessageHandler("runtime","post-to-debugger",(a)=>this._OnPostToDebugger(a)),a.AddRuntimeComponentMessageHandler("runtime","before-start-ticking",()=>this._OnBeforeStartTicking()),a.AddRuntimeComponentMessageHandler("runtime","debug-highlight",(a)=>this._OnDebugHighlight(a));const b=a.GetCanvas();b.addEventListener("contextmenu",(a)=>a.preventDefault()),b.addEventListener("selectstart",(a)=>a.preventDefault()),b.addEventListener("gesturehold",(a)=>a.preventDefault()),b.addEventListener("touchstart",(a)=>a.preventDefault()),window.addEventListener("mousedown",(a)=>{1===a.button&&a.preventDefault()}),window.addEventListener("resize",()=>this._OnWindowResize()),this._mediaPendingPlay=new Set,this._mediaRemovedPendingPlay=new WeakSet,this._isSilent=!1}_OnBeforeStartTicking(){return window.addEventListener("visibilitychange",()=>this._OnVisibilityChange(document.hidden)),document.addEventListener("pause",()=>this._OnVisibilityChange(!0)),document.addEventListener("resume",()=>this._OnVisibilityChange(!1)),{"isSuspended":!!(document.hidden||e)}}Attach(){window.addEventListener("focus",()=>this._PostRuntimeEvent("window-focus")),window.addEventListener("blur",()=>this._PostRuntimeEvent("window-blur",{"parentHasFocus":d()})),window.addEventListener("fullscreenchange",()=>this._OnFullscreenChange()),window.addEventListener("webkitfullscreenchange",()=>this._OnFullscreenChange()),window.addEventListener("mozfullscreenchange",()=>this._OnFullscreenChange()),window.addEventListener("fullscreenerror",(a)=>this._OnFullscreenError(a)),window.addEventListener("webkitfullscreenerror",(a)=>this._OnFullscreenError(a)),window.addEventListener("mozfullscreenerror",(a)=>this._OnFullscreenError(a)),window.addEventListener("keydown",(a)=>this._OnKeyEvent("keydown",a)),window.addEventListener("keyup",(a)=>this._OnKeyEvent("keyup",a)),window.addEventListener("mousemove",(a)=>this._OnMouseEvent("mousemove",a)),window.addEventListener("mousedown",(a)=>this._OnMouseEvent("mousedown",a)),window.addEventListener("mouseup",(a)=>this._OnMouseEvent("mouseup",a)),window.addEventListener("dblclick",(a)=>this._OnMouseEvent("dblclick",a)),window.addEventListener("wheel",(a)=>this._OnMouseWheelEvent("wheel",a)),"undefined"==typeof PointerEvent?(window.addEventListener("touchstart",(a)=>this._OnTouchEvent("pointerdown",a)),window.addEventListener("touchmove",(a)=>this._OnTouchEvent("pointermove",a)),window.addEventListener("touchend",(a)=>this._OnTouchEvent("pointerup",a)),window.addEventListener("touchcancel",(a)=>this._OnTouchEvent("pointercancel",a))):(window.addEventListener("pointerdown",(a)=>this._OnPointerEvent("pointerdown",a)),window.addEventListener("pointermove",(a)=>this._OnPointerEvent("pointermove",a)),window.addEventListener("pointerup",(a)=>this._OnPointerEvent("pointerup",a)),window.addEventListener("pointercancel",(a)=>this._OnPointerEvent("pointercancel",a))),window.addEventListener("deviceorientation",(a)=>this._OnDeviceOrientation(a)),window.addEventListener("devicemotion",(a)=>this._OnDeviceMotion(a));const a=()=>this._PlayPendingMedia();window.addEventListener("pointerup",a,!0),window.addEventListener("touchend",a,!0),window.addEventListener("click",a,!0),window.addEventListener("keydown",a,!0),window.addEventListener("gamepadconnected",a,!0)}_PostRuntimeEvent(a,b){this.PostToRuntime(a,b||null,!0)}_OnWindowResize(){this.PostToRuntime("window-resize",{"innerWidth":window.innerWidth,"innerHeight":window.innerHeight,"devicePixelRatio":window.devicePixelRatio},!0)}_OnSetTargetOrientation(a){this._targetOrientation=a["targetOrientation"]}_TrySetTargetOrientation(){const a=this._targetOrientation;if(screen["orientation"]&&screen["orientation"]["lock"])screen["orientation"]["lock"](a).catch((a)=>console.warn("[Construct 3] Failed to lock orientation: ",a));else try{let b=!1;screen["lockOrientation"]?b=screen["lockOrientation"](a):screen["webkitLockOrientation"]?b=screen["webkitLockOrientation"](a):screen["mozLockOrientation"]?b=screen["mozLockOrientation"](a):screen["msLockOrientation"]&&(b=screen["msLockOrientation"](a)),b||console.warn("[Construct 3] Failed to lock orientation")}catch(a){console.warn("[Construct 3] Failed to lock orientation: ",a)}}_OnFullscreenChange(){const a=RuntimeInterface.IsDocumentFullscreen();a&&"any"!==this._targetOrientation&&this._TrySetTargetOrientation(),this.PostToRuntime("fullscreenchange",{"isFullscreen":a,"innerWidth":window.innerWidth,"innerHeight":window.innerHeight})}_OnFullscreenError(a){console.warn("[Construct 3] Fullscreen request failed: ",a),this.PostToRuntime("fullscreenerror",{"isFullscreen":RuntimeInterface.IsDocumentFullscreen(),"innerWidth":window.innerWidth,"innerHeight":window.innerHeight})}_OnVisibilityChange(a){a?this._iRuntime._CancelAnimationFrame():this._iRuntime._RequestAnimationFrame(),this.PostToRuntime("visibilitychange",{"hidden":a})}_OnKeyEvent(a,b){this._PostToRuntimeMaybeSync(a,{"code":b.code,"key":b.key,"which":b.which,"repeat":b.repeat,"altKey":b.altKey,"ctrlKey":b.ctrlKey,"metaKey":b.metaKey,"shiftKey":b.shiftKey,"timeStamp":b.timeStamp},!0)}_OnMouseEvent(b,c){a(c)||("mousedown"===b&&window!==window.top&&window.focus(),this._PostToRuntimeMaybeSync(b,{"button":c.button,"clientX":c.clientX,"clientY":c.clientY,"timeStamp":c.timeStamp},!0))}_OnMouseWheelEvent(a,b){this.PostToRuntime(a,{"clientX":b.clientX,"clientY":b.clientY,"deltaX":b.deltaX,"deltaY":b.deltaY,"deltaZ":b.deltaZ,"deltaMode":b.deltaMode,"timeStamp":b.timeStamp},!0)}_OnPointerEvent(a,b){"pointerdown"===a&&window!==window.top&&window.focus(),this._PostToRuntimeMaybeSync(a,{"pointerId":b.pointerId,"pointerType":b.pointerType,"clientX":b.clientX,"clientY":b.clientY,"width":b.width||0,"height":b.height||0,"pressure":b.pressure||0,"tangentialPressure":b["tangentialPressure"]||0,"tiltX":b.tiltX||0,"tiltY":b.tiltY||0,"twist":b["twist"]||0,"timeStamp":b.timeStamp},!0)}_OnTouchEvent(a,b){"pointerdown"===a&&window!==window.top&&window.focus();for(let c=0,d=b.changedTouches.length;c{this._mediaRemovedPendingPlay.has(b)||this._mediaPendingPlay.add(b)})}}TryPlayMedia(a,b){if("function"!=typeof a.play)throw new Error("missing play function");if(this._mediaRemovedPendingPlay.delete(a),b)return void this._mediaPendingPlay.add(a);let c;try{c=a.play()}catch(b){return void this._mediaPendingPlay.add(a)}c&&c.catch(()=>{this._mediaRemovedPendingPlay.has(a)||this._mediaPendingPlay.add(a)})}RemovePendingPlay(a){this._mediaPendingPlay.delete(a),this._mediaRemovedPendingPlay.add(a)}SetSilent(a){this._isSilent=!!a}_OnDebugHighlight(a){const b=a["show"];if(!b)return void(this._debugHighlightElem&&(this._debugHighlightElem.style.display="none"));this._debugHighlightElem||(this._debugHighlightElem=document.createElement("div"),this._debugHighlightElem.id="inspectOutline",document.body.appendChild(this._debugHighlightElem));const c=this._debugHighlightElem;c.style.display="",c.style.left=a["left"]-1+"px",c.style.top=a["top"]-1+"px",c.style.width=a["width"]+2+"px",c.style.height=a["height"]+2+"px",c.textContent=a["name"]}_OnRegisterSW(){window["C3_RegisterSW"]&&window["C3_RegisterSW"]()}_OnPostToDebugger(a){window["c3_postToMessagePort"]&&(a["from"]="runtime",window["c3_postToMessagePort"](a))}};RuntimeInterface.AddDOMHandlerClass(f)}
8 |
9 | "use strict";{const a=document.currentScript.src;self.JobSchedulerDOM=class{constructor(b){this._runtimeInterface=b,this._baseUrl=a.substr(0,a.lastIndexOf("/")+1),this._maxNumWorkers=Math.min(navigator.hardwareConcurrency||2,16),this._dispatchWorker=null,this._jobWorkers=[],this._inputPort=null,this._outputPort=null}async Init(){if(this._hasInitialised)throw new Error("already initialised");this._hasInitialised=!0;const a=this._runtimeInterface._GetWorkerURL("dispatchWorker.js");this._dispatchWorker=await this._runtimeInterface.CreateWorker(a,this._baseUrl,{name:"DispatchWorker"});const b=new MessageChannel;this._inputPort=b.port1,this._dispatchWorker.postMessage({"type":"_init","in-port":b.port2},[b.port2]),this._outputPort=await this._CreateJobWorker()}async _CreateJobWorker(){const a=this._jobWorkers.length,b=this._runtimeInterface._GetWorkerURL("jobWorker.js"),c=await this._runtimeInterface.CreateWorker(b,this._baseUrl,{name:"JobWorker"+a}),d=new MessageChannel,e=new MessageChannel;return this._dispatchWorker.postMessage({"type":"_addJobWorker","port":d.port1},[d.port1]),c.postMessage({"type":"init","number":a,"dispatch-port":d.port2,"output-port":e.port2},[d.port2,e.port2]),this._jobWorkers.push(c),e.port1}GetPortData(){return{"inputPort":this._inputPort,"outputPort":this._outputPort,"maxNumWorkers":this._maxNumWorkers}}GetPortTransferables(){return[this._inputPort,this._outputPort]}}}
10 |
11 | "use strict";if(window["C3_IsSupported"]){const a=false,b="undefined"!=typeof OffscreenCanvas;window["c3_runtimeInterface"]=new RuntimeInterface({useWorker:a&&b,workerMainUrl:"workerMain.js",engineScripts:["scripts/c3runtime.js"],exportType:"scirra-arcade"})}"use strict";
12 | {
13 | const a = class extends DOMHandler {
14 | constructor(a) {
15 | super(a, "stranianelli_htmlelement"),
16 | this.AddRuntimeMessageHandler("prova", (a)=>this._prova(a))
17 | }
18 | _prova(a) {
19 | console.log(a);
20 | }
21 | };
22 | RuntimeInterface.AddDOMHandlerClass(a)
23 | }
24 | "use strict";{const a=class extends DOMHandler{constructor(a){super(a,"browser"),this._exportType="",this.AddRuntimeMessageHandler("get-initial-state",(a)=>this._OnGetInitialState(a)),this.AddRuntimeMessageHandler("ready-for-sw-messages",()=>this._OnReadyForSWMessages()),this.AddRuntimeMessageHandler("alert",(a)=>this._OnAlert(a)),this.AddRuntimeMessageHandler("close",()=>this._OnClose()),this.AddRuntimeMessageHandler("set-focus",(a)=>this._OnSetFocus(a)),this.AddRuntimeMessageHandler("vibrate",(a)=>this._OnVibrate(a)),this.AddRuntimeMessageHandler("lock-orientation",(a)=>this._OnLockOrientation(a)),this.AddRuntimeMessageHandler("unlock-orientation",()=>this._OnUnlockOrientation()),this.AddRuntimeMessageHandler("navigate",(a)=>this._OnNavigate(a)),this.AddRuntimeMessageHandler("request-fullscreen",()=>this._OnRequestFullscreen()),this.AddRuntimeMessageHandler("exit-fullscreen",()=>this._OnExitFullscreen()),window.addEventListener("online",()=>this._OnOnlineStateChanged(!0)),window.addEventListener("offline",()=>this._OnOnlineStateChanged(!1)),document.addEventListener("backbutton",()=>this._OnCordovaBackButton()),"undefined"!=typeof Windows&&Windows["UI"]["Core"]["SystemNavigationManager"]["getForCurrentView"]().addEventListener("backrequested",(a)=>this._OnWin10BackRequested(a))}_OnGetInitialState(a){return this._exportType=a["exportType"],{"location":location.toString(),"isOnline":!!navigator.onLine,"referrer":document.referrer,"title":document.title,"isCookieEnabled":!!navigator.cookieEnabled,"screenWidth":screen.width,"screenHeight":screen.height,"windowOuterWidth":window.outerWidth,"windowOuterHeight":window.outerHeight,"isScirraArcade":"undefined"!=typeof window["is_scirra_arcade"]}}_OnReadyForSWMessages(){window["C3_RegisterSW"]&&window["OfflineClientInfo"]&&window["OfflineClientInfo"]["SetMessageCallback"]((a)=>this.PostToRuntime("sw-message",a["data"]))}_OnOnlineStateChanged(a){this.PostToRuntime("online-state",{"isOnline":a})}_OnCordovaBackButton(){this.PostToRuntime("backbutton")}_OnWin10BackRequested(a){a["handled"]=!0,this.PostToRuntime("backbutton")}GetNWjsWindow(){return"nwjs"===this._exportType?nw["Window"]["get"]():null}_OnAlert(a){alert(a["message"])}_OnClose(){navigator["app"]&&navigator["app"]["exitApp"]?navigator["app"]["exitApp"]():navigator["device"]&&navigator["device"]["exitApp"]?navigator["device"]["exitApp"]():window.close()}_OnSetFocus(a){const b=a["isFocus"];if("nwjs"===this._exportType){const a=this.GetNWjsWindow();b?a["focus"]():a["blur"]()}else b?window.focus():window.blur()}_OnVibrate(a){navigator["vibrate"]&&navigator["vibrate"](a["pattern"])}_OnLockOrientation(a){const b=a["orientation"];if(screen["orientation"]&&screen["orientation"]["lock"])screen["orientation"]["lock"](b).catch((a)=>console.warn("[Construct 3] Failed to lock orientation: ",a));else try{let a=!1;screen["lockOrientation"]?a=screen["lockOrientation"](b):screen["webkitLockOrientation"]?a=screen["webkitLockOrientation"](b):screen["mozLockOrientation"]?a=screen["mozLockOrientation"](b):screen["msLockOrientation"]&&(a=screen["msLockOrientation"](b)),a||console.warn("[Construct 3] Failed to lock orientation")}catch(a){console.warn("[Construct 3] Failed to lock orientation: ",a)}}_OnUnlockOrientation(){try{screen["orientation"]&&screen["orientation"]["unlock"]?screen["orientation"]["unlock"]():screen["unlockOrientation"]?screen["unlockOrientation"]():screen["webkitUnlockOrientation"]?screen["webkitUnlockOrientation"]():screen["mozUnlockOrientation"]?screen["mozUnlockOrientation"]():screen["msUnlockOrientation"]&&screen["msUnlockOrientation"]()}catch(a){}}_OnNavigate(a){const b=a["type"];if("back"===b)navigator["app"]&&navigator["app"]["backHistory"]?navigator["app"]["backHistory"]():window.back();else if("forward"===b)window.forward();else if("home"===b)window.home();else if("reload"===b)location.reload();else if("url"===b){const b=a["url"],c=a["target"],d=a["exportType"];"windows-uwp"===d&&"undefined"!=typeof Windows?Windows["System"]["Launcher"]["launchUriAsync"](new Windows["Foundation"]["Uri"](b)):navigator["app"]&&navigator["app"]["loadUrl"]?navigator["app"]["loadUrl"](b,{"openExternal":!0}):"cordova"===d?window.open(b,"_system"):"preview"===d?window.open(b,"_blank"):!this._isScirraArcade&&(2===c?window.top.location=b:1===c?window.parent.location=b:window.location=b)}else if("new-window"===b){const b=a["url"],c=a["tag"],d=a["exportType"];"windows-uwp"===d&&"undefined"!=typeof Windows?Windows["System"]["Launcher"]["launchUriAsync"](new Windows["Foundation"]["Uri"](b)):navigator["app"]&&navigator["app"]["loadUrl"]?navigator["app"]["loadUrl"](b,{"openExternal":!0}):"cordova"===d?window.open(b,"_system"):window.open(b,c)}}_OnRequestFullscreen(){const a=document.documentElement;a["requestFullscreen"]?a["requestFullscreen"]():a["mozRequestFullScreen"]?a["mozRequestFullScreen"]():a["msRequestFullscreen"]?a["msRequestFullscreen"]():a["webkitRequestFullScreen"]&&("undefined"==typeof Element["ALLOW_KEYBOARD_INPUT"]?a["webkitRequestFullScreen"]():a["webkitRequestFullScreen"](Element["ALLOW_KEYBOARD_INPUT"]))}_OnExitFullscreen(){document["exitFullscreen"]?document["exitFullscreen"]():document["mozCancelFullScreen"]?document["mozCancelFullScreen"]():document["msExitFullscreen"]?document["msExitFullscreen"]():document["webkitCancelFullScreen"]&&document["webkitCancelFullScreen"]()}};RuntimeInterface.AddDOMHandlerClass(a)}"use strict";{const a=class extends DOMHandler{constructor(a){super(a,"platform-info"),this.AddRuntimeMessageHandler("get-initial-state",()=>this._OnGetInitialState()),window.addEventListener("resize",()=>this._OnResize())}_OnGetInitialState(){return{"screenWidth":screen.width,"screenHeight":screen.height,"windowOuterWidth":window.outerWidth,"windowOuterHeight":window.outerHeight}}_OnResize(){this.PostToRuntime("window-resize",{"windowOuterWidth":window.outerWidth,"windowOuterHeight":window.outerHeight})}};RuntimeInterface.AddDOMHandlerClass(a)}
--------------------------------------------------------------------------------
/src/data.json:
--------------------------------------------------------------------------------
1 | {"project":["Markdown Editor",null,[[0,true,false,false,false,false,false,false,false,false],[1,false,true,false,false,false,false,false,false,true],[3,true,false,false,false,false,false,false,false,false],[4,true,false,false,false,false,false,false,false,false],[8,true,false,false,false,false,false,false,false,false],[9,true,false,false,false,false,false,false,false,false]],[["InjectCSS",0,false,[],0,0,null,null,[],false,false,307712450042625,[],null,["menucss.css\nmarkstyle.css","https://use.fontawesome.com/releases/v5.5.0/css/all.css\nhttps://fonts.googleapis.com/css?family=Titillium+Web:300","converter.js","",false,false,false,false]],["preview",1,false,[[263867434321866,2],[785042420224724,2]],1,0,null,null,[["Pin",2,368126188696563]],false,false,223545613238781,[],null],["editor",1,false,[[318945251937074,2],[895058529110085,2]],1,0,null,null,[["Pin",2,417003925356019]],false,false,379315665423625,[],null],["Function",3,false,[],0,0,null,null,[],false,false,172763551076055,[],null,[]],["Browser",4,false,[],0,0,null,null,[],false,false,662787060195425,[],null,[]],["CreatedWith",1,false,[[921206691251334,2],[402616821581492,2],[271399795865870,2],[332486191708084,2]],0,0,null,null,[],false,false,809925256147814,[],null],["divEditor",1,false,[],2,0,null,null,[["DragDrop",5,914999733418918],["Tween",6,227761053902080]],false,false,538644577466113,[],null],["titleEditor",1,false,[],0,0,null,null,[],false,false,509901999180459,[],null],["divPreview",1,false,[],2,0,null,null,[["DragDrop",5,214056802439630],["Tween",6,366455074170027]],false,false,958528057323824,[],null],["titlePreview",1,false,[],0,0,null,null,[],false,false,695530591836299,[],null],["resizer",1,false,[[261499545436827,2]],1,0,null,null,[["DragDrop",5,715876396963551]],false,false,162872161460963,[],null],["barraMenu",1,false,[],0,0,null,null,[],false,false,714155732742882,[],null],["background",1,false,[],1,0,null,null,[["Anchor",7,740118925598862]],false,false,900136884544268,[],null],["itemMenu",1,false,[[554792414275197,2],[363427625248036,2],[736879988041575,2]],0,0,null,null,[],false,false,434096926873497,[],null],["PlatformInfo",8,false,[],0,0,null,null,[],false,false,997400297525423,[],null,[]],["Showdown",9,false,[],0,0,null,null,[],false,false,857540965958785,[],null,["github"]]],[],[["Markdown",854,480,false,"Markdown",379442058550755,[["Layer 0",0,206465746893004,true,[239,239,239],false,1,1,1,false,false,1,0,0,[[[0,0,0,856,480,0,0,[1,1,1,0.4],0,0,0,0,[]],12,18,[],[[0,0,1,1,true]],["","","","",true,true,true,true,"div","backgroundpatternd","","",false,false,"",false,false,0,"",false,false,false,"",0,0,0,0,0,"position: fixed;\ntop: 0;\nleft: 0;\nwidth: 100vw;\nheight: 100vh;",[0.7529411764705882,0.7529411764705882,0.7529411764705882],2,[0,0,0],true,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[424,64,0,248,328,0,0,[1,1,1,1],0,0,0,0,[]],8,8,[],[[0,true],[true,true]],["","","","",true,false,true,true,"div","card-preview","","",false,false,"text",true,true,5,"4px",true,false,false,"2px",2,0,0,0,0,"box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);",[1,0.3411764705882353,0.13333333333333333],2,[0.9019607843137255,0.2901960784313726,0.09411764705882353],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[456,64,0,96,24,0,0,[1,1,1,1],0,0,0,0,[]],9,7,[],[],["","[4]","","card-preview",false,false,false,true,"div","title-editor","noTextSelectable","",true,false,"{{title}}",false,false,0,"",true,true,false,"4px",0,0,0,0,0,"text-transform: uppercase;\nheight: 24px;\nwidth: 100%;",[1,0.6274509803921569,0.25882352941176473],2,[0,0,0],false,[0,0,0],true,"lato-bold",14,[0.9411764705882353,0.9411764705882353,0.9411764705882353],true,false,0,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[424,88,0,240,296,0,0,[1,1,1,1],0,0,0,0,[]],1,4,[["Preview"],[""]],[[]],["[\"title\", \"text\"]","","","card-preview",false,false,false,true,"div","preview","","",true,true,"{{text}}",true,true,5,"",true,true,false,"8px",2,0,0,0,3,"position: fixed;\ntop: 25px;\nbottom:2px;\nleft: 0px;\nwidth: 100%;\nresize: none;",[0.9411764705882353,0.9411764705882353,0.9411764705882353],1,[0.9019607843137255,0.2901960784313726,0.09411764705882353],false,[0,0,0],true,"lato-regular",12,[0.12941176470588237,0.12941176470588237,0.12941176470588237],false,false,0,0,0,"",true,"",false,"",false,"",false,"",false,"",true,"",true,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[112,88,0,296,256,0,0,[1,1,1,1],0,0,0,0,[]],6,11,[],[[0,true],[true,true]],["","","","",true,false,true,true,"div","card-editor","","",false,false,"text",true,true,5,"4px",true,false,false,"2px",2,0,0,0,0,"box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);",[0.24705882352941178,0.3176470588235294,0.7098039215686275],2,[0.18823529411764706,0.24705882352941178,0.7411764705882353],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[152,88,0,120,24,0,0,[1,1,1,1],0,0,0,0,[]],7,1,[],[],["","[3]","","card-editor",false,false,false,true,"div","title-editor","noTextSelectable","",true,false,"{{title}}",false,false,0,"",true,true,false,"4px",0,0,0,0,0,"text-transform: uppercase;\nheight: 24px;\nwidth: 100%;",[0,0.5019607843137255,1],2,[0,0,0],false,[0,0,0],true,"lato-bold",14,[0.9411764705882353,0.9411764705882353,0.9411764705882353],true,false,0,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[112,112,0,288,224,0,0,[1,1,1,1],0,0,0,0,[]],2,3,[["Editor"],["# ![Construct 3][c3-logo] Markdown Editor\n\nCreated with [**Construct 3**](https://www.construct.net/), [**HTMLElements**](https://www.construct.net/en/make-games/addons/190/html-element) and [showdownjs](http://demo.showdownjs.com/).\n\n\n[c3-logo]:\nhttps://s1.construct.net/images/v558/r/global/construct-3-logo_v43.png"]],[[]],["[\"title\",\"text\"]","","","card-editor",false,false,false,true,"textarea","editor","","",true,false,"{{text}}",true,true,5,"",true,true,false,"8px",2,4,4,0,4,"position: fixed;\ntop: 25px;\nbottom:2px;\nleft: 0px;\nwidth: 100%;\nresize: none;",[0.9411764705882353,0.9411764705882353,0.9411764705882353],1,[0.18823529411764706,0.24705882352941178,0.7411764705882353],false,[0,0,0],true,"lato-regular",12,[0.12941176470588237,0.12941176470588237,0.12941176470588237],false,false,0,0,0,"",true,"",false,"",false,"",false,"",false,"",true,"",true,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",true,"onInput()",false,"",false,"",false,"",false,""]],[[400,88,0,8,256,0,0,[1,1,1,0],0,0,0,0,[]],10,9,[["editor-dx"]],[[1,true]],["","","","",true,false,true,true,"div","editor-dx","resizer-dx","",false,false,"text",true,false,0,"",false,false,false,"",0,0,0,0,0,"",[1,1,0],2,[0,0,0],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[112,336,0,296,8,0,0,[1,1,1,0],0,0,0,0,[]],10,13,[["editor-bottom"]],[[2,true]],["","","","",true,false,true,true,"div","editor-bottom","resizer-bottom","",false,false,"text",true,false,0,"",false,false,false,"",0,0,0,0,0,"",[1,1,0],2,[0,0,0],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[664,64,0,8,328,0,0,[1,1,1,0],0,0,0,0,[]],10,12,[["preview-dx"]],[[1,true]],["","","","",true,false,true,true,"div","preview-dx","resizer-dx","",false,false,"text",true,false,0,"",false,false,false,"",0,0,0,0,0,"",[1,1,0],2,[0,0,0],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[424,384,0,248,8,0,0,[1,1,1,0],0,0,0,0,[]],10,14,[["preview-bottom"]],[[2,true]],["","","","",true,false,true,true,"div","preview-bottom","resizer-bottom","",false,false,"text",true,false,0,"",false,false,false,"",0,0,0,0,0,"",[1,1,0],2,[0,0,0],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[400,336,0,8,8,0,0,[1,1,1,0],0,0,0,0,[]],10,15,[["editor-bassodestra"]],[[0,true]],["","","","",true,false,true,true,"div","editor-bassodestra","resizer-bassodestra","",false,false,"text",true,false,0,"",false,false,false,"",0,0,0,0,0,"",[1,0,0],2,[0,0,0],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",true,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[664,384,0,8,8,0,0,[1,1,1,0],0,0,0,0,[]],10,16,[["preview-bassodestra"]],[[0,true]],["","","","",true,false,true,true,"div","preview-bassodestra","resizer-bassodestra","",false,false,"text",true,false,0,"",false,false,false,"",0,0,0,0,0,"",[1,0,0],2,[0,0,0],false,[0,0,0],true,"Arial",12,[0,0,0],false,false,1,0,0,"",true,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[16,8,0,72,472,0,0,[1,1,1,1],0,0,0,0,[]],11,17,[],[],["","","","",false,false,false,true,"nav","main-menu","main-menu","",true,true,"",false,false,0,"",false,false,false,"",0,0,0,0,0,"",[0.12941176470588237,0.12941176470588237,0.12941176470588237],2,[0,0,0],true,[0,0,0],true,"lato-bold",12,[0,0,0],false,false,1,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[784,-16,0,128,48,0,0.7853981633974483,[1,1,1,1],0,0,0,0,[]],5,10,[["data:image/svg+xml;utf8;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCAyNzkuODUxIDI3OS44NTEiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDI3OS44NTEgMjc5Ljg1MTsiIHhtbDpzcGFjZT0icHJlc2VydmUiIHdpZHRoPSI1MTJweCIgaGVpZ2h0PSI1MTJweCI+CjxnPgoJPHBhdGggc3R5bGU9ImZpbGw6I0UyNTc0QzsiIGQ9Ik0yNTUuMzYxLDQxLjgzOWMtNDEuNDQ0LTQxLjQ1My04Mi41MzgtMjMuMzM5LTExNS40MzMsNi4yMyAgIEMxMDcuMDE2LDE4LjUsNjYuMjY0LDAuMDYyLDI0LjQ4Nyw0MS44MzljLTMyLjU3MSwzMi41NTMtMzIuNzI4LDg0Ljg2NiwwLDExNy4yNDRDMTM5LjU3LDI2Mi42MDUsMTM5LjU0MywyNjIuNDIxLDEzOS41NDMsMjYyLjQyMSAgIHMwLjE2NiwwLjM0MSwxMTUuODA5LTEwMy4zMzlDMjg4LjA5OCwxMjYuNzA0LDI4Ny45MzIsNzQuMzkyLDI1NS4zNjEsNDEuODM5eiIvPgoJPHBhdGggc3R5bGU9ImZpbGw6I0NCNEU0NDsiIGQ9Ik0xMzkuOTIsNDguMDZsLTAuMDc5LTAuMDYxdjIxNC4xNjhjMS44NDYtMS41NTgsMTUuNDE5LTEzLjM0NSwxMTUuNTExLTEwMy4wOTQgICBjMzIuNzM3LTMyLjM2OSwzMi41NzktODQuNjgyLDAtMTE3LjIzNUMyMTMuOTA4LDAuMzg2LDE3Mi44MjMsMTguNSwxMzkuOTIsNDguMDZ6Ii8+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPC9zdmc+Cg=="],[""],[""],["height:32px; width:32px; float:left; margin:2px;"]],[],["[\"love\",\"c3\",\"plugin\", \"imgS\"]","","","",false,false,true,true,"div","tag-made-with-love-and-c3","noTextSelectable","",true,true,"MADE WITH
\n
\n\n",true,true,5,"4px",true,true,false,"",0,0,0,0,0,"position: fixed;\ntop: -50px;\nright: -110px;\nwidth: 200px;\nheigt: 50px;\npadding: 2px;\nbox-shadow: 2px 2px 2px 1px rgba(128, 128, 128, .4);\nalign:center;\nz-index: 100;",[1,1,0.5019607843137255],1,[0.5019607843137255,0.5019607843137255,0.5019607843137255],true,[0,0,0],true,"Arial",11,[0.5019607843137255,0.5019607843137255,0.5019607843137255],true,false,1,0,0,"",true,"goToHome()",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[24,40,0,56,40,0,0,[1,1,1,1],0,0,0,0,[]],13,19,[["GitHub"],["fab fa-github fa-2x"],["goToHome()"]],[],["[\"text\",\"icon\",\"function\"]","","","main-menu",false,false,false,true,"li","","","",true,true,"
\n\n{{text}}\n",false,false,0,"",false,false,false,"",0,0,0,0,0,"",[0.25098039215686274,0.5019607843137255,0.5019607843137255],2,[0,0,0],true,[0,0,0],true,"Arial",12,[1,1,1],false,false,0,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[24,88,0,56,40,0,0,[1,1,1,1],0,0,0,0,[]],13,22,[["New"],["fas fa-file fa-2x"],["newFile()"]],[],["[\"text\",\"icon\",\"function\"]","","","main-menu",false,false,false,true,"li","","has-subnav","",true,true,"\n\n{{text}}\n",false,false,0,"",false,false,false,"",0,0,0,0,0,"",[0.25098039215686274,0.5019607843137255,0.5019607843137255],2,[0,0,0],true,[0,0,0],true,"Arial",12,[1,1,1],false,false,0,0,0,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,"",false,""]],[[24,136,0,56,40,0,0,[1,1,1,1],0,0,0,0,[]],13,20,[["Open"],["fas fa-folder-open fa-2x"],[""]],[],["[\"text\",\"icon\",\"function\"]","","","main-menu",false,false,false,true,"li","","has-subnav","",true,true,"\n\n\n\n\n