Don't generate new IDs for variables when making a sprite clone.

This commit is contained in:
Karishma Chadha 2018-08-07 16:24:02 -04:00
parent 337c1f464d
commit d91788406c

View file

@ -317,14 +317,16 @@ class Target extends EventEmitter {
* Create a clone of the variable with the given id from the dictionary of * Create a clone of the variable with the given id from the dictionary of
* this target's variables. * this target's variables.
* @param {string} id Id of variable to duplicate. * @param {string} id Id of variable to duplicate.
* @param {boolean=} optKeepOriginalId Optional flag to keep the original variable ID
* for the duplicate variable. This is necessary when cloning a sprite, for example.
* @return {?Variable} The duplicated variable, or null if * @return {?Variable} The duplicated variable, or null if
* the original variable was not found. * the original variable was not found.
*/ */
duplicateVariable (id) { duplicateVariable (id, optKeepOriginalId) {
if (this.variables.hasOwnProperty(id)) { if (this.variables.hasOwnProperty(id)) {
const originalVariable = this.variables[id]; const originalVariable = this.variables[id];
const newVariable = new Variable( const newVariable = new Variable(
null, // generate a new uid optKeepOriginalId ? id : null, // conditionally keep original id or generate a new one
originalVariable.name, originalVariable.name,
originalVariable.type, originalVariable.type,
originalVariable.isCloud originalVariable.isCloud
@ -338,19 +340,25 @@ class Target extends EventEmitter {
/** /**
* Duplicate the dictionary of this target's variables as part of duplicating. * Duplicate the dictionary of this target's variables as part of duplicating.
* this target or making a clone. * this target or making a clone.
* @param {object} blocks Block container for the target being duplicated * @param {object=} optBlocks Optional block container for the target being duplicated.
* If provided, new variables will be generated with new UIDs and any variable references
* in this blocks container will be updated to refer to the corresponding new IDs.
* @return {object} The duplicated dictionary of variables * @return {object} The duplicated dictionary of variables
*/ */
duplicateVariables (blocks) { duplicateVariables (optBlocks) {
const allVarRefs = blocks.getAllVariableAndListReferences(); let allVarRefs;
if (optBlocks) {
allVarRefs = optBlocks.getAllVariableAndListReferences();
}
return Object.keys(this.variables).reduce((accum, varId) => { return Object.keys(this.variables).reduce((accum, varId) => {
const newVariable = this.duplicateVariable(varId); const newVariable = this.duplicateVariable(varId, !optBlocks);
accum[newVariable.id] = newVariable; accum[newVariable.id] = newVariable;
const currVarRefs = allVarRefs[varId]; if (optBlocks && allVarRefs) {
if (currVarRefs) { const currVarRefs = allVarRefs[varId];
this.mergeVariables(varId, newVariable.id, currVarRefs); if (currVarRefs) {
this.mergeVariables(varId, newVariable.id, currVarRefs);
}
} }
return accum; return accum;
}, {}); }, {});
} }