UNPKG

angular-tree-component

Version:

A simple yet powerful tree component for Angular2

200 lines 26 kB
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'; var ɵ0 = function (tree, node, $event) { return node && node.toggleActivated(); }, ɵ1 = function (tree, node, $event) { return node && node.toggleActivated(true); }, ɵ2 = function (tree, node, $event) { return node && node.toggleSelected(); }, ɵ3 = function (tree, node, $event) { return node.setIsActive(true); }, ɵ4 = function (tree, node, $event) { return node.setIsActive(false); }, ɵ5 = function (tree, node, $event) { return node.setIsSelected(true); }, ɵ6 = function (tree, node, $event) { return node.setIsSelected(false); }, ɵ7 = function (tree, node, $event) { return node.focus(); }, ɵ8 = function (tree, node, $event) { return node.hasChildren && node.toggleExpanded(); }, ɵ9 = function (tree, node, $event) { return node.expand(); }, ɵ10 = function (tree, node, $event) { return node.collapse(); }, ɵ11 = function (tree, node, $event) { return tree.focusDrillDown(); }, ɵ12 = function (tree, node, $event) { return tree.focusDrillUp(); }, ɵ13 = function (tree, node, $event) { return tree.focusNextNode(); }, ɵ14 = function (tree, node, $event) { return tree.focusPreviousNode(); }, ɵ15 = 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); } }; export var TREE_ACTIONS = { TOGGLE_ACTIVE: ɵ0, TOGGLE_ACTIVE_MULTI: ɵ1, TOGGLE_SELECTED: ɵ2, ACTIVATE: ɵ3, DEACTIVATE: ɵ4, SELECT: ɵ5, DESELECT: ɵ6, FOCUS: ɵ7, TOGGLE_EXPANDED: ɵ8, EXPAND: ɵ9, COLLAPSE: ɵ10, DRILL_DOWN: ɵ11, DRILL_UP: ɵ12, NEXT_NODE: ɵ13, PREVIOUS_NODE: ɵ14, MOVE_NODE: ɵ15 }; 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 }; export { ɵ0, ɵ1, ɵ2, ɵ3, ɵ4, ɵ5, ɵ6, ɵ7, ɵ8, ɵ9, ɵ10, ɵ11, ɵ12, ɵ13, ɵ14, ɵ15 }; //# 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    mouseOver?: IActionHandler,\n    mouseOut?: 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"]}