@omegagrid/tree 0.10.2 → 0.10.4

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 (85) hide show
  1. package/dist/adapters/dateAdapter.d.ts +35 -0
  2. package/dist/adapters/dateAdapter.d.ts.map +1 -0
  3. package/dist/adapters/dateAdapter.js +222 -0
  4. package/dist/adapters/dateAdapter.js.map +1 -0
  5. package/dist/adapters/index.d.ts +2 -0
  6. package/dist/adapters/index.d.ts.map +1 -0
  7. package/dist/adapters/index.js +2 -0
  8. package/dist/adapters/index.js.map +1 -0
  9. package/dist/constants.d.ts +53 -0
  10. package/dist/constants.d.ts.map +1 -0
  11. package/dist/constants.js +11 -0
  12. package/dist/constants.js.map +1 -0
  13. package/dist/index.d.ts +6 -0
  14. package/dist/index.d.ts.map +1 -0
  15. package/dist/index.js +5 -0
  16. package/dist/index.js.map +1 -0
  17. package/dist/model/filterModel.d.ts +17 -0
  18. package/dist/model/filterModel.d.ts.map +1 -0
  19. package/dist/model/filterModel.js +60 -0
  20. package/dist/model/filterModel.js.map +1 -0
  21. package/dist/model/index.d.ts +5 -0
  22. package/dist/model/index.d.ts.map +1 -0
  23. package/dist/model/index.js +5 -0
  24. package/dist/model/index.js.map +1 -0
  25. package/dist/model/nodeModel.d.ts +100 -0
  26. package/dist/model/nodeModel.d.ts.map +1 -0
  27. package/dist/model/nodeModel.js +59 -0
  28. package/dist/model/nodeModel.js.map +1 -0
  29. package/dist/model/selectionModel.d.ts +39 -0
  30. package/dist/model/selectionModel.d.ts.map +1 -0
  31. package/dist/model/selectionModel.js +199 -0
  32. package/dist/model/selectionModel.js.map +1 -0
  33. package/dist/model/treeAdapter.d.ts +10 -0
  34. package/dist/model/treeAdapter.d.ts.map +1 -0
  35. package/dist/model/treeAdapter.js +10 -0
  36. package/dist/model/treeAdapter.js.map +1 -0
  37. package/dist/model/treeModel.d.ts +27 -0
  38. package/dist/model/treeModel.d.ts.map +1 -0
  39. package/dist/model/treeModel.js +97 -0
  40. package/dist/model/treeModel.js.map +1 -0
  41. package/dist/options.d.ts +35 -0
  42. package/dist/options.d.ts.map +1 -0
  43. package/dist/options.js +30 -0
  44. package/dist/options.js.map +1 -0
  45. package/dist/types.d.ts +42 -0
  46. package/dist/types.d.ts.map +1 -0
  47. package/dist/types.js +15 -0
  48. package/dist/types.js.map +1 -0
  49. package/dist/ui/dropdown.d.ts +68 -0
  50. package/dist/ui/dropdown.d.ts.map +1 -0
  51. package/dist/ui/dropdown.js +383 -0
  52. package/dist/ui/dropdown.js.map +1 -0
  53. package/dist/ui/dropdown.style.d.ts +2 -0
  54. package/dist/ui/dropdown.style.d.ts.map +1 -0
  55. package/dist/ui/dropdown.style.js +68 -0
  56. package/dist/ui/dropdown.style.js.map +1 -0
  57. package/dist/ui/index.d.ts +6 -0
  58. package/dist/ui/index.d.ts.map +1 -0
  59. package/dist/ui/index.js +6 -0
  60. package/dist/ui/index.js.map +1 -0
  61. package/dist/ui/levels.d.ts +13 -0
  62. package/dist/ui/levels.d.ts.map +1 -0
  63. package/dist/ui/levels.js +64 -0
  64. package/dist/ui/levels.js.map +1 -0
  65. package/dist/ui/menu.d.ts +14 -0
  66. package/dist/ui/menu.d.ts.map +1 -0
  67. package/dist/ui/menu.js +89 -0
  68. package/dist/ui/menu.js.map +1 -0
  69. package/dist/ui/search.d.ts +18 -0
  70. package/dist/ui/search.d.ts.map +1 -0
  71. package/dist/ui/search.js +92 -0
  72. package/dist/ui/search.js.map +1 -0
  73. package/dist/ui/tree.d.ts +86 -0
  74. package/dist/ui/tree.d.ts.map +1 -0
  75. package/dist/ui/tree.js +482 -0
  76. package/dist/ui/tree.js.map +1 -0
  77. package/dist/ui/tree.renderer.d.ts +7 -0
  78. package/dist/ui/tree.renderer.d.ts.map +1 -0
  79. package/dist/ui/tree.renderer.js +114 -0
  80. package/dist/ui/tree.renderer.js.map +1 -0
  81. package/dist/ui/tree.style.d.ts +3 -0
  82. package/dist/ui/tree.style.d.ts.map +1 -0
  83. package/dist/ui/tree.style.js +147 -0
  84. package/dist/ui/tree.style.js.map +1 -0
  85. package/package.json +3 -3
