Skip to content

Commit

Permalink
Merge branch 'TurboWarp:master' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
RedMan13 committed Jul 11, 2023
2 parents a84a31a + c0b8f2d commit a9804e9
Show file tree
Hide file tree
Showing 16 changed files with 390 additions and 11 deletions.
39 changes: 38 additions & 1 deletion development/builder.js
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,39 @@ class SVGFile extends ImageFile {
}
}

class SitemapFile extends DiskFile {
constructor (build) {
super(null);
this.getDiskPath = null;
this.build = build;
}

getType () {
return '.xml';
}

read () {
let xml = '';
xml += '<?xml version="1.0" encoding="UTF-8"?>\n';
xml += '<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">\n';

xml += Object.keys(this.build.files)
.filter(file => file.endsWith('.html'))
.map(file => file.replace('index.html', '').replace('.html', ''))
.sort((a, b) => {
if (a.length < b.length) return -1;
if (a.length > b.length) return 1;
return a - b;
})
.map(path => `https://extensions.turbowarp.org${path}`)
.map(absoluteURL => `<url><loc>${absoluteURL}</loc></url>`)
.join('\n');

xml += '</urlset>\n';
return xml;
}
}

const IMAGE_FORMATS = new Map();
IMAGE_FORMATS.set('.png', ImageFile);
IMAGE_FORMATS.set('.jpg', ImageFile);
Expand All @@ -116,7 +149,7 @@ class Build {
}

getFile (path) {
return this.files[path] || this.files[`${path}index.html`] || null;
return this.files[path] || this.files[`${path}.html`] || this.files[`${path}index.html`] || null;
}

export (root) {
Expand Down Expand Up @@ -192,6 +225,10 @@ class Builder {
build.files[oldPath] = build.files[newPath];
}

if (this.mode !== 'desktop') {
build.files['/sitemap.xml'] = new SitemapFile(build);
}

const mostRecentExtensions = extensionFiles
.sort((a, b) => b.getLastModified() - a.getLastModified())
.slice(0, 5)
Expand Down
73 changes: 73 additions & 0 deletions extensions/Alestore/nfcwarp.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
(function(Scratch) {
'use strict';

/* globals NDEFReader */

const extIcon = '';
const blocksIcon = '';

class NFCWarp {
getInfo() {
return {
id: 'alestorenfc',
name: 'NFCWarp',
color1: '#FF4646',
color2: '#FF0000',
color3: '#990033',
menuIconURI: extIcon,
blockIconURI: blocksIcon,
blocks: [
{
blockType: Scratch.BlockType.LABEL,
text: 'Only works in Chrome on Android'
},
{
opcode: 'supported',
blockType: Scratch.BlockType.BOOLEAN,
text: 'NFC supported?'
},
{
opcode: 'nfcRead',
blockType: Scratch.BlockType.REPORTER,
text: 'read NFC tag',
disableMonitor: true
}
]
};
}

supported () {
return typeof NDEFReader !== 'undefined';
}

nfcRead() {
if (!this.supported()) {
return 'NFC not supported';
}
return new Promise((resolve, reject) => {
const ndef = new NDEFReader();
ndef.scan()
.then(() => {
ndef.onreadingerror = event => {
console.log('Reading error', event);
resolve('Tag not supported');
};
ndef.onreading = evt => {
const decoder = new TextDecoder();
const record = evt.message.records[0];
console.log('Record type: ' + record.recordType);
console.log('Record encoding: ' + record.encoding);
console.log('Record data: ' + decoder.decode(record.data));
resolve(decoder.decode(record.data));
};
})
.catch(error => {
console.log('Scan error', error);
resolve(`Error: ${error}`);
});
});
}
}

Scratch.extensions.register(new NFCWarp());
})(Scratch);
73 changes: 73 additions & 0 deletions extensions/Lily/Cast.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
(function (Scratch) {
'use strict';

const Cast = Scratch.Cast;

class CastUtil {
getInfo() {
return {
id: 'lmsCast',
name: 'Cast',
blocks: [
{
opcode: 'toType',
blockType: Scratch.BlockType.REPORTER,
text: 'cast [INPUT] to [TYPE]',
allowDropAnywhere: true,
disableMonitor: true,
arguments: {
INPUT: {
type: Scratch.ArgumentType.STRING,
defaultValue: 'apple'
},
TYPE: {
type: Scratch.ArgumentType.STRING,
menu: 'type'
}
}
},
{
opcode: 'typeOf',
blockType: Scratch.BlockType.REPORTER,
text: 'type of [INPUT]',
disableMonitor: true,
arguments: {
INPUT: {
type: Scratch.ArgumentType.STRING,
defaultValue: 'apple'
}
}
}
],
menus: {
type: {
acceptReporters: true,
items: ['number', 'string', 'boolean', 'default']
}
}
};
}

toType(args) {
const input = args.INPUT;
switch (args.TYPE) {
case ('number'): return Cast.toNumber(input);
case ('string'): return Cast.toString(input);
case ('boolean'): return Cast.toBoolean(input);
default: return input;
}
}

typeOf(args) {
const input = args.INPUT;
switch (typeof input) {
case ('number'): return 'number';
case ('string'): return 'string';
case ('boolean'): return 'boolean';
default: return '';
}
}
}

Scratch.extensions.register(new CastUtil());
})(Scratch);
1 change: 0 additions & 1 deletion extensions/Lily/TempVariables2.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@
});

