mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-11 10:39:56 -05:00
Repopulate blocks with ids
This commit is contained in:
parent
31def7d03d
commit
2545d1955d
3 changed files with 33 additions and 1 deletions
|
@ -1,6 +1,33 @@
|
|||
const mutationAdapter = require('./mutation-adapter');
|
||||
const html = require('htmlparser2');
|
||||
|
||||
/**
|
||||
* (Copied from Blockly.utils)
|
||||
* Legal characters for the unique ID. Should be all on a US keyboard.
|
||||
* No characters that conflict with XML or JSON. Requests to remove additional
|
||||
* 'problematic' characters from this soup will be denied. That's your failure
|
||||
* to properly escape in your own environment. Issues #251, #625, #682, #1304.
|
||||
* @private
|
||||
*/
|
||||
const genUidSoup_ = '!#$%()*+,-./:;=?@[]^_`{|}~' +
|
||||
'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
|
||||
|
||||
/**
|
||||
* (Copied from Blockly.utils)
|
||||
* Generate a unique ID. This should be globally unique.
|
||||
* 87 characters ^ 20 length > 128 bits (better than a UUID).
|
||||
* @return {string} A globally unique ID string.
|
||||
*/
|
||||
const genUid_ = function () {
|
||||
const length = 20;
|
||||
const soupLength = genUidSoup_.length;
|
||||
const id = [];
|
||||
for (let i = 0; i < length; i++) {
|
||||
id[i] = genUidSoup_.charAt(Math.random() * soupLength);
|
||||
}
|
||||
return id.join('');
|
||||
};
|
||||
|
||||
/**
|
||||
* Convert and an individual block DOM to the representation tree.
|
||||
* Based on Blockly's `domToBlockHeadless_`.
|
||||
|
@ -11,6 +38,10 @@ const html = require('htmlparser2');
|
|||
* @return {undefined}
|
||||
*/
|
||||
const domToBlock = function (blockDOM, blocks, isTopBlock, parent) {
|
||||
if (!blockDOM.attribs.id) {
|
||||
blockDOM.attribs.id = genUid_();
|
||||
}
|
||||
|
||||
// Block skeleton.
|
||||
const block = {
|
||||
id: blockDOM.attribs.id, // Block ID
|
||||
|
|
|
@ -288,7 +288,7 @@ class Blocks {
|
|||
newCoordinate: e.newCoordinate
|
||||
});
|
||||
break;
|
||||
case 'drag':
|
||||
case 'dragOutside':
|
||||
if (optRuntime) {
|
||||
optRuntime.emitBlockDragUpdate(e.isOutside);
|
||||
}
|
||||
|
|
|
@ -626,6 +626,7 @@ class VirtualMachine extends EventEmitter {
|
|||
this._hoveredSpriteId !== this.editingTarget.id) {
|
||||
const dragTarget = this.runtime.getTargetById(this._hoveredSpriteId);
|
||||
if (dragTarget) {
|
||||
// TODO tell gui to tell blocks to undo, to cause the blocks to move back into place.
|
||||
const newBlocks = adapter(e);
|
||||
for (let i = 0; i < newBlocks.length; i++) {
|
||||
dragTarget.blocks.createBlock(newBlocks[i]);
|
||||
|
|
Loading…
Reference in a new issue