@@ -0,0 +1,6 @@
1
+ export * from './dropdown';
2
+ export * from './levels';
3
+ export * from './search';
4
+ export * from './tree';
5
+ export * from './menu';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC"}
@@ -0,0 +1,6 @@
1
+ export * from './dropdown';
2
+ export * from './levels';
3
+ export * from './search';
4
+ export * from './tree';
5
+ export * from './menu';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC","sourcesContent":["export * from './dropdown';\nexport * from './levels';\nexport * from './search';\nexport * from './tree';\nexport * from './menu';"]}
@@ -0,0 +1,13 @@
1
+ import { LitElement } from "lit";
2
+ export declare class LevelSelectEvent extends Event {
3
+ readonly level: number;
4
+ constructor(level: number);
5
+ }
6
+ export default class Levels extends LitElement {
7
+ static styles: import("lit").CSSResult[];
8
+ count: number;
9
+ selection: Map<number, boolean>;
10
+ firstUpdated(): void;
11
+ render: () => import("lit-html").TemplateResult<1>;
12
+ }
13
+ //# sourceMappingURL=levels.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"levels.d.ts","sourceRoot":"","sources":["../../src/ui/levels.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,UAAU,EAAE,MAAM,KAAK,CAAC;AAO5C,qBAAa,gBAAiB,SAAQ,KAAK;aACd,KAAK,EAAE,MAAM;gBAAb,KAAK,EAAE,MAAM;CAGzC;AAGD,MAAM,CAAC,OAAO,OAAO,MAAO,SAAQ,UAAU;IAE7C,MAAM,CAAC,MAAM,4BAiBV;IAGH,KAAK,EAAE,MAAM,CAAC;IAGd,SAAS,uBAA8B;IAEvC,YAAY;IAOZ,MAAM,6CAIJ;CACF"}
@@ -0,0 +1,64 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { css, html, LitElement } from "lit";
8
+ import { customElement, property } from "lit/decorators.js";
9
+ import { range } from 'lit/directives/range.js';
10
+ import { map } from 'lit/directives/map.js';
11
+ import { dom } from "@omegagrid/core";
12
+ import { classMap } from 'lit/directives/class-map.js';
13
+ export class LevelSelectEvent extends Event {
14
+ constructor(level) {
15
+ super('levelselect', { bubbles: false, cancelable: true, composed: true });
16
+ this.level = level;
17
+ }
18
+ }
19
+ let Levels = class Levels extends LitElement {
20
+ constructor() {
21
+ super(...arguments);
22
+ this.selection = new Map();
23
+ this.render = () => html `
24
+ ${map(range(1, this.count + 1), i => html `
25
+ <div class="${classMap({ level: true, selected: this.selection.has(i) && this.selection.get(i) })}" data-level=${i}>${i}</div>
26
+ `)}
27
+ `;
28
+ }
29
+ firstUpdated() {
30
+ dom.on(this, 'mousedown', '.level', (e, elm) => {
31
+ e.stopPropagation();
32
+ this.dispatchEvent(new LevelSelectEvent(parseInt(elm.dataset.level)));
33
+ });
34
+ }
35
+ };
36
+ Levels.styles = [css `
37
+ :host {
38
+ display: flex;
39
+ flex-direction: row;
40
+ }
41
+
42
+ div {
43
+ width: 15px;
44
+ border: 1px solid var(--og-accent-color);
45
+ text-align: center;
46
+ cursor: pointer;
47
+ }
48
+
49
+ div.selected {
50
+ background-color: var(--og-accent-color);
51
+ color: #ffffff;
52
+ }
53
+ `];
54
+ __decorate([
55
+ property({ type: Number })
56
+ ], Levels.prototype, "count", void 0);
57
+ __decorate([
58
+ property({ type: Object })
59
+ ], Levels.prototype, "selection", void 0);
60
+ Levels = __decorate([
61
+ customElement('og-tree-levels')
62
+ ], Levels);
63
+ export default Levels;
64
+ //# sourceMappingURL=levels.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"levels.js","sourceRoot":"","sources":["../../src/ui/levels.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AAChD,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAC5C,OAAO,EAAE,GAAG,EAAE,MAAM,iBAAiB,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAEvD,MAAM,OAAO,gBAAiB,SAAQ,KAAK;IAC1C,YAA4B,KAAa;QACxC,KAAK,CAAC,aAAa,EAAE,EAAC,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;QAD9C,UAAK,GAAL,KAAK,CAAQ;IAEzC,CAAC;CACD;AAGc,IAAM,MAAM,GAAZ,MAAM,MAAO,SAAQ,UAAU;IAA/B;;QAyBd,cAAS,GAAG,IAAI,GAAG,EAAmB,CAAC;QASvC,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;IAChB,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAA;iBAC1B,QAAQ,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC;GACrH,CAAC;EACF,CAAC;IACH,CAAC;IAZA,YAAY;QACX,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YAC9C,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,gBAAgB,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;IACJ,CAAC;;AA9BM,aAAM,GAAG,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;;;EAiBnB,CAAC,AAjBW,CAiBV;AAGH;IADC,QAAQ,CAAC,EAAC,IAAI,EAAE,MAAM,EAAC,CAAC;qCACX;AAGd;IADC,QAAQ,CAAC,EAAC,IAAI,EAAE,MAAM,EAAC,CAAC;yCACc;AAzBnB,MAAM;IAD1B,aAAa,CAAC,gBAAgB,CAAC;GACX,MAAM,CAuC1B;eAvCoB,MAAM","sourcesContent":["import { css, html, LitElement } from \"lit\";\nimport { customElement, property } from \"lit/decorators.js\";\nimport { range } from 'lit/directives/range.js';\nimport { map } from 'lit/directives/map.js';\nimport { dom } from \"@omegagrid/core\";\nimport { classMap } from 'lit/directives/class-map.js';\n\nexport class LevelSelectEvent extends Event {\n\tconstructor(public readonly level: number) {\n\t\tsuper('levelselect', {bubbles: false, cancelable: true, composed: true});\n\t}\n}\n\n@customElement('og-tree-levels')\nexport default class Levels extends LitElement {\n\n\tstatic styles = [css`\n\t\t:host {\n\t\t\tdisplay: flex;\n\t\t\tflex-direction: row;\n\t\t}\n\n\t\tdiv {\n\t\t\twidth: 15px;\n\t\t\tborder: 1px solid var(--og-accent-color);\n\t\t\ttext-align: center;\n\t\t\tcursor: pointer;\n\t\t}\n\n\t\tdiv.selected {\n\t\t\tbackground-color: var(--og-accent-color);\n\t\t\tcolor: #ffffff;\n\t\t}\n\t`];\n\n\t@property({type: Number})\n\tcount: number;\n\n\t@property({type: Object})\n\tselection = new Map<number, boolean>();\n\n\tfirstUpdated() {\n\t\tdom.on(this, 'mousedown', '.level', (e, elm) => {\n\t\t\te.stopPropagation();\n\t\t\tthis.dispatchEvent(new LevelSelectEvent(parseInt(elm.dataset.level)));\n\t\t});\n\t}\n\n\trender = () => html`\n\t\t${map(range(1, this.count + 1), i => html`\n\t\t\t<div class=\"${classMap({level: true, selected: this.selection.has(i) && this.selection.get(i)})}\" data-level=${i}>${i}</div>\n\t\t`)}\n\t`;\n}"]}
@@ -0,0 +1,14 @@
1
+ import { MenuPosition } from "@omegagrid/core";
2
+ import { Tree } from "./tree";
3
+ export declare class TreeMenu extends Tree {
4
+ static styles: import("lit").CSSResult[];
5
+ private _autoHide;
6
+ constructor();
7
+ connectedCallback(): void;
8
+ firstUpdated(): Promise<void>;
9
+ updateWidth(): Promise<void>;
10
+ _hideEvent: () => void;
11
+ open(elm: HTMLElement, position?: MenuPosition): Promise<void>;
12
+ openAt(x: number, y: number): Promise<void>;
13
+ }
14
+ //# sourceMappingURL=menu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["../../src/ui/menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAGpD,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,qBACa,QAAS,SAAQ,IAAI;IAEjC,MAAM,CAAC,MAAM,4BASV;IAEH,OAAO,CAAC,SAAS,CAAS;;IAM1B,iBAAiB;IAIX,YAAY;IAWZ,WAAW;IAWjB,UAAU,aAKT;IAEK,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,QAAQ,GAAE,YAAqB;IAgBtD,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;CAYjC"}
@@ -0,0 +1,89 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { dom } from "@omegagrid/core";
8
+ import { css } from "lit";
9
+ import { customElement } from "lit/decorators.js";
10
+ import { Tree } from "./tree";
11
+ let TreeMenu = class TreeMenu extends Tree {
12
+ constructor() {
13
+ super();
14
+ this._autoHide = false;
15
+ this._hideEvent = () => {
16
+ if (!this.list.container?.isScrolling) {
17
+ dom.hideElement(this);
18
+ document.body.removeEventListener('mousedown', this._hideEvent);
19
+ }
20
+ };
21
+ }
22
+ connectedCallback() {
23
+ super.connectedCallback();
24
+ }
25
+ async firstUpdated() {
26
+ super.firstUpdated();
27
+ this.addEventListener('select', () => {
28
+ if (this._autoHide)
29
+ dom.hideElement(this);
30
+ });
31
+ // this.addEventListener('mouseup', (e: MouseEvent) => {
32
+ // e.stopPropagation();
33
+ // });
34
+ }
35
+ async updateWidth() {
36
+ await this.list.updateComplete;
37
+ let maxWidth = 0;
38
+ this.list.items.forEach(item => {
39
+ let w = 0;
40
+ for (const ch of item.children)
41
+ w += ch.offsetWidth;
42
+ maxWidth = Math.max(maxWidth, w, item.offsetWidth);
43
+ });
44
+ dom.setSize(this, { w: maxWidth });
45
+ }
46
+ async open(elm, position = 'left') {
47
+ this._autoHide = true;
48
+ if (this.parentElement != document.body)
49
+ document.body.appendChild(this);
50
+ dom.showElement(this);
51
+ await this.updateWidth();
52
+ const offset = dom.getElementOffset(elm, this.parentElement);
53
+ dom.setPosition(this, {
54
+ t: offset.top + elm.offsetHeight,
55
+ l: position == 'left' ? offset.left : (offset.left + elm.offsetWidth - this.offsetWidth)
56
+ });
57
+ dom.fixElementPosition(this);
58
+ this.list.select(0);
59
+ this.list.focus();
60
+ document.body.addEventListener('mousedown', this._hideEvent);
61
+ }
62
+ async openAt(x, y) {
63
+ this._autoHide = true;
64
+ if (this.parentElement != document.body)
65
+ document.body.appendChild(this);
66
+ dom.showElement(this);
67
+ await this.updateWidth();
68
+ dom.setPosition(this, { l: x, t: y });
69
+ dom.fixElementPosition(this);
70
+ this.list.select(0);
71
+ this.list.focus();
72
+ document.body.addEventListener('mousedown', this._hideEvent);
73
+ }
74
+ };
75
+ TreeMenu.styles = [css `
76
+ :host {
77
+ font-size: var(--og-font-size);
78
+ font-family: var(--og-font-family);
79
+ display: block;
80
+ border: 1px solid var(--og-accent-color);
81
+ background: var(--og-background-color);
82
+ color: var(--og-text-color);
83
+ }
84
+ `];
85
+ TreeMenu = __decorate([
86
+ customElement('og-tree-menu')
87
+ ], TreeMenu);
88
+ export { TreeMenu };
89
+ //# sourceMappingURL=menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.js","sourceRoot":"","sources":["../../src/ui/menu.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,GAAG,EAAgB,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAC1B,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAGvB,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,IAAI;IAejC;QACC,KAAK,EAAE,CAAC;QAHD,cAAS,GAAG,KAAK,CAAC;QAgC1B,eAAU,GAAG,GAAG,EAAE;YACjB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,EAAE,CAAC;gBACvC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBACtB,QAAQ,CAAC,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACjE,CAAC;QACF,CAAC,CAAA;IAjCD,CAAC;IAED,iBAAiB;QAChB,KAAK,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,YAAY;QACjB,KAAK,CAAC,YAAY,EAAE,CAAC;QACrB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACpC,IAAI,IAAI,CAAC,SAAS;gBAAE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,wDAAwD;QACxD,wBAAwB;QACxB,MAAM;IACP,CAAC;IAED,KAAK,CAAC,WAAW;QAChB,MAAM,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;QAC/B,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC9B,IAAI,CAAC,GAAG,CAAC,CAAC;YACV,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,QAAQ;gBAAE,CAAC,IAAK,EAAkB,CAAC,WAAW,CAAC;YACrE,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QACH,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,EAAC,CAAC,EAAE,QAAQ,EAAC,CAAC,CAAC;IAClC,CAAC;IASD,KAAK,CAAC,IAAI,CAAC,GAAgB,EAAE,WAAyB,MAAM;QAC3D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,IAAI,CAAC,aAAa,IAAI,QAAQ,CAAC,IAAI;YAAE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACzE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACtB,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;QACzB,MAAM,MAAM,GAAG,GAAG,CAAC,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC7D,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE;YACrB,CAAC,EAAE,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,YAAY;YAChC,CAAC,EAAE,QAAQ,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;SACxF,CAAC,CAAC;QACH,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;QAClB,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9D,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,CAAS,EAAE,CAAS;QAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,IAAI,CAAC,aAAa,IAAI,QAAQ,CAAC,IAAI;YAAE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACzE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACtB,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;QACzB,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,CAAC,CAAC;QACpC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;QAClB,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9D,CAAC;;AA5EM,eAAM,GAAG,CAAC,GAAG,CAAA;;;;;;;;;EASnB,CAAC,AATW,CASV;AAXS,QAAQ;IADpB,aAAa,CAAC,cAAc,CAAC;GACjB,QAAQ,CAgFpB","sourcesContent":["import { dom, MenuPosition } from \"@omegagrid/core\";\nimport { css } from \"lit\";\nimport { customElement } from \"lit/decorators.js\";\nimport { Tree } from \"./tree\";\n\n@customElement('og-tree-menu')\nexport class TreeMenu extends Tree {\n\n\tstatic styles = [css`\n\t\t:host {\n\t\t\tfont-size: var(--og-font-size);\n\t\t\tfont-family: var(--og-font-family);\n\t\t\tdisplay: block;\n\t\t\tborder: 1px solid var(--og-accent-color);\n\t\t\tbackground: var(--og-background-color);\n\t\t\tcolor: var(--og-text-color);\n\t\t}\n\t`];\n\n\tprivate _autoHide = false;\n\n\tconstructor() {\n\t\tsuper();\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback();\n\t}\n\n\tasync firstUpdated() {\n\t\tsuper.firstUpdated();\n\t\tthis.addEventListener('select', () => {\n\t\t\tif (this._autoHide) dom.hideElement(this);\n\t\t});\n\n\t\t// this.addEventListener('mouseup', (e: MouseEvent) => {\n\t\t// \te.stopPropagation();\n\t\t// });\n\t}\n\n\tasync updateWidth() {\n\t\tawait this.list.updateComplete;\n\t\tlet maxWidth = 0;\n\t\tthis.list.items.forEach(item => {\n\t\t\tlet w = 0;\n\t\t\tfor (const ch of item.children) w += (ch as HTMLElement).offsetWidth;\n\t\t\tmaxWidth = Math.max(maxWidth, w, item.offsetWidth);\n\t\t});\n\t\tdom.setSize(this, {w: maxWidth});\n\t}\n\n\t_hideEvent = () => {\n\t\tif (!this.list.container?.isScrolling) {\n\t\t\tdom.hideElement(this);\n\t\t\tdocument.body.removeEventListener('mousedown', this._hideEvent);\n\t\t}\n\t}\n\n\tasync open(elm: HTMLElement, position: MenuPosition = 'left') {\n\t\tthis._autoHide = true;\n\t\tif (this.parentElement != document.body) document.body.appendChild(this);\n\t\tdom.showElement(this);\n\t\tawait this.updateWidth();\n\t\tconst offset = dom.getElementOffset(elm, this.parentElement);\n\t\tdom.setPosition(this, {\n\t\t\tt: offset.top + elm.offsetHeight,\n\t\t\tl: position == 'left' ? offset.left : (offset.left + elm.offsetWidth - this.offsetWidth)\n\t\t});\n\t\tdom.fixElementPosition(this);\n\t\tthis.list.select(0);\n\t\tthis.list.focus();\n\t\tdocument.body.addEventListener('mousedown', this._hideEvent);\n\t}\n\n\tasync openAt(x: number, y: number) {\n\t\tthis._autoHide = true;\n\t\tif (this.parentElement != document.body) document.body.appendChild(this);\n\t\tdom.showElement(this);\n\t\tawait this.updateWidth();\n\t\tdom.setPosition(this, {l: x, t: y});\n\t\tdom.fixElementPosition(this);\n\t\tthis.list.select(0);\n\t\tthis.list.focus();\n\t\tdocument.body.addEventListener('mousedown', this._hideEvent);\n\t}\n\n}"]}
@@ -0,0 +1,18 @@
1
+ import { LitElement } from "lit";
2
+ import { Tree } from "./tree";
3
+ export declare class TreeSearchEvent extends Event {
4
+ readonly component: Search;
5
+ constructor(type: string, component: Search);
6
+ }
7
+ export default class Search extends LitElement {
8
+ searchInput: HTMLInputElement;
9
+ tree: Tree;
10
+ static styles: import("lit").CSSResult[];
11
+ debounceKeyUp: {
12
+ (this: unknown, ...args: [e: KeyboardEvent] & any[]): Promise<Promise<void>>;
13
+ cancel: (reason?: any) => void;
14
+ };
15
+ _onKeyDown: (e: KeyboardEvent) => void;
16
+ render: () => import("lit-html").TemplateResult<1>;
17
+ }
18
+ //# sourceMappingURL=search.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../src/ui/search.ts"],"names":[],"mappings":"AACA,OAAO,EAAa,UAAU,EAAE,MAAM,KAAK,CAAC;AAK5C,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,qBAAa,eAAgB,SAAQ,KAAK;aAGxB,SAAS,EAAE,MAAM;gBADjC,IAAI,EAAE,MAAM,EACI,SAAS,EAAE,MAAM;CAIlC;AAGD,MAAM,CAAC,OAAO,OAAO,MAAO,SAAQ,UAAU;IAG7C,WAAW,EAAE,gBAAgB,CAAC;IAG9B,IAAI,EAAE,IAAI,CAAC;IAEX,MAAM,CAAC,MAAM,4BAuBV;IAEH,aAAa;;uBA/BP,CAAC;MAmCmD;IAE1D,UAAU,GAAI,GAAG,aAAa,UAgB7B;IAED,MAAM,6CAUJ;CACF"}
@@ -0,0 +1,92 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { ListSelectTrigger, utils } from "@omegagrid/core";
8
+ import { css, html, LitElement } from "lit";
9
+ import { customElement, property, query } from "lit/decorators.js";
10
+ import { msg } from '@omegagrid/localize';
11
+ import { debounce } from "ts-debounce";
12
+ import constants from "../constants";
13
+ export class TreeSearchEvent extends Event {
14
+ constructor(type, component) {
15
+ super(`${type}`, { bubbles: false, cancelable: true, composed: false });
16
+ this.component = component;
17
+ }
18
+ }
19
+ let Search = class Search extends LitElement {
20
+ constructor() {
21
+ super(...arguments);
22
+ this.debounceKeyUp = debounce(async (e) => {
23
+ if (utils.isControlCharacter(e.key))
24
+ return;
25
+ await this.tree.filter(this.searchInput.value);
26
+ this.dispatchEvent(new TreeSearchEvent('search', this));
27
+ }, constants.SEARCH_DEBOUNCE_DELAY, { isImmediate: false });
28
+ this._onKeyDown = (e) => {
29
+ switch (e.key) {
30
+ case 'ArrowDown':
31
+ e.preventDefault();
32
+ this.tree.list.moveDown();
33
+ break;
34
+ case 'ArrowUp':
35
+ e.preventDefault();
36
+ this.tree.list.moveUp();
37
+ break;
38
+ case 'Enter':
39
+ e.preventDefault();
40
+ this.tree.list.select(this.tree.list.selectedIndex, ListSelectTrigger.Enter);
41
+ setTimeout(() => this.searchInput.focus(), 100);
42
+ break;
43
+ }
44
+ };
45
+ this.render = () => html `
46
+ <og-icon icon="search"></og-icon>
47
+
48
+ <input id="searchInput"
49
+ autocomplete="off"
50
+ spellcheck="false"
51
+ type="text"
52
+ placeholder="${msg('Search')}"
53
+ @keydown="${this._onKeyDown}"
54
+ @keyup="${this.debounceKeyUp}">
55
+ `;
56
+ }
57
+ };
58
+ Search.styles = [css `
59
+ :host {
60
+ display: flex;
61
+ flex-direction: row;
62
+ box-sizing: border-box;
63
+ align-items: center;
64
+ }
65
+
66
+ og-icon {
67
+ height: 100%;
68
+ margin: 0 2px;
69
+ flex: 0;
70
+ }
71
+
72
+ input {
73
+ font-size: var(--og-font-size);
74
+ font-family: var(--og-font-family);
75
+ width: 100%;
76
+ background-color: var(--og-background-color);
77
+ outline: none;
78
+ border: none;
79
+ color: var(--og-text-color);
80
+ }
81
+ `];
82
+ __decorate([
83
+ query('#searchInput')
84
+ ], Search.prototype, "searchInput", void 0);
85
+ __decorate([
86
+ property({ type: Object })
87
+ ], Search.prototype, "tree", void 0);
88
+ Search = __decorate([
89
+ customElement('og-tree-search')
90
+ ], Search);
91
+ export default Search;
92
+ //# sourceMappingURL=search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.js","sourceRoot":"","sources":["../../src/ui/search.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,SAAS,MAAM,cAAc,CAAC;AAGrC,MAAM,OAAO,eAAgB,SAAQ,KAAK;IACzC,YACC,IAAY,EACI,SAAiB;QAEjC,KAAK,CAAC,GAAG,IAAI,EAAE,EAAE,EAAC,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAC,CAAC,CAAC;QAFtD,cAAS,GAAT,SAAS,CAAQ;IAGlC,CAAC;CACD;AAGc,IAAM,MAAM,GAAZ,MAAM,MAAO,SAAQ,UAAU;IAA/B;;QAiCd,kBAAa,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAgB,EAAE,EAAE;YACnD,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC,GAAG,CAAC;gBAAE,OAAO;YAC5C,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC/C,IAAI,CAAC,aAAa,CAAC,IAAI,eAAe,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;QACzD,CAAC,EAAE,SAAS,CAAC,qBAAqB,EAAE,EAAC,WAAW,EAAE,KAAK,EAAC,CAAC,CAAC;QAE1D,eAAU,GAAG,CAAC,CAAgB,EAAE,EAAE;YACjC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;gBACf,KAAK,WAAW;oBACf,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAC1B,MAAM;gBACP,KAAK,SAAS;oBACb,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;oBACxB,MAAM;gBACP,KAAK,OAAO;oBACX,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC;oBAC7E,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,GAAG,CAAC,CAAC;oBAChD,MAAM;YACR,CAAC;QACF,CAAC,CAAA;QAED,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;;;;;;;kBAOF,GAAG,CAAC,QAAQ,CAAC;eAChB,IAAI,CAAC,UAAU;aACjB,IAAI,CAAC,aAAa;EAC7B,CAAC;IACH,CAAC;;AA5DO,aAAM,GAAG,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;EAuBnB,CAAC,AAvBW,CAuBV;AA5BH;IADC,KAAK,CAAC,cAAc,CAAC;2CACQ;AAG9B;IADC,QAAQ,CAAC,EAAC,IAAI,EAAE,MAAM,EAAC,CAAC;oCACd;AANS,MAAM;IAD1B,aAAa,CAAC,gBAAgB,CAAC;GACX,MAAM,CAoE1B;eApEoB,MAAM","sourcesContent":["import { ListSelectTrigger, utils } from \"@omegagrid/core\";\nimport { css, html, LitElement } from \"lit\";\nimport { customElement, property, query } from \"lit/decorators.js\";\nimport { msg } from '@omegagrid/localize';\nimport { debounce } from \"ts-debounce\";\nimport constants from \"../constants\";\nimport { Tree } from \"./tree\";\n\nexport class TreeSearchEvent extends Event {\n\tconstructor(\n\t\ttype: string,\n\t\tpublic readonly component: Search,\n\t) {\n\t\tsuper(`${type}`, {bubbles: false, cancelable: true, composed: false});\n\t}\n}\n\n@customElement('og-tree-search')\nexport default class Search extends LitElement {\n\n\t@query('#searchInput')\n\tsearchInput: HTMLInputElement;\n\n\t@property({type: Object})\n\ttree: Tree;\n\n\tstatic styles = [css`\n\t\t:host {\n\t\t\tdisplay: flex;\n\t\t\tflex-direction: row;\n\t\t\tbox-sizing: border-box;\n\t\t\talign-items: center;\n\t\t}\n\n\t\tog-icon {\n\t\t\theight: 100%;\n\t\t\tmargin: 0 2px;\n\t\t\tflex: 0;\n\t\t}\n\n\t\tinput {\n\t\t\tfont-size: var(--og-font-size);\n\t\t\tfont-family: var(--og-font-family);\n\t\t\twidth: 100%;\n\t\t\tbackground-color: var(--og-background-color);\n\t\t\toutline: none;\n\t\t\tborder: none;\n\t\t\tcolor: var(--og-text-color);\n\t\t}\n\t`];\n\n\tdebounceKeyUp = debounce(async (e: KeyboardEvent) => {\n\t\tif (utils.isControlCharacter(e.key)) return;\n\t\tawait this.tree.filter(this.searchInput.value);\n\t\tthis.dispatchEvent(new TreeSearchEvent('search', this));\n\t}, constants.SEARCH_DEBOUNCE_DELAY, {isImmediate: false});\n\n\t_onKeyDown = (e: KeyboardEvent) => {\n\t\tswitch (e.key) {\n\t\t\tcase 'ArrowDown':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.tree.list.moveDown();\n\t\t\t\tbreak;\n\t\t\tcase 'ArrowUp':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.tree.list.moveUp();\n\t\t\t\tbreak;\n\t\t\tcase 'Enter':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.tree.list.select(this.tree.list.selectedIndex, ListSelectTrigger.Enter);\n\t\t\t\tsetTimeout(() => this.searchInput.focus(), 100);\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\trender = () => html`\n\t\t<og-icon icon=\"search\"></og-icon>\n\n\t\t<input id=\"searchInput\"\n\t\t\tautocomplete=\"off\"\n\t\t\tspellcheck=\"false\"\n\t\t\ttype=\"text\"\n\t\t\tplaceholder=\"${msg('Search')}\"\n\t\t\t@keydown=\"${this._onKeyDown}\"\n\t\t\t@keyup=\"${this.debounceKeyUp}\">\n\t`;\n}\n"]}
@@ -0,0 +1,86 @@
1
+ import { List, log, ListPointerEvent } from '@omegagrid/core';
2
+ import { Options } from '../options';
3
+ import { TreeModel, TreeSource } from '../model/treeModel';
4
+ import { LitElement } from 'lit';
5
+ import Levels, { LevelSelectEvent } from './levels';
6
+ import { TreeSelectionModel, SerializedValue } from '../model/selectionModel';
7
+ import { NodeModel } from '../model/nodeModel';
8
+ import { TreeAdapter } from '../model/treeAdapter';
9
+ import { FilterModel } from '../model/filterModel';
10
+ import Search from './search';
11
+ import { TreeAdapterParams } from '../types';
12
+ export declare class TreeEvent extends Event {
13
+ component: Tree;
14
+ node: NodeModel;
15
+ constructor(type: string, args?: Partial<TreeEvent>);
16
+ }
17
+ export declare class TreePointerEvent extends PointerEvent {
18
+ tree: Tree;
19
+ node: NodeModel;
20
+ constructor(type: string, e: PointerEvent, args?: Partial<TreePointerEvent>);
21
+ }
22
+ export declare class TreeDropEvent extends DragEvent {
23
+ tree: Tree;
24
+ node: NodeModel;
25
+ constructor(type: string, e: DragEvent, args?: Partial<TreeDropEvent>);
26
+ }
27
+ export declare class Tree extends LitElement {
28
+ static styles: import("lit").CSSResult[];
29
+ model: TreeModel;
30
+ adapter: TreeAdapter;
31
+ options: Options;
32
+ selection: TreeSelectionModel;
33
+ logger: log.Logger;
34
+ maxHeight: number;
35
+ itemHeight: number;
36
+ value: SerializedValue[];
37
+ disableAutoload: boolean;
38
+ list: List;
39
+ searchBar: Search;
40
+ globalTreeLevels: Levels;
41
+ loading: boolean;
42
+ noMatches: boolean;
43
+ filtering: FilterModel;
44
+ awaitFilter: boolean;
45
+ currentFilter: string;
46
+ loadingNodes: Set<string>;
47
+ pendingHighlight: string;
48
+ get size(): number;
49
+ get hasGlobalLevels(): boolean;
50
+ _lastDragItem: HTMLElement;
51
+ _onDragover: (e: DragEvent) => void;
52
+ _onDrop: (e: DragEvent) => void;
53
+ _onDragLeave: () => void;
54
+ constructor();
55
+ destroy(): void;
56
+ connectedCallback(): void;
57
+ setSourceData(sourceData: TreeSource, options?: Partial<Options>): void;
58
+ setValue(values: SerializedValue[]): void;
59
+ loadData(params?: TreeAdapterParams): Promise<void>;
60
+ loadMore(parent: NodeModel): Promise<void>;
61
+ refresh(): Promise<void>;
62
+ keyActions: {
63
+ ArrowRight: () => void;
64
+ ArrowLeft: () => void;
65
+ };
66
+ willUpdate(props: Map<PropertyKey, unknown>): void;
67
+ updated(changedProps: Map<PropertyKey, unknown>): void;
68
+ firstUpdated(): Promise<void>;
69
+ _onGlobalLevelSelect: (e: LevelSelectEvent) => Promise<void>;
70
+ _onSearch: () => void;
71
+ toggleNode(node: NodeModel, level: number, dispatchEvent?: boolean): void;
72
+ updateNodeLoadState(node: NodeModel, newNodeCount: number): void;
73
+ toggleNodeCollapse(node: NodeModel, dispatchEvent?: boolean): Promise<void>;
74
+ toggleTreeCollapse(node?: NodeModel, dispatchEvent?: boolean): void;
75
+ _onListRender: () => void;
76
+ _onListMenu: (e: ListPointerEvent) => void;
77
+ get itemStyle(): (string | import("lit").CSSResultOrNative)[];
78
+ render(): Iterable<string | import("lit-html").TemplateResult<1>>;
79
+ highlightNode(key: string): Promise<void>;
80
+ highlightFirstSelectedNode(): void;
81
+ renderItems(all?: boolean): void;
82
+ clearSelection(): void;
83
+ filter(term?: string): Promise<void>;
84
+ clearFilter(): Promise<void>;
85
+ }
86
+ //# sourceMappingURL=tree.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tree.d.ts","sourceRoot":"","sources":["../../src/ui/tree.ts"],"names":[],"mappings":"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"}