angular-tree-component
Version:
A simple yet powerful tree component for Angular2
199 lines (198 loc) • 25.5 kB
JavaScript
var _a;
import { KEYS } from '../constants/keys';
import defaultsDeep from 'lodash/defaultsDeep';
import get from 'lodash/get';
import omit from 'lodash/omit';
import isNumber from 'lodash/isNumber';
export var TREE_ACTIONS = {
TOGGLE_ACTIVE: function (tree, node, $event) { return node && node.toggleActivated(); },
TOGGLE_ACTIVE_MULTI: function (tree, node, $event) { return node && node.toggleActivated(true); },
TOGGLE_SELECTED: function (tree, node, $event) { return node && node.toggleSelected(); },
ACTIVATE: function (tree, node, $event) { return node.setIsActive(true); },
DEACTIVATE: function (tree, node, $event) { return node.setIsActive(false); },
SELECT: function (tree, node, $event) { return node.setIsSelected(true); },
DESELECT: function (tree, node, $event) { return node.setIsSelected(false); },
FOCUS: function (tree, node, $event) { return node.focus(); },
TOGGLE_EXPANDED: function (tree, node, $event) { return node.hasChildren && node.toggleExpanded(); },
EXPAND: function (tree, node, $event) { return node.expand(); },
COLLAPSE: function (tree, node, $event) { return node.collapse(); },
DRILL_DOWN: function (tree, node, $event) { return tree.focusDrillDown(); },
DRILL_UP: function (tree, node, $event) { return tree.focusDrillUp(); },
NEXT_NODE: function (tree, node, $event) { return tree.focusNextNode(); },
PREVIOUS_NODE: function (tree, node, $event) { return tree.focusPreviousNode(); },
MOVE_NODE: function (tree, node, $event, _a) {
var from = _a.from, to = _a.to;
// default action assumes from = node, to = {parent, index}
if ($event.ctrlKey) {
tree.copyNode(from, to);
}
else {
tree.moveNode(from, to);
}
}
};
var defaultActionMapping = {
mouse: {
click: TREE_ACTIONS.TOGGLE_ACTIVE,
dblClick: null,
contextMenu: null,
expanderClick: TREE_ACTIONS.TOGGLE_EXPANDED,
checkboxClick: TREE_ACTIONS.TOGGLE_SELECTED,
drop: TREE_ACTIONS.MOVE_NODE
},
keys: (_a = {},
_a[KEYS.RIGHT] = TREE_ACTIONS.DRILL_DOWN,
_a[KEYS.LEFT] = TREE_ACTIONS.DRILL_UP,
_a[KEYS.DOWN] = TREE_ACTIONS.NEXT_NODE,
_a[KEYS.UP] = TREE_ACTIONS.PREVIOUS_NODE,
_a[KEYS.SPACE] = TREE_ACTIONS.TOGGLE_ACTIVE,
_a[KEYS.ENTER] = TREE_ACTIONS.TOGGLE_ACTIVE,
_a)
};
var TreeOptions = /** @class */ (function () {
function TreeOptions(options) {
if (options === void 0) { options = {}; }
this.options = options;
this.actionMapping = defaultsDeep({}, this.options.actionMapping, defaultActionMapping);
if (options.rtl) {
this.actionMapping.keys[KEYS.RIGHT] = get(options, ['actionMapping', 'keys', KEYS.RIGHT]) || TREE_ACTIONS.DRILL_UP;
this.actionMapping.keys[KEYS.LEFT] = get(options, ['actionMapping', 'keys', KEYS.LEFT]) || TREE_ACTIONS.DRILL_DOWN;
}
}
Object.defineProperty(TreeOptions.prototype, "hasChildrenField", {
get: function () { return this.options.hasChildrenField || 'hasChildren'; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "childrenField", {
get: function () { return this.options.childrenField || 'children'; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "displayField", {
get: function () { return this.options.displayField || 'name'; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "idField", {
get: function () { return this.options.idField || 'id'; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "isExpandedField", {
get: function () { return this.options.isExpandedField || 'isExpanded'; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "getChildren", {
get: function () { return this.options.getChildren; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "levelPadding", {
get: function () { return this.options.levelPadding || 0; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "useVirtualScroll", {
get: function () { return this.options.useVirtualScroll; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "animateExpand", {
get: function () { return this.options.animateExpand; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "animateSpeed", {
get: function () { return this.options.animateSpeed || 1; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "animateAcceleration", {
get: function () { return this.options.animateAcceleration || 1.2; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "scrollOnActivate", {
get: function () { return this.options.scrollOnActivate === undefined ? true : this.options.scrollOnActivate; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "rtl", {
get: function () { return !!this.options.rtl; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "rootId", {
get: function () { return this.options.rootId; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "useCheckbox", {
get: function () { return this.options.useCheckbox; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "useTriState", {
get: function () { return this.options.useTriState === undefined ? true : this.options.useTriState; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "scrollContainer", {
get: function () { return this.options.scrollContainer; },
enumerable: true,
configurable: true
});
Object.defineProperty(TreeOptions.prototype, "allowDragoverStyling", {
get: function () { return this.options.allowDragoverStyling === undefined ? true : this.options.allowDragoverStyling; },
enumerable: true,
configurable: true
});
TreeOptions.prototype.getNodeClone = function (node) {
if (this.options.getNodeClone) {
return this.options.getNodeClone(node);
}
return omit(Object.assign({}, node.data), ['id']);
};
TreeOptions.prototype.allowDrop = function (element, to, $event) {
if (this.options.allowDrop instanceof Function) {
return this.options.allowDrop(element, to, $event);
}
else {
return this.options.allowDrop === undefined ? true : this.options.allowDrop;
}
};
TreeOptions.prototype.allowDrag = function (node) {
if (this.options.allowDrag instanceof Function) {
return this.options.allowDrag(node);
}
else {
return this.options.allowDrag;
}
};
TreeOptions.prototype.nodeClass = function (node) {
return this.options.nodeClass ? this.options.nodeClass(node) : '';
};
TreeOptions.prototype.nodeHeight = function (node) {
if (node.data.virtual) {
return 0;
}
var nodeHeight = this.options.nodeHeight || 22;
if (typeof nodeHeight === 'function') {
nodeHeight = nodeHeight(node);
}
// account for drop slots:
return nodeHeight + (node.index === 0 ? 2 : 1) * this.dropSlotHeight;
};
Object.defineProperty(TreeOptions.prototype, "dropSlotHeight", {
get: function () {
return isNumber(this.options.dropSlotHeight) ? this.options.dropSlotHeight : 2;
},
enumerable: true,
configurable: true
});
return TreeOptions;
}());
export { TreeOptions };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-options.model.js","sourceRoot":"","sources":["../../lib/models/tree-options.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { TreeNode } from './tree-node.model';\nimport { TreeModel } from './tree.model';\nimport { KEYS } from '../constants/keys';\nimport { ITreeOptions } from '../defs/api';\n\nimport defaultsDeep from 'lodash/defaultsDeep';\nimport get from 'lodash/get';\nimport omit from 'lodash/omit';\nimport isNumber from 'lodash/isNumber';\n\nexport interface IActionHandler {\n  (tree: TreeModel, node: TreeNode, $event: any, ...rest);\n}\n\nexport const TREE_ACTIONS = {\n  TOGGLE_ACTIVE: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleActivated(),\n  TOGGLE_ACTIVE_MULTI: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleActivated(true),\n  TOGGLE_SELECTED: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleSelected(),\n  ACTIVATE: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsActive(true),\n  DEACTIVATE: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsActive(false),\n  SELECT: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsSelected(true),\n  DESELECT: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsSelected(false),\n  FOCUS: (tree: TreeModel, node: TreeNode, $event: any) => node.focus(),\n  TOGGLE_EXPANDED: (tree: TreeModel, node: TreeNode, $event: any) => node.hasChildren && node.toggleExpanded(),\n  EXPAND: (tree: TreeModel, node: TreeNode, $event: any) => node.expand(),\n  COLLAPSE: (tree: TreeModel, node: TreeNode, $event: any) => node.collapse(),\n  DRILL_DOWN: (tree: TreeModel, node: TreeNode, $event: any) => tree.focusDrillDown(),\n  DRILL_UP: (tree: TreeModel, node: TreeNode, $event: any) => tree.focusDrillUp(),\n  NEXT_NODE: (tree: TreeModel, node: TreeNode, $event: any) =>  tree.focusNextNode(),\n  PREVIOUS_NODE: (tree: TreeModel, node: TreeNode, $event: any) =>  tree.focusPreviousNode(),\n  MOVE_NODE: (tree: TreeModel, node: TreeNode, $event: any, {from , to}: {from: any, to: any}) => {\n    // default action assumes from = node, to = {parent, index}\n    if ($event.ctrlKey) {\n      tree.copyNode(from, to);\n    } else {\n      tree.moveNode(from, to);\n    }\n  }\n};\n\nconst defaultActionMapping: IActionMapping = {\n  mouse: {\n    click: TREE_ACTIONS.TOGGLE_ACTIVE,\n    dblClick: null,\n    contextMenu: null,\n    expanderClick: TREE_ACTIONS.TOGGLE_EXPANDED,\n    checkboxClick: TREE_ACTIONS.TOGGLE_SELECTED,\n    drop: TREE_ACTIONS.MOVE_NODE\n  },\n  keys: {\n    [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,\n    [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,\n    [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,\n    [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,\n    [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,\n    [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE\n  }\n};\n\nexport interface IActionMapping {\n  mouse?: {\n    click?: IActionHandler,\n    dblClick?: IActionHandler,\n    contextMenu?: IActionHandler,\n    expanderClick?: IActionHandler,\n    checkboxClick?: IActionHandler,\n    dragStart?: IActionHandler,\n    drag?: IActionHandler,\n    dragEnd?: IActionHandler,\n    dragOver?: IActionHandler,\n    dragLeave?: IActionHandler,\n    dragEnter?: IActionHandler,\n    drop?: IActionHandler\n  };\n  keys?: {\n    [key: number]: IActionHandler\n  };\n}\n\nexport class TreeOptions {\n  get hasChildrenField(): string { return this.options.hasChildrenField || 'hasChildren'; }\n  get childrenField(): string { return this.options.childrenField || 'children'; }\n  get displayField(): string { return this.options.displayField || 'name'; }\n  get idField(): string { return this.options.idField || 'id'; }\n  get isExpandedField(): string { return this.options.isExpandedField || 'isExpanded'; }\n  get getChildren(): any { return this.options.getChildren; }\n  get levelPadding(): number { return this.options.levelPadding || 0; }\n  get useVirtualScroll(): boolean { return this.options.useVirtualScroll; }\n  get animateExpand(): boolean { return this.options.animateExpand; }\n  get animateSpeed(): number { return this.options.animateSpeed || 1; }\n  get animateAcceleration(): number { return this.options.animateAcceleration || 1.2; }\n  get scrollOnActivate(): boolean { return this.options.scrollOnActivate === undefined ? true : this.options.scrollOnActivate; }\n  get rtl(): boolean { return !!this.options.rtl; }\n  get rootId(): any {return this.options.rootId; }\n  get useCheckbox(): boolean { return this.options.useCheckbox; }\n  get useTriState(): boolean { return this.options.useTriState === undefined ? true : this.options.useTriState; }\n  get scrollContainer(): HTMLElement { return this.options.scrollContainer; }\n  get allowDragoverStyling(): boolean { return this.options.allowDragoverStyling === undefined ? true : this.options.allowDragoverStyling; }\n  actionMapping: IActionMapping;\n\n  constructor(private options: ITreeOptions = {}) {\n    this.actionMapping = defaultsDeep({}, this.options.actionMapping, defaultActionMapping);\n    if (options.rtl) {\n      this.actionMapping.keys[KEYS.RIGHT] = <IActionHandler>get(options, ['actionMapping', 'keys', KEYS.RIGHT]) || TREE_ACTIONS.DRILL_UP;\n      this.actionMapping.keys[KEYS.LEFT] = <IActionHandler>get(options, ['actionMapping', 'keys', KEYS.LEFT]) || TREE_ACTIONS.DRILL_DOWN;\n    }\n  }\n\n  getNodeClone(node: TreeNode): any {\n    if (this.options.getNodeClone) {\n      return this.options.getNodeClone(node);\n    }\n\n    return omit(Object.assign({}, node.data), ['id']);\n  }\n\n  allowDrop(element, to, $event?): boolean {\n    if (this.options.allowDrop instanceof Function) {\n      return this.options.allowDrop(element, to, $event);\n    }\n    else {\n      return this.options.allowDrop === undefined ? true : this.options.allowDrop;\n    }\n  }\n\n  allowDrag(node: TreeNode): boolean {\n    if (this.options.allowDrag instanceof Function) {\n      return this.options.allowDrag(node);\n    } else {\n      return this.options.allowDrag;\n    }\n  }\n\n  nodeClass(node: TreeNode): string {\n    return this.options.nodeClass ? this.options.nodeClass(node) : '';\n  }\n\n  nodeHeight(node: TreeNode): number {\n    if (node.data.virtual) {\n      return 0;\n    }\n\n    let nodeHeight = this.options.nodeHeight || 22;\n\n    if (typeof nodeHeight === 'function') {\n      nodeHeight = nodeHeight(node);\n    }\n\n    // account for drop slots:\n    return nodeHeight + (node.index === 0 ?  2 : 1) * this.dropSlotHeight;\n  }\n\n  get dropSlotHeight(): number {\n    return isNumber(this.options.dropSlotHeight) ? this.options.dropSlotHeight : 2;\n  }\n}\n"]}