mirror of
https://github.com/google/blockly.git
synced 2025-12-15 22:00:07 +01:00
182 lines
5.2 KiB
TypeScript
182 lines
5.2 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2012 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
// Former goog.module ID: Blockly.libraryBlocks.variables
|
|
|
|
import type {Block} from '../core/block.js';
|
|
import {
|
|
createBlockDefinitionsFromJsonArray,
|
|
defineBlocks,
|
|
} from '../core/common.js';
|
|
import * as ContextMenu from '../core/contextmenu.js';
|
|
import type {
|
|
ContextMenuOption,
|
|
LegacyContextMenuOption,
|
|
} from '../core/contextmenu_registry.js';
|
|
import * as Extensions from '../core/extensions.js';
|
|
import '../core/field_label.js';
|
|
import {FieldVariable} from '../core/field_variable.js';
|
|
import {Msg} from '../core/msg.js';
|
|
import * as Variables from '../core/variables.js';
|
|
|
|
/**
|
|
* A dictionary of the block definitions provided by this module.
|
|
*/
|
|
export const blocks = createBlockDefinitionsFromJsonArray([
|
|
// Block for variable getter.
|
|
{
|
|
'type': 'variables_get',
|
|
'message0': '%1',
|
|
'args0': [
|
|
{
|
|
'type': 'field_variable',
|
|
'name': 'VAR',
|
|
'variable': '%{BKY_VARIABLES_DEFAULT_NAME}',
|
|
},
|
|
],
|
|
'output': null,
|
|
'style': 'variable_blocks',
|
|
'helpUrl': '%{BKY_VARIABLES_GET_HELPURL}',
|
|
'tooltip': '%{BKY_VARIABLES_GET_TOOLTIP}',
|
|
'extensions': ['contextMenu_variableSetterGetter'],
|
|
},
|
|
// Block for variable setter.
|
|
{
|
|
'type': 'variables_set',
|
|
'message0': '%{BKY_VARIABLES_SET}',
|
|
'args0': [
|
|
{
|
|
'type': 'field_variable',
|
|
'name': 'VAR',
|
|
'variable': '%{BKY_VARIABLES_DEFAULT_NAME}',
|
|
},
|
|
{
|
|
'type': 'input_value',
|
|
'name': 'VALUE',
|
|
},
|
|
],
|
|
'previousStatement': null,
|
|
'nextStatement': null,
|
|
'style': 'variable_blocks',
|
|
'tooltip': '%{BKY_VARIABLES_SET_TOOLTIP}',
|
|
'helpUrl': '%{BKY_VARIABLES_SET_HELPURL}',
|
|
'extensions': ['contextMenu_variableSetterGetter'],
|
|
},
|
|
]);
|
|
|
|
/** Type of a block that has CUSTOM_CONTEXT_MENU_VARIABLE_GETTER_SETTER_MIXIN */
|
|
type VariableBlock = Block & VariableMixin;
|
|
interface VariableMixin extends VariableMixinType {}
|
|
type VariableMixinType =
|
|
typeof CUSTOM_CONTEXT_MENU_VARIABLE_GETTER_SETTER_MIXIN;
|
|
|
|
/**
|
|
* Mixin to add context menu items to create getter/setter blocks for this
|
|
* setter/getter.
|
|
* Used by blocks 'variables_set' and 'variables_get'.
|
|
*/
|
|
const CUSTOM_CONTEXT_MENU_VARIABLE_GETTER_SETTER_MIXIN = {
|
|
/**
|
|
* Add menu option to create getter/setter block for this setter/getter.
|
|
*
|
|
* @param options List of menu options to add to.
|
|
*/
|
|
customContextMenu: function (
|
|
this: VariableBlock,
|
|
options: Array<ContextMenuOption | LegacyContextMenuOption>,
|
|
) {
|
|
if (!this.isInFlyout) {
|
|
let oppositeType;
|
|
let contextMenuMsg;
|
|
// Getter blocks have the option to create a setter block, and vice versa.
|
|
if (this.type === 'variables_get') {
|
|
oppositeType = 'variables_set';
|
|
contextMenuMsg = Msg['VARIABLES_GET_CREATE_SET'];
|
|
} else {
|
|
oppositeType = 'variables_get';
|
|
contextMenuMsg = Msg['VARIABLES_SET_CREATE_GET'];
|
|
}
|
|
|
|
const varField = this.getField('VAR')!;
|
|
const newVarBlockState = {
|
|
type: oppositeType,
|
|
fields: {VAR: varField.saveState(true)},
|
|
};
|
|
|
|
options.push({
|
|
enabled: this.workspace.remainingCapacity() > 0,
|
|
text: contextMenuMsg.replace('%1', varField.getText()),
|
|
callback: ContextMenu.callbackFactory(this, newVarBlockState),
|
|
});
|
|
// Getter blocks have the option to rename or delete that variable.
|
|
} else {
|
|
if (
|
|
this.type === 'variables_get' ||
|
|
this.type === 'variables_get_reporter'
|
|
) {
|
|
const renameOption = {
|
|
text: Msg['RENAME_VARIABLE'],
|
|
enabled: true,
|
|
callback: renameOptionCallbackFactory(this),
|
|
};
|
|
const name = this.getField('VAR')!.getText();
|
|
const deleteOption = {
|
|
text: Msg['DELETE_VARIABLE'].replace('%1', name),
|
|
enabled: true,
|
|
callback: deleteOptionCallbackFactory(this),
|
|
};
|
|
options.unshift(renameOption);
|
|
options.unshift(deleteOption);
|
|
}
|
|
}
|
|
},
|
|
};
|
|
|
|
/**
|
|
* Factory for callbacks for rename variable dropdown menu option
|
|
* associated with a variable getter block.
|
|
*
|
|
* @param block The block with the variable to rename.
|
|
* @returns A function that renames the variable.
|
|
*/
|
|
const renameOptionCallbackFactory = function (
|
|
block: VariableBlock,
|
|
): () => void {
|
|
return function () {
|
|
const workspace = block.workspace;
|
|
const variableField = block.getField('VAR') as FieldVariable;
|
|
const variable = variableField.getVariable()!;
|
|
Variables.renameVariable(workspace, variable);
|
|
};
|
|
};
|
|
|
|
/**
|
|
* Factory for callbacks for delete variable dropdown menu option
|
|
* associated with a variable getter block.
|
|
*
|
|
* @param block The block with the variable to delete.
|
|
* @returns A function that deletes the variable.
|
|
*/
|
|
const deleteOptionCallbackFactory = function (
|
|
block: VariableBlock,
|
|
): () => void {
|
|
return function () {
|
|
const variableField = block.getField('VAR') as FieldVariable;
|
|
const variable = variableField.getVariable();
|
|
if (variable) {
|
|
Variables.deleteVariable(variable.getWorkspace(), variable, block);
|
|
}
|
|
};
|
|
};
|
|
|
|
Extensions.registerMixin(
|
|
'contextMenu_variableSetterGetter',
|
|
CUSTOM_CONTEXT_MENU_VARIABLE_GETTER_SETTER_MIXIN,
|
|
);
|
|
|
|
// Register provided blocks.
|
|
defineBlocks(blocks);
|