@omegagrid/core 0.10.1 → 0.10.2

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 (317) hide show
  1. package/package.json +2 -2
  2. package/dist/common/actions.d.ts +0 -16
  3. package/dist/common/actions.d.ts.map +0 -1
  4. package/dist/common/actions.js +0 -14
  5. package/dist/common/actions.js.map +0 -1
  6. package/dist/common/colors.d.ts +0 -39
  7. package/dist/common/colors.d.ts.map +0 -1
  8. package/dist/common/colors.js +0 -59
  9. package/dist/common/colors.js.map +0 -1
  10. package/dist/common/csv.d.ts +0 -23
  11. package/dist/common/csv.d.ts.map +0 -1
  12. package/dist/common/csv.js +0 -93
  13. package/dist/common/csv.js.map +0 -1
  14. package/dist/common/dates.d.ts +0 -32
  15. package/dist/common/dates.d.ts.map +0 -1
  16. package/dist/common/dates.js +0 -172
  17. package/dist/common/dates.js.map +0 -1
  18. package/dist/common/device.d.ts +0 -2
  19. package/dist/common/device.d.ts.map +0 -1
  20. package/dist/common/device.js +0 -13
  21. package/dist/common/device.js.map +0 -1
  22. package/dist/common/dom.d.ts +0 -90
  23. package/dist/common/dom.d.ts.map +0 -1
  24. package/dist/common/dom.js +0 -308
  25. package/dist/common/dom.js.map +0 -1
  26. package/dist/common/events.d.ts +0 -15
  27. package/dist/common/events.d.ts.map +0 -1
  28. package/dist/common/events.js +0 -33
  29. package/dist/common/events.js.map +0 -1
  30. package/dist/common/html.d.ts +0 -3
  31. package/dist/common/html.d.ts.map +0 -1
  32. package/dist/common/html.js +0 -25
  33. package/dist/common/html.js.map +0 -1
  34. package/dist/common/index.d.ts +0 -19
  35. package/dist/common/index.d.ts.map +0 -1
  36. package/dist/common/index.js +0 -19
  37. package/dist/common/index.js.map +0 -1
  38. package/dist/common/linkedList.d.ts +0 -24
  39. package/dist/common/linkedList.d.ts.map +0 -1
  40. package/dist/common/linkedList.js +0 -65
  41. package/dist/common/linkedList.js.map +0 -1
  42. package/dist/common/loaders.d.ts +0 -17
  43. package/dist/common/loaders.d.ts.map +0 -1
  44. package/dist/common/loaders.js +0 -54
  45. package/dist/common/loaders.js.map +0 -1
  46. package/dist/common/logger.d.ts +0 -25
  47. package/dist/common/logger.d.ts.map +0 -1
  48. package/dist/common/logger.js +0 -57
  49. package/dist/common/logger.js.map +0 -1
  50. package/dist/common/matrix.d.ts +0 -6
  51. package/dist/common/matrix.d.ts.map +0 -1
  52. package/dist/common/matrix.js +0 -17
  53. package/dist/common/matrix.js.map +0 -1
  54. package/dist/common/numbers.d.ts +0 -26
  55. package/dist/common/numbers.d.ts.map +0 -1
  56. package/dist/common/numbers.js +0 -239
  57. package/dist/common/numbers.js.map +0 -1
  58. package/dist/common/options.d.ts +0 -17
  59. package/dist/common/options.d.ts.map +0 -1
  60. package/dist/common/options.js +0 -29
  61. package/dist/common/options.js.map +0 -1
  62. package/dist/common/paper.d.ts +0 -8
  63. package/dist/common/paper.d.ts.map +0 -1
  64. package/dist/common/paper.js +0 -17
  65. package/dist/common/paper.js.map +0 -1
  66. package/dist/common/shortcutManager.d.ts +0 -17
  67. package/dist/common/shortcutManager.d.ts.map +0 -1
  68. package/dist/common/shortcutManager.js +0 -49
  69. package/dist/common/shortcutManager.js.map +0 -1
  70. package/dist/common/tree.d.ts +0 -87
  71. package/dist/common/tree.d.ts.map +0 -1
  72. package/dist/common/tree.js +0 -204
  73. package/dist/common/tree.js.map +0 -1
  74. package/dist/common/utils.d.ts +0 -30
  75. package/dist/common/utils.d.ts.map +0 -1
  76. package/dist/common/utils.js +0 -136
  77. package/dist/common/utils.js.map +0 -1
  78. package/dist/constants.d.ts +0 -48
  79. package/dist/constants.d.ts.map +0 -1
  80. package/dist/constants.js +0 -24
  81. package/dist/constants.js.map +0 -1
  82. package/dist/index.d.ts +0 -8
  83. package/dist/index.d.ts.map +0 -1
  84. package/dist/index.js +0 -8
  85. package/dist/index.js.map +0 -1
  86. package/dist/model/adapter.d.ts +0 -8
  87. package/dist/model/adapter.d.ts.map +0 -1
  88. package/dist/model/adapter.js +0 -13
  89. package/dist/model/adapter.js.map +0 -1
  90. package/dist/model/component.d.ts +0 -19
  91. package/dist/model/component.d.ts.map +0 -1
  92. package/dist/model/component.js +0 -84
  93. package/dist/model/component.js.map +0 -1
  94. package/dist/model/componentSlice.d.ts +0 -8
  95. package/dist/model/componentSlice.d.ts.map +0 -1
  96. package/dist/model/componentSlice.js +0 -10
  97. package/dist/model/componentSlice.js.map +0 -1
  98. package/dist/model/componentStore.d.ts +0 -12
  99. package/dist/model/componentStore.d.ts.map +0 -1
  100. package/dist/model/componentStore.js +0 -26
  101. package/dist/model/componentStore.js.map +0 -1
  102. package/dist/model/index.d.ts +0 -6
  103. package/dist/model/index.d.ts.map +0 -1
  104. package/dist/model/index.js +0 -6
  105. package/dist/model/index.js.map +0 -1
  106. package/dist/model/plugins.d.ts +0 -13
  107. package/dist/model/plugins.d.ts.map +0 -1
  108. package/dist/model/plugins.js +0 -27
  109. package/dist/model/plugins.js.map +0 -1
  110. package/dist/themes/definitions/tmDark.d.ts +0 -4
  111. package/dist/themes/definitions/tmDark.d.ts.map +0 -1
  112. package/dist/themes/definitions/tmDark.js +0 -83
  113. package/dist/themes/definitions/tmDark.js.map +0 -1
  114. package/dist/themes/definitions/tmLight.d.ts +0 -4
  115. package/dist/themes/definitions/tmLight.d.ts.map +0 -1
  116. package/dist/themes/definitions/tmLight.js +0 -83
  117. package/dist/themes/definitions/tmLight.js.map +0 -1
  118. package/dist/themes/helpers.d.ts +0 -7
  119. package/dist/themes/helpers.d.ts.map +0 -1
  120. package/dist/themes/helpers.js +0 -34
  121. package/dist/themes/helpers.js.map +0 -1
  122. package/dist/themes/index.d.ts +0 -18
  123. package/dist/themes/index.d.ts.map +0 -1
  124. package/dist/themes/index.js +0 -48
  125. package/dist/themes/index.js.map +0 -1
  126. package/dist/themes/mixins.d.ts +0 -10
  127. package/dist/themes/mixins.d.ts.map +0 -1
  128. package/dist/themes/mixins.js +0 -39
  129. package/dist/themes/mixins.js.map +0 -1
  130. package/dist/themes/transformations.d.ts +0 -9
  131. package/dist/themes/transformations.d.ts.map +0 -1
  132. package/dist/themes/transformations.js +0 -48
  133. package/dist/themes/transformations.js.map +0 -1
  134. package/dist/types.d.ts +0 -130
  135. package/dist/types.d.ts.map +0 -1
  136. package/dist/types.js +0 -12
  137. package/dist/types.js.map +0 -1
  138. package/dist/ui/accordion.d.ts +0 -16
  139. package/dist/ui/accordion.d.ts.map +0 -1
  140. package/dist/ui/accordion.js +0 -209
  141. package/dist/ui/accordion.js.map +0 -1
  142. package/dist/ui/alert.d.ts +0 -15
  143. package/dist/ui/alert.d.ts.map +0 -1
  144. package/dist/ui/alert.js +0 -101
  145. package/dist/ui/alert.js.map +0 -1
  146. package/dist/ui/baseElement.d.ts +0 -7
  147. package/dist/ui/baseElement.d.ts.map +0 -1
  148. package/dist/ui/baseElement.js +0 -10
  149. package/dist/ui/baseElement.js.map +0 -1
  150. package/dist/ui/button.d.ts +0 -21
  151. package/dist/ui/button.d.ts.map +0 -1
  152. package/dist/ui/button.js +0 -100
  153. package/dist/ui/button.js.map +0 -1
  154. package/dist/ui/button.style.d.ts +0 -2
  155. package/dist/ui/button.style.d.ts.map +0 -1
  156. package/dist/ui/button.style.js +0 -60
  157. package/dist/ui/button.style.js.map +0 -1
  158. package/dist/ui/checkbox.d.ts +0 -14
  159. package/dist/ui/checkbox.d.ts.map +0 -1
  160. package/dist/ui/checkbox.js +0 -47
  161. package/dist/ui/checkbox.js.map +0 -1
  162. package/dist/ui/close.d.ts +0 -6
  163. package/dist/ui/close.d.ts.map +0 -1
  164. package/dist/ui/close.js +0 -33
  165. package/dist/ui/close.js.map +0 -1
  166. package/dist/ui/colorpicker.d.ts +0 -24
  167. package/dist/ui/colorpicker.d.ts.map +0 -1
  168. package/dist/ui/colorpicker.js +0 -228
  169. package/dist/ui/colorpicker.js.map +0 -1
  170. package/dist/ui/container.d.ts +0 -39
  171. package/dist/ui/container.d.ts.map +0 -1
  172. package/dist/ui/container.js +0 -313
  173. package/dist/ui/container.js.map +0 -1
  174. package/dist/ui/dropdown.d.ts +0 -48
  175. package/dist/ui/dropdown.d.ts.map +0 -1
  176. package/dist/ui/dropdown.js +0 -300
  177. package/dist/ui/dropdown.js.map +0 -1
  178. package/dist/ui/dropdownColorPicker.d.ts +0 -12
  179. package/dist/ui/dropdownColorPicker.d.ts.map +0 -1
  180. package/dist/ui/dropdownColorPicker.js +0 -60
  181. package/dist/ui/dropdownColorPicker.js.map +0 -1
  182. package/dist/ui/dropdownList.d.ts +0 -8
  183. package/dist/ui/dropdownList.d.ts.map +0 -1
  184. package/dist/ui/dropdownList.js +0 -48
  185. package/dist/ui/dropdownList.js.map +0 -1
  186. package/dist/ui/dropdownMenu.d.ts +0 -11
  187. package/dist/ui/dropdownMenu.d.ts.map +0 -1
  188. package/dist/ui/dropdownMenu.js +0 -61
  189. package/dist/ui/dropdownMenu.js.map +0 -1
  190. package/dist/ui/expander.d.ts +0 -28
  191. package/dist/ui/expander.d.ts.map +0 -1
  192. package/dist/ui/expander.js +0 -144
  193. package/dist/ui/expander.js.map +0 -1
  194. package/dist/ui/fileInput.d.ts +0 -24
  195. package/dist/ui/fileInput.d.ts.map +0 -1
  196. package/dist/ui/fileInput.js +0 -130
  197. package/dist/ui/fileInput.js.map +0 -1
  198. package/dist/ui/fileInput.style.d.ts +0 -2
  199. package/dist/ui/fileInput.style.d.ts.map +0 -1
  200. package/dist/ui/fileInput.style.js +0 -73
  201. package/dist/ui/fileInput.style.js.map +0 -1
  202. package/dist/ui/floatingWindow.d.ts +0 -19
  203. package/dist/ui/floatingWindow.d.ts.map +0 -1
  204. package/dist/ui/floatingWindow.js +0 -87
  205. package/dist/ui/floatingWindow.js.map +0 -1
  206. package/dist/ui/icon.d.ts +0 -46
  207. package/dist/ui/icon.d.ts.map +0 -1
  208. package/dist/ui/icon.js +0 -189
  209. package/dist/ui/icon.js.map +0 -1
  210. package/dist/ui/icon.style.d.ts +0 -2
  211. package/dist/ui/icon.style.d.ts.map +0 -1
  212. package/dist/ui/icon.style.js +0 -556
  213. package/dist/ui/icon.style.js.map +0 -1
  214. package/dist/ui/images.d.ts +0 -2
  215. package/dist/ui/images.d.ts.map +0 -1
  216. package/dist/ui/images.js +0 -14
  217. package/dist/ui/images.js.map +0 -1
  218. package/dist/ui/index.d.ts +0 -32
  219. package/dist/ui/index.d.ts.map +0 -1
  220. package/dist/ui/index.js +0 -32
  221. package/dist/ui/index.js.map +0 -1
  222. package/dist/ui/input.d.ts +0 -12
  223. package/dist/ui/input.d.ts.map +0 -1
  224. package/dist/ui/input.js +0 -45
  225. package/dist/ui/input.js.map +0 -1
  226. package/dist/ui/input.style.d.ts +0 -2
  227. package/dist/ui/input.style.d.ts.map +0 -1
  228. package/dist/ui/input.style.js +0 -36
  229. package/dist/ui/input.style.js.map +0 -1
  230. package/dist/ui/label.d.ts +0 -16
  231. package/dist/ui/label.d.ts.map +0 -1
  232. package/dist/ui/label.js +0 -90
  233. package/dist/ui/label.js.map +0 -1
  234. package/dist/ui/list.d.ts +0 -87
  235. package/dist/ui/list.d.ts.map +0 -1
  236. package/dist/ui/list.js +0 -427
  237. package/dist/ui/list.js.map +0 -1
  238. package/dist/ui/list.style.d.ts +0 -2
  239. package/dist/ui/list.style.d.ts.map +0 -1
  240. package/dist/ui/list.style.js +0 -35
  241. package/dist/ui/list.style.js.map +0 -1
  242. package/dist/ui/loader.d.ts +0 -6
  243. package/dist/ui/loader.d.ts.map +0 -1
  244. package/dist/ui/loader.js +0 -25
  245. package/dist/ui/loader.js.map +0 -1
  246. package/dist/ui/menu.d.ts +0 -41
  247. package/dist/ui/menu.d.ts.map +0 -1
  248. package/dist/ui/menu.js +0 -154
  249. package/dist/ui/menu.js.map +0 -1
  250. package/dist/ui/menu.style.d.ts +0 -3
  251. package/dist/ui/menu.style.d.ts.map +0 -1
  252. package/dist/ui/menu.style.js +0 -50
  253. package/dist/ui/menu.style.js.map +0 -1
  254. package/dist/ui/numericInput.d.ts +0 -37
  255. package/dist/ui/numericInput.d.ts.map +0 -1
  256. package/dist/ui/numericInput.js +0 -175
  257. package/dist/ui/numericInput.js.map +0 -1
  258. package/dist/ui/numericInput.style.d.ts +0 -2
  259. package/dist/ui/numericInput.style.d.ts.map +0 -1
  260. package/dist/ui/numericInput.style.js +0 -29
  261. package/dist/ui/numericInput.style.js.map +0 -1
  262. package/dist/ui/overlay.d.ts +0 -17
  263. package/dist/ui/overlay.d.ts.map +0 -1
  264. package/dist/ui/overlay.js +0 -87
  265. package/dist/ui/overlay.js.map +0 -1
  266. package/dist/ui/overlay.style.d.ts +0 -2
  267. package/dist/ui/overlay.style.d.ts.map +0 -1
  268. package/dist/ui/overlay.style.js +0 -46
  269. package/dist/ui/overlay.style.js.map +0 -1
  270. package/dist/ui/panel.d.ts +0 -25
  271. package/dist/ui/panel.d.ts.map +0 -1
  272. package/dist/ui/panel.js +0 -151
  273. package/dist/ui/panel.js.map +0 -1
  274. package/dist/ui/panel.style.d.ts +0 -2
  275. package/dist/ui/panel.style.d.ts.map +0 -1
  276. package/dist/ui/panel.style.js +0 -73
  277. package/dist/ui/panel.style.js.map +0 -1
  278. package/dist/ui/sizer.d.ts +0 -53
  279. package/dist/ui/sizer.d.ts.map +0 -1
  280. package/dist/ui/sizer.js +0 -203
  281. package/dist/ui/sizer.js.map +0 -1
  282. package/dist/ui/slider.d.ts +0 -52
  283. package/dist/ui/slider.d.ts.map +0 -1
  284. package/dist/ui/slider.js +0 -213
  285. package/dist/ui/slider.js.map +0 -1
  286. package/dist/ui/slider.style.d.ts +0 -2
  287. package/dist/ui/slider.style.d.ts.map +0 -1
  288. package/dist/ui/slider.style.js +0 -61
  289. package/dist/ui/slider.style.js.map +0 -1
  290. package/dist/ui/sortableList.d.ts +0 -39
  291. package/dist/ui/sortableList.d.ts.map +0 -1
  292. package/dist/ui/sortableList.js +0 -167
  293. package/dist/ui/sortableList.js.map +0 -1
  294. package/dist/ui/splitContainer.d.ts +0 -52
  295. package/dist/ui/splitContainer.d.ts.map +0 -1
  296. package/dist/ui/splitContainer.js +0 -252
  297. package/dist/ui/splitContainer.js.map +0 -1
  298. package/dist/ui/splitContainer.style.d.ts +0 -2
  299. package/dist/ui/splitContainer.style.d.ts.map +0 -1
  300. package/dist/ui/splitContainer.style.js +0 -62
  301. package/dist/ui/splitContainer.style.js.map +0 -1
  302. package/dist/ui/switch.d.ts +0 -22
  303. package/dist/ui/switch.d.ts.map +0 -1
  304. package/dist/ui/switch.js +0 -83
  305. package/dist/ui/switch.js.map +0 -1
  306. package/dist/ui/switch.style.d.ts +0 -2
  307. package/dist/ui/switch.style.d.ts.map +0 -1
  308. package/dist/ui/switch.style.js +0 -149
  309. package/dist/ui/switch.style.js.map +0 -1
  310. package/dist/ui/tooltip.d.ts +0 -24
  311. package/dist/ui/tooltip.d.ts.map +0 -1
  312. package/dist/ui/tooltip.js +0 -143
  313. package/dist/ui/tooltip.js.map +0 -1
  314. package/dist/ui/tooltip.style.d.ts +0 -2
  315. package/dist/ui/tooltip.style.d.ts.map +0 -1
  316. package/dist/ui/tooltip.style.js +0 -112
  317. package/dist/ui/tooltip.style.js.map +0 -1
