@ali-hm/angular-tree-component 16.0.1 → 17.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/esm2022/ali-hm-angular-tree-component.mjs +4 -4
  2. package/esm2022/lib/angular-tree-component.module.mjs +99 -99
  3. package/esm2022/lib/components/loading.component.mjs +20 -20
  4. package/esm2022/lib/components/tree-node-checkbox.component.mjs +14 -14
  5. package/esm2022/lib/components/tree-node-collection.component.mjs +119 -119
  6. package/esm2022/lib/components/tree-node-content.component.mjs +22 -22
  7. package/esm2022/lib/components/tree-node-drop-slot.component.mjs +25 -25
  8. package/esm2022/lib/components/tree-node-expander.component.mjs +15 -15
  9. package/esm2022/lib/components/tree-node-wrapper.component.mjs +23 -23
  10. package/esm2022/lib/components/tree-viewport.component.mjs +55 -55
  11. package/esm2022/lib/components/tree.component.mjs +137 -137
  12. package/esm2022/lib/constants/events.mjs +19 -19
  13. package/esm2022/lib/constants/keys.mjs +9 -9
  14. package/esm2022/lib/defs/api.mjs +1 -1
  15. package/esm2022/lib/directives/tree-animate-open.directive.mjs +101 -101
  16. package/esm2022/lib/directives/tree-drag.directive.mjs +65 -65
  17. package/esm2022/lib/directives/tree-drop.directive.mjs +127 -127
  18. package/esm2022/lib/mobx-angular/mobx-proxy.mjs +16 -16
  19. package/esm2022/lib/mobx-angular/tree-mobx-autorun.directive.mjs +40 -40
  20. package/esm2022/lib/models/tree-dragged-element.model.mjs +24 -24
  21. package/esm2022/lib/models/tree-node.model.mjs +389 -389
  22. package/esm2022/lib/models/tree-options.model.mjs +150 -150
  23. package/esm2022/lib/models/tree-virtual-scroll.model.mjs +197 -197
  24. package/esm2022/lib/models/tree.model.mjs +546 -546
  25. package/esm2022/public-api.mjs +4 -4
  26. package/fesm2022/ali-hm-angular-tree-component.mjs +2080 -2080
  27. package/fesm2022/ali-hm-angular-tree-component.mjs.map +1 -1
  28. package/index.d.ts +5 -5
  29. package/lib/angular-tree-component.module.d.ts +43 -43
  30. package/lib/components/loading.component.d.ts +9 -9
  31. package/lib/components/tree-node-checkbox.component.d.ts +7 -7
  32. package/lib/components/tree-node-collection.component.d.ts +34 -34
  33. package/lib/components/tree-node-content.component.d.ts +10 -10
  34. package/lib/components/tree-node-drop-slot.component.d.ts +10 -10
  35. package/lib/components/tree-node-expander.component.d.ts +7 -7
  36. package/lib/components/tree-node-wrapper.component.d.ts +9 -9
  37. package/lib/components/tree-viewport.component.d.ts +17 -17
  38. package/lib/components/tree.component.d.ts +47 -47
  39. package/lib/constants/events.d.ts +19 -19
  40. package/lib/constants/keys.d.ts +9 -9
  41. package/lib/defs/api.d.ts +611 -611
  42. package/lib/directives/tree-animate-open.directive.d.ts +20 -20
  43. package/lib/directives/tree-drag.directive.d.ts +21 -21
  44. package/lib/directives/tree-drop.directive.d.ts +33 -33
  45. package/lib/mobx-angular/mobx-proxy.d.ts +7 -7
  46. package/lib/mobx-angular/tree-mobx-autorun.directive.d.ts +17 -17
  47. package/lib/models/tree-dragged-element.model.d.ts +9 -9
  48. package/lib/models/tree-node.model.d.ts +83 -83
  49. package/lib/models/tree-options.model.d.ts +77 -77
  50. package/lib/models/tree-virtual-scroll.model.d.ts +27 -27
  51. package/lib/models/tree.model.d.ts +91 -91
  52. package/package.json +3 -3
  53. package/public-api.d.ts +1 -1
