mirror of
https://github.com/google/blockly.git
synced 2026-01-08 09:30:06 +01:00
Refactor and simplify marked spot logic.
This commit is contained in:
@@ -56,8 +56,8 @@ blocklyApp.AppComponent = ng.core.Component({
|
|||||||
// https://www.sitepoint.com/angular-2-components-providers-classes-factories-values/
|
// https://www.sitepoint.com/angular-2-components-providers-classes-factories-values/
|
||||||
providers: [
|
providers: [
|
||||||
blocklyApp.AudioService,
|
blocklyApp.AudioService,
|
||||||
|
blocklyApp.BlockConnectionService,
|
||||||
blocklyApp.BlockOptionsModalService,
|
blocklyApp.BlockOptionsModalService,
|
||||||
blocklyApp.ClipboardService,
|
|
||||||
blocklyApp.KeyboardInputService,
|
blocklyApp.KeyboardInputService,
|
||||||
blocklyApp.NotificationsService,
|
blocklyApp.NotificationsService,
|
||||||
blocklyApp.ToolboxModalService,
|
blocklyApp.ToolboxModalService,
|
||||||
|
|||||||
111
accessible/block-connection.service.js
Normal file
111
accessible/block-connection.service.js
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
/**
|
||||||
|
* AccessibleBlockly
|
||||||
|
*
|
||||||
|
* Copyright 2016 Google Inc.
|
||||||
|
* https://developers.google.com/blockly/
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview Angular2 Service for handling the mechanics of how blocks
|
||||||
|
* get connected to each other.
|
||||||
|
* @author sll@google.com (Sean Lip)
|
||||||
|
*/
|
||||||
|
|
||||||
|
blocklyApp.BlockConnectionService = ng.core.Class({
|
||||||
|
constructor: [
|
||||||
|
blocklyApp.NotificationsService, blocklyApp.AudioService,
|
||||||
|
function(_notificationsService, _audioService) {
|
||||||
|
this.notificationsService = _notificationsService;
|
||||||
|
this.audioService = _audioService;
|
||||||
|
|
||||||
|
// When a user "adds a link" to a block, the connection representing this
|
||||||
|
// link is stored here.
|
||||||
|
this.markedConnection_ = null;
|
||||||
|
}],
|
||||||
|
findCompatibleConnection_: function(block) {
|
||||||
|
// Locates and returns a connection on the given block that is compatible
|
||||||
|
// with the marked connection, if one exists. Returns null if no such
|
||||||
|
// connection exists.
|
||||||
|
// Note: this currently ignores input connections on the given block, since
|
||||||
|
// one doesn't usually mark an output connection and attach a block to it.
|
||||||
|
if (!this.markedConnection_ ||
|
||||||
|
!this.markedConnection_.getSourceBlock().workspace) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
var desiredType = Blockly.OPPOSITE_TYPE[this.markedConnection_.type];
|
||||||
|
var potentialConnection = (
|
||||||
|
desiredType == Blockly.OUTPUT_VALUE ? block.outputConnection :
|
||||||
|
desiredType == Blockly.PREVIOUS_STATEMENT ? block.previousConnection :
|
||||||
|
desiredType == Blockly.NEXT_STATEMENT ? block.nextConnection :
|
||||||
|
null);
|
||||||
|
|
||||||
|
if (potentialConnection &&
|
||||||
|
potentialConnection.checkType_(this.markedConnection_)) {
|
||||||
|
return potentialConnection;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
isAnyConnectionMarked: function() {
|
||||||
|
return Boolean(this.markedConnection_);
|
||||||
|
},
|
||||||
|
getMarkedConnectionSourceBlock: function() {
|
||||||
|
return this.markedConnection_ ?
|
||||||
|
this.markedConnection_.getSourceBlock() : null;
|
||||||
|
},
|
||||||
|
canBeAttachedToMarkedConnection: function(block) {
|
||||||
|
return Boolean(this.findCompatibleConnection_(block));
|
||||||
|
},
|
||||||
|
canBeMovedToMarkedConnection: function(block) {
|
||||||
|
if (!this.markedConnection_) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// It should not be possible to move any ancestor of the block containing
|
||||||
|
// the marked connection to the marked connection.
|
||||||
|
var ancestorBlock = this.getMarkedConnectionSourceBlock();
|
||||||
|
while (ancestorBlock) {
|
||||||
|
if (ancestorBlock.id == block.id) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
ancestorBlock = ancestorBlock.getParent();
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.canBeAttachedToMarkedConnection(block);
|
||||||
|
},
|
||||||
|
markConnection: function(connection) {
|
||||||
|
this.markedConnection_ = connection;
|
||||||
|
this.notificationsService.speak(Blockly.Msg.ADDED_LINK_MSG);
|
||||||
|
},
|
||||||
|
attachToMarkedConnection: function(block) {
|
||||||
|
var xml = Blockly.Xml.blockToDom(block);
|
||||||
|
var reconstitutedBlock = Blockly.Xml.domToBlock(blocklyApp.workspace, xml);
|
||||||
|
|
||||||
|
var connection = this.findCompatibleConnection_(reconstitutedBlock);
|
||||||
|
if (connection) {
|
||||||
|
this.markedConnection_.connect(connection);
|
||||||
|
this.markedConnection_ = null;
|
||||||
|
this.audioService.playConnectSound();
|
||||||
|
return reconstitutedBlock.id;
|
||||||
|
} else {
|
||||||
|
// We throw an error here, because we expect any UI controls that would
|
||||||
|
// result in a non-connection to be disabled or hidden.
|
||||||
|
throw Error(
|
||||||
|
'Unable to connect block to marked connection. This should not ' +
|
||||||
|
'happen.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
@@ -1,123 +0,0 @@
|
|||||||
/**
|
|
||||||
* AccessibleBlockly
|
|
||||||
*
|
|
||||||
* Copyright 2016 Google Inc.
|
|
||||||
* https://developers.google.com/blockly/
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @fileoverview Angular2 Service that handles the clipboard and marked spots.
|
|
||||||
* @author madeeha@google.com (Madeeha Ghori)
|
|
||||||
*/
|
|
||||||
|
|
||||||
blocklyApp.ClipboardService = ng.core.Class({
|
|
||||||
constructor: [
|
|
||||||
blocklyApp.NotificationsService, blocklyApp.UtilsService,
|
|
||||||
blocklyApp.AudioService,
|
|
||||||
function(_notificationsService, _utilsService, _audioService) {
|
|
||||||
this.markedConnection_ = null;
|
|
||||||
this.notificationsService = _notificationsService;
|
|
||||||
this.utilsService = _utilsService;
|
|
||||||
this.audioService = _audioService;
|
|
||||||
}],
|
|
||||||
areConnectionsCompatible_: function(blockConnection, connection) {
|
|
||||||
// Check that both connections exist, that it's the right kind of
|
|
||||||
// connection, and that the types match.
|
|
||||||
return Boolean(
|
|
||||||
connection && blockConnection &&
|
|
||||||
Blockly.OPPOSITE_TYPE[blockConnection.type] == connection.type &&
|
|
||||||
connection.checkType_(blockConnection));
|
|
||||||
},
|
|
||||||
getMarkedConnectionBlock: function() {
|
|
||||||
if (!this.markedConnection_) {
|
|
||||||
return null;
|
|
||||||
} else {
|
|
||||||
return this.markedConnection_.getSourceBlock();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
isAnyConnectionMarked: function() {
|
|
||||||
return Boolean(this.markedConnection_);
|
|
||||||
},
|
|
||||||
isMovableToMarkedConnection: function(block) {
|
|
||||||
// It should not be possible to move any ancestor of the block containing
|
|
||||||
// the marked spot to the marked spot.
|
|
||||||
if (!this.markedConnection_) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var markedSpotAncestorBlock = this.getMarkedConnectionBlock();
|
|
||||||
while (markedSpotAncestorBlock) {
|
|
||||||
if (markedSpotAncestorBlock.id == block.id) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
markedSpotAncestorBlock = markedSpotAncestorBlock.getParent();
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.canBeAttachedToMarkedConnection(block);
|
|
||||||
},
|
|
||||||
canBeAttachedToMarkedConnection: function(block) {
|
|
||||||
if (!this.markedConnection_ ||
|
|
||||||
!this.markedConnection_.getSourceBlock().workspace) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var potentialConnections = [
|
|
||||||
block.outputConnection,
|
|
||||||
block.previousConnection,
|
|
||||||
block.nextConnection
|
|
||||||
];
|
|
||||||
|
|
||||||
var that = this;
|
|
||||||
return potentialConnections.some(function(connection) {
|
|
||||||
return that.areConnectionsCompatible_(
|
|
||||||
connection, that.markedConnection_);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
markConnection: function(connection) {
|
|
||||||
this.markedConnection_ = connection;
|
|
||||||
this.notificationsService.speak(Blockly.Msg.ADDED_LINK_MSG);
|
|
||||||
},
|
|
||||||
pasteToMarkedConnection: function(block) {
|
|
||||||
var xml = Blockly.Xml.blockToDom(block);
|
|
||||||
var reconstitutedBlock = Blockly.Xml.domToBlock(
|
|
||||||
blocklyApp.workspace, xml);
|
|
||||||
|
|
||||||
var potentialConnections = [
|
|
||||||
reconstitutedBlock.outputConnection,
|
|
||||||
reconstitutedBlock.previousConnection,
|
|
||||||
reconstitutedBlock.nextConnection
|
|
||||||
];
|
|
||||||
|
|
||||||
var connectionSuccessful = false;
|
|
||||||
for (var i = 0; i < potentialConnections.length; i++) {
|
|
||||||
if (this.areConnectionsCompatible_(
|
|
||||||
this.markedConnection_, potentialConnections[i])) {
|
|
||||||
this.markedConnection_.connect(potentialConnections[i]);
|
|
||||||
this.audioService.playConnectSound();
|
|
||||||
connectionSuccessful = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!connectionSuccessful) {
|
|
||||||
console.error('ERROR: Could not connect block to marked spot.');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.markedConnection_ = null;
|
|
||||||
|
|
||||||
return reconstitutedBlock.id;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
@@ -37,7 +37,7 @@ Blockly.Msg.DELETE = 'Delete block';
|
|||||||
Blockly.Msg.MARK_SPOT_BEFORE = 'Add link before';
|
Blockly.Msg.MARK_SPOT_BEFORE = 'Add link before';
|
||||||
Blockly.Msg.MARK_SPOT_AFTER = 'Add link after';
|
Blockly.Msg.MARK_SPOT_AFTER = 'Add link after';
|
||||||
Blockly.Msg.MARK_THIS_SPOT = 'Add link inside';
|
Blockly.Msg.MARK_THIS_SPOT = 'Add link inside';
|
||||||
Blockly.Msg.MOVE_TO_MARKED_SPOT = 'Attach to existing link';
|
Blockly.Msg.MOVE_TO_MARKED_SPOT = 'Move to existing link';
|
||||||
Blockly.Msg.PASTE_AFTER = 'Paste after';
|
Blockly.Msg.PASTE_AFTER = 'Paste after';
|
||||||
Blockly.Msg.PASTE_BEFORE = 'Paste before';
|
Blockly.Msg.PASTE_BEFORE = 'Paste before';
|
||||||
Blockly.Msg.PASTE_INSIDE = 'Paste inside';
|
Blockly.Msg.PASTE_INSIDE = 'Paste inside';
|
||||||
|
|||||||
@@ -61,12 +61,13 @@ blocklyApp.SidebarComponent = ng.core.Component({
|
|||||||
})
|
})
|
||||||
.Class({
|
.Class({
|
||||||
constructor: [
|
constructor: [
|
||||||
blocklyApp.NotificationsService, blocklyApp.TreeService,
|
blocklyApp.BlockConnectionService,
|
||||||
blocklyApp.UtilsService, blocklyApp.ToolboxModalService,
|
blocklyApp.ToolboxModalService,
|
||||||
blocklyApp.ClipboardService,
|
blocklyApp.TreeService,
|
||||||
|
blocklyApp.UtilsService,
|
||||||
function(
|
function(
|
||||||
_notificationsService, _treeService, _utilsService,
|
blockConnectionService, toolboxModalService, treeService,
|
||||||
_toolboxModalService, _clipboardService) {
|
utilsService) {
|
||||||
// ACCESSIBLE_GLOBALS is a global variable defined by the containing
|
// ACCESSIBLE_GLOBALS is a global variable defined by the containing
|
||||||
// page. It should contain a key, customSidebarButtons, describing
|
// page. It should contain a key, customSidebarButtons, describing
|
||||||
// additional buttons that should be displayed after the default ones.
|
// additional buttons that should be displayed after the default ones.
|
||||||
@@ -75,18 +76,18 @@ blocklyApp.SidebarComponent = ng.core.Component({
|
|||||||
ACCESSIBLE_GLOBALS && ACCESSIBLE_GLOBALS.customSidebarButtons ?
|
ACCESSIBLE_GLOBALS && ACCESSIBLE_GLOBALS.customSidebarButtons ?
|
||||||
ACCESSIBLE_GLOBALS.customSidebarButtons : [];
|
ACCESSIBLE_GLOBALS.customSidebarButtons : [];
|
||||||
this.workspace = blocklyApp.workspace;
|
this.workspace = blocklyApp.workspace;
|
||||||
this.notificationsService = _notificationsService;
|
|
||||||
this.treeService = _treeService;
|
this.blockConnectionService = blockConnectionService;
|
||||||
this.utilsService = _utilsService;
|
this.toolboxModalService = toolboxModalService;
|
||||||
this.toolboxModalService = _toolboxModalService;
|
this.treeService = treeService;
|
||||||
this.clipboardService = _clipboardService;
|
this.utilsService = utilsService;
|
||||||
|
|
||||||
this.ID_FOR_ATTACH_TO_LINK_BUTTON = 'blocklyAttachToLinkBtn';
|
this.ID_FOR_ATTACH_TO_LINK_BUTTON = 'blocklyAttachToLinkBtn';
|
||||||
this.ID_FOR_CREATE_NEW_GROUP_BUTTON = 'blocklyCreateNewGroupBtn';
|
this.ID_FOR_CREATE_NEW_GROUP_BUTTON = 'blocklyCreateNewGroupBtn';
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
isAnyConnectionMarked: function() {
|
isAnyConnectionMarked: function() {
|
||||||
return this.clipboardService.isAnyConnectionMarked();
|
return this.blockConnectionService.isAnyConnectionMarked();
|
||||||
},
|
},
|
||||||
handleButtonClick: function(buttonConfig) {
|
handleButtonClick: function(buttonConfig) {
|
||||||
buttonConfig.action();
|
buttonConfig.action();
|
||||||
|
|||||||
@@ -25,15 +25,17 @@
|
|||||||
|
|
||||||
blocklyApp.ToolboxModalService = ng.core.Class({
|
blocklyApp.ToolboxModalService = ng.core.Class({
|
||||||
constructor: [
|
constructor: [
|
||||||
blocklyApp.TreeService, blocklyApp.UtilsService,
|
blocklyApp.BlockConnectionService,
|
||||||
blocklyApp.NotificationsService, blocklyApp.ClipboardService,
|
blocklyApp.NotificationsService,
|
||||||
|
blocklyApp.TreeService,
|
||||||
|
blocklyApp.UtilsService,
|
||||||
function(
|
function(
|
||||||
_treeService, _utilsService,
|
blockConnectionService, notificationsService, treeService,
|
||||||
_notificationsService, _clipboardService) {
|
utilsService) {
|
||||||
this.treeService = _treeService;
|
this.blockConnectionService = blockConnectionService;
|
||||||
this.utilsService = _utilsService;
|
this.notificationsService = notificationsService;
|
||||||
this.notificationsService = _notificationsService;
|
this.treeService = treeService;
|
||||||
this.clipboardService = _clipboardService;
|
this.utilsService = utilsService;
|
||||||
|
|
||||||
this.modalIsShown = false;
|
this.modalIsShown = false;
|
||||||
|
|
||||||
@@ -109,7 +111,8 @@ blocklyApp.ToolboxModalService = ng.core.Class({
|
|||||||
var selectedToolboxCategories = [];
|
var selectedToolboxCategories = [];
|
||||||
this.allToolboxCategories.forEach(function(toolboxCategory) {
|
this.allToolboxCategories.forEach(function(toolboxCategory) {
|
||||||
var selectedBlocks = toolboxCategory.blocks.filter(function(block) {
|
var selectedBlocks = toolboxCategory.blocks.filter(function(block) {
|
||||||
return that.clipboardService.canBeAttachedToMarkedConnection(block);
|
return that.blockConnectionService.canBeAttachedToMarkedConnection(
|
||||||
|
block);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (selectedBlocks.length > 0) {
|
if (selectedBlocks.length > 0) {
|
||||||
@@ -125,9 +128,10 @@ blocklyApp.ToolboxModalService = ng.core.Class({
|
|||||||
|
|
||||||
// Clean up the active desc for the destination tree.
|
// Clean up the active desc for the destination tree.
|
||||||
var oldDestinationTreeId = that.treeService.getTreeIdForBlock(
|
var oldDestinationTreeId = that.treeService.getTreeIdForBlock(
|
||||||
that.clipboardService.getMarkedConnectionBlock().id);
|
that.blockConnectionService.getMarkedConnectionSourceBlock().id);
|
||||||
that.treeService.clearActiveDesc(oldDestinationTreeId);
|
that.treeService.clearActiveDesc(oldDestinationTreeId);
|
||||||
var newBlockId = that.clipboardService.pasteToMarkedConnection(block);
|
var newBlockId = that.blockConnectionService.attachToMarkedConnection(
|
||||||
|
block);
|
||||||
|
|
||||||
// Invoke a digest cycle, so that the DOM settles.
|
// Invoke a digest cycle, so that the DOM settles.
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
|
|||||||
@@ -26,19 +26,22 @@
|
|||||||
|
|
||||||
blocklyApp.TreeService = ng.core.Class({
|
blocklyApp.TreeService = ng.core.Class({
|
||||||
constructor: [
|
constructor: [
|
||||||
blocklyApp.NotificationsService, blocklyApp.UtilsService,
|
|
||||||
blocklyApp.ClipboardService, blocklyApp.BlockOptionsModalService,
|
|
||||||
blocklyApp.AudioService,
|
blocklyApp.AudioService,
|
||||||
|
blocklyApp.BlockConnectionService,
|
||||||
|
blocklyApp.BlockOptionsModalService,
|
||||||
|
blocklyApp.NotificationsService,
|
||||||
|
blocklyApp.UtilsService,
|
||||||
function(
|
function(
|
||||||
_notificationsService, _utilsService, _clipboardService,
|
audioService, blockConnectionService, blockOptionsModalService,
|
||||||
_blockOptionsModalService, _audioService) {
|
notificationsService, utilsService) {
|
||||||
|
this.audioService = audioService;
|
||||||
|
this.blockConnectionService = blockConnectionService;
|
||||||
|
this.blockOptionsModalService = blockOptionsModalService;
|
||||||
|
this.notificationsService = notificationsService;
|
||||||
|
this.utilsService = utilsService;
|
||||||
|
|
||||||
// Stores active descendant ids for each tree in the page.
|
// Stores active descendant ids for each tree in the page.
|
||||||
this.activeDescendantIds_ = {};
|
this.activeDescendantIds_ = {};
|
||||||
this.notificationsService = _notificationsService;
|
|
||||||
this.utilsService = _utilsService;
|
|
||||||
this.clipboardService = _clipboardService;
|
|
||||||
this.blockOptionsModalService = _blockOptionsModalService;
|
|
||||||
this.audioService = _audioService;
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
// Returns a list of all top-level workspace tree nodes on the page.
|
// Returns a list of all top-level workspace tree nodes on the page.
|
||||||
@@ -273,7 +276,7 @@ blocklyApp.TreeService = ng.core.Class({
|
|||||||
if (block.previousConnection) {
|
if (block.previousConnection) {
|
||||||
actionButtonsInfo.push({
|
actionButtonsInfo.push({
|
||||||
action: function() {
|
action: function() {
|
||||||
that.clipboardService.markConnection(block.previousConnection);
|
that.blockConnectionService.markConnection(block.previousConnection);
|
||||||
that.focusOnBlock(block.id);
|
that.focusOnBlock(block.id);
|
||||||
},
|
},
|
||||||
translationIdForText: 'MARK_SPOT_BEFORE'
|
translationIdForText: 'MARK_SPOT_BEFORE'
|
||||||
@@ -283,23 +286,23 @@ blocklyApp.TreeService = ng.core.Class({
|
|||||||
if (block.nextConnection) {
|
if (block.nextConnection) {
|
||||||
actionButtonsInfo.push({
|
actionButtonsInfo.push({
|
||||||
action: function() {
|
action: function() {
|
||||||
that.clipboardService.markConnection(block.nextConnection);
|
that.blockConnectionService.markConnection(block.nextConnection);
|
||||||
that.focusOnBlock(block.id);
|
that.focusOnBlock(block.id);
|
||||||
},
|
},
|
||||||
translationIdForText: 'MARK_SPOT_AFTER'
|
translationIdForText: 'MARK_SPOT_AFTER'
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.clipboardService.isMovableToMarkedConnection(block)) {
|
if (this.blockConnectionService.canBeMovedToMarkedConnection(block)) {
|
||||||
actionButtonsInfo.push({
|
actionButtonsInfo.push({
|
||||||
action: function() {
|
action: function() {
|
||||||
var blockDescription = that.utilsService.getBlockDescription(
|
var blockDescription = that.utilsService.getBlockDescription(
|
||||||
block);
|
block);
|
||||||
var oldDestinationTreeId = that.getTreeIdForBlock(
|
var oldDestinationTreeId = that.getTreeIdForBlock(
|
||||||
that.clipboardService.getMarkedConnectionBlock().id);
|
that.blockConnectionService.getMarkedConnectionSourceBlock().id);
|
||||||
that.clearActiveDesc(oldDestinationTreeId);
|
that.clearActiveDesc(oldDestinationTreeId);
|
||||||
|
|
||||||
var newBlockId = that.clipboardService.pasteToMarkedConnection(
|
var newBlockId = that.blockConnectionService.attachToMarkedConnection(
|
||||||
block);
|
block);
|
||||||
|
|
||||||
that.removeBlockAndSetFocus(block, blockRootNode, function() {
|
that.removeBlockAndSetFocus(block, blockRootNode, function() {
|
||||||
|
|||||||
@@ -78,15 +78,17 @@ blocklyApp.WorkspaceTreeComponent = ng.core.Component({
|
|||||||
})
|
})
|
||||||
.Class({
|
.Class({
|
||||||
constructor: [
|
constructor: [
|
||||||
blocklyApp.ClipboardService, blocklyApp.TreeService,
|
blocklyApp.AudioService,
|
||||||
blocklyApp.UtilsService, blocklyApp.AudioService,
|
blocklyApp.BlockConnectionService,
|
||||||
function(
|
blocklyApp.TreeService,
|
||||||
_clipboardService, _treeService, _utilsService, _audioService) {
|
blocklyApp.UtilsService,
|
||||||
this.clipboardService = _clipboardService;
|
function(audioService, blockConnectionService, treeService, utilsService) {
|
||||||
this.treeService = _treeService;
|
this.audioService = audioService;
|
||||||
this.utilsService = _utilsService;
|
this.blockConnectionService = blockConnectionService;
|
||||||
this.audioService = _audioService;
|
this.treeService = treeService;
|
||||||
}],
|
this.utilsService = utilsService;
|
||||||
|
}
|
||||||
|
],
|
||||||
ngOnInit: function() {
|
ngOnInit: function() {
|
||||||
var SUPPORTED_FIELDS = [
|
var SUPPORTED_FIELDS = [
|
||||||
Blockly.FieldTextInput, Blockly.FieldDropdown,
|
Blockly.FieldTextInput, Blockly.FieldDropdown,
|
||||||
@@ -137,7 +139,7 @@ blocklyApp.WorkspaceTreeComponent = ng.core.Component({
|
|||||||
baseIdKey: 'markSpot',
|
baseIdKey: 'markSpot',
|
||||||
translationIdForText: 'MARK_THIS_SPOT',
|
translationIdForText: 'MARK_THIS_SPOT',
|
||||||
action: function(connection) {
|
action: function(connection) {
|
||||||
that.clipboardService.markConnection(connection);
|
that.blockConnectionService.markConnection(connection);
|
||||||
},
|
},
|
||||||
isDisabled: function() {
|
isDisabled: function() {
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -20,10 +20,10 @@
|
|||||||
|
|
||||||
<script src="../../accessible/utils.service.js"></script>
|
<script src="../../accessible/utils.service.js"></script>
|
||||||
<script src="../../accessible/audio.service.js"></script>
|
<script src="../../accessible/audio.service.js"></script>
|
||||||
|
<script src="../../accessible/notifications.service.js"></script>
|
||||||
|
<script src="../../accessible/block-connection.service.js"></script>
|
||||||
<script src="../../accessible/block-options-modal.service.js"></script>
|
<script src="../../accessible/block-options-modal.service.js"></script>
|
||||||
<script src="../../accessible/keyboard-input.service.js"></script>
|
<script src="../../accessible/keyboard-input.service.js"></script>
|
||||||
<script src="../../accessible/notifications.service.js"></script>
|
|
||||||
<script src="../../accessible/clipboard.service.js"></script>
|
|
||||||
<script src="../../accessible/tree.service.js"></script>
|
<script src="../../accessible/tree.service.js"></script>
|
||||||
<script src="../../accessible/toolbox-modal.service.js"></script>
|
<script src="../../accessible/toolbox-modal.service.js"></script>
|
||||||
<script src="../../accessible/translate.pipe.js"></script>
|
<script src="../../accessible/translate.pipe.js"></script>
|
||||||
|
|||||||
Reference in New Issue
Block a user