function resetRuntimeVariables() {
console.log('runtime variables cleared');
runtimeVariables = Object.create(null);
}

Expand Down
118 changes: 118 additions & 0 deletions extensions/clipboard.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
/*!
* Copyright 2023 tomyo-code + AdamMady
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

(function(Scratch) {
'use strict';

if (!Scratch.extensions.unsandboxed) {
throw new Error('Clipboard must run unsandboxed');
}

const extensionicon = "";

let lastPastedText = '';

window.addEventListener('copy', (event) => {
Scratch.vm.runtime.startHats('clipboard_whenCopied') ;
});
window.addEventListener('paste', (event) => {
Scratch.vm.runtime.startHats('clipboard_whenPasted');
const clipboardData = event.clipboardData || window.clipboardData;
const pastedText = clipboardData.getData('Text');
lastPastedText = pastedText;
});

class Clipboard {
getInfo() {
return {
id: 'clipboard',
name: 'Clipboard',
blockIconURI: extensionicon,
color1: '#008080',
color2: '#006666',
blocks: [
{
opcode: 'whenCopied',
blockType: Scratch.BlockType.HAT,
text: 'when something is copied',
isEdgeActivated: false
},
{
opcode: 'whenPasted',
blockType: Scratch.BlockType.HAT,
text: 'when something is pasted',
isEdgeActivated: false
},
'---',
{
opcode: 'setClipboard',
blockType: Scratch.BlockType.COMMAND,
text: 'copy to clipboard: [TEXT]',
arguments: {
TEXT: {
type: Scratch.ArgumentType.STRING
}
}
},
{
opcode: 'resetClipboard',
blockType: Scratch.BlockType.COMMAND,
text: 'reset clipboard'
},
'---',
{
opcode: 'clipboard',
blockType: Scratch.BlockType.REPORTER,
text: 'clipboard',
disableMonitor: true
},
{
opcode: 'getLastPastedText',
blockType: Scratch.BlockType.REPORTER,
text: 'last pasted text',
disableMonitor: true
}
],
};
}

setClipboard(args) {
navigator.clipboard.writeText(args.TEXT);
}

resetClipboard() {
navigator.clipboard.writeText('');
}

clipboard() {
if (navigator.clipboard && navigator.clipboard.readText) {
return Scratch.canReadClipboard().then(allowed => {
if (allowed) {
return navigator.clipboard.readText();
}
return '';
});
}
return '';
}

getLastPastedText() {
return lastPastedText;
}
}

Scratch.extensions.register(new Clipboard());
})(Scratch);
Loading

0 comments on commit a9804e9

Please sign in to comment.