@@ -1,150 +1,150 @@
1
- import { KEYS } from '../constants/keys';
2
- export const TREE_ACTIONS = {
3
- TOGGLE_ACTIVE: (tree, node, $event) => node && node.toggleActivated(),
4
- TOGGLE_ACTIVE_MULTI: (tree, node, $event) => node && node.toggleActivated(true),
5
- TOGGLE_SELECTED: (tree, node, $event) => node && node.toggleSelected(),
6
- ACTIVATE: (tree, node, $event) => node.setIsActive(true),
7
- DEACTIVATE: (tree, node, $event) => node.setIsActive(false),
8
- SELECT: (tree, node, $event) => node.setIsSelected(true),
9
- DESELECT: (tree, node, $event) => node.setIsSelected(false),
10
- FOCUS: (tree, node, $event) => node.focus(),
11
- TOGGLE_EXPANDED: (tree, node, $event) => node.hasChildren && node.toggleExpanded(),
12
- EXPAND: (tree, node, $event) => node.expand(),
13
- COLLAPSE: (tree, node, $event) => node.collapse(),
14
- DRILL_DOWN: (tree, node, $event) => tree.focusDrillDown(),
15
- DRILL_UP: (tree, node, $event) => tree.focusDrillUp(),
16
- NEXT_NODE: (tree, node, $event) => tree.focusNextNode(),
17
- PREVIOUS_NODE: (tree, node, $event) => tree.focusPreviousNode(),
18
- MOVE_NODE: (tree, node, $event, { from, to }) => {
19
- // default action assumes from = node, to = {parent, index}
20
- if ($event.ctrlKey) {
21
- tree.copyNode(from, to);
22
- }
23
- else {
24
- tree.moveNode(from, to);
25
- }
26
- }
27
- };
28
- const defaultActionMapping = {
29
- mouse: {
30
- click: TREE_ACTIONS.TOGGLE_ACTIVE,
31
- dblClick: null,
32
- contextMenu: null,
33
- expanderClick: TREE_ACTIONS.TOGGLE_EXPANDED,
34
- checkboxClick: TREE_ACTIONS.TOGGLE_SELECTED,
35
- drop: TREE_ACTIONS.MOVE_NODE
36
- },
37
- keys: {
38
- [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,
39
- [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,
40
- [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,
41
- [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,
42
- [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,
43
- [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE
44
- }
45
- };
46
- export class TreeOptions {
47
- get hasChildrenField() { return this.options.hasChildrenField || 'hasChildren'; }
48
- get childrenField() { return this.options.childrenField || 'children'; }
49
- get displayField() { return this.options.displayField || 'name'; }
50
- get idField() { return this.options.idField || 'id'; }
51
- get isExpandedField() { return this.options.isExpandedField || 'isExpanded'; }
52
- get getChildren() { return this.options.getChildren; }
53
- get levelPadding() { return this.options.levelPadding || 0; }
54
- get useVirtualScroll() { return this.options.useVirtualScroll; }
55
- get animateExpand() { return this.options.animateExpand; }
56
- get animateSpeed() { return this.options.animateSpeed || 1; }
57
- get animateAcceleration() { return this.options.animateAcceleration || 1.2; }
58
- get scrollOnActivate() { return this.options.scrollOnActivate === undefined ? true : this.options.scrollOnActivate; }
59
- get rtl() { return !!this.options.rtl; }
60
- get rootId() { return this.options.rootId; }
61
- get useCheckbox() { return this.options.useCheckbox; }
62
- get useTriState() { return this.options.useTriState === undefined ? true : this.options.useTriState; }
63
- get scrollContainer() { return this.options.scrollContainer; }
64
- get allowDragoverStyling() { return this.options.allowDragoverStyling === undefined ? true : this.options.allowDragoverStyling; }
65
- constructor(options = {}) {
66
- this.options = options;
67
- this.actionMapping = {
68
- mouse: {
69
- click: this.options?.actionMapping?.mouse?.click ?? defaultActionMapping.mouse.click,
70
- dblClick: this.options?.actionMapping?.mouse?.dblClick ?? defaultActionMapping.mouse.dblClick,
71
- contextMenu: this.options?.actionMapping?.mouse?.contextMenu ?? defaultActionMapping.mouse.contextMenu,
72
- expanderClick: this.options?.actionMapping?.mouse?.expanderClick ?? defaultActionMapping.mouse.expanderClick,
73
- checkboxClick: this.options?.actionMapping?.mouse?.checkboxClick ?? defaultActionMapping.mouse.checkboxClick,
74
- drop: this.options?.actionMapping?.mouse?.drop ?? defaultActionMapping.mouse.drop,
75
- dragStart: this.options?.actionMapping?.mouse?.dragStart ?? undefined,
76
- drag: this.options?.actionMapping?.mouse?.drag ?? undefined,
77
- dragEnd: this.options?.actionMapping?.mouse?.dragEnd ?? undefined,
78
- dragOver: this.options?.actionMapping?.mouse?.dragOver ?? undefined,
79
- dragLeave: this.options?.actionMapping?.mouse?.dragLeave ?? undefined,
80
- dragEnter: this.options?.actionMapping?.mouse?.dragEnter ?? undefined,
81
- mouseOver: this.options?.actionMapping?.mouse?.mouseOver ?? undefined,
82
- mouseOut: this.options?.actionMapping?.mouse?.mouseOut ?? undefined,
83
- },
84
- keys: {
85
- [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,
86
- [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,
87
- [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,
88
- [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,
89
- [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,
90
- [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE
91
- }
92
- };
93
- if (this.options?.actionMapping?.keys) {
94
- this.actionMapping.keys = {
95
- ...this.actionMapping.keys,
96
- ...this.options.actionMapping.keys
97
- };
98
- }
99
- if (options.rtl) {
100
- this.actionMapping.keys[KEYS.RIGHT] = options.actionMapping?.keys[KEYS.RIGHT] || TREE_ACTIONS.DRILL_UP;
101
- this.actionMapping.keys[KEYS.LEFT] = options.actionMapping?.keys[KEYS.LEFT] || TREE_ACTIONS.DRILL_DOWN;
102
- }
103
- }
104
- getNodeClone(node) {
105
- if (this.options.getNodeClone) {
106
- return this.options.getNodeClone(node);
107
- }
108
- // remove id from clone
109
- // keeping ie11 compatibility
110
- const nodeClone = Object.assign({}, node.data);
111
- if (nodeClone.id) {
112
- delete nodeClone.id;
113
- }
114
- return nodeClone;
115
- }
116
- allowDrop(element, to, $event) {
117
- if (this.options.allowDrop instanceof Function) {
118
- return this.options.allowDrop(element, to, $event);
119
- }
120
- else {
121
- return this.options.allowDrop === undefined ? true : this.options.allowDrop;
122
- }
123
- }
124
- allowDrag(node) {
125
- if (this.options.allowDrag instanceof Function) {
126
- return this.options.allowDrag(node);
127
- }
128
- else {
129
- return this.options.allowDrag;
130
- }
131
- }
132
- nodeClass(node) {
133
- return this.options.nodeClass ? this.options.nodeClass(node) : '';
134
- }
135
- nodeHeight(node) {
136
- if (node.data.virtual) {
137
- return 0;
138
- }
139
- let nodeHeight = this.options.nodeHeight || 22;
140
- if (typeof nodeHeight === 'function') {
141
- nodeHeight = nodeHeight(node);
142
- }
143
- // account for drop slots:
144
- return nodeHeight + (node.index === 0 ? 2 : 1) * this.dropSlotHeight;
145
- }
146
- get dropSlotHeight() {
147
- return typeof this.options.dropSlotHeight === 'number' ? this.options.dropSlotHeight : 2;
148
- }
149
- }
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-options.model.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/models/tree-options.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { TreeNode } from './tree-node.model';\r\nimport { TreeModel } from './tree.model';\r\nimport { KEYS } from '../constants/keys';\r\nimport { ITreeOptions } from '../defs/api';\r\n\r\nexport interface IActionHandler {\r\n  (tree: TreeModel, node: TreeNode, $event: any, ...rest);\r\n}\r\n\r\nexport const TREE_ACTIONS = {\r\n  TOGGLE_ACTIVE: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleActivated(),\r\n  TOGGLE_ACTIVE_MULTI: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleActivated(true),\r\n  TOGGLE_SELECTED: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleSelected(),\r\n  ACTIVATE: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsActive(true),\r\n  DEACTIVATE: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsActive(false),\r\n  SELECT: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsSelected(true),\r\n  DESELECT: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsSelected(false),\r\n  FOCUS: (tree: TreeModel, node: TreeNode, $event: any) => node.focus(),\r\n  TOGGLE_EXPANDED: (tree: TreeModel, node: TreeNode, $event: any) => node.hasChildren && node.toggleExpanded(),\r\n  EXPAND: (tree: TreeModel, node: TreeNode, $event: any) => node.expand(),\r\n  COLLAPSE: (tree: TreeModel, node: TreeNode, $event: any) => node.collapse(),\r\n  DRILL_DOWN: (tree: TreeModel, node: TreeNode, $event: any) => tree.focusDrillDown(),\r\n  DRILL_UP: (tree: TreeModel, node: TreeNode, $event: any) => tree.focusDrillUp(),\r\n  NEXT_NODE: (tree: TreeModel, node: TreeNode, $event: any) =>  tree.focusNextNode(),\r\n  PREVIOUS_NODE: (tree: TreeModel, node: TreeNode, $event: any) =>  tree.focusPreviousNode(),\r\n  MOVE_NODE: (tree: TreeModel, node: TreeNode, $event: any, {from , to}: {from: any, to: any}) => {\r\n    // default action assumes from = node, to = {parent, index}\r\n    if ($event.ctrlKey) {\r\n      tree.copyNode(from, to);\r\n    } else {\r\n      tree.moveNode(from, to);\r\n    }\r\n  }\r\n};\r\n\r\nconst defaultActionMapping: IActionMapping = {\r\n  mouse: {\r\n    click: TREE_ACTIONS.TOGGLE_ACTIVE,\r\n    dblClick: null,\r\n    contextMenu: null,\r\n    expanderClick: TREE_ACTIONS.TOGGLE_EXPANDED,\r\n    checkboxClick: TREE_ACTIONS.TOGGLE_SELECTED,\r\n    drop: TREE_ACTIONS.MOVE_NODE\r\n  },\r\n  keys: {\r\n    [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,\r\n    [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,\r\n    [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,\r\n    [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,\r\n    [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,\r\n    [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE\r\n  }\r\n};\r\n\r\nexport interface IActionMapping {\r\n  mouse?: {\r\n    click?: IActionHandler,\r\n    dblClick?: IActionHandler,\r\n    contextMenu?: IActionHandler,\r\n    expanderClick?: IActionHandler,\r\n    checkboxClick?: IActionHandler,\r\n    dragStart?: IActionHandler,\r\n    drag?: IActionHandler,\r\n    dragEnd?: IActionHandler,\r\n    dragOver?: IActionHandler,\r\n    dragLeave?: IActionHandler,\r\n    dragEnter?: IActionHandler,\r\n    drop?: IActionHandler,\r\n    mouseOver?: IActionHandler,\r\n    mouseOut?: IActionHandler\r\n  };\r\n  keys?: {\r\n    [key: number]: IActionHandler\r\n  };\r\n}\r\n\r\nexport class TreeOptions {\r\n  get hasChildrenField(): string { return this.options.hasChildrenField || 'hasChildren'; }\r\n  get childrenField(): string { return this.options.childrenField || 'children'; }\r\n  get displayField(): string { return this.options.displayField || 'name'; }\r\n  get idField(): string { return this.options.idField || 'id'; }\r\n  get isExpandedField(): string { return this.options.isExpandedField || 'isExpanded'; }\r\n  get getChildren(): any { return this.options.getChildren; }\r\n  get levelPadding(): number { return this.options.levelPadding || 0; }\r\n  get useVirtualScroll(): boolean { return this.options.useVirtualScroll; }\r\n  get animateExpand(): boolean { return this.options.animateExpand; }\r\n  get animateSpeed(): number { return this.options.animateSpeed || 1; }\r\n  get animateAcceleration(): number { return this.options.animateAcceleration || 1.2; }\r\n  get scrollOnActivate(): boolean { return this.options.scrollOnActivate === undefined ? true : this.options.scrollOnActivate; }\r\n  get rtl(): boolean { return !!this.options.rtl; }\r\n  get rootId(): any {return this.options.rootId; }\r\n  get useCheckbox(): boolean { return this.options.useCheckbox; }\r\n  get useTriState(): boolean { return this.options.useTriState === undefined ? true : this.options.useTriState; }\r\n  get scrollContainer(): HTMLElement { return this.options.scrollContainer; }\r\n  get allowDragoverStyling(): boolean { return this.options.allowDragoverStyling === undefined ? true : this.options.allowDragoverStyling; }\r\n  actionMapping: IActionMapping;\r\n\r\n  constructor(private options: ITreeOptions = {}) {\r\n    this.actionMapping = {\r\n      mouse: {\r\n        click: this.options?.actionMapping?.mouse?.click ?? defaultActionMapping.mouse.click,\r\n        dblClick: this.options?.actionMapping?.mouse?.dblClick ?? defaultActionMapping.mouse.dblClick,\r\n        contextMenu: this.options?.actionMapping?.mouse?.contextMenu ?? defaultActionMapping.mouse.contextMenu,\r\n        expanderClick: this.options?.actionMapping?.mouse?.expanderClick ?? defaultActionMapping.mouse.expanderClick,\r\n        checkboxClick: this.options?.actionMapping?.mouse?.checkboxClick ?? defaultActionMapping.mouse.checkboxClick,\r\n        drop: this.options?.actionMapping?.mouse?.drop ?? defaultActionMapping.mouse.drop,\r\n        dragStart: this.options?.actionMapping?.mouse?.dragStart ?? undefined,\r\n        drag: this.options?.actionMapping?.mouse?.drag ?? undefined,\r\n        dragEnd: this.options?.actionMapping?.mouse?.dragEnd ?? undefined,\r\n        dragOver: this.options?.actionMapping?.mouse?.dragOver ?? undefined,\r\n        dragLeave: this.options?.actionMapping?.mouse?.dragLeave ?? undefined,\r\n        dragEnter: this.options?.actionMapping?.mouse?.dragEnter ?? undefined,\r\n        mouseOver: this.options?.actionMapping?.mouse?.mouseOver ?? undefined,\r\n        mouseOut: this.options?.actionMapping?.mouse?.mouseOut ?? undefined,\r\n      },\r\n      keys: {\r\n        [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,\r\n        [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,\r\n        [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,\r\n        [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,\r\n        [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,\r\n        [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE\r\n      }\r\n    }\r\n\r\n    if (this.options?.actionMapping?.keys) {\r\n      this.actionMapping.keys = {\r\n        ...this.actionMapping.keys,\r\n        ...this.options.actionMapping.keys\r\n      }\r\n    }\r\n\r\n    if (options.rtl) {\r\n      this.actionMapping.keys[KEYS.RIGHT] = <IActionHandler>options.actionMapping?.keys[KEYS.RIGHT] || TREE_ACTIONS.DRILL_UP;\r\n      this.actionMapping.keys[KEYS.LEFT] = <IActionHandler>options.actionMapping?.keys[KEYS.LEFT] || TREE_ACTIONS.DRILL_DOWN;\r\n    }\r\n  }\r\n\r\n  getNodeClone(node: TreeNode): any {\r\n    if (this.options.getNodeClone) {\r\n      return this.options.getNodeClone(node);\r\n    }\r\n\r\n    // remove id from clone\r\n    // keeping ie11 compatibility\r\n    const nodeClone = Object.assign({}, node.data);\r\n    if (nodeClone.id) {\r\n      delete nodeClone.id;\r\n    }\r\n    return nodeClone;\r\n  }\r\n\r\n  allowDrop(element, to, $event?): boolean {\r\n    if (this.options.allowDrop instanceof Function) {\r\n      return this.options.allowDrop(element, to, $event);\r\n    }\r\n    else {\r\n      return this.options.allowDrop === undefined ? true : this.options.allowDrop;\r\n    }\r\n  }\r\n\r\n  allowDrag(node: TreeNode): boolean {\r\n    if (this.options.allowDrag instanceof Function) {\r\n      return this.options.allowDrag(node);\r\n    } else {\r\n      return this.options.allowDrag;\r\n    }\r\n  }\r\n\r\n  nodeClass(node: TreeNode): string {\r\n    return this.options.nodeClass ? this.options.nodeClass(node) : '';\r\n  }\r\n\r\n  nodeHeight(node: TreeNode): number {\r\n    if (node.data.virtual) {\r\n      return 0;\r\n    }\r\n\r\n    let nodeHeight = this.options.nodeHeight || 22;\r\n\r\n    if (typeof nodeHeight === 'function') {\r\n      nodeHeight = nodeHeight(node);\r\n    }\r\n\r\n    // account for drop slots:\r\n    return nodeHeight + (node.index === 0 ?  2 : 1) * this.dropSlotHeight;\r\n  }\r\n\r\n  get dropSlotHeight(): number {\r\n    return typeof this.options.dropSlotHeight === 'number' ? this.options.dropSlotHeight : 2;\r\n  }\r\n}\r\n"]}
1
+ import { KEYS } from '../constants/keys';
2
+ export const TREE_ACTIONS = {
3
+ TOGGLE_ACTIVE: (tree, node, $event) => node && node.toggleActivated(),
4
+ TOGGLE_ACTIVE_MULTI: (tree, node, $event) => node && node.toggleActivated(true),
5
+ TOGGLE_SELECTED: (tree, node, $event) => node && node.toggleSelected(),
6
+ ACTIVATE: (tree, node, $event) => node.setIsActive(true),
7
+ DEACTIVATE: (tree, node, $event) => node.setIsActive(false),
8
+ SELECT: (tree, node, $event) => node.setIsSelected(true),
9
+ DESELECT: (tree, node, $event) => node.setIsSelected(false),
10
+ FOCUS: (tree, node, $event) => node.focus(),
11
+ TOGGLE_EXPANDED: (tree, node, $event) => node.hasChildren && node.toggleExpanded(),
12
+ EXPAND: (tree, node, $event) => node.expand(),
13
+ COLLAPSE: (tree, node, $event) => node.collapse(),
14
+ DRILL_DOWN: (tree, node, $event) => tree.focusDrillDown(),
15
+ DRILL_UP: (tree, node, $event) => tree.focusDrillUp(),
16
+ NEXT_NODE: (tree, node, $event) => tree.focusNextNode(),
17
+ PREVIOUS_NODE: (tree, node, $event) => tree.focusPreviousNode(),
18
+ MOVE_NODE: (tree, node, $event, { from, to }) => {
19
+ // default action assumes from = node, to = {parent, index}
20
+ if ($event.ctrlKey) {
21
+ tree.copyNode(from, to);
22
+ }
23
+ else {
24
+ tree.moveNode(from, to);
25
+ }
26
+ }
27
+ };
28
+ const defaultActionMapping = {
29
+ mouse: {
30
+ click: TREE_ACTIONS.TOGGLE_ACTIVE,
31
+ dblClick: null,
32
+ contextMenu: null,
33
+ expanderClick: TREE_ACTIONS.TOGGLE_EXPANDED,
34
+ checkboxClick: TREE_ACTIONS.TOGGLE_SELECTED,
35
+ drop: TREE_ACTIONS.MOVE_NODE
36
+ },
37
+ keys: {
38
+ [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,
39
+ [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,
40
+ [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,
41
+ [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,
42
+ [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,
43
+ [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE
44
+ }
45
+ };
46
+ export class TreeOptions {
47
+ get hasChildrenField() { return this.options.hasChildrenField || 'hasChildren'; }
48
+ get childrenField() { return this.options.childrenField || 'children'; }
49
+ get displayField() { return this.options.displayField || 'name'; }
50
+ get idField() { return this.options.idField || 'id'; }
51
+ get isExpandedField() { return this.options.isExpandedField || 'isExpanded'; }
52
+ get getChildren() { return this.options.getChildren; }
53
+ get levelPadding() { return this.options.levelPadding || 0; }
54
+ get useVirtualScroll() { return this.options.useVirtualScroll; }
55
+ get animateExpand() { return this.options.animateExpand; }
56
+ get animateSpeed() { return this.options.animateSpeed || 1; }
57
+ get animateAcceleration() { return this.options.animateAcceleration || 1.2; }
58
+ get scrollOnActivate() { return this.options.scrollOnActivate === undefined ? true : this.options.scrollOnActivate; }
59
+ get rtl() { return !!this.options.rtl; }
60
+ get rootId() { return this.options.rootId; }
61
+ get useCheckbox() { return this.options.useCheckbox; }
62
+ get useTriState() { return this.options.useTriState === undefined ? true : this.options.useTriState; }
63
+ get scrollContainer() { return this.options.scrollContainer; }
64
+ get allowDragoverStyling() { return this.options.allowDragoverStyling === undefined ? true : this.options.allowDragoverStyling; }
65
+ constructor(options = {}) {
66
+ this.options = options;
67
+ this.actionMapping = {
68
+ mouse: {
69
+ click: this.options?.actionMapping?.mouse?.click ?? defaultActionMapping.mouse.click,
70
+ dblClick: this.options?.actionMapping?.mouse?.dblClick ?? defaultActionMapping.mouse.dblClick,
71
+ contextMenu: this.options?.actionMapping?.mouse?.contextMenu ?? defaultActionMapping.mouse.contextMenu,
72
+ expanderClick: this.options?.actionMapping?.mouse?.expanderClick ?? defaultActionMapping.mouse.expanderClick,
73
+ checkboxClick: this.options?.actionMapping?.mouse?.checkboxClick ?? defaultActionMapping.mouse.checkboxClick,
74
+ drop: this.options?.actionMapping?.mouse?.drop ?? defaultActionMapping.mouse.drop,
75
+ dragStart: this.options?.actionMapping?.mouse?.dragStart ?? undefined,
76
+ drag: this.options?.actionMapping?.mouse?.drag ?? undefined,
77
+ dragEnd: this.options?.actionMapping?.mouse?.dragEnd ?? undefined,
78
+ dragOver: this.options?.actionMapping?.mouse?.dragOver ?? undefined,
79
+ dragLeave: this.options?.actionMapping?.mouse?.dragLeave ?? undefined,
80
+ dragEnter: this.options?.actionMapping?.mouse?.dragEnter ?? undefined,
81
+ mouseOver: this.options?.actionMapping?.mouse?.mouseOver ?? undefined,
82
+ mouseOut: this.options?.actionMapping?.mouse?.mouseOut ?? undefined,
83
+ },
84
+ keys: {
85
+ [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,
86
+ [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,
87
+ [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,
88
+ [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,
89
+ [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,
90
+ [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE
91
+ }
92
+ };
93
+ if (this.options?.actionMapping?.keys) {
94
+ this.actionMapping.keys = {
95
+ ...this.actionMapping.keys,
96
+ ...this.options.actionMapping.keys
97
+ };
98
+ }
99
+ if (options.rtl) {
100
+ this.actionMapping.keys[KEYS.RIGHT] = options.actionMapping?.keys[KEYS.RIGHT] || TREE_ACTIONS.DRILL_UP;
101
+ this.actionMapping.keys[KEYS.LEFT] = options.actionMapping?.keys[KEYS.LEFT] || TREE_ACTIONS.DRILL_DOWN;
102
+ }
103
+ }
104
+ getNodeClone(node) {
105
+ if (this.options.getNodeClone) {
106
+ return this.options.getNodeClone(node);
107
+ }
108
+ // remove id from clone
109
+ // keeping ie11 compatibility
110
+ const nodeClone = Object.assign({}, node.data);
111
+ if (nodeClone.id) {
112
+ delete nodeClone.id;
113
+ }
114
+ return nodeClone;
115
+ }
116
+ allowDrop(element, to, $event) {
117
+ if (this.options.allowDrop instanceof Function) {
118
+ return this.options.allowDrop(element, to, $event);
119
+ }
120
+ else {
121
+ return this.options.allowDrop === undefined ? true : this.options.allowDrop;
122
+ }
123
+ }
124
+ allowDrag(node) {
125
+ if (this.options.allowDrag instanceof Function) {
126
+ return this.options.allowDrag(node);
127
+ }
128
+ else {
129
+ return this.options.allowDrag;
130
+ }
131
+ }
132
+ nodeClass(node) {
133
+ return this.options.nodeClass ? this.options.nodeClass(node) : '';
134
+ }
135
+ nodeHeight(node) {
136
+ if (node.data.virtual) {
137
+ return 0;
138
+ }
139
+ let nodeHeight = this.options.nodeHeight || 22;
140
+ if (typeof nodeHeight === 'function') {
141
+ nodeHeight = nodeHeight(node);
142
+ }
143
+ // account for drop slots:
144
+ return nodeHeight + (node.index === 0 ? 2 : 1) * this.dropSlotHeight;
145
+ }
146
+ get dropSlotHeight() {
147
+ return typeof this.options.dropSlotHeight === 'number' ? this.options.dropSlotHeight : 2;
148
+ }
149
+ }
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-options.model.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/models/tree-options.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { TreeNode } from './tree-node.model';\r\nimport { TreeModel } from './tree.model';\r\nimport { KEYS } from '../constants/keys';\r\nimport { ITreeOptions } from '../defs/api';\r\n\r\nexport interface IActionHandler {\r\n  (tree: TreeModel, node: TreeNode, $event: any, ...rest);\r\n}\r\n\r\nexport const TREE_ACTIONS = {\r\n  TOGGLE_ACTIVE: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleActivated(),\r\n  TOGGLE_ACTIVE_MULTI: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleActivated(true),\r\n  TOGGLE_SELECTED: (tree: TreeModel, node: TreeNode, $event: any) => node && node.toggleSelected(),\r\n  ACTIVATE: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsActive(true),\r\n  DEACTIVATE: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsActive(false),\r\n  SELECT: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsSelected(true),\r\n  DESELECT: (tree: TreeModel, node: TreeNode, $event: any) => node.setIsSelected(false),\r\n  FOCUS: (tree: TreeModel, node: TreeNode, $event: any) => node.focus(),\r\n  TOGGLE_EXPANDED: (tree: TreeModel, node: TreeNode, $event: any) => node.hasChildren && node.toggleExpanded(),\r\n  EXPAND: (tree: TreeModel, node: TreeNode, $event: any) => node.expand(),\r\n  COLLAPSE: (tree: TreeModel, node: TreeNode, $event: any) => node.collapse(),\r\n  DRILL_DOWN: (tree: TreeModel, node: TreeNode, $event: any) => tree.focusDrillDown(),\r\n  DRILL_UP: (tree: TreeModel, node: TreeNode, $event: any) => tree.focusDrillUp(),\r\n  NEXT_NODE: (tree: TreeModel, node: TreeNode, $event: any) =>  tree.focusNextNode(),\r\n  PREVIOUS_NODE: (tree: TreeModel, node: TreeNode, $event: any) =>  tree.focusPreviousNode(),\r\n  MOVE_NODE: (tree: TreeModel, node: TreeNode, $event: any, {from , to}: {from: any, to: any}) => {\r\n    // default action assumes from = node, to = {parent, index}\r\n    if ($event.ctrlKey) {\r\n      tree.copyNode(from, to);\r\n    } else {\r\n      tree.moveNode(from, to);\r\n    }\r\n  }\r\n};\r\n\r\nconst defaultActionMapping: IActionMapping = {\r\n  mouse: {\r\n    click: TREE_ACTIONS.TOGGLE_ACTIVE,\r\n    dblClick: null,\r\n    contextMenu: null,\r\n    expanderClick: TREE_ACTIONS.TOGGLE_EXPANDED,\r\n    checkboxClick: TREE_ACTIONS.TOGGLE_SELECTED,\r\n    drop: TREE_ACTIONS.MOVE_NODE\r\n  },\r\n  keys: {\r\n    [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,\r\n    [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,\r\n    [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,\r\n    [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,\r\n    [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,\r\n    [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE\r\n  }\r\n};\r\n\r\nexport interface IActionMapping {\r\n  mouse?: {\r\n    click?: IActionHandler,\r\n    dblClick?: IActionHandler,\r\n    contextMenu?: IActionHandler,\r\n    expanderClick?: IActionHandler,\r\n    checkboxClick?: IActionHandler,\r\n    dragStart?: IActionHandler,\r\n    drag?: IActionHandler,\r\n    dragEnd?: IActionHandler,\r\n    dragOver?: IActionHandler,\r\n    dragLeave?: IActionHandler,\r\n    dragEnter?: IActionHandler,\r\n    drop?: IActionHandler,\r\n    mouseOver?: IActionHandler,\r\n    mouseOut?: IActionHandler\r\n  };\r\n  keys?: {\r\n    [key: number]: IActionHandler\r\n  };\r\n}\r\n\r\nexport class TreeOptions {\r\n  get hasChildrenField(): string { return this.options.hasChildrenField || 'hasChildren'; }\r\n  get childrenField(): string { return this.options.childrenField || 'children'; }\r\n  get displayField(): string { return this.options.displayField || 'name'; }\r\n  get idField(): string { return this.options.idField || 'id'; }\r\n  get isExpandedField(): string { return this.options.isExpandedField || 'isExpanded'; }\r\n  get getChildren(): any { return this.options.getChildren; }\r\n  get levelPadding(): number { return this.options.levelPadding || 0; }\r\n  get useVirtualScroll(): boolean { return this.options.useVirtualScroll; }\r\n  get animateExpand(): boolean { return this.options.animateExpand; }\r\n  get animateSpeed(): number { return this.options.animateSpeed || 1; }\r\n  get animateAcceleration(): number { return this.options.animateAcceleration || 1.2; }\r\n  get scrollOnActivate(): boolean { return this.options.scrollOnActivate === undefined ? true : this.options.scrollOnActivate; }\r\n  get rtl(): boolean { return !!this.options.rtl; }\r\n  get rootId(): any {return this.options.rootId; }\r\n  get useCheckbox(): boolean { return this.options.useCheckbox; }\r\n  get useTriState(): boolean { return this.options.useTriState === undefined ? true : this.options.useTriState; }\r\n  get scrollContainer(): HTMLElement { return this.options.scrollContainer; }\r\n  get allowDragoverStyling(): boolean { return this.options.allowDragoverStyling === undefined ? true : this.options.allowDragoverStyling; }\r\n  actionMapping: IActionMapping;\r\n\r\n  constructor(private options: ITreeOptions = {}) {\r\n    this.actionMapping = {\r\n      mouse: {\r\n        click: this.options?.actionMapping?.mouse?.click ?? defaultActionMapping.mouse.click,\r\n        dblClick: this.options?.actionMapping?.mouse?.dblClick ?? defaultActionMapping.mouse.dblClick,\r\n        contextMenu: this.options?.actionMapping?.mouse?.contextMenu ?? defaultActionMapping.mouse.contextMenu,\r\n        expanderClick: this.options?.actionMapping?.mouse?.expanderClick ?? defaultActionMapping.mouse.expanderClick,\r\n        checkboxClick: this.options?.actionMapping?.mouse?.checkboxClick ?? defaultActionMapping.mouse.checkboxClick,\r\n        drop: this.options?.actionMapping?.mouse?.drop ?? defaultActionMapping.mouse.drop,\r\n        dragStart: this.options?.actionMapping?.mouse?.dragStart ?? undefined,\r\n        drag: this.options?.actionMapping?.mouse?.drag ?? undefined,\r\n        dragEnd: this.options?.actionMapping?.mouse?.dragEnd ?? undefined,\r\n        dragOver: this.options?.actionMapping?.mouse?.dragOver ?? undefined,\r\n        dragLeave: this.options?.actionMapping?.mouse?.dragLeave ?? undefined,\r\n        dragEnter: this.options?.actionMapping?.mouse?.dragEnter ?? undefined,\r\n        mouseOver: this.options?.actionMapping?.mouse?.mouseOver ?? undefined,\r\n        mouseOut: this.options?.actionMapping?.mouse?.mouseOut ?? undefined,\r\n      },\r\n      keys: {\r\n        [KEYS.RIGHT]: TREE_ACTIONS.DRILL_DOWN,\r\n        [KEYS.LEFT]: TREE_ACTIONS.DRILL_UP,\r\n        [KEYS.DOWN]: TREE_ACTIONS.NEXT_NODE,\r\n        [KEYS.UP]: TREE_ACTIONS.PREVIOUS_NODE,\r\n        [KEYS.SPACE]: TREE_ACTIONS.TOGGLE_ACTIVE,\r\n        [KEYS.ENTER]: TREE_ACTIONS.TOGGLE_ACTIVE\r\n      }\r\n    }\r\n\r\n    if (this.options?.actionMapping?.keys) {\r\n      this.actionMapping.keys = {\r\n        ...this.actionMapping.keys,\r\n        ...this.options.actionMapping.keys\r\n      }\r\n    }\r\n\r\n    if (options.rtl) {\r\n      this.actionMapping.keys[KEYS.RIGHT] = <IActionHandler>options.actionMapping?.keys[KEYS.RIGHT] || TREE_ACTIONS.DRILL_UP;\r\n      this.actionMapping.keys[KEYS.LEFT] = <IActionHandler>options.actionMapping?.keys[KEYS.LEFT] || TREE_ACTIONS.DRILL_DOWN;\r\n    }\r\n  }\r\n\r\n  getNodeClone(node: TreeNode): any {\r\n    if (this.options.getNodeClone) {\r\n      return this.options.getNodeClone(node);\r\n    }\r\n\r\n    // remove id from clone\r\n    // keeping ie11 compatibility\r\n    const nodeClone = Object.assign({}, node.data);\r\n    if (nodeClone.id) {\r\n      delete nodeClone.id;\r\n    }\r\n    return nodeClone;\r\n  }\r\n\r\n  allowDrop(element, to, $event?): boolean {\r\n    if (this.options.allowDrop instanceof Function) {\r\n      return this.options.allowDrop(element, to, $event);\r\n    }\r\n    else {\r\n      return this.options.allowDrop === undefined ? true : this.options.allowDrop;\r\n    }\r\n  }\r\n\r\n  allowDrag(node: TreeNode): boolean {\r\n    if (this.options.allowDrag instanceof Function) {\r\n      return this.options.allowDrag(node);\r\n    } else {\r\n      return this.options.allowDrag;\r\n    }\r\n  }\r\n\r\n  nodeClass(node: TreeNode): string {\r\n    return this.options.nodeClass ? this.options.nodeClass(node) : '';\r\n  }\r\n\r\n  nodeHeight(node: TreeNode): number {\r\n    if (node.data.virtual) {\r\n      return 0;\r\n    }\r\n\r\n    let nodeHeight = this.options.nodeHeight || 22;\r\n\r\n    if (typeof nodeHeight === 'function') {\r\n      nodeHeight = nodeHeight(node);\r\n    }\r\n\r\n    // account for drop slots:\r\n    return nodeHeight + (node.index === 0 ?  2 : 1) * this.dropSlotHeight;\r\n  }\r\n\r\n  get dropSlotHeight(): number {\r\n    return typeof this.options.dropSlotHeight === 'number' ? this.options.dropSlotHeight : 2;\r\n  }\r\n}\r\n"]}