@omegagrid/core 0.2.5

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 (233) hide show
  1. package/dist/common/actions.d.ts +16 -0
  2. package/dist/common/actions.d.ts.map +1 -0
  3. package/dist/common/actions.js +19 -0
  4. package/dist/common/actions.js.map +1 -0
  5. package/dist/common/colors.d.ts +25 -0
  6. package/dist/common/colors.d.ts.map +1 -0
  7. package/dist/common/colors.js +54 -0
  8. package/dist/common/colors.js.map +1 -0
  9. package/dist/common/csv.d.ts +23 -0
  10. package/dist/common/csv.d.ts.map +1 -0
  11. package/dist/common/csv.js +99 -0
  12. package/dist/common/csv.js.map +1 -0
  13. package/dist/common/dates.d.ts +13 -0
  14. package/dist/common/dates.d.ts.map +1 -0
  15. package/dist/common/dates.js +118 -0
  16. package/dist/common/dates.js.map +1 -0
  17. package/dist/common/dom.d.ts +79 -0
  18. package/dist/common/dom.d.ts.map +1 -0
  19. package/dist/common/dom.js +242 -0
  20. package/dist/common/dom.js.map +1 -0
  21. package/dist/common/html.d.ts +3 -0
  22. package/dist/common/html.d.ts.map +1 -0
  23. package/dist/common/html.js +33 -0
  24. package/dist/common/html.js.map +1 -0
  25. package/dist/common/index.d.ts +14 -0
  26. package/dist/common/index.d.ts.map +1 -0
  27. package/dist/common/index.js +43 -0
  28. package/dist/common/index.js.map +1 -0
  29. package/dist/common/linkedList.d.ts +24 -0
  30. package/dist/common/linkedList.d.ts.map +1 -0
  31. package/dist/common/linkedList.js +70 -0
  32. package/dist/common/linkedList.js.map +1 -0
  33. package/dist/common/logger.d.ts +23 -0
  34. package/dist/common/logger.d.ts.map +1 -0
  35. package/dist/common/logger.js +58 -0
  36. package/dist/common/logger.js.map +1 -0
  37. package/dist/common/matrix.d.ts +6 -0
  38. package/dist/common/matrix.d.ts.map +1 -0
  39. package/dist/common/matrix.js +24 -0
  40. package/dist/common/matrix.js.map +1 -0
  41. package/dist/common/mixin.d.ts +4 -0
  42. package/dist/common/mixin.d.ts.map +1 -0
  43. package/dist/common/mixin.js +3 -0
  44. package/dist/common/mixin.js.map +1 -0
  45. package/dist/common/numbers.d.ts +18 -0
  46. package/dist/common/numbers.d.ts.map +1 -0
  47. package/dist/common/numbers.js +209 -0
  48. package/dist/common/numbers.js.map +1 -0
  49. package/dist/common/options.d.ts +10 -0
  50. package/dist/common/options.d.ts.map +1 -0
  51. package/dist/common/options.js +22 -0
  52. package/dist/common/options.js.map +1 -0
  53. package/dist/common/tree.d.ts +68 -0
  54. package/dist/common/tree.d.ts.map +1 -0
  55. package/dist/common/tree.js +190 -0
  56. package/dist/common/tree.js.map +1 -0
  57. package/dist/common/utils.d.ts +15 -0
  58. package/dist/common/utils.d.ts.map +1 -0
  59. package/dist/common/utils.js +92 -0
  60. package/dist/common/utils.js.map +1 -0
  61. package/dist/constants.d.ts +45 -0
  62. package/dist/constants.d.ts.map +1 -0
  63. package/dist/constants.js +29 -0
  64. package/dist/constants.js.map +1 -0
  65. package/dist/index.d.ts +8 -0
  66. package/dist/index.d.ts.map +1 -0
  67. package/dist/index.js +37 -0
  68. package/dist/index.js.map +1 -0
  69. package/dist/model/adapter.d.ts +8 -0
  70. package/dist/model/adapter.d.ts.map +1 -0
  71. package/dist/model/adapter.js +17 -0
  72. package/dist/model/adapter.js.map +1 -0
  73. package/dist/model/componentStore.d.ts +11 -0
  74. package/dist/model/componentStore.d.ts.map +1 -0
  75. package/dist/model/componentStore.js +26 -0
  76. package/dist/model/componentStore.js.map +1 -0
  77. package/dist/model/index.d.ts +5 -0
  78. package/dist/model/index.d.ts.map +1 -0
  79. package/dist/model/index.js +21 -0
  80. package/dist/model/index.js.map +1 -0
  81. package/dist/model/plugins.d.ts +13 -0
  82. package/dist/model/plugins.d.ts.map +1 -0
  83. package/dist/model/plugins.js +29 -0
  84. package/dist/model/plugins.js.map +1 -0
  85. package/dist/model/ui.d.ts +19 -0
  86. package/dist/model/ui.d.ts.map +1 -0
  87. package/dist/model/ui.js +16 -0
  88. package/dist/model/ui.js.map +1 -0
  89. package/dist/styling/index.d.ts +3 -0
  90. package/dist/styling/index.d.ts.map +1 -0
  91. package/dist/styling/index.js +10 -0
  92. package/dist/styling/index.js.map +1 -0
  93. package/dist/styling/stylable.d.ts +10 -0
  94. package/dist/styling/stylable.d.ts.map +1 -0
  95. package/dist/styling/stylable.js +43 -0
  96. package/dist/styling/stylable.js.map +1 -0
  97. package/dist/styling/styleManager.d.ts +20 -0
  98. package/dist/styling/styleManager.d.ts.map +1 -0
  99. package/dist/styling/styleManager.js +126 -0
  100. package/dist/styling/styleManager.js.map +1 -0
  101. package/dist/themes.d.ts +7 -0
  102. package/dist/themes.d.ts.map +1 -0
  103. package/dist/themes.js +163 -0
  104. package/dist/themes.js.map +1 -0
  105. package/dist/types.d.ts +48 -0
  106. package/dist/types.d.ts.map +1 -0
  107. package/dist/types.js +14 -0
  108. package/dist/types.js.map +1 -0
  109. package/dist/ui/accordion.d.ts +12 -0
  110. package/dist/ui/accordion.d.ts.map +1 -0
  111. package/dist/ui/accordion.js +94 -0
  112. package/dist/ui/accordion.js.map +1 -0
  113. package/dist/ui/alert.d.ts +15 -0
  114. package/dist/ui/alert.d.ts.map +1 -0
  115. package/dist/ui/alert.js +106 -0
  116. package/dist/ui/alert.js.map +1 -0
  117. package/dist/ui/attributeTable.d.ts +8 -0
  118. package/dist/ui/attributeTable.d.ts.map +1 -0
  119. package/dist/ui/attributeTable.js +39 -0
  120. package/dist/ui/attributeTable.js.map +1 -0
  121. package/dist/ui/baseElement.d.ts +7 -0
  122. package/dist/ui/baseElement.d.ts.map +1 -0
  123. package/dist/ui/baseElement.js +15 -0
  124. package/dist/ui/baseElement.js.map +1 -0
  125. package/dist/ui/button.d.ts +20 -0
  126. package/dist/ui/button.d.ts.map +1 -0
  127. package/dist/ui/button.js +98 -0
  128. package/dist/ui/button.js.map +1 -0
  129. package/dist/ui/button.style.d.ts +2 -0
  130. package/dist/ui/button.style.d.ts.map +1 -0
  131. package/dist/ui/button.style.js +72 -0
  132. package/dist/ui/button.style.js.map +1 -0
  133. package/dist/ui/checkbox.d.ts +14 -0
  134. package/dist/ui/checkbox.d.ts.map +1 -0
  135. package/dist/ui/checkbox.js +59 -0
  136. package/dist/ui/checkbox.js.map +1 -0
  137. package/dist/ui/colorpicker.d.ts +15 -0
  138. package/dist/ui/colorpicker.d.ts.map +1 -0
  139. package/dist/ui/colorpicker.js +160 -0
  140. package/dist/ui/colorpicker.js.map +1 -0
  141. package/dist/ui/container.d.ts +26 -0
  142. package/dist/ui/container.d.ts.map +1 -0
  143. package/dist/ui/container.js +240 -0
  144. package/dist/ui/container.js.map +1 -0
  145. package/dist/ui/dropdown.d.ts +32 -0
  146. package/dist/ui/dropdown.d.ts.map +1 -0
  147. package/dist/ui/dropdown.js +197 -0
  148. package/dist/ui/dropdown.js.map +1 -0
  149. package/dist/ui/dropdownMenu.d.ts +12 -0
  150. package/dist/ui/dropdownMenu.d.ts.map +1 -0
  151. package/dist/ui/dropdownMenu.js +58 -0
  152. package/dist/ui/dropdownMenu.js.map +1 -0
  153. package/dist/ui/expander.d.ts +28 -0
  154. package/dist/ui/expander.d.ts.map +1 -0
  155. package/dist/ui/expander.js +151 -0
  156. package/dist/ui/expander.js.map +1 -0
  157. package/dist/ui/icon.d.ts +24 -0
  158. package/dist/ui/icon.d.ts.map +1 -0
  159. package/dist/ui/icon.js +77 -0
  160. package/dist/ui/icon.js.map +1 -0
  161. package/dist/ui/images.d.ts +2 -0
  162. package/dist/ui/images.d.ts.map +1 -0
  163. package/dist/ui/images.js +17 -0
  164. package/dist/ui/images.js.map +1 -0
  165. package/dist/ui/index.d.ts +25 -0
  166. package/dist/ui/index.d.ts.map +1 -0
  167. package/dist/ui/index.js +41 -0
  168. package/dist/ui/index.js.map +1 -0
  169. package/dist/ui/input.d.ts +11 -0
  170. package/dist/ui/input.d.ts.map +1 -0
  171. package/dist/ui/input.js +67 -0
  172. package/dist/ui/input.js.map +1 -0
  173. package/dist/ui/list.d.ts +67 -0
  174. package/dist/ui/list.d.ts.map +1 -0
  175. package/dist/ui/list.js +362 -0
  176. package/dist/ui/list.js.map +1 -0
  177. package/dist/ui/loader.d.ts +9 -0
  178. package/dist/ui/loader.d.ts.map +1 -0
  179. package/dist/ui/loader.js +40 -0
  180. package/dist/ui/loader.js.map +1 -0
  181. package/dist/ui/menu.d.ts +36 -0
  182. package/dist/ui/menu.d.ts.map +1 -0
  183. package/dist/ui/menu.js +154 -0
  184. package/dist/ui/menu.js.map +1 -0
  185. package/dist/ui/menu.style.d.ts +3 -0
  186. package/dist/ui/menu.style.d.ts.map +1 -0
  187. package/dist/ui/menu.style.js +45 -0
  188. package/dist/ui/menu.style.js.map +1 -0
  189. package/dist/ui/overlay.d.ts +17 -0
  190. package/dist/ui/overlay.d.ts.map +1 -0
  191. package/dist/ui/overlay.js +95 -0
  192. package/dist/ui/overlay.js.map +1 -0
  193. package/dist/ui/overlay.style.d.ts +2 -0
  194. package/dist/ui/overlay.style.d.ts.map +1 -0
  195. package/dist/ui/overlay.style.js +49 -0
  196. package/dist/ui/overlay.style.js.map +1 -0
  197. package/dist/ui/panel.d.ts +24 -0
  198. package/dist/ui/panel.d.ts.map +1 -0
  199. package/dist/ui/panel.js +131 -0
  200. package/dist/ui/panel.js.map +1 -0
  201. package/dist/ui/panel.style.d.ts +2 -0
  202. package/dist/ui/panel.style.d.ts.map +1 -0
  203. package/dist/ui/panel.style.js +66 -0
  204. package/dist/ui/panel.style.js.map +1 -0
  205. package/dist/ui/sizer.d.ts +44 -0
  206. package/dist/ui/sizer.d.ts.map +1 -0
  207. package/dist/ui/sizer.js +216 -0
  208. package/dist/ui/sizer.js.map +1 -0
  209. package/dist/ui/slider.d.ts +41 -0
  210. package/dist/ui/slider.d.ts.map +1 -0
  211. package/dist/ui/slider.js +228 -0
  212. package/dist/ui/slider.js.map +1 -0
  213. package/dist/ui/sortableList.d.ts +33 -0
  214. package/dist/ui/sortableList.d.ts.map +1 -0
  215. package/dist/ui/sortableList.js +159 -0
  216. package/dist/ui/sortableList.js.map +1 -0
  217. package/dist/ui/splitContainer.d.ts +37 -0
  218. package/dist/ui/splitContainer.d.ts.map +1 -0
  219. package/dist/ui/splitContainer.js +201 -0
  220. package/dist/ui/splitContainer.js.map +1 -0
  221. package/dist/ui/splitContainer.style.d.ts +2 -0
  222. package/dist/ui/splitContainer.style.d.ts.map +1 -0
  223. package/dist/ui/splitContainer.style.js +46 -0
  224. package/dist/ui/splitContainer.style.js.map +1 -0
  225. package/dist/ui/tooltip.d.ts +23 -0
  226. package/dist/ui/tooltip.d.ts.map +1 -0
  227. package/dist/ui/tooltip.js +163 -0
  228. package/dist/ui/tooltip.js.map +1 -0
  229. package/dist/ui/tooltip.style.d.ts +2 -0
  230. package/dist/ui/tooltip.style.d.ts.map +1 -0
  231. package/dist/ui/tooltip.style.js +114 -0
  232. package/dist/ui/tooltip.style.js.map +1 -0
  233. package/package.json +60 -0