@@ -1,52 +0,0 @@
1
- import { LitElement } from 'lit';
2
- export declare class SlideEvent extends Event {
3
- readonly value: number;
4
- constructor(type: string, value: number);
5
- }
6
- export declare enum SliderDirection {
7
- Vertical = "vertical",
8
- Horizontal = "horizontal"
9
- }
10
- export declare class Slider extends LitElement {
11
- #private;
12
- static readonly DEFAULT_MAX_VALUE = 100;
13
- static readonly DEFAULT_PAGE_SIZE = 20;
14
- static readonly SLIDE_DELAY = 5;
15
- static styles: import("lit").CSSResult[];
16
- direction: SliderDirection;
17
- value: number;
18
- maxValue: number;
19
- cursor: string;
20
- pageSize: number;
21
- hidden: boolean;
22
- innerBar: HTMLDivElement;
23
- private barRef;
24
- private pos0;
25
- private page0;
26
- private _value;
27
- private _sliding;
28
- get sliding(): boolean;
29
- show: () => boolean;
30
- hide: () => boolean;
31
- private calcValue;
32
- get barSize(): number;
33
- private onDocumentMouseMove;
34
- private onDocumentMouseUp;
35
- _onMouseDown: (e: MouseEvent) => void;
36
- setText(text: string): void;
37
- _onClick: (e: MouseEvent) => void;
38
- render: () => import("lit-html").TemplateResult<1>;
39
- willUpdate(props: Map<string, unknown>): void;
40
- updated(props: Map<string, unknown>): void;
41
- updatePosition(): void;
42
- get scrollKey(): "scrollTop" | "scrollLeft";
43
- _onSlide: () => void;
44
- _onScroll: () => void;
45
- _onWheel: (e: WheelEvent) => void;
46
- _onTouchStart: (e: TouchEvent) => void;
47
- _onTouchEnd: () => void;
48
- _onTouchMove: (e: TouchEvent) => void;
49
- attachElement(element: HTMLElement): void;
50
- deatachElement(): void;
51
- }
52
- //# sourceMappingURL=slider.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"slider.d.ts","sourceRoot":"","sources":["../../src/ui/slider.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAQ,MAAM,KAAK,CAAC;AAMvC,qBAAa,UAAW,SAAQ,KAAK;aACM,KAAK,EAAE,MAAM;gBAA3C,IAAI,EAAE,MAAM,EAAkB,KAAK,EAAE,MAAM;CAGvD;AAED,oBAAY,eAAe;IAC1B,QAAQ,aAAa;IACrB,UAAU,eAAe;CACzB;AAED,qBACa,MAAO,SAAQ,UAAU;;IAErC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,OAAO;IACxC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,MAAM;IACvC,MAAM,CAAC,QAAQ,CAAC,WAAW,KAAK;IAEhC,MAAM,CAAC,MAAM,4BAAW;IAGxB,SAAS,EAAE,eAAe,CAAC;IAG3B,KAAK,SAAK;IAGV,QAAQ,SAAK;IAGb,MAAM,EAAE,MAAM,CAAC;IAGf,QAAQ,EAAE,MAAM,CAAC;IAGjB,MAAM,EAAE,OAAO,CAAC;IAGhB,QAAQ,EAAE,cAAc,CAAC;IAEzB,OAAO,CAAC,MAAM,CAAoC;IAClD,OAAO,CAAC,IAAI,CAAK;IACjB,OAAO,CAAC,KAAK,CAAK;IAClB,OAAO,CAAC,MAAM,CAAS;IAEvB,OAAO,CAAC,QAAQ,CAAS;IACzB,IAAI,OAAO,YAA4B;IAEvC,IAAI,gBAA6B;IACjC,IAAI,gBAA4B;IAEhC,OAAO,CAAC,SAAS;IAMjB,IAAI,OAAO,IAAK,MAAM,CAMrB;IAED,OAAO,CAAC,mBAAmB,CAWzB;IAEF,OAAO,CAAC,iBAAiB,CAOvB;IAEF,YAAY,GAAI,GAAG,UAAU,UAU5B;IAED,OAAO,CAAC,IAAI,EAAE,MAAM;IAIpB,QAAQ,GAAI,GAAG,UAAU,UAExB;IAED,MAAM,6CAMJ;IAEF,UAAU,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC;IAOtC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC;IASnC,cAAc;IAkBd,IAAI,SAAS,+BAAuE;IAEpF,QAAQ,aAEP;IAED,SAAS,aAER;IAED,QAAQ,GAAI,GAAG,UAAU,UAExB;IAED,aAAa,GAAI,GAAG,UAAU,UAE5B;IAEF,WAAW,aAET;IAEF,YAAY,GAAI,GAAG,UAAU,UAM5B;IAED,aAAa,CAAC,OAAO,EAAE,WAAW;IAkBlC,cAAc;CAYd"}
package/dist/ui/slider.js DELETED
@@ -1,213 +0,0 @@
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
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
- };
12
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
13
- if (kind === "m") throw new TypeError("Private method is not writable");
14
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
15
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
16
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
17
- };
18
- var _Slider_attachedParent, _Slider_attachedParentObserver, _Slider_touchStart;
19
- import * as dom from '../common/dom';
20
- import constants from '../constants';
21
- import { LitElement, html } from 'lit';
22
- import { customElement, property, query } from 'lit/decorators.js';
23
- import { createRef, ref } from 'lit/directives/ref.js';
24
- import { styleMap } from 'lit/directives/style-map.js';
25
- import { style } from './slider.style';
26
- export class SlideEvent extends Event {
27
- constructor(type, value) {
28
- super(type);
29
- this.value = value;
30
- }
31
- }
32
- export var SliderDirection;
33
- (function (SliderDirection) {
34
- SliderDirection["Vertical"] = "vertical";
35
- SliderDirection["Horizontal"] = "horizontal";
36
- })(SliderDirection || (SliderDirection = {}));
37
- let Slider = class Slider extends LitElement {
38
- constructor() {
39
- super(...arguments);
40
- this.value = 0;
41
- this.maxValue = 0;
42
- this.barRef = createRef();
43
- this.pos0 = 0;
44
- this.page0 = 0;
45
- this._sliding = false;
46
- this.show = () => this.hidden = false;
47
- this.hide = () => this.hidden = true;
48
- this.onDocumentMouseMove = (e) => {
49
- e.preventDefault();
50
- const delta = (this.direction == SliderDirection.Vertical ? e.pageY : e.pageX) - this.page0;
51
- dom.setPosition(this.barRef.value, this.direction == SliderDirection.Vertical
52
- ? { t: Math.min(Math.max(this.pos0 + delta, 0), this.clientHeight - this.barRef.value.clientHeight) }
53
- : { l: Math.min(Math.max(this.pos0 + delta, 0), this.clientWidth - this.barRef.value.clientWidth) });
54
- this._value = this.calcValue();
55
- this.dispatchEvent(new SlideEvent('slide', this._value));
56
- };
57
- this.onDocumentMouseUp = () => {
58
- this.classList.remove('sliding');
59
- document.removeEventListener('mouseup', this.onDocumentMouseUp);
60
- document.removeEventListener('mousemove', this.onDocumentMouseMove);
61
- this.value = this._value;
62
- this._sliding = false;
63
- this.dispatchEvent(new SlideEvent('slideEnd', this.value));
64
- };
65
- this._onMouseDown = (e) => {
66
- this._sliding = true;
67
- e.preventDefault();
68
- e.stopPropagation();
69
- this.pos0 = (this.direction == SliderDirection.Vertical ? this.barRef.value.offsetTop : this.barRef.value.offsetLeft);
70
- this.page0 = this.direction == SliderDirection.Vertical ? e.pageY : e.pageX;
71
- this.classList.add('sliding');
72
- document.addEventListener('mouseup', this.onDocumentMouseUp);
73
- document.addEventListener('mousemove', this.onDocumentMouseMove);
74
- this.dispatchEvent(new SlideEvent('slideStart', this.value));
75
- };
76
- this._onClick = (e) => {
77
- console.log(e);
78
- };
79
- this.render = () => html `
80
- <div ${ref(this.barRef)}
81
- class="bar"
82
- @mousedown="${this._onMouseDown}">
83
- <div class="bar-inner" style="${styleMap({ cursor: this.cursor })}"></div>
84
- </div>
85
- `;
86
- _Slider_attachedParent.set(this, void 0);
87
- _Slider_attachedParentObserver.set(this, void 0);
88
- _Slider_touchStart.set(this, void 0);
89
- this._onSlide = () => {
90
- __classPrivateFieldGet(this, _Slider_attachedParent, "f")[this.scrollKey] = this._value;
91
- };
92
- this._onScroll = () => {
93
- this.value = __classPrivateFieldGet(this, _Slider_attachedParent, "f")[this.scrollKey];
94
- };
95
- this._onWheel = (e) => {
96
- this.value += this.direction == 'vertical' ? e.deltaY : e.deltaX;
97
- };
98
- this._onTouchStart = (e) => {
99
- __classPrivateFieldSet(this, _Slider_touchStart, e.touches[0], "f");
100
- };
101
- this._onTouchEnd = () => {
102
- __classPrivateFieldSet(this, _Slider_touchStart, null, "f");
103
- };
104
- this._onTouchMove = (e) => {
105
- if (__classPrivateFieldGet(this, _Slider_touchStart, "f")) {
106
- const touch = e.touches[0];
107
- this.value += __classPrivateFieldGet(this, _Slider_touchStart, "f").clientY - touch.clientY;
108
- __classPrivateFieldSet(this, _Slider_touchStart, touch, "f");
109
- }
110
- };
111
- }
112
- get sliding() { return this._sliding; }
113
- calcValue() {
114
- return Math.round(this.direction == SliderDirection.Vertical
115
- ? (this.barRef.value.offsetTop * this.maxValue / (this.clientHeight - this.barRef.value.clientHeight))
116
- : this.maxValue * (this.barRef.value.offsetLeft / (this.clientWidth - this.barRef.value.clientWidth)));
117
- }
118
- get barSize() {
119
- return Math.max(constants.SLIDER_MIN_LENGTH, Math.round((this.direction == SliderDirection.Vertical ? this.clientHeight : this.clientWidth) * this.pageSize / (this.pageSize + this.maxValue)));
120
- }
121
- setText(text) {
122
- this.innerBar.innerText = text;
123
- }
124
- willUpdate(props) {
125
- if (props.has('value')) {
126
- this.value = this.value == null ? 0 : Math.min(this.maxValue, Math.max(0, this.value));
127
- this._value = this.value;
128
- }
129
- }
130
- updated(props) {
131
- if (this.sliding)
132
- return; // do not allow external update while sliding
133
- this.updatePosition();
134
- if (props.has('value') && __classPrivateFieldGet(this, _Slider_attachedParent, "f")) {
135
- __classPrivateFieldGet(this, _Slider_attachedParent, "f")[this.scrollKey] = this.value;
136
- }
137
- }
138
- updatePosition() {
139
- const barSize = this.barSize;
140
- if (this.barRef.value) {
141
- if (this.direction == SliderDirection.Vertical) {
142
- dom.setSize(this.barRef.value, { w: '100%', h: barSize });
143
- dom.setPosition(this.barRef.value, { t: Math.round(this.value * (this.clientHeight - barSize) / this.maxValue) });
144
- }
145
- else {
146
- dom.setSize(this.barRef.value, { w: barSize, h: '100%' });
147
- dom.setPosition(this.barRef.value, { l: Math.round(this.value * (this.clientWidth - barSize) / this.maxValue) });
148
- }
149
- }
150
- }
151
- get scrollKey() { return this.direction == 'vertical' ? 'scrollTop' : 'scrollLeft'; }
152
- attachElement(element) {
153
- __classPrivateFieldSet(this, _Slider_attachedParent, element, "f");
154
- this.pageSize = element.clientHeight;
155
- this.maxValue = element.scrollHeight - element.clientHeight;
156
- this.addEventListener('slide', this._onSlide);
157
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").addEventListener('scroll', this._onScroll);
158
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").addEventListener('wheel', this._onWheel, { passive: true });
159
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").addEventListener('touchmove', this._onTouchMove, { passive: true });
160
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").addEventListener('touchstart', this._onTouchStart, { passive: true });
161
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").addEventListener('touchend', this._onTouchEnd, { passive: true });
162
- __classPrivateFieldSet(this, _Slider_attachedParentObserver, new MutationObserver(() => {
163
- this.pageSize = element.clientHeight;
164
- this.maxValue = element.scrollHeight - element.clientHeight;
165
- }), "f");
166
- __classPrivateFieldGet(this, _Slider_attachedParentObserver, "f").observe(element, { attributes: true, childList: true, subtree: true });
167
- }
168
- deatachElement() {
169
- this.removeEventListener('slide', this._onSlide);
170
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").removeEventListener('scroll', this._onScroll);
171
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").removeEventListener('wheel', this._onWheel);
172
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").removeEventListener('touchmove', this._onTouchMove);
173
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").removeEventListener('touchstart', this._onTouchStart);
174
- __classPrivateFieldGet(this, _Slider_attachedParent, "f").removeEventListener('touchend', this._onTouchEnd);
175
- __classPrivateFieldSet(this, _Slider_attachedParent, null, "f");
176
- if (__classPrivateFieldGet(this, _Slider_attachedParentObserver, "f"))
177
- __classPrivateFieldGet(this, _Slider_attachedParentObserver, "f").disconnect();
178
- __classPrivateFieldSet(this, _Slider_attachedParentObserver, null, "f");
179
- }
180
- };
181
- _Slider_attachedParent = new WeakMap();
182
- _Slider_attachedParentObserver = new WeakMap();
183
- _Slider_touchStart = new WeakMap();
184
- Slider.DEFAULT_MAX_VALUE = 100;
185
- Slider.DEFAULT_PAGE_SIZE = 20;
186
- Slider.SLIDE_DELAY = 5;
187
- Slider.styles = [style];
188
- __decorate([
189
- property({ type: String, reflect: true })
190
- ], Slider.prototype, "direction", void 0);
191
- __decorate([
192
- property({ type: Number })
193
- ], Slider.prototype, "value", void 0);
194
- __decorate([
195
- property({ type: Number })
196
- ], Slider.prototype, "maxValue", void 0);
197
- __decorate([
198
- property({ type: String })
199
- ], Slider.prototype, "cursor", void 0);
200
- __decorate([
201
- property({ type: Number })
202
- ], Slider.prototype, "pageSize", void 0);
203
- __decorate([
204
- property({ type: Boolean, reflect: true })
205
- ], Slider.prototype, "hidden", void 0);
206
- __decorate([
207
- query('.bar-inner')
208
- ], Slider.prototype, "innerBar", void 0);
209
- Slider = __decorate([
210
- customElement('og-slider')
211
- ], Slider);
212
- export { Slider };
213
- //# sourceMappingURL=slider.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"slider.js","sourceRoot":"","sources":["../../src/ui/slider.ts"],"names":[],"mappings":"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","sourcesContent":["import * as dom from '../common/dom';\nimport constants from '../constants';\nimport { LitElement, html } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\nimport { createRef, Ref, ref } from 'lit/directives/ref.js';\nimport { styleMap } from 'lit/directives/style-map.js';\nimport { style } from './slider.style';\n\nexport class SlideEvent extends Event {\n\tconstructor(type: string, public readonly value: number) {\n\t\tsuper(type);\n\t}\n}\n\nexport enum SliderDirection {\n\tVertical = 'vertical',\n\tHorizontal = 'horizontal'\n}\n\n@customElement('og-slider')\nexport class Slider extends LitElement {\n\n\tstatic readonly DEFAULT_MAX_VALUE = 100;\n\tstatic readonly DEFAULT_PAGE_SIZE = 20;\n\tstatic readonly SLIDE_DELAY = 5;\n\n\tstatic styles = [style];\n\n\t@property({type: String, reflect: true})\n\tdirection: SliderDirection;\n\t\n\t@property({type: Number})\n\tvalue = 0;\n\n\t@property({type: Number})\n\tmaxValue = 0;\n\n\t@property({type: String})\n\tcursor: string;\n\t\n\t@property({type: Number})\n\tpageSize: number;\n\n\t@property({type: Boolean, reflect: true})\n\thidden: boolean;\n\n\t@query('.bar-inner')\n\tinnerBar: HTMLDivElement;\n\n\tprivate barRef: Ref<HTMLDivElement> = createRef();\n\tprivate pos0 = 0;\n\tprivate page0 = 0;\n\tprivate _value: number;\n\t\n\tprivate _sliding = false;\n\tget sliding() { return this._sliding; }\n\t\n\tshow = () => this.hidden = false;\n\thide = () => this.hidden = true;\n\t\n\tprivate calcValue() : number {\n\t\treturn Math.round(this.direction == SliderDirection.Vertical\n\t\t\t? (this.barRef.value.offsetTop * this.maxValue / (this.clientHeight - this.barRef.value.clientHeight))\n\t\t\t: this.maxValue * (this.barRef.value.offsetLeft / (this.clientWidth - this.barRef.value.clientWidth)));\n\t}\n\n\tget barSize() : number {\n\t\treturn Math.max(\n\t\t\tconstants.SLIDER_MIN_LENGTH, Math.round(\n\t\t\t\t(this.direction == SliderDirection.Vertical ? this.clientHeight : this.clientWidth) * this.pageSize / (this.pageSize + this.maxValue)\n\t\t\t)\n\t\t);\n\t}\n\n\tprivate onDocumentMouseMove = (e: MouseEvent) => {\n\t\te.preventDefault();\n\t\tconst delta = (this.direction == SliderDirection.Vertical ? e.pageY : e.pageX) - this.page0;\n\n\t\tdom.setPosition(this.barRef.value, this.direction == SliderDirection.Vertical \n\t\t\t? {t: Math.min(Math.max(this.pos0 + delta, 0), this.clientHeight - this.barRef.value.clientHeight)} \n\t\t\t: {l: Math.min(Math.max(this.pos0 + delta, 0), this.clientWidth - this.barRef.value.clientWidth)} \n\t\t);\n\n\t\tthis._value = this.calcValue();\n\t\tthis.dispatchEvent(new SlideEvent('slide', this._value));\n\t};\n\n\tprivate onDocumentMouseUp = () => {\n\t\tthis.classList.remove('sliding');\n\t\tdocument.removeEventListener('mouseup', this.onDocumentMouseUp);\n\t\tdocument.removeEventListener('mousemove', this.onDocumentMouseMove);\n\t\tthis.value = this._value;\n\t\tthis._sliding = false;\n\t\tthis.dispatchEvent(new SlideEvent('slideEnd', this.value));\n\t};\n\n\t_onMouseDown = (e: MouseEvent) => {\n\t\tthis._sliding = true;\n\t\te.preventDefault();\n\t\te.stopPropagation();\n\t\tthis.pos0 = (this.direction == SliderDirection.Vertical ? this.barRef.value.offsetTop : this.barRef.value.offsetLeft);\n\t\tthis.page0 = this.direction == SliderDirection.Vertical ? e.pageY : e.pageX;\n\t\tthis.classList.add('sliding');\n\t\tdocument.addEventListener('mouseup', this.onDocumentMouseUp);\n\t\tdocument.addEventListener('mousemove', this.onDocumentMouseMove);\n\t\tthis.dispatchEvent(new SlideEvent('slideStart', this.value));\n\t}\n\n\tsetText(text: string) {\n\t\tthis.innerBar.innerText = text;\n\t}\n\n\t_onClick = (e: MouseEvent) => {\n\t\tconsole.log(e);\n\t}\n\n\trender = () => html`\n\t\t<div ${ref(this.barRef)}\n\t\t\tclass=\"bar\"\n\t\t\t@mousedown=\"${this._onMouseDown}\">\n\t\t\t<div class=\"bar-inner\" style=\"${styleMap({cursor: this.cursor})}\"></div>\n\t\t</div>\n\t`;\n\n\twillUpdate(props: Map<string, unknown>) {\n\t\tif (props.has('value')) {\n\t\t\tthis.value = this.value == null ? 0 : Math.min(this.maxValue, Math.max(0, this.value));\n\t\t\tthis._value = this.value;\n\t\t}\n\t}\n\t\n\tupdated(props: Map<string, unknown>) {\n\t\tif (this.sliding) return; // do not allow external update while sliding\n\t\tthis.updatePosition();\n\n\t\tif (props.has('value') && this.#attachedParent) {\n\t\t\tthis.#attachedParent[this.scrollKey] = this.value;\n\t\t}\n\t}\n\t\n\tupdatePosition() {\n\t\tconst barSize = this.barSize;\n\t\tif (this.barRef.value) {\n\t\t\tif (this.direction == SliderDirection.Vertical) {\n\t\t\t\tdom.setSize(this.barRef.value, {w: '100%', h: barSize});\n\t\t\t\tdom.setPosition(this.barRef.value, {t: Math.round(this.value * (this.clientHeight - barSize) / this.maxValue)});\n\t\t\t} else {\n\t\t\t\tdom.setSize(this.barRef.value, {w: barSize, h: '100%'});\n\t\t\t\tdom.setPosition(this.barRef.value, {l: Math.round(this.value * (this.clientWidth - barSize) / this.maxValue)});\n\t\t\t}\n\t\t}\n\t}\n\n\n\t#attachedParent: HTMLElement;\n\t#attachedParentObserver: MutationObserver;\n\t#touchStart: Touch;\n\n\tget scrollKey() { return this.direction == 'vertical' ? 'scrollTop' : 'scrollLeft' }\n\n\t_onSlide = () => {\n\t\tthis.#attachedParent[this.scrollKey] = this._value;\n\t}\n\n\t_onScroll = () => {\n\t\tthis.value = this.#attachedParent[this.scrollKey];\n\t}\n\n\t_onWheel = (e: WheelEvent) => {\n\t\tthis.value += this.direction == 'vertical' ? e.deltaY : e.deltaX;\n\t}\n\n\t_onTouchStart = (e: TouchEvent) => {\n\t\tthis.#touchStart = e.touches[0];\n\t};\n\n\t_onTouchEnd = () => {\n\t\tthis.#touchStart = null;\n\t};\n\n\t_onTouchMove = (e: TouchEvent) => {\n\t\tif (this.#touchStart) {\n\t\t\tconst touch = e.touches[0];\n\t\t\tthis.value += this.#touchStart.clientY - touch.clientY;\n\t\t\tthis.#touchStart = touch;\n\t\t}\n\t}\n\n\tattachElement(element: HTMLElement) {\n\t\tthis.#attachedParent = element;\n\t\tthis.pageSize = element.clientHeight;\n\t\tthis.maxValue = element.scrollHeight - element.clientHeight;\n\t\tthis.addEventListener('slide', this._onSlide);\n\t\tthis.#attachedParent.addEventListener('scroll', this._onScroll);\n\t\tthis.#attachedParent.addEventListener('wheel', this._onWheel, {passive: true});\n\t\tthis.#attachedParent.addEventListener('touchmove', this._onTouchMove, {passive: true});\n\t\tthis.#attachedParent.addEventListener('touchstart', this._onTouchStart, {passive: true});\n\t\tthis.#attachedParent.addEventListener('touchend', this._onTouchEnd, {passive: true});\n\n\t\tthis.#attachedParentObserver = new MutationObserver(() => {\n\t\t\tthis.pageSize = element.clientHeight;\n\t\t\tthis.maxValue = element.scrollHeight - element.clientHeight;\n\t\t});\n\t\tthis.#attachedParentObserver.observe(element, {attributes: true, childList: true, subtree: true});\n\t}\n\n\tdeatachElement() {\n\t\tthis.removeEventListener('slide', this._onSlide);\n\t\tthis.#attachedParent.removeEventListener('scroll', this._onScroll);\n\t\tthis.#attachedParent.removeEventListener('wheel', this._onWheel);\n\t\tthis.#attachedParent.removeEventListener('touchmove', this._onTouchMove);\n\t\tthis.#attachedParent.removeEventListener('touchstart', this._onTouchStart);\n\t\tthis.#attachedParent.removeEventListener('touchend', this._onTouchEnd);\n\t\tthis.#attachedParent = null;\n\t\tif (this.#attachedParentObserver) this.#attachedParentObserver.disconnect();\n\t\tthis.#attachedParentObserver = null;\n\t}\n\n}"]}
@@ -1,2 +0,0 @@
1
- export declare const style: import("lit").CSSResult;
2
- //# sourceMappingURL=slider.style.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"slider.style.d.ts","sourceRoot":"","sources":["../../src/ui/slider.style.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,KAAK,yBAyDjB,CAAC"}
@@ -1,61 +0,0 @@
1
- import { css, unsafeCSS } from 'lit';
2
- import constants from '../constants';
3
- export const style = css `
4
- * {
5
- box-sizing: border-box;
6
- }
7
-
8
- :host {
9
- display: block;
10
- background-color: var(--og-slider-background-color);
11
- position: relative;
12
- opacity: 0.8;
13
- transition: visibility 0s, opacity 0.1s linear;
14
- font-size: var(--og-font-size);
15
- z-index: 100;
16
- }
17
-
18
- :host([hidden]) {
19
- visibility: hidden;
20
- opacity: 0;
21
- transition: opacity 1s linear, visibility 0s 1s;
22
- }
23
-
24
- :host([direction="vertical"]) {
25
- position: absolute;
26
- right: 0;
27
- top: 0;
28
- bottom: 0;
29
- width: ${unsafeCSS(constants.SLIDER_SIZE)}px
30
- }
31
-
32
- :host([direction="vertical"]) .bar {
33
- width: 100%;
34
- }
35
-
36
- :host([direction="horizontal"]) .bar {
37
- height: 100%;
38
- }
39
-
40
- :host([direction="horizontal"]) {
41
- position: absolute;
42
- right: 0;
43
- left: 0;
44
- bottom: 0;
45
- height: ${unsafeCSS(constants.SLIDER_SIZE)}px
46
- }
47
-
48
- .bar {
49
- position: absolute;
50
- }
51
-
52
- .bar-inner {
53
- width: 100%;
54
- height: 100%;
55
- background-color: var(--og-slider-bar-color);
56
- _border: 1px solid #8B8B8B;
57
- text-align: center;
58
- border-radius: 6px;
59
- }
60
- `;
61
- //# sourceMappingURL=slider.style.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"slider.style.js","sourceRoot":"","sources":["../../src/ui/slider.style.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AACrC,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,MAAM,CAAC,MAAM,KAAK,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;WA0Bb,SAAS,CAAC,SAAS,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;YAgB/B,SAAS,CAAC,SAAS,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;CAe3C,CAAC","sourcesContent":["import { css, unsafeCSS } from 'lit';\nimport constants from '../constants';\n\nexport const style = css`\n\t* {\n\t\tbox-sizing: border-box;\n\t}\n\n\t:host {\n\t\tdisplay: block;\n\t\tbackground-color: var(--og-slider-background-color);\n\t\tposition: relative;\n\t\topacity: 0.8;\n\t\ttransition: visibility 0s, opacity 0.1s linear;\n\t\tfont-size: var(--og-font-size);\n\t\tz-index: 100;\n\t}\n\n\t:host([hidden]) {\n\t\tvisibility: hidden;\n\t\topacity: 0;\n\t\ttransition: opacity 1s linear, visibility 0s 1s;\n\t}\n\n\t:host([direction=\"vertical\"]) {\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\t\tbottom: 0;\n\t\twidth: ${unsafeCSS(constants.SLIDER_SIZE)}px\n\t}\n\n\t:host([direction=\"vertical\"]) .bar {\n\t\twidth: 100%;\n\t}\n\n\t:host([direction=\"horizontal\"]) .bar {\n\t\theight: 100%;\n\t}\n\n\t:host([direction=\"horizontal\"]) {\n\t\tposition: absolute;\n\t\tright: 0;\n\t\tleft: 0;\n\t\tbottom: 0;\n\t\theight: ${unsafeCSS(constants.SLIDER_SIZE)}px\n\t}\n\n\t.bar {\n\t\tposition: absolute;\n\t}\n\n\t.bar-inner {\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\tbackground-color: var(--og-slider-bar-color);\n\t\t_border: 1px solid #8B8B8B;\n\t\ttext-align: center;\n\t\tborder-radius: 6px;\n\t}\n`;\n"]}
@@ -1,39 +0,0 @@
1
- import { List, ListItemElement } from './list';
2
- import { Direction } from '../types';
3
- export interface SortableListItem extends HTMLElement {
4
- moveHandle?: HTMLElement;
5
- }
6
- export declare class ListSortEvent extends Event {
7
- readonly fromIndex: number;
8
- readonly toIndex: number;
9
- readonly sourceList: SortableList;
10
- readonly targetList: SortableList;
11
- readonly drop: 'before' | 'after';
12
- constructor(type: string, args?: Partial<ListSortEvent>);
13
- }
14
- export declare class SortableList extends List {
15
- static sourceList: SortableList;
16
- connectedLists: SortableList[];
17
- customHandle: boolean;
18
- private _sorting;
19
- get sorting(): boolean;
20
- get connectedSorting(): boolean;
21
- private sortIndex;
22
- private targetIndex;
23
- private markedItem;
24
- private drop;
25
- private autoscrollTimer;
26
- private autoscrollDirection;
27
- static contentStyles: import("lit").CSSResult[];
28
- constructor();
29
- startSorting(item: ListItemElement): void;
30
- removeMark(): void;
31
- stopSorting(dispatchEvent?: boolean): void;
32
- startAutoscroll(direction: Direction): void;
33
- stopAutoscroll(): void;
34
- _onMouseDown: (e: MouseEvent) => void;
35
- _onMouseUp: () => void;
36
- _onMouseMove: (e: MouseEvent) => void;
37
- firstUpdated(): void;
38
- }
39
- //# sourceMappingURL=sortableList.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sortableList.d.ts","sourceRoot":"","sources":["../../src/ui/sortableList.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE/C,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAGrC,MAAM,WAAW,gBAAiB,SAAQ,WAAW;IACpD,UAAU,CAAC,EAAE,WAAW,CAAC;CACzB;AAED,qBAAa,aAAc,SAAQ,KAAK;IAEvC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,UAAU,EAAE,YAAY,CAAC;IAClC,QAAQ,CAAC,UAAU,EAAE,YAAY,CAAC;IAClC,QAAQ,CAAC,IAAI,EAAE,QAAQ,GAAC,OAAO,CAAC;gBAEpB,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,aAAa,CAAC;CAKvD;AAED,qBACa,YAAa,SAAQ,IAAI;IAErC,MAAM,CAAC,UAAU,EAAE,YAAY,CAAC;IAChC,cAAc,EAAE,YAAY,EAAE,CAAC;IAG/B,YAAY,UAAS;IAErB,OAAO,CAAC,QAAQ,CAAS;IACzB,IAAI,OAAO,IAAK,OAAO,CAAyB;IAChD,IAAI,gBAAgB,IAAK,OAAO,CAE/B;IAED,OAAO,CAAC,SAAS,CAAM;IACvB,OAAO,CAAC,WAAW,CAAM;IACzB,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,IAAI,CAAmB;IAC/B,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,mBAAmB,CAAY;IAEvC,MAAM,CAAC,aAAa,4BAgBjB;;IAMH,YAAY,CAAC,IAAI,EAAE,eAAe;IAQlC,UAAU;IAIV,WAAW,CAAC,aAAa,CAAC,EAAE,OAAO;IAsBnC,eAAe,CAAC,SAAS,EAAE,SAAS;IAcpC,cAAc;IAQd,YAAY,GAAI,GAAG,UAAU,UAc5B;IAED,UAAU,aAET;IAED,YAAY,GAAI,GAAG,UAAU,UAgC5B;IAED,YAAY;CAQZ"}
@@ -1,167 +0,0 @@
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
- var SortableList_1;
8
- import { css } from 'lit';
9
- import { customElement, property } from 'lit/decorators.js';
10
- import { List } from './list';
11
- import { dom } from '../common';
12
- import constants from '../constants';
13
- export class ListSortEvent extends Event {
14
- constructor(type, args) {
15
- super(`list.${type}`, { bubbles: true, composed: true });
16
- if (args)
17
- Object.assign(this, args);
18
- }
19
- }
20
- let SortableList = SortableList_1 = class SortableList extends List {
21
- get sorting() { return this._sorting; }
22
- get connectedSorting() {
23
- return this.connectedLists && this.connectedLists.some(list => list.sorting);
24
- }
25
- constructor() {
26
- super();
27
- this.customHandle = false;
28
- this._sorting = false;
29
- this.sortIndex = -1;
30
- this.targetIndex = -1;
31
- this._onMouseDown = (e) => {
32
- const path = e.composedPath();
33
- const item = path.find((el) => el.classList && el.classList.contains('item'));
34
- if (this.customHandle) {
35
- let handle = item && item.moveHandle;
36
- if (!handle && item?.firstElementChild) {
37
- handle = item.firstElementChild.moveHandle;
38
- }
39
- if (handle && path.find((el) => el == handle)) {
40
- this.startSorting(item);
41
- }
42
- }
43
- else if (item)
44
- this.startSorting(item);
45
- };
46
- this._onMouseUp = () => {
47
- this.stopSorting(true);
48
- };
49
- this._onMouseMove = (e) => {
50
- if (this.sorting || this.connectedSorting) {
51
- this.connectedLists?.forEach(list => list.removeMark());
52
- const item = e.composedPath().find((el) => el.classList && el.classList.contains('item'));
53
- if (!(item instanceof HTMLElement))
54
- return;
55
- const offset = dom.getElementOffset(item, this.container);
56
- const top = offset.top + e.offsetY;
57
- if (top < constants.LIST_AUTOSCROLL_TRESHOLD) {
58
- this.startAutoscroll('up');
59
- }
60
- else if (this.container.clientHeight - top < constants.LIST_AUTOSCROLL_TRESHOLD) {
61
- this.startAutoscroll('down');
62
- }
63
- else {
64
- this.stopAutoscroll();
65
- }
66
- if (this.markedItem)
67
- this.markedItem.classList.remove('target-prev', 'target-next');
68
- if (e.offsetY > item.clientHeight / 2) {
69
- item.classList.add('target-next');
70
- this.drop = 'after';
71
- }
72
- else {
73
- item.classList.add('target-prev');
74
- this.drop = 'before';
75
- }
76
- this.markedItem = item;
77
- this.targetIndex = item.index;
78
- }
79
- };
80
- }
81
- startSorting(item) {
82
- SortableList_1.sourceList = this;
83
- this._sorting = true;
84
- this.sortIndex = item.index;
85
- this.dispatchEvent(new ListSortEvent('sortstart', { fromIndex: this.sortIndex, sourceList: this }));
86
- document.body.addEventListener('mouseup', () => this.stopSorting(false), { once: true });
87
- }
88
- removeMark() {
89
- this.markedItem?.classList.remove('target-prev', 'target-next');
90
- }
91
- stopSorting(dispatchEvent) {
92
- this._sorting = false;
93
- this.stopAutoscroll();
94
- this.removeMark();
95
- if (this.targetIndex > -1 && dispatchEvent) {
96
- this.dispatchEvent(new ListSortEvent('sort', {
97
- fromIndex: (SortableList_1.sourceList ? SortableList_1.sourceList : this).sortIndex,
98
- toIndex: this.targetIndex,
99
- sourceList: SortableList_1.sourceList,
100
- targetList: this,
101
- drop: this.drop
102
- }));
103
- }
104
- this.targetIndex = -1;
105
- this.sortIndex = -1;
106
- SortableList_1.sourceList = null;
107
- if (dispatchEvent)
108
- this.dispatchEvent(new ListSortEvent('sortend'));
109
- }
110
- startAutoscroll(direction) {
111
- if (this.autoscrollDirection == direction)
112
- return;
113
- this.autoscrollDirection = direction;
114
- this.autoscrollTimer = window.setInterval(() => {
115
- if (this.autoscrollDirection == 'down') {
116
- const offset = Math.min(this.offset + this.itemHeight, this.size * this.itemHeight - this.clientHeight);
117
- if (offset > this.offset)
118
- this.scrollToOffset(offset);
119
- }
120
- else {
121
- const offset = Math.max(0, this.offset - this.itemHeight);
122
- if (offset < this.offset)
123
- this.scrollToOffset(offset);
124
- }
125
- }, constants.LIST_AUTOSCROLL_DELAY);
126
- }
127
- stopAutoscroll() {
128
- if (this.autoscrollTimer != null) {
129
- clearInterval(this.autoscrollTimer);
130
- this.autoscrollTimer = null;
131
- this.autoscrollDirection = null;
132
- }
133
- }
134
- firstUpdated() {
135
- super.firstUpdated();
136
- if (!this.container)
137
- return;
138
- this.container.addEventListener('mousedown', this._onMouseDown);
139
- this.container.addEventListener('mousemove', this._onMouseMove);
140
- this.container.addEventListener('mouseup', this._onMouseUp);
141
- }
142
- };
143
- SortableList.contentStyles = [...List.contentStyles, css `
144
- .item {
145
- cursor: move !important;
146
- }
147
-
148
- :host([customHandle]) .item {
149
- cursor: default !important;
150
- }
151
-
152
- .item.target-prev {
153
- border-top: 2px solid var(--og-accent-color);
154
- }
155
-
156
- .item.target-next {
157
- border-bottom: 2px solid var(--og-accent-color);
158
- }
159
- `];
160
- __decorate([
161
- property({ type: Boolean, reflect: true })
162
- ], SortableList.prototype, "customHandle", void 0);
163
- SortableList = SortableList_1 = __decorate([
164
- customElement(`og-sortablelist`)
165
- ], SortableList);
166
- export { SortableList };
167
- //# sourceMappingURL=sortableList.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sortableList.js","sourceRoot":"","sources":["../../src/ui/sortableList.ts"],"names":[],"mappings":"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","sourcesContent":["import { css } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { List, ListItemElement } from './list';\nimport { dom } from '../common';\nimport { Direction } from '../types';\nimport constants from '../constants';\n\nexport interface SortableListItem extends HTMLElement {\n\tmoveHandle?: HTMLElement;\n}\n\nexport class ListSortEvent extends Event {\n\n\treadonly fromIndex: number;\n\treadonly toIndex: number;\n\treadonly sourceList: SortableList;\n\treadonly targetList: SortableList;\n\treadonly drop: 'before'|'after';\n\n\tconstructor(type: string, args?: Partial<ListSortEvent>) {\n\t\tsuper(`list.${type}`, {bubbles: true, composed: true});\n\t\tif (args) Object.assign(this, args);\n\t}\n\n}\n\n@customElement(`og-sortablelist`)\nexport class SortableList extends List {\n\n\tstatic sourceList: SortableList;\n\tconnectedLists: SortableList[];\n\n\t@property({type: Boolean, reflect: true})\n\tcustomHandle = false;\n\n\tprivate _sorting = false;\n\tget sorting() : boolean { return this._sorting }\n\tget connectedSorting() : boolean {\n\t\treturn this.connectedLists && this.connectedLists.some(list => list.sorting);\n\t}\n\n\tprivate sortIndex = -1;\n\tprivate targetIndex = -1;\n\tprivate markedItem: ListItemElement;\n\tprivate drop: 'before'|'after';\n\tprivate autoscrollTimer: number;\n\tprivate autoscrollDirection: Direction;\n\n\tstatic contentStyles = [...List.contentStyles, css`\n\t\t.item {\n\t\t\tcursor: move !important;\n\t\t}\n\n\t\t:host([customHandle]) .item {\n\t\t\tcursor: default !important;\n\t\t}\n\n\t\t.item.target-prev {\n\t\t\tborder-top: 2px solid var(--og-accent-color);\n\t\t}\n\n\t\t.item.target-next {\n\t\t\tborder-bottom: 2px solid var(--og-accent-color);\n\t\t}\n\t`];\n\n\tconstructor() {\n\t\tsuper();\n\t}\n\n\tstartSorting(item: ListItemElement) {\n\t\tSortableList.sourceList = this;\n\t\tthis._sorting = true;\n\t\tthis.sortIndex = item.index;\n\t\tthis.dispatchEvent(new ListSortEvent('sortstart', {fromIndex: this.sortIndex, sourceList: this}));\n\t\tdocument.body.addEventListener('mouseup', () => this.stopSorting(false), {once: true});\n\t}\n\n\tremoveMark() {\n\t\tthis.markedItem?.classList.remove('target-prev', 'target-next');\n\t}\n\n\tstopSorting(dispatchEvent?: boolean) {\n\t\tthis._sorting = false;\n\t\tthis.stopAutoscroll();\n\t\tthis.removeMark();\n\n\t\tif (this.targetIndex > -1 && dispatchEvent) {\n\t\t\tthis.dispatchEvent(new ListSortEvent('sort', {\n\t\t\t\tfromIndex: (SortableList.sourceList ? SortableList.sourceList : this).sortIndex,\n\t\t\t\ttoIndex: this.targetIndex,\n\t\t\t\tsourceList: SortableList.sourceList,\n\t\t\t\ttargetList: this,\n\t\t\t\tdrop: this.drop\n\t\t\t}));\n\t\t}\n\n\t\tthis.targetIndex = -1;\n\t\tthis.sortIndex = -1;\n\t\tSortableList.sourceList = null;\n\n\t\tif (dispatchEvent) this.dispatchEvent(new ListSortEvent('sortend'));\n\t}\n\n\tstartAutoscroll(direction: Direction) {\n\t\tif (this.autoscrollDirection == direction) return;\n\t\tthis.autoscrollDirection = direction;\n\t\tthis.autoscrollTimer = window.setInterval(() => {\n\t\t\tif (this.autoscrollDirection == 'down') {\n\t\t\t\tconst offset = Math.min(this.offset + this.itemHeight, this.size * this.itemHeight - this.clientHeight);\n\t\t\t\tif (offset > this.offset) this.scrollToOffset(offset);\n\t\t\t} else {\n\t\t\t\tconst offset = Math.max(0, this.offset - this.itemHeight);\n\t\t\t\tif (offset < this.offset) this.scrollToOffset(offset);\n\t\t\t}\n\t\t}, constants.LIST_AUTOSCROLL_DELAY);\n\t}\n\n\tstopAutoscroll() {\n\t\tif (this.autoscrollTimer != null) {\n\t\t\tclearInterval(this.autoscrollTimer);\n\t\t\tthis.autoscrollTimer = null;\n\t\t\tthis.autoscrollDirection = null;\n\t\t}\n\t}\n\n\t_onMouseDown = (e: MouseEvent) => {\n\t\tconst path = e.composedPath();\n\t\tconst item = path.find((el: HTMLElement) => el.classList && el.classList.contains('item')) as ListItemElement;\n\n\t\tif (this.customHandle) {\n\t\t\tlet handle = item && (item as SortableListItem).moveHandle;\n\t\t\tif (!handle && item?.firstElementChild) {\n\t\t\t\thandle = (item.firstElementChild as SortableListItem).moveHandle;\n\t\t\t}\n\n\t\t\tif (handle && path.find((el: HTMLElement) => el == handle)) {\n\t\t\t\tthis.startSorting(item);\n\t\t\t}\n\t\t} else if (item) this.startSorting(item);\n\t}\n\n\t_onMouseUp = () => {\n\t\tthis.stopSorting(true);\n\t}\n\n\t_onMouseMove = (e: MouseEvent) => {\n\t\tif (this.sorting || this.connectedSorting) {\n\t\t\tthis.connectedLists?.forEach(list => list.removeMark());\n\n\t\t\tconst item = e.composedPath().find(\n\t\t\t\t(el: HTMLElement) => el.classList && el.classList.contains('item')\n\t\t\t) as ListItemElement;\n\t\t\tif (!(item instanceof HTMLElement)) return;\n\t\t\tconst offset = dom.getElementOffset(item as HTMLElement, this.container);\n\t\t\tconst top = offset.top + e.offsetY;\n\n\t\t\tif (top < constants.LIST_AUTOSCROLL_TRESHOLD) {\n\t\t\t\tthis.startAutoscroll('up');\n\t\t\t} else if (this.container.clientHeight - top < constants.LIST_AUTOSCROLL_TRESHOLD) {\n\t\t\t\tthis.startAutoscroll('down');\n\t\t\t} else {\n\t\t\t\tthis.stopAutoscroll();\n\t\t\t}\n\n\t\t\tif (this.markedItem) this.markedItem.classList.remove('target-prev', 'target-next');\n\n\t\t\tif (e.offsetY > item.clientHeight / 2) {\n\t\t\t\titem.classList.add('target-next');\n\t\t\t\tthis.drop = 'after';\n\t\t\t} else {\n\t\t\t\titem.classList.add('target-prev');\n\t\t\t\tthis.drop = 'before';\n\t\t\t}\n\n\t\t\tthis.markedItem = item;\n\t\t\tthis.targetIndex = item.index;\n\t\t}\n\t}\n\n\tfirstUpdated() {\n super.firstUpdated();\n if (!this.container) return;\n\t\tthis.container.addEventListener('mousedown', this._onMouseDown);\n\t\tthis.container.addEventListener('mousemove', this._onMouseMove);\n\t\tthis.container.addEventListener('mouseup', this._onMouseUp);\n\t}\n\n}\n"]}