@omegagrid/core 0.10.2 → 0.10.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 (317) 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 +14 -0
  4. package/dist/common/actions.js.map +1 -0
  5. package/dist/common/colors.d.ts +39 -0
  6. package/dist/common/colors.d.ts.map +1 -0
  7. package/dist/common/colors.js +59 -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 +93 -0
  12. package/dist/common/csv.js.map +1 -0
  13. package/dist/common/dates.d.ts +32 -0
  14. package/dist/common/dates.d.ts.map +1 -0
  15. package/dist/common/dates.js +172 -0
  16. package/dist/common/dates.js.map +1 -0
  17. package/dist/common/device.d.ts +2 -0
  18. package/dist/common/device.d.ts.map +1 -0
  19. package/dist/common/device.js +13 -0
  20. package/dist/common/device.js.map +1 -0
  21. package/dist/common/dom.d.ts +90 -0
  22. package/dist/common/dom.d.ts.map +1 -0
  23. package/dist/common/dom.js +308 -0
  24. package/dist/common/dom.js.map +1 -0
  25. package/dist/common/events.d.ts +15 -0
  26. package/dist/common/events.d.ts.map +1 -0
  27. package/dist/common/events.js +33 -0
  28. package/dist/common/events.js.map +1 -0
  29. package/dist/common/html.d.ts +3 -0
  30. package/dist/common/html.d.ts.map +1 -0
  31. package/dist/common/html.js +25 -0
  32. package/dist/common/html.js.map +1 -0
  33. package/dist/common/index.d.ts +19 -0
  34. package/dist/common/index.d.ts.map +1 -0
  35. package/dist/common/index.js +19 -0
  36. package/dist/common/index.js.map +1 -0
  37. package/dist/common/linkedList.d.ts +24 -0
  38. package/dist/common/linkedList.d.ts.map +1 -0
  39. package/dist/common/linkedList.js +65 -0
  40. package/dist/common/linkedList.js.map +1 -0
  41. package/dist/common/loaders.d.ts +17 -0
  42. package/dist/common/loaders.d.ts.map +1 -0
  43. package/dist/common/loaders.js +54 -0
  44. package/dist/common/loaders.js.map +1 -0
  45. package/dist/common/logger.d.ts +25 -0
  46. package/dist/common/logger.d.ts.map +1 -0
  47. package/dist/common/logger.js +57 -0
  48. package/dist/common/logger.js.map +1 -0
  49. package/dist/common/matrix.d.ts +6 -0
  50. package/dist/common/matrix.d.ts.map +1 -0
  51. package/dist/common/matrix.js +17 -0
  52. package/dist/common/matrix.js.map +1 -0
  53. package/dist/common/numbers.d.ts +26 -0
  54. package/dist/common/numbers.d.ts.map +1 -0
  55. package/dist/common/numbers.js +239 -0
  56. package/dist/common/numbers.js.map +1 -0
  57. package/dist/common/options.d.ts +17 -0
  58. package/dist/common/options.d.ts.map +1 -0
  59. package/dist/common/options.js +29 -0
  60. package/dist/common/options.js.map +1 -0
  61. package/dist/common/paper.d.ts +8 -0
  62. package/dist/common/paper.d.ts.map +1 -0
  63. package/dist/common/paper.js +17 -0
  64. package/dist/common/paper.js.map +1 -0
  65. package/dist/common/shortcutManager.d.ts +17 -0
  66. package/dist/common/shortcutManager.d.ts.map +1 -0
  67. package/dist/common/shortcutManager.js +49 -0
  68. package/dist/common/shortcutManager.js.map +1 -0
  69. package/dist/common/tree.d.ts +87 -0
  70. package/dist/common/tree.d.ts.map +1 -0
  71. package/dist/common/tree.js +204 -0
  72. package/dist/common/tree.js.map +1 -0
  73. package/dist/common/utils.d.ts +30 -0
  74. package/dist/common/utils.d.ts.map +1 -0
  75. package/dist/common/utils.js +136 -0
  76. package/dist/common/utils.js.map +1 -0
  77. package/dist/constants.d.ts +48 -0
  78. package/dist/constants.d.ts.map +1 -0
  79. package/dist/constants.js +24 -0
  80. package/dist/constants.js.map +1 -0
  81. package/dist/index.d.ts +8 -0
  82. package/dist/index.d.ts.map +1 -0
  83. package/dist/index.js +8 -0
  84. package/dist/index.js.map +1 -0
  85. package/dist/model/adapter.d.ts +8 -0
  86. package/dist/model/adapter.d.ts.map +1 -0
  87. package/dist/model/adapter.js +13 -0
  88. package/dist/model/adapter.js.map +1 -0
  89. package/dist/model/component.d.ts +19 -0
  90. package/dist/model/component.d.ts.map +1 -0
  91. package/dist/model/component.js +84 -0
  92. package/dist/model/component.js.map +1 -0
  93. package/dist/model/componentSlice.d.ts +8 -0
  94. package/dist/model/componentSlice.d.ts.map +1 -0
  95. package/dist/model/componentSlice.js +10 -0
  96. package/dist/model/componentSlice.js.map +1 -0
  97. package/dist/model/componentStore.d.ts +12 -0
  98. package/dist/model/componentStore.d.ts.map +1 -0
  99. package/dist/model/componentStore.js +26 -0
  100. package/dist/model/componentStore.js.map +1 -0
  101. package/dist/model/index.d.ts +6 -0
  102. package/dist/model/index.d.ts.map +1 -0
  103. package/dist/model/index.js +6 -0
  104. package/dist/model/index.js.map +1 -0
  105. package/dist/model/plugins.d.ts +13 -0
  106. package/dist/model/plugins.d.ts.map +1 -0
  107. package/dist/model/plugins.js +27 -0
  108. package/dist/model/plugins.js.map +1 -0
  109. package/dist/themes/definitions/tmDark.d.ts +4 -0
  110. package/dist/themes/definitions/tmDark.d.ts.map +1 -0
  111. package/dist/themes/definitions/tmDark.js +83 -0
  112. package/dist/themes/definitions/tmDark.js.map +1 -0
  113. package/dist/themes/definitions/tmLight.d.ts +4 -0
  114. package/dist/themes/definitions/tmLight.d.ts.map +1 -0
  115. package/dist/themes/definitions/tmLight.js +83 -0
  116. package/dist/themes/definitions/tmLight.js.map +1 -0
  117. package/dist/themes/helpers.d.ts +7 -0
  118. package/dist/themes/helpers.d.ts.map +1 -0
  119. package/dist/themes/helpers.js +34 -0
  120. package/dist/themes/helpers.js.map +1 -0
  121. package/dist/themes/index.d.ts +18 -0
  122. package/dist/themes/index.d.ts.map +1 -0
  123. package/dist/themes/index.js +48 -0
  124. package/dist/themes/index.js.map +1 -0
  125. package/dist/themes/mixins.d.ts +10 -0
  126. package/dist/themes/mixins.d.ts.map +1 -0
  127. package/dist/themes/mixins.js +39 -0
  128. package/dist/themes/mixins.js.map +1 -0
  129. package/dist/themes/transformations.d.ts +9 -0
  130. package/dist/themes/transformations.d.ts.map +1 -0
  131. package/dist/themes/transformations.js +48 -0
  132. package/dist/themes/transformations.js.map +1 -0
  133. package/dist/types.d.ts +130 -0
  134. package/dist/types.d.ts.map +1 -0
  135. package/dist/types.js +12 -0
  136. package/dist/types.js.map +1 -0
  137. package/dist/ui/accordion.d.ts +16 -0
  138. package/dist/ui/accordion.d.ts.map +1 -0
  139. package/dist/ui/accordion.js +209 -0
  140. package/dist/ui/accordion.js.map +1 -0
  141. package/dist/ui/alert.d.ts +15 -0
  142. package/dist/ui/alert.d.ts.map +1 -0
  143. package/dist/ui/alert.js +101 -0
  144. package/dist/ui/alert.js.map +1 -0
  145. package/dist/ui/baseElement.d.ts +7 -0
  146. package/dist/ui/baseElement.d.ts.map +1 -0
  147. package/dist/ui/baseElement.js +10 -0
  148. package/dist/ui/baseElement.js.map +1 -0
  149. package/dist/ui/button.d.ts +21 -0
  150. package/dist/ui/button.d.ts.map +1 -0
  151. package/dist/ui/button.js +100 -0
  152. package/dist/ui/button.js.map +1 -0
  153. package/dist/ui/button.style.d.ts +2 -0
  154. package/dist/ui/button.style.d.ts.map +1 -0
  155. package/dist/ui/button.style.js +60 -0
  156. package/dist/ui/button.style.js.map +1 -0
  157. package/dist/ui/checkbox.d.ts +14 -0
  158. package/dist/ui/checkbox.d.ts.map +1 -0
  159. package/dist/ui/checkbox.js +47 -0
  160. package/dist/ui/checkbox.js.map +1 -0
  161. package/dist/ui/close.d.ts +6 -0
  162. package/dist/ui/close.d.ts.map +1 -0
  163. package/dist/ui/close.js +33 -0
  164. package/dist/ui/close.js.map +1 -0
  165. package/dist/ui/colorpicker.d.ts +24 -0
  166. package/dist/ui/colorpicker.d.ts.map +1 -0
  167. package/dist/ui/colorpicker.js +228 -0
  168. package/dist/ui/colorpicker.js.map +1 -0
  169. package/dist/ui/container.d.ts +39 -0
  170. package/dist/ui/container.d.ts.map +1 -0
  171. package/dist/ui/container.js +313 -0
  172. package/dist/ui/container.js.map +1 -0
  173. package/dist/ui/dropdown.d.ts +48 -0
  174. package/dist/ui/dropdown.d.ts.map +1 -0
  175. package/dist/ui/dropdown.js +300 -0
  176. package/dist/ui/dropdown.js.map +1 -0
  177. package/dist/ui/dropdownColorPicker.d.ts +12 -0
  178. package/dist/ui/dropdownColorPicker.d.ts.map +1 -0
  179. package/dist/ui/dropdownColorPicker.js +60 -0
  180. package/dist/ui/dropdownColorPicker.js.map +1 -0
  181. package/dist/ui/dropdownList.d.ts +8 -0
  182. package/dist/ui/dropdownList.d.ts.map +1 -0
  183. package/dist/ui/dropdownList.js +48 -0
  184. package/dist/ui/dropdownList.js.map +1 -0
  185. package/dist/ui/dropdownMenu.d.ts +11 -0
  186. package/dist/ui/dropdownMenu.d.ts.map +1 -0
  187. package/dist/ui/dropdownMenu.js +61 -0
  188. package/dist/ui/dropdownMenu.js.map +1 -0
  189. package/dist/ui/expander.d.ts +28 -0
  190. package/dist/ui/expander.d.ts.map +1 -0
  191. package/dist/ui/expander.js +144 -0
  192. package/dist/ui/expander.js.map +1 -0
  193. package/dist/ui/fileInput.d.ts +24 -0
  194. package/dist/ui/fileInput.d.ts.map +1 -0
  195. package/dist/ui/fileInput.js +130 -0
  196. package/dist/ui/fileInput.js.map +1 -0
  197. package/dist/ui/fileInput.style.d.ts +2 -0
  198. package/dist/ui/fileInput.style.d.ts.map +1 -0
  199. package/dist/ui/fileInput.style.js +73 -0
  200. package/dist/ui/fileInput.style.js.map +1 -0
  201. package/dist/ui/floatingWindow.d.ts +19 -0
  202. package/dist/ui/floatingWindow.d.ts.map +1 -0
  203. package/dist/ui/floatingWindow.js +87 -0
  204. package/dist/ui/floatingWindow.js.map +1 -0
  205. package/dist/ui/icon.d.ts +46 -0
  206. package/dist/ui/icon.d.ts.map +1 -0
  207. package/dist/ui/icon.js +189 -0
  208. package/dist/ui/icon.js.map +1 -0
  209. package/dist/ui/icon.style.d.ts +2 -0
  210. package/dist/ui/icon.style.d.ts.map +1 -0
  211. package/dist/ui/icon.style.js +556 -0
  212. package/dist/ui/icon.style.js.map +1 -0
  213. package/dist/ui/images.d.ts +2 -0
  214. package/dist/ui/images.d.ts.map +1 -0
  215. package/dist/ui/images.js +14 -0
  216. package/dist/ui/images.js.map +1 -0
  217. package/dist/ui/index.d.ts +32 -0
  218. package/dist/ui/index.d.ts.map +1 -0
  219. package/dist/ui/index.js +32 -0
  220. package/dist/ui/index.js.map +1 -0
  221. package/dist/ui/input.d.ts +12 -0
  222. package/dist/ui/input.d.ts.map +1 -0
  223. package/dist/ui/input.js +45 -0
  224. package/dist/ui/input.js.map +1 -0
  225. package/dist/ui/input.style.d.ts +2 -0
  226. package/dist/ui/input.style.d.ts.map +1 -0
  227. package/dist/ui/input.style.js +36 -0
  228. package/dist/ui/input.style.js.map +1 -0
  229. package/dist/ui/label.d.ts +16 -0
  230. package/dist/ui/label.d.ts.map +1 -0
  231. package/dist/ui/label.js +90 -0
  232. package/dist/ui/label.js.map +1 -0
  233. package/dist/ui/list.d.ts +87 -0
  234. package/dist/ui/list.d.ts.map +1 -0
  235. package/dist/ui/list.js +427 -0
  236. package/dist/ui/list.js.map +1 -0
  237. package/dist/ui/list.style.d.ts +2 -0
  238. package/dist/ui/list.style.d.ts.map +1 -0
  239. package/dist/ui/list.style.js +35 -0
  240. package/dist/ui/list.style.js.map +1 -0
  241. package/dist/ui/loader.d.ts +6 -0
  242. package/dist/ui/loader.d.ts.map +1 -0
  243. package/dist/ui/loader.js +25 -0
  244. package/dist/ui/loader.js.map +1 -0
  245. package/dist/ui/menu.d.ts +41 -0
  246. package/dist/ui/menu.d.ts.map +1 -0
  247. package/dist/ui/menu.js +154 -0
  248. package/dist/ui/menu.js.map +1 -0
  249. package/dist/ui/menu.style.d.ts +3 -0
  250. package/dist/ui/menu.style.d.ts.map +1 -0
  251. package/dist/ui/menu.style.js +50 -0
  252. package/dist/ui/menu.style.js.map +1 -0
  253. package/dist/ui/numericInput.d.ts +37 -0
  254. package/dist/ui/numericInput.d.ts.map +1 -0
  255. package/dist/ui/numericInput.js +175 -0
  256. package/dist/ui/numericInput.js.map +1 -0
  257. package/dist/ui/numericInput.style.d.ts +2 -0
  258. package/dist/ui/numericInput.style.d.ts.map +1 -0
  259. package/dist/ui/numericInput.style.js +29 -0
  260. package/dist/ui/numericInput.style.js.map +1 -0
  261. package/dist/ui/overlay.d.ts +17 -0
  262. package/dist/ui/overlay.d.ts.map +1 -0
  263. package/dist/ui/overlay.js +87 -0
  264. package/dist/ui/overlay.js.map +1 -0
  265. package/dist/ui/overlay.style.d.ts +2 -0
  266. package/dist/ui/overlay.style.d.ts.map +1 -0
  267. package/dist/ui/overlay.style.js +46 -0
  268. package/dist/ui/overlay.style.js.map +1 -0
  269. package/dist/ui/panel.d.ts +25 -0
  270. package/dist/ui/panel.d.ts.map +1 -0
  271. package/dist/ui/panel.js +151 -0
  272. package/dist/ui/panel.js.map +1 -0
  273. package/dist/ui/panel.style.d.ts +2 -0
  274. package/dist/ui/panel.style.d.ts.map +1 -0
  275. package/dist/ui/panel.style.js +73 -0
  276. package/dist/ui/panel.style.js.map +1 -0
  277. package/dist/ui/sizer.d.ts +57 -0
  278. package/dist/ui/sizer.d.ts.map +1 -0
  279. package/dist/ui/sizer.js +224 -0
  280. package/dist/ui/sizer.js.map +1 -0
  281. package/dist/ui/slider.d.ts +52 -0
  282. package/dist/ui/slider.d.ts.map +1 -0
  283. package/dist/ui/slider.js +213 -0
  284. package/dist/ui/slider.js.map +1 -0
  285. package/dist/ui/slider.style.d.ts +2 -0
  286. package/dist/ui/slider.style.d.ts.map +1 -0
  287. package/dist/ui/slider.style.js +61 -0
  288. package/dist/ui/slider.style.js.map +1 -0
  289. package/dist/ui/sortableList.d.ts +39 -0
  290. package/dist/ui/sortableList.d.ts.map +1 -0
  291. package/dist/ui/sortableList.js +167 -0
  292. package/dist/ui/sortableList.js.map +1 -0
  293. package/dist/ui/splitContainer.d.ts +52 -0
  294. package/dist/ui/splitContainer.d.ts.map +1 -0
  295. package/dist/ui/splitContainer.js +252 -0
  296. package/dist/ui/splitContainer.js.map +1 -0
  297. package/dist/ui/splitContainer.style.d.ts +2 -0
  298. package/dist/ui/splitContainer.style.d.ts.map +1 -0
  299. package/dist/ui/splitContainer.style.js +62 -0
  300. package/dist/ui/splitContainer.style.js.map +1 -0
  301. package/dist/ui/switch.d.ts +22 -0
  302. package/dist/ui/switch.d.ts.map +1 -0
  303. package/dist/ui/switch.js +83 -0
  304. package/dist/ui/switch.js.map +1 -0
  305. package/dist/ui/switch.style.d.ts +2 -0
  306. package/dist/ui/switch.style.d.ts.map +1 -0
  307. package/dist/ui/switch.style.js +149 -0
  308. package/dist/ui/switch.style.js.map +1 -0
  309. package/dist/ui/tooltip.d.ts +24 -0
  310. package/dist/ui/tooltip.d.ts.map +1 -0
  311. package/dist/ui/tooltip.js +143 -0
  312. package/dist/ui/tooltip.js.map +1 -0
  313. package/dist/ui/tooltip.style.d.ts +2 -0
  314. package/dist/ui/tooltip.style.d.ts.map +1 -0
  315. package/dist/ui/tooltip.style.js +112 -0
  316. package/dist/ui/tooltip.style.js.map +1 -0
  317. package/package.json +2 -2
@@ -0,0 +1,52 @@
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
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,213 @@
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
@@ -0,0 +1 @@
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}"]}
@@ -0,0 +1,2 @@
1
+ export declare const style: import("lit").CSSResult;
2
+ //# sourceMappingURL=slider.style.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slider.style.d.ts","sourceRoot":"","sources":["../../src/ui/slider.style.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,KAAK,yBAyDjB,CAAC"}
@@ -0,0 +1,61 @@
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
@@ -0,0 +1 @@
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"]}
@@ -0,0 +1,39 @@
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
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,167 @@
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
@@ -0,0 +1 @@
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"]}