@@ -0,0 +1,362 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ 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;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || function (mod) {
25
+ if (mod && mod.__esModule) return mod;
26
+ var result = {};
27
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
28
+ __setModuleDefault(result, mod);
29
+ return result;
30
+ };
31
+ var __importDefault = (this && this.__importDefault) || function (mod) {
32
+ return (mod && mod.__esModule) ? mod : { "default": mod };
33
+ };
34
+ Object.defineProperty(exports, "__esModule", { value: true });
35
+ exports.List = exports.ListPointerEvent = exports.ListSelectEvent = exports.ListSelectTrigger = void 0;
36
+ const dom = __importStar(require("../common/dom"));
37
+ const utils_1 = require("../common/utils");
38
+ const constants_1 = __importDefault(require("../constants"));
39
+ const lit_1 = require("lit");
40
+ const decorators_js_1 = require("lit/decorators.js");
41
+ const ref_js_1 = require("lit/directives/ref.js");
42
+ const styling_1 = require("../styling");
43
+ const baseElement_1 = require("./baseElement");
44
+ var ListSelectTrigger;
45
+ (function (ListSelectTrigger) {
46
+ ListSelectTrigger["Enter"] = "enter";
47
+ ListSelectTrigger["Click"] = "click";
48
+ ListSelectTrigger["Arrow"] = "arrow";
49
+ })(ListSelectTrigger || (exports.ListSelectTrigger = ListSelectTrigger = {}));
50
+ class ListSelectEvent extends Event {
51
+ constructor(type, trigger, index, elm) {
52
+ super(type, { bubbles: true, composed: true });
53
+ this.trigger = trigger;
54
+ this.index = index;
55
+ this.elm = elm;
56
+ }
57
+ }
58
+ exports.ListSelectEvent = ListSelectEvent;
59
+ class ListPointerEvent extends PointerEvent {
60
+ constructor(type, e, args) {
61
+ super(`list.${type}`, e);
62
+ Object.assign(this, args);
63
+ }
64
+ }
65
+ exports.ListPointerEvent = ListPointerEvent;
66
+ let List = class List extends lit_1.LitElement {
67
+ get selectedIndex() { return this._selectedIndex; }
68
+ set selectedIndex(value) { this._selectedIndex = value; }
69
+ get offset() { return this._offset; }
70
+ set offset(value) {
71
+ this._offset = value;
72
+ this.requestRender();
73
+ }
74
+ get container() { return this.containerRef.value; }
75
+ connectedCallback() {
76
+ super.connectedCallback();
77
+ this.tabIndex = 0;
78
+ }
79
+ constructor() {
80
+ super();
81
+ this._selectedIndex = -1;
82
+ this.itemHeight = constants_1.default.LIST_ITEM_HEIGHT;
83
+ this.lineHeight = null;
84
+ this.selectable = true;
85
+ this.nativeHeight = false;
86
+ this.arrowEvents = false;
87
+ this.disableSelect = false;
88
+ this.maxHeight = null;
89
+ this.items = new Map();
90
+ this.containerRef = (0, ref_js_1.createRef)();
91
+ this.scrollContainerRef = (0, ref_js_1.createRef)();
92
+ this.itemContainerRef = (0, ref_js_1.createRef)();
93
+ this.scrolling = false;
94
+ this.renderEvent = new baseElement_1.ComponentEvent('render', { bubbles: true, composed: true });
95
+ this._offset = 0;
96
+ this.keyActions = {
97
+ 'ArrowUp': () => this.moveUp(),
98
+ 'PageUp': () => this.moveUp(this.pageSize),
99
+ 'ArrowDown': () => this.moveDown(),
100
+ 'PageDown': () => this.moveDown(this.pageSize),
101
+ 'Enter': () => this._selectedIndex > -1 ? this.select(this._selectedIndex, ListSelectTrigger.Enter) : null,
102
+ };
103
+ this.render = () => (0, lit_1.html) `
104
+ <og-container ${(0, ref_js_1.ref)(this.containerRef)}>
105
+ <div slot="content" style="position: relative; height: ${this.size * this.itemHeight}px" ${(0, ref_js_1.ref)(this.scrollContainerRef)}>
106
+ <style>${Object.getPrototypeOf(this).constructor.contentStyles}</style>
107
+ ${this.customStyle ? (0, lit_1.html) `<style>${this.customStyle}</style>` : ``}
108
+ <div class="item-container" ${(0, ref_js_1.ref)(this.itemContainerRef)}></div>
109
+ </div>
110
+ </og-container>
111
+ `;
112
+ }
113
+ get pageSize() {
114
+ return Math.floor(this.containerRef.value.offsetHeight / this.itemHeight);
115
+ }
116
+ get calculatedHeight() {
117
+ var _a, _b, _c;
118
+ return Math.min((_a = this.maxHeight) !== null && _a !== void 0 ? _a : ((_c = (_b = this.parentElement) === null || _b === void 0 ? void 0 : _b.clientHeight) !== null && _c !== void 0 ? _c : 0), this.itemHeight * this.size);
119
+ }
120
+ reset() {
121
+ this.items.clear();
122
+ this.offset = 0;
123
+ }
124
+ scrollToOffset(offset) {
125
+ this.containerRef.value.scrollVerticalTo(offset);
126
+ this.offset = offset;
127
+ }
128
+ scrollToView(item) {
129
+ if (!item || dom.getElementOffset(item, this.containerRef.value).top < 0) {
130
+ const scrollTo = this._selectedIndex == this.size - 1 ? (((this._selectedIndex + 1) * this.itemHeight) - this.containerRef.value.clientHeight) : (this._selectedIndex * this.itemHeight);
131
+ this.containerRef.value.scrollVerticalTo(scrollTo);
132
+ this.offset = scrollTo;
133
+ }
134
+ else if (dom.getElementOffset(item, this.containerRef.value).top + this.itemHeight > this.containerRef.value.offsetHeight) {
135
+ const scrollTo = this._selectedIndex == 0 ? 0 : ((this._selectedIndex + 1) * this.itemHeight) - this.containerRef.value.clientHeight;
136
+ this.containerRef.value.scrollVerticalTo(scrollTo);
137
+ this.offset = scrollTo;
138
+ }
139
+ }
140
+ moveUp(count = 1) {
141
+ var _a;
142
+ if (this.size == 0)
143
+ return;
144
+ this._selectedIndex = (_a = this._selectedIndex) !== null && _a !== void 0 ? _a : 0;
145
+ this.select(this._selectedIndex - count, ListSelectTrigger.Arrow);
146
+ this.scrollToView(this.items.get(this._selectedIndex));
147
+ }
148
+ moveDown(count = 1) {
149
+ var _a;
150
+ if (this.size == 0)
151
+ return;
152
+ this._selectedIndex = (_a = this._selectedIndex) !== null && _a !== void 0 ? _a : 0;
153
+ this.select(this._selectedIndex + count, ListSelectTrigger.Arrow);
154
+ this.scrollToView(this.items.get(this._selectedIndex));
155
+ }
156
+ deselect() {
157
+ if (this._selectedIndex >= 0) {
158
+ if (this.items.has(this._selectedIndex)) {
159
+ this.items.get(this._selectedIndex).classList.remove('selected');
160
+ }
161
+ }
162
+ this._selectedIndex = -1;
163
+ }
164
+ select(index, trigger = null, elm = null) {
165
+ this.deselect();
166
+ index = index >= this.size ? 0 : index;
167
+ index = index < 0 ? this.size - 1 : index;
168
+ if (this.items.has(index)) {
169
+ this.getItem(index).classList.add('selected');
170
+ }
171
+ this._selectedIndex = index;
172
+ if (trigger && (trigger != ListSelectTrigger.Arrow || this.arrowEvents)) {
173
+ this.dispatchEvent(new ListSelectEvent('select', trigger, index, elm)); // TODO - remove
174
+ this.dispatchEvent(new ListSelectEvent('list.select', trigger, index, elm));
175
+ }
176
+ }
177
+ getItem(index) {
178
+ var _a;
179
+ if (!this.items.has(index)) {
180
+ const div = dom.createElement('div');
181
+ div.dataset.index = index.toString();
182
+ dom.setClasses(div, ['item', index == this._selectedIndex ? 'selected' : null]);
183
+ dom.setSize(div, { h: this.itemHeight });
184
+ div.style.lineHeight = dom.numToPixels((_a = this.lineHeight) !== null && _a !== void 0 ? _a : this.itemHeight);
185
+ if (this.itemRenderer) {
186
+ const result = this.itemRenderer(div, index);
187
+ if ((0, utils_1.isString)(result)) {
188
+ div.innerHTML = result;
189
+ }
190
+ else if (result) {
191
+ dom.empty(div);
192
+ (0, lit_1.render)(result, div);
193
+ }
194
+ }
195
+ else {
196
+ div.innerHTML = `item-${index}`;
197
+ }
198
+ this.items.set(index, div);
199
+ }
200
+ return this.items.get(index);
201
+ }
202
+ firstUpdated() {
203
+ this.addEventListener('keydown', e => {
204
+ if (this.disableSelect)
205
+ return;
206
+ const action = this.keyActions[e.key];
207
+ if (action)
208
+ action();
209
+ });
210
+ this.container.addEventListener('verticalscroll', (e) => {
211
+ this.offset = e.value;
212
+ });
213
+ dom.on(this.container, 'mousedown', '.item', (e, elm) => {
214
+ if (this.disableSelect)
215
+ return;
216
+ if (!this.container.isScrolling && e.button == 0 && elm.parentElement == this.itemContainerRef.value) {
217
+ const tabIndex = e.target.tabIndex;
218
+ if (tabIndex == null || tabIndex < 0) {
219
+ e.preventDefault(); // prevents from stealing focus from another element in select event
220
+ this.focus(); // default focus is on list
221
+ }
222
+ this.select(parseInt(elm.dataset.index), ListSelectTrigger.Click, e.target);
223
+ }
224
+ });
225
+ dom.on(this.container, 'contextmenu', '.item', (e, elm) => {
226
+ this.dispatchEvent(new ListPointerEvent('menu', e, { list: this, index: parseInt(elm.dataset.index) }));
227
+ });
228
+ }
229
+ willUpdate(changedProps) {
230
+ var _a;
231
+ if (changedProps.has('size') && this.offset >= this.size * this.itemHeight) {
232
+ this._offset = 0;
233
+ (_a = this.container) === null || _a === void 0 ? void 0 : _a.scrollVerticalTo(0);
234
+ }
235
+ if (!this.nativeHeight) {
236
+ dom.setSize(this, { h: this.calculatedHeight });
237
+ }
238
+ }
239
+ updated() {
240
+ this.items.clear();
241
+ this.renderItems(true);
242
+ }
243
+ requestRender() {
244
+ if (!this.scrolling) {
245
+ window.requestAnimationFrame(() => {
246
+ this.renderItems();
247
+ this.scrolling = false;
248
+ });
249
+ this.scrolling = true;
250
+ }
251
+ }
252
+ renderItems(all = false) {
253
+ if (all)
254
+ this.items.clear();
255
+ const itemContainer = this.itemContainerRef.value;
256
+ if (!itemContainer)
257
+ return;
258
+ // min visible index
259
+ const minIndex1 = Math.floor(this.offset / this.itemHeight);
260
+ // min rendered index
261
+ const minIndex2 = Math.max(0, minIndex1 - constants_1.default.LIST_RENDERING_TRESHOLD);
262
+ // max visible index
263
+ const maxIndex1 = minIndex1 + Math.ceil(this.clientHeight / this.itemHeight);
264
+ // max rendered index
265
+ const maxIndex2 = Math.min(this.size - 1, maxIndex1 + constants_1.default.LIST_RENDERING_TRESHOLD);
266
+ dom.empty(itemContainer);
267
+ dom.hideElement(itemContainer);
268
+ // delete
269
+ for (const [i, item] of this.items) {
270
+ if (i < minIndex2 || i > maxIndex2) {
271
+ item.remove();
272
+ this.items.delete(i);
273
+ }
274
+ }
275
+ // insert
276
+ for (let i = minIndex2; i <= maxIndex2; i++) {
277
+ itemContainer.appendChild(this.getItem(i));
278
+ }
279
+ dom.setPosition(itemContainer, { t: minIndex2 * this.itemHeight });
280
+ dom.showElement(itemContainer);
281
+ this.dispatchEvent(this.renderEvent);
282
+ }
283
+ updateSliders() {
284
+ var _a;
285
+ (_a = this.containerRef.value) === null || _a === void 0 ? void 0 : _a.updateSliders();
286
+ }
287
+ };
288
+ exports.List = List;
289
+ List.styles = [(0, lit_1.css) `
290
+ * {
291
+ box-sizing: border-box;
292
+ }
293
+
294
+ :host {
295
+ position: relative;
296
+ display: block;
297
+ outline: none;
298
+ }
299
+
300
+ og-container {
301
+ height: 100%;
302
+ }
303
+
304
+ :host(:not([disableSelect])) .item {
305
+ cursor: pointer;
306
+ }
307
+
308
+ :host(:not([disableSelect])) .item:hover {
309
+ background-color: var(--accent-color-alpha-15);
310
+ }
311
+
312
+ .item.selected {
313
+ background-color: var(--accent-color-alpha-30);
314
+ }
315
+
316
+ .item-container {
317
+ position: absolute;
318
+ left: 0;
319
+ width: 100%;
320
+ }
321
+ `];
322
+ List.contentStyles = [(0, lit_1.css) `
323
+ :host {
324
+ font-family: var(--font-family);
325
+ font-size: var(--font-size);
326
+ }
327
+ `];
328
+ __decorate([
329
+ (0, decorators_js_1.property)({ type: Number })
330
+ ], List.prototype, "itemHeight", void 0);
331
+ __decorate([
332
+ (0, decorators_js_1.property)({ type: Number })
333
+ ], List.prototype, "lineHeight", void 0);
334
+ __decorate([
335
+ (0, decorators_js_1.property)({ type: Boolean })
336
+ ], List.prototype, "selectable", void 0);
337
+ __decorate([
338
+ (0, decorators_js_1.property)({ type: Number })
339
+ ], List.prototype, "size", void 0);
340
+ __decorate([
341
+ (0, decorators_js_1.property)({ type: Object })
342
+ ], List.prototype, "customStyle", void 0);
343
+ __decorate([
344
+ (0, decorators_js_1.property)({ type: Boolean })
345
+ ], List.prototype, "nativeHeight", void 0);
346
+ __decorate([
347
+ (0, decorators_js_1.property)({ type: Boolean })
348
+ ], List.prototype, "arrowEvents", void 0);
349
+ __decorate([
350
+ (0, decorators_js_1.property)({ type: Boolean, reflect: true })
351
+ ], List.prototype, "disableSelect", void 0);
352
+ __decorate([
353
+ (0, decorators_js_1.property)({ type: Number })
354
+ ], List.prototype, "maxHeight", void 0);
355
+ __decorate([
356
+ (0, decorators_js_1.property)()
357
+ ], List.prototype, "itemRenderer", void 0);
358
+ exports.List = List = __decorate([
359
+ (0, decorators_js_1.customElement)('og-list'),
360
+ (0, styling_1.stylable)({ vars: ['font-*', 'accent-*'] })
361
+ ], List);
362
+ //# sourceMappingURL=list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list.js","sourceRoot":"","sources":["../../src/ui/list.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import { LitElement } from 'lit';
2
+ export declare class Loader extends LitElement {
3
+ static styles: import("lit").CSSResult;
4
+ icon: string;
5
+ color: string;
6
+ size: '' | 'lg' | 'xs' | 'sm' | '1x' | '2x' | '3x' | '4x' | '5x' | '6x' | '7x' | '8x' | '9x' | '10x' | null;
7
+ render: () => import("lit-html").TemplateResult<1>;
8
+ }
9
+ //# sourceMappingURL=loader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/ui/loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAC;AAG5C,qBACa,MAAO,SAAQ,UAAU;IAErC,MAAM,CAAC,MAAM,0BAIX;IAGF,IAAI,SAAa;IAGjB,KAAK,EAAE,MAAM,CAAC;IAGd,IAAI,EAAE,EAAE,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,IAAI,GAAC,KAAK,GAAC,IAAI,CAAQ;IAEvF,MAAM,6CAEJ;CAEF"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.Loader = void 0;
10
+ const lit_1 = require("lit");
11
+ const decorators_js_1 = require("lit/decorators.js");
12
+ let Loader = class Loader extends lit_1.LitElement {
13
+ constructor() {
14
+ super(...arguments);
15
+ this.icon = "spinner";
16
+ this.size = 'lg';
17
+ this.render = () => (0, lit_1.html) `
18
+ <og-fa-icon .icon="${this.icon}" .size="${this.size}" spin></og-fa-icon>
19
+ `;
20
+ }
21
+ };
22
+ exports.Loader = Loader;
23
+ Loader.styles = (0, lit_1.css) `
24
+ :host {
25
+ display: block;
26
+ }
27
+ `;
28
+ __decorate([
29
+ (0, decorators_js_1.property)({ type: String, reflect: true })
30
+ ], Loader.prototype, "icon", void 0);
31
+ __decorate([
32
+ (0, decorators_js_1.property)({ type: String, reflect: true })
33
+ ], Loader.prototype, "color", void 0);
34
+ __decorate([
35
+ (0, decorators_js_1.property)({ type: String, reflect: true })
36
+ ], Loader.prototype, "size", void 0);
37
+ exports.Loader = Loader = __decorate([
38
+ (0, decorators_js_1.customElement)(`og-loader`)
39
+ ], Loader);
40
+ //# sourceMappingURL=loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/ui/loader.ts"],"names":[],"mappings":";;;;;;;;;AAAA,6BAA4C;AAC5C,qDAA4D;AAGrD,IAAM,MAAM,GAAZ,MAAM,MAAO,SAAQ,gBAAU;IAA/B;;QASN,SAAI,GAAG,SAAS,CAAC;QAMjB,SAAI,GAA8E,IAAI,CAAC;QAEvF,WAAM,GAAG,GAAG,EAAE,CAAC,IAAA,UAAI,EAAA;uBACG,IAAI,CAAC,IAAI,YAAY,IAAI,CAAC,IAAI;EACnD,CAAC;IAEH,CAAC;;AArBY,wBAAM;AAEX,aAAM,GAAG,IAAA,SAAG,EAAA;;;;EAIlB,AAJY,CAIX;AAGF;IADC,IAAA,wBAAQ,EAAC,EAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC;oCACvB;AAGjB;IADC,IAAA,wBAAQ,EAAC,EAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC;qCAC1B;AAGd;IADC,IAAA,wBAAQ,EAAC,EAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC;oCAC+C;iBAf3E,MAAM;IADlB,IAAA,6BAAa,EAAC,WAAW,CAAC;GACd,MAAM,CAqBlB"}
@@ -0,0 +1,36 @@
1
+ import { LitElement } from 'lit';
2
+ import { List, ListSelectEvent } from './list';
3
+ import { IconSpec } from './icon';
4
+ export type MenuItem = {
5
+ key?: number | string;
6
+ value: string;
7
+ icon?: IconSpec | string;
8
+ color?: string;
9
+ divider?: boolean;
10
+ exec?: (item: MenuItem) => void;
11
+ };
12
+ export declare class MenuEvent extends Event {
13
+ readonly item: MenuItem;
14
+ constructor(type: string, item: MenuItem);
15
+ }
16
+ export type MenuPosition = 'right' | 'left';
17
+ export declare class Menu extends LitElement {
18
+ static styles: import("lit").CSSResult[];
19
+ items: MenuItem[];
20
+ dynamicWidth: boolean;
21
+ list: List;
22
+ private _hasIcons;
23
+ private _autoHide;
24
+ willUpdate(changedProps: Map<PropertyKey, unknown>): void;
25
+ updated(changedProps: Map<PropertyKey, unknown>): void;
26
+ updateWidth(): Promise<void>;
27
+ constructor();
28
+ connectedCallback(): void;
29
+ itemRenderer: (div: HTMLDivElement, index: number) => import("lit-html").TemplateResult<1>;
30
+ open(elm: HTMLElement, position?: MenuPosition): Promise<void>;
31
+ openAt(x: number, y: number): Promise<void>;
32
+ _onRender: () => void;
33
+ _onSelect: (e: ListSelectEvent) => void;
34
+ render: () => import("lit-html").TemplateResult<1>;
35
+ }
36
+ //# 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,EAAE,UAAU,EAAQ,MAAM,KAAK,CAAC;AAKvC,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAG/C,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,MAAM,MAAM,QAAQ,GAAG;IACtB,GAAG,CAAC,EAAE,MAAM,GAAC,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,QAAQ,GAAC,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,KAAK,IAAI,CAAC;CAChC,CAAC;AAEF,qBAAa,SAAU,SAAQ,KAAK;aAGlB,IAAI,EAAE,QAAQ;gBAD9B,IAAI,EAAE,MAAM,EACI,IAAI,EAAE,QAAQ;CAI/B;AAED,MAAM,MAAM,YAAY,GAAG,OAAO,GAAC,MAAM,CAAC;AAE1C,qBAEa,IAAK,SAAQ,UAAU;IAEnC,MAAM,CAAC,MAAM,4BAAW;IAGxB,KAAK,EAAE,QAAQ,EAAE,CAAC;IAGlB,YAAY,UAAS;IAGrB,IAAI,EAAE,IAAI,CAAC;IAEX,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,SAAS,CAAS;IAE1B,UAAU,CAAC,YAAY,EAAE,GAAG,CAAC,WAAW,EAAE,OAAO,CAAC;IAMlD,OAAO,CAAC,YAAY,EAAE,GAAG,CAAC,WAAW,EAAE,OAAO,CAAC;IAMzC,WAAW;;IAkBjB,iBAAiB;IAKjB,YAAY,QAAS,cAAc,SAAS,MAAM,0CAiBjD;IAEK,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,QAAQ,GAAE,YAAqB;IAmBtD,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAiBjC,SAAS,aAER;IAED,SAAS,MAAO,eAAe,UAK9B;IAED,MAAM,6CAWJ;CAEF"}
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __importDefault = (this && this.__importDefault) || function (mod) {
9
+ return (mod && mod.__esModule) ? mod : { "default": mod };
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.Menu = exports.MenuEvent = void 0;
13
+ const lit_1 = require("lit");
14
+ const decorators_js_1 = require("lit/decorators.js");
15
+ const styling_1 = require("../styling");
16
+ const constants_1 = __importDefault(require("../constants"));
17
+ const dom_1 = require("../common/dom");
18
+ const localize_1 = require("@lit/localize");
19
+ const menu_style_1 = require("./menu.style");
20
+ class MenuEvent extends Event {
21
+ constructor(type, item) {
22
+ super(`menu.${type}`, { bubbles: true, composed: true });
23
+ this.item = item;
24
+ }
25
+ }
26
+ exports.MenuEvent = MenuEvent;
27
+ let Menu = class Menu extends lit_1.LitElement {
28
+ willUpdate(changedProps) {
29
+ if (changedProps.has('items')) {
30
+ this._hasIcons = this.items.findIndex(item => !!item.icon) > -1;
31
+ }
32
+ }
33
+ updated(changedProps) {
34
+ if (changedProps.has('items')) {
35
+ this.list.reset();
36
+ }
37
+ }
38
+ async updateWidth() {
39
+ await this.list.updateComplete;
40
+ let maxWidth = 0;
41
+ this.list.items.forEach(item => {
42
+ let w = 0;
43
+ for (const ch of item.children)
44
+ w += ch.offsetWidth;
45
+ maxWidth = Math.max(maxWidth, w);
46
+ });
47
+ (0, dom_1.setSize)(this, { w: maxWidth > 0 ? maxWidth : 100 });
48
+ }
49
+ constructor() {
50
+ super();
51
+ this.dynamicWidth = false;
52
+ this._hasIcons = false;
53
+ this._autoHide = false;
54
+ this.itemRenderer = (div, index) => {
55
+ const item = this.items[index];
56
+ div.classList.toggle('divider', !!item.divider);
57
+ if (item.divider) {
58
+ (0, dom_1.setSize)(div, { h: constants_1.default.MENU_ITEM_HEIGHT - 1 });
59
+ }
60
+ div.style.color = item.color ? item.color : 'inherit';
61
+ return (0, lit_1.html) `
62
+ ${this._hasIcons ? (0, lit_1.html) `
63
+ <div class="icon">
64
+ ${item.icon ? (0, lit_1.html) `<og-icon .icon="${item.icon}"></og-icon>` : ``}
65
+ </div>
66
+ ` : ``}
67
+ <div class="text">${(0, localize_1.msg)(item.value)}</div>
68
+ `;
69
+ };
70
+ this._onRender = () => {
71
+ this.updateWidth();
72
+ };
73
+ this._onSelect = (e) => {
74
+ if (this._autoHide)
75
+ (0, dom_1.hideElement)(this);
76
+ const item = this.items[e.index];
77
+ if (item.exec)
78
+ item.exec(item);
79
+ this.dispatchEvent(new MenuEvent('select', item));
80
+ };
81
+ this.render = () => {
82
+ var _a, _b;
83
+ return (0, lit_1.html) `
84
+ <og-list
85
+ ?dynamicWidth="${true}"
86
+ maxHeight="200"
87
+ itemHeight="${constants_1.default.MENU_ITEM_HEIGHT}"
88
+ size="${(_b = (_a = this.items) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0}"
89
+ .itemRenderer="${this.itemRenderer}"
90
+ .customStyle=${menu_style_1.itemStyle},
91
+ @render=${this._onRender}
92
+ @select=${this._onSelect}>
93
+ </og-list>
94
+ `;
95
+ };
96
+ this.addEventListener('contextmenu', e => e.preventDefault());
97
+ this.addEventListener('focus', () => setTimeout(() => this.list.focus(), 100));
98
+ }
99
+ connectedCallback() {
100
+ super.connectedCallback();
101
+ this.tabIndex = 0;
102
+ }
103
+ async open(elm, position = 'left') {
104
+ this._autoHide = true;
105
+ if (this.parentElement != document.body)
106
+ document.body.appendChild(this);
107
+ (0, dom_1.showElement)(this);
108
+ await this.updateWidth();
109
+ const offset = (0, dom_1.getElementOffset)(elm, this.parentElement);
110
+ const pos = (0, dom_1.fixPosition)({
111
+ x: position == 'left' ? offset.left : (offset.left + elm.offsetWidth - this.offsetWidth),
112
+ y: offset.top + elm.offsetHeight,
113
+ w: this.offsetWidth,
114
+ h: this.offsetHeight
115
+ }, document.body);
116
+ (0, dom_1.setPosition)(this, { t: pos.y, l: pos.x });
117
+ this.list.select(0);
118
+ this.list.focus();
119
+ document.body.addEventListener('mouseup', () => (0, dom_1.hideElement)(this), { once: true });
120
+ }
121
+ async openAt(x, y) {
122
+ this._autoHide = true;
123
+ if (this.parentElement != document.body)
124
+ document.body.appendChild(this);
125
+ (0, dom_1.showElement)(this);
126
+ await this.updateWidth();
127
+ const pos = (0, dom_1.fixPosition)({
128
+ x: x,
129
+ y: y,
130
+ w: this.offsetWidth,
131
+ h: this.offsetHeight
132
+ }, document.body);
133
+ (0, dom_1.setPosition)(this, { t: pos.y, l: pos.x });
134
+ this.list.select(0);
135
+ this.list.focus();
136
+ document.body.addEventListener('mouseup', () => (0, dom_1.hideElement)(this), { once: true });
137
+ }
138
+ };
139
+ exports.Menu = Menu;
140
+ Menu.styles = [menu_style_1.style];
141
+ __decorate([
142
+ (0, decorators_js_1.property)({ type: Array })
143
+ ], Menu.prototype, "items", void 0);
144
+ __decorate([
145
+ (0, decorators_js_1.property)({ type: Boolean })
146
+ ], Menu.prototype, "dynamicWidth", void 0);
147
+ __decorate([
148
+ (0, decorators_js_1.query)('og-list')
149
+ ], Menu.prototype, "list", void 0);
150
+ exports.Menu = Menu = __decorate([
151
+ (0, decorators_js_1.customElement)(`og-menu`),
152
+ (0, styling_1.stylable)({ vars: ['font-*', 'accent-color', 'background-color', 'text-color'] })
153
+ ], Menu);
154
+ //# sourceMappingURL=menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.js","sourceRoot":"","sources":["../../src/ui/menu.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare const itemStyle: import("lit").CSSResult;
2
+ export declare const style: import("lit").CSSResult;
3
+ //# sourceMappingURL=menu.style.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.style.d.ts","sourceRoot":"","sources":["../../src/ui/menu.style.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,SAAS,yBA0BrB,CAAC;AAEF,eAAO,MAAM,KAAK,yBAQjB,CAAC"}