mirror of
https://github.com/FoggedLens/iD.git
synced 2026-02-13 17:23:02 +00:00
This commit includes a bunch of minor things: - change keyboard shortcut to 'E' to not conflict with anything - move `disabled` check from operation into action and simplify - use `actionMoveNode` to place the detached node at the mouse cursor - disable the operation if the node is connected to hidden features - lots of code simplification - make the icon more centered
86 lines
2.5 KiB
JavaScript
86 lines
2.5 KiB
JavaScript
import _some from 'lodash-es/some';
|
|
|
|
import { actionDetachNode, actionMoveNode } from '../actions';
|
|
import { behaviorOperation } from '../behavior';
|
|
import { modeMove } from '../modes';
|
|
import { t } from '../util/locale';
|
|
|
|
|
|
export function operationDetachNode(selectedIDs, context) {
|
|
var nodeID = selectedIDs.length && selectedIDs[0];
|
|
var action = actionDetachNode(nodeID);
|
|
|
|
var operation = function () {
|
|
context.perform(action); // do the detach
|
|
|
|
var mouse = context.map().mouseCoordinates();
|
|
if (mouse.some(isNaN)) {
|
|
enterMoveMode();
|
|
|
|
} else {
|
|
// move detached node to the mouse location (transitioned)
|
|
context.perform(actionMoveNode(nodeID, mouse));
|
|
|
|
// after transition completes, put at final mouse location and enter move mode.
|
|
window.setTimeout(function() {
|
|
mouse = context.map().mouseCoordinates();
|
|
context.replace(actionMoveNode(nodeID, mouse));
|
|
enterMoveMode();
|
|
}, 150);
|
|
}
|
|
|
|
function enterMoveMode() {
|
|
var baseGraph = context.graph();
|
|
context.enter(modeMove(context, [nodeID], baseGraph));
|
|
}
|
|
};
|
|
|
|
|
|
operation.available = function () {
|
|
if (selectedIDs.length !== 1) return false;
|
|
|
|
var graph = context.graph();
|
|
var entity = graph.hasEntity(nodeID);
|
|
if (!entity) return false;
|
|
|
|
return entity.type === 'node' &&
|
|
entity.hasInterestingTags() &&
|
|
graph.parentWays(entity).length > 0;
|
|
};
|
|
|
|
|
|
operation.disabled = function () {
|
|
var reason;
|
|
if (_some(selectedIDs, context.hasHiddenConnections)) {
|
|
reason = 'connected_to_hidden';
|
|
}
|
|
return action.disabled(context.graph()) || reason;
|
|
};
|
|
|
|
|
|
operation.tooltip = function () {
|
|
var disableReason = operation.disabled();
|
|
if (disableReason) {
|
|
return t('operations.detach_node.' + disableReason,
|
|
{ relation: context.presets().item('type/restriction').name() });
|
|
} else {
|
|
return t('operations.detach_node.description');
|
|
}
|
|
};
|
|
|
|
|
|
operation.annotation = function () {
|
|
return t('operations.detach_node.annotation');
|
|
};
|
|
|
|
|
|
operation.id = 'detach-node';
|
|
operation.keys = [t('operations.detach_node.key')];
|
|
operation.title = t('operations.detach_node.title');
|
|
operation.behavior = behaviorOperation(context).which(operation);
|
|
|
|
|
|
return operation;
|
|
}
|
|
|