Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions src/extension-support/extension-manager.js
Original file line number Diff line number Diff line change
Expand Up @@ -71,8 +71,7 @@

builtinExtensions.koshien = () => {
const formatMessage = require('format-message');
const ext = require('../extensions/koshien/index.js');
const blockClass = ext.blockClass;
const blockClass = require('../extensions/koshien/index.js');
blockClass.formatMessage = formatMessage;
return blockClass;
};
Expand Down Expand Up @@ -369,11 +368,11 @@
const menuFunc = extensionObject[menuItemFunctionName];
const menuItems = menuFunc.call(extensionObject, editingTargetID).map(
item => {
item = maybeFormatMessage(item, extensionMessageContext);

Check warning on line 371 in src/extension-support/extension-manager.js

View workflow job for this annotation

GitHub Actions / ci-cd

Pattern is not a string literal
switch (typeof item) {
case 'object':
return [
maybeFormatMessage(item.text, extensionMessageContext),

Check warning on line 375 in src/extension-support/extension-manager.js

View workflow job for this annotation

GitHub Actions / ci-cd

Pattern is not a string literal
item.value
];
case 'string':
Expand Down
57 changes: 45 additions & 12 deletions src/extensions/koshien/index.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,17 @@
import ArgumentType from '../../extension-support/argument-type';
import BlockType from '../../extension-support/block-type';
import TargetType from '../../extension-support/target-type';
import Variable from '../../engine/variable';
const ArgumentType = require('../../extension-support/argument-type');
const BlockType = require('../../extension-support/block-type');
const TargetType = require('../../extension-support/target-type');
const Variable = require('../../engine/variable');

import blockIcon from './block-icon.png';
import translations from './translations.json';
/**
* Icon svg to be displayed at the left edge of each extension block, encoded as a data URI.
* @type {string}
*/
// eslint-disable-next-line max-len
const blockIconURI = '';

let formatMessage = messageData => messageData.defaultMessage;
let formatMessage = require('format-message');
const translations = require('./translations.json');

/**
* Setup format-message for this extension.
Expand Down Expand Up @@ -122,6 +127,11 @@ class KoshienClient {
return new Promise(resolve => resolve());
}

// eslint-disable-next-line no-unused-vars
setMessage (message) {
return new Promise(resolve => resolve());
}

calcRoute (props) {
// eslint-disable-next-line no-unused-vars
const {src, dst, exceptCells, result} = props;
Expand Down Expand Up @@ -413,7 +423,7 @@ class KoshienBlocks {
return {
id: KoshienBlocks.EXTENSION_ID,
name: KoshienBlocks.EXTENSION_NAME,
blockIconURI: blockIcon,
blockIconURI: blockIconURI,
showStatusButton: false,
blocks: [
{
Expand Down Expand Up @@ -703,6 +713,22 @@ class KoshienBlocks {

},
filter: [TargetType.SPRITE]
},
{
opcode: 'setMessage',
blockType: BlockType.COMMAND,
text: formatMessage({
id: 'koshien.setMessage',
default: 'message [MESSAGE]',
description: 'display a message'
}),
arguments: {
MESSAGE: {
type: ArgumentType.STRING,
defaultValue: 'hello'
}
},
filter: [TargetType.SPRITE]
}
],
menus: {
Expand Down Expand Up @@ -958,9 +984,16 @@ class KoshienBlocks {
return -1;
}
}

/**
* display a message
* @param {object} args - the block's arguments.
* @param {string} args.MESSAGE - message.
*/
// eslint-disable-next-line no-unused-vars
setMessage (args) {
return this._client.setMessage(args.MESSAGE);
}
}

export {
KoshienBlocks as default,
KoshienBlocks as blockClass
};
module.exports = KoshienBlocks;
2 changes: 2 additions & 0 deletions src/extensions/koshien/translations.json
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@
"koshien.locateObjects": "範囲内の地形・アイテム (中心 座標 [POSITION] 、範囲 [SQ_SIZE] 、地形・アイテム [OBJECTS])をリスト [RESULT] に保存する",
"koshien.targetCoordinate": "[TARGET] の [COORDINATE]",
"koshien.turnOver": "ターンを終了する",
"koshien.setMessage": "メッセージ [MESSAGE]",
"koshien.position": "座標 [X] [Y]",
"koshien.positionOf": "[POSITION] の [COORDINATE]",
"koshien.object": "[OBJECT]"
Expand Down Expand Up @@ -81,6 +82,7 @@
"koshien.locateObjects": "はんいないのちけい・アイテム (ちゅうしん ざひょう [POSITION] 、はんい [SQ_SIZE] 、ちけい・アイテム [OBJECTS])をリスト [RESULT] にほぞんする",
"koshien.targetCoordinate": "[TARGET] の [COORDINATE]",
"koshien.turnOver": "ターンをしゅうりょうする",
"koshien.setMessage": "メッセージ [MESSAGE]",
"koshien.position": "ざひょう [X] [Y]",
"koshien.positionOf": "[POSITION] の [COORDINATE]",
"koshien.object": "[OBJECT]"
Expand Down
Loading
Loading