@omegagrid/core 0.10.2 → 0.10.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/common/actions.d.ts +16 -0
- package/dist/common/actions.d.ts.map +1 -0
- package/dist/common/actions.js +14 -0
- package/dist/common/actions.js.map +1 -0
- package/dist/common/colors.d.ts +39 -0
- package/dist/common/colors.d.ts.map +1 -0
- package/dist/common/colors.js +59 -0
- package/dist/common/colors.js.map +1 -0
- package/dist/common/csv.d.ts +23 -0
- package/dist/common/csv.d.ts.map +1 -0
- package/dist/common/csv.js +93 -0
- package/dist/common/csv.js.map +1 -0
- package/dist/common/dates.d.ts +32 -0
- package/dist/common/dates.d.ts.map +1 -0
- package/dist/common/dates.js +172 -0
- package/dist/common/dates.js.map +1 -0
- package/dist/common/device.d.ts +2 -0
- package/dist/common/device.d.ts.map +1 -0
- package/dist/common/device.js +13 -0
- package/dist/common/device.js.map +1 -0
- package/dist/common/dom.d.ts +90 -0
- package/dist/common/dom.d.ts.map +1 -0
- package/dist/common/dom.js +308 -0
- package/dist/common/dom.js.map +1 -0
- package/dist/common/events.d.ts +15 -0
- package/dist/common/events.d.ts.map +1 -0
- package/dist/common/events.js +33 -0
- package/dist/common/events.js.map +1 -0
- package/dist/common/html.d.ts +3 -0
- package/dist/common/html.d.ts.map +1 -0
- package/dist/common/html.js +25 -0
- package/dist/common/html.js.map +1 -0
- package/dist/common/index.d.ts +19 -0
- package/dist/common/index.d.ts.map +1 -0
- package/dist/common/index.js +19 -0
- package/dist/common/index.js.map +1 -0
- package/dist/common/linkedList.d.ts +24 -0
- package/dist/common/linkedList.d.ts.map +1 -0
- package/dist/common/linkedList.js +65 -0
- package/dist/common/linkedList.js.map +1 -0
- package/dist/common/loaders.d.ts +17 -0
- package/dist/common/loaders.d.ts.map +1 -0
- package/dist/common/loaders.js +54 -0
- package/dist/common/loaders.js.map +1 -0
- package/dist/common/logger.d.ts +25 -0
- package/dist/common/logger.d.ts.map +1 -0
- package/dist/common/logger.js +57 -0
- package/dist/common/logger.js.map +1 -0
- package/dist/common/matrix.d.ts +6 -0
- package/dist/common/matrix.d.ts.map +1 -0
- package/dist/common/matrix.js +17 -0
- package/dist/common/matrix.js.map +1 -0
- package/dist/common/numbers.d.ts +26 -0
- package/dist/common/numbers.d.ts.map +1 -0
- package/dist/common/numbers.js +239 -0
- package/dist/common/numbers.js.map +1 -0
- package/dist/common/options.d.ts +17 -0
- package/dist/common/options.d.ts.map +1 -0
- package/dist/common/options.js +29 -0
- package/dist/common/options.js.map +1 -0
- package/dist/common/paper.d.ts +8 -0
- package/dist/common/paper.d.ts.map +1 -0
- package/dist/common/paper.js +17 -0
- package/dist/common/paper.js.map +1 -0
- package/dist/common/shortcutManager.d.ts +17 -0
- package/dist/common/shortcutManager.d.ts.map +1 -0
- package/dist/common/shortcutManager.js +49 -0
- package/dist/common/shortcutManager.js.map +1 -0
- package/dist/common/tree.d.ts +87 -0
- package/dist/common/tree.d.ts.map +1 -0
- package/dist/common/tree.js +204 -0
- package/dist/common/tree.js.map +1 -0
- package/dist/common/utils.d.ts +30 -0
- package/dist/common/utils.d.ts.map +1 -0
- package/dist/common/utils.js +136 -0
- package/dist/common/utils.js.map +1 -0
- package/dist/constants.d.ts +48 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +24 -0
- package/dist/constants.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/model/adapter.d.ts +8 -0
- package/dist/model/adapter.d.ts.map +1 -0
- package/dist/model/adapter.js +13 -0
- package/dist/model/adapter.js.map +1 -0
- package/dist/model/component.d.ts +19 -0
- package/dist/model/component.d.ts.map +1 -0
- package/dist/model/component.js +84 -0
- package/dist/model/component.js.map +1 -0
- package/dist/model/componentSlice.d.ts +8 -0
- package/dist/model/componentSlice.d.ts.map +1 -0
- package/dist/model/componentSlice.js +10 -0
- package/dist/model/componentSlice.js.map +1 -0
- package/dist/model/componentStore.d.ts +12 -0
- package/dist/model/componentStore.d.ts.map +1 -0
- package/dist/model/componentStore.js +26 -0
- package/dist/model/componentStore.js.map +1 -0
- package/dist/model/index.d.ts +6 -0
- package/dist/model/index.d.ts.map +1 -0
- package/dist/model/index.js +6 -0
- package/dist/model/index.js.map +1 -0
- package/dist/model/plugins.d.ts +13 -0
- package/dist/model/plugins.d.ts.map +1 -0
- package/dist/model/plugins.js +27 -0
- package/dist/model/plugins.js.map +1 -0
- package/dist/themes/definitions/tmDark.d.ts +4 -0
- package/dist/themes/definitions/tmDark.d.ts.map +1 -0
- package/dist/themes/definitions/tmDark.js +83 -0
- package/dist/themes/definitions/tmDark.js.map +1 -0
- package/dist/themes/definitions/tmLight.d.ts +4 -0
- package/dist/themes/definitions/tmLight.d.ts.map +1 -0
- package/dist/themes/definitions/tmLight.js +83 -0
- package/dist/themes/definitions/tmLight.js.map +1 -0
- package/dist/themes/helpers.d.ts +7 -0
- package/dist/themes/helpers.d.ts.map +1 -0
- package/dist/themes/helpers.js +34 -0
- package/dist/themes/helpers.js.map +1 -0
- package/dist/themes/index.d.ts +18 -0
- package/dist/themes/index.d.ts.map +1 -0
- package/dist/themes/index.js +48 -0
- package/dist/themes/index.js.map +1 -0
- package/dist/themes/mixins.d.ts +10 -0
- package/dist/themes/mixins.d.ts.map +1 -0
- package/dist/themes/mixins.js +39 -0
- package/dist/themes/mixins.js.map +1 -0
- package/dist/themes/transformations.d.ts +9 -0
- package/dist/themes/transformations.d.ts.map +1 -0
- package/dist/themes/transformations.js +48 -0
- package/dist/themes/transformations.js.map +1 -0
- package/dist/types.d.ts +130 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +12 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/accordion.d.ts +16 -0
- package/dist/ui/accordion.d.ts.map +1 -0
- package/dist/ui/accordion.js +209 -0
- package/dist/ui/accordion.js.map +1 -0
- package/dist/ui/alert.d.ts +15 -0
- package/dist/ui/alert.d.ts.map +1 -0
- package/dist/ui/alert.js +101 -0
- package/dist/ui/alert.js.map +1 -0
- package/dist/ui/baseElement.d.ts +7 -0
- package/dist/ui/baseElement.d.ts.map +1 -0
- package/dist/ui/baseElement.js +10 -0
- package/dist/ui/baseElement.js.map +1 -0
- package/dist/ui/button.d.ts +21 -0
- package/dist/ui/button.d.ts.map +1 -0
- package/dist/ui/button.js +100 -0
- package/dist/ui/button.js.map +1 -0
- package/dist/ui/button.style.d.ts +2 -0
- package/dist/ui/button.style.d.ts.map +1 -0
- package/dist/ui/button.style.js +60 -0
- package/dist/ui/button.style.js.map +1 -0
- package/dist/ui/checkbox.d.ts +14 -0
- package/dist/ui/checkbox.d.ts.map +1 -0
- package/dist/ui/checkbox.js +47 -0
- package/dist/ui/checkbox.js.map +1 -0
- package/dist/ui/close.d.ts +6 -0
- package/dist/ui/close.d.ts.map +1 -0
- package/dist/ui/close.js +33 -0
- package/dist/ui/close.js.map +1 -0
- package/dist/ui/colorpicker.d.ts +24 -0
- package/dist/ui/colorpicker.d.ts.map +1 -0
- package/dist/ui/colorpicker.js +228 -0
- package/dist/ui/colorpicker.js.map +1 -0
- package/dist/ui/container.d.ts +39 -0
- package/dist/ui/container.d.ts.map +1 -0
- package/dist/ui/container.js +313 -0
- package/dist/ui/container.js.map +1 -0
- package/dist/ui/dropdown.d.ts +48 -0
- package/dist/ui/dropdown.d.ts.map +1 -0
- package/dist/ui/dropdown.js +300 -0
- package/dist/ui/dropdown.js.map +1 -0
- package/dist/ui/dropdownColorPicker.d.ts +12 -0
- package/dist/ui/dropdownColorPicker.d.ts.map +1 -0
- package/dist/ui/dropdownColorPicker.js +60 -0
- package/dist/ui/dropdownColorPicker.js.map +1 -0
- package/dist/ui/dropdownList.d.ts +8 -0
- package/dist/ui/dropdownList.d.ts.map +1 -0
- package/dist/ui/dropdownList.js +48 -0
- package/dist/ui/dropdownList.js.map +1 -0
- package/dist/ui/dropdownMenu.d.ts +11 -0
- package/dist/ui/dropdownMenu.d.ts.map +1 -0
- package/dist/ui/dropdownMenu.js +61 -0
- package/dist/ui/dropdownMenu.js.map +1 -0
- package/dist/ui/expander.d.ts +28 -0
- package/dist/ui/expander.d.ts.map +1 -0
- package/dist/ui/expander.js +144 -0
- package/dist/ui/expander.js.map +1 -0
- package/dist/ui/fileInput.d.ts +24 -0
- package/dist/ui/fileInput.d.ts.map +1 -0
- package/dist/ui/fileInput.js +130 -0
- package/dist/ui/fileInput.js.map +1 -0
- package/dist/ui/fileInput.style.d.ts +2 -0
- package/dist/ui/fileInput.style.d.ts.map +1 -0
- package/dist/ui/fileInput.style.js +73 -0
- package/dist/ui/fileInput.style.js.map +1 -0
- package/dist/ui/floatingWindow.d.ts +19 -0
- package/dist/ui/floatingWindow.d.ts.map +1 -0
- package/dist/ui/floatingWindow.js +87 -0
- package/dist/ui/floatingWindow.js.map +1 -0
- package/dist/ui/icon.d.ts +46 -0
- package/dist/ui/icon.d.ts.map +1 -0
- package/dist/ui/icon.js +189 -0
- package/dist/ui/icon.js.map +1 -0
- package/dist/ui/icon.style.d.ts +2 -0
- package/dist/ui/icon.style.d.ts.map +1 -0
- package/dist/ui/icon.style.js +556 -0
- package/dist/ui/icon.style.js.map +1 -0
- package/dist/ui/images.d.ts +2 -0
- package/dist/ui/images.d.ts.map +1 -0
- package/dist/ui/images.js +14 -0
- package/dist/ui/images.js.map +1 -0
- package/dist/ui/index.d.ts +32 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +32 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/input.d.ts +12 -0
- package/dist/ui/input.d.ts.map +1 -0
- package/dist/ui/input.js +45 -0
- package/dist/ui/input.js.map +1 -0
- package/dist/ui/input.style.d.ts +2 -0
- package/dist/ui/input.style.d.ts.map +1 -0
- package/dist/ui/input.style.js +36 -0
- package/dist/ui/input.style.js.map +1 -0
- package/dist/ui/label.d.ts +16 -0
- package/dist/ui/label.d.ts.map +1 -0
- package/dist/ui/label.js +90 -0
- package/dist/ui/label.js.map +1 -0
- package/dist/ui/list.d.ts +87 -0
- package/dist/ui/list.d.ts.map +1 -0
- package/dist/ui/list.js +427 -0
- package/dist/ui/list.js.map +1 -0
- package/dist/ui/list.style.d.ts +2 -0
- package/dist/ui/list.style.d.ts.map +1 -0
- package/dist/ui/list.style.js +35 -0
- package/dist/ui/list.style.js.map +1 -0
- package/dist/ui/loader.d.ts +6 -0
- package/dist/ui/loader.d.ts.map +1 -0
- package/dist/ui/loader.js +25 -0
- package/dist/ui/loader.js.map +1 -0
- package/dist/ui/menu.d.ts +41 -0
- package/dist/ui/menu.d.ts.map +1 -0
- package/dist/ui/menu.js +154 -0
- package/dist/ui/menu.js.map +1 -0
- package/dist/ui/menu.style.d.ts +3 -0
- package/dist/ui/menu.style.d.ts.map +1 -0
- package/dist/ui/menu.style.js +50 -0
- package/dist/ui/menu.style.js.map +1 -0
- package/dist/ui/numericInput.d.ts +37 -0
- package/dist/ui/numericInput.d.ts.map +1 -0
- package/dist/ui/numericInput.js +175 -0
- package/dist/ui/numericInput.js.map +1 -0
- package/dist/ui/numericInput.style.d.ts +2 -0
- package/dist/ui/numericInput.style.d.ts.map +1 -0
- package/dist/ui/numericInput.style.js +29 -0
- package/dist/ui/numericInput.style.js.map +1 -0
- package/dist/ui/overlay.d.ts +17 -0
- package/dist/ui/overlay.d.ts.map +1 -0
- package/dist/ui/overlay.js +87 -0
- package/dist/ui/overlay.js.map +1 -0
- package/dist/ui/overlay.style.d.ts +2 -0
- package/dist/ui/overlay.style.d.ts.map +1 -0
- package/dist/ui/overlay.style.js +46 -0
- package/dist/ui/overlay.style.js.map +1 -0
- package/dist/ui/panel.d.ts +25 -0
- package/dist/ui/panel.d.ts.map +1 -0
- package/dist/ui/panel.js +151 -0
- package/dist/ui/panel.js.map +1 -0
- package/dist/ui/panel.style.d.ts +2 -0
- package/dist/ui/panel.style.d.ts.map +1 -0
- package/dist/ui/panel.style.js +73 -0
- package/dist/ui/panel.style.js.map +1 -0
- package/dist/ui/sizer.d.ts +53 -0
- package/dist/ui/sizer.d.ts.map +1 -0
- package/dist/ui/sizer.js +203 -0
- package/dist/ui/sizer.js.map +1 -0
- package/dist/ui/slider.d.ts +52 -0
- package/dist/ui/slider.d.ts.map +1 -0
- package/dist/ui/slider.js +213 -0
- package/dist/ui/slider.js.map +1 -0
- package/dist/ui/slider.style.d.ts +2 -0
- package/dist/ui/slider.style.d.ts.map +1 -0
- package/dist/ui/slider.style.js +61 -0
- package/dist/ui/slider.style.js.map +1 -0
- package/dist/ui/sortableList.d.ts +39 -0
- package/dist/ui/sortableList.d.ts.map +1 -0
- package/dist/ui/sortableList.js +167 -0
- package/dist/ui/sortableList.js.map +1 -0
- package/dist/ui/splitContainer.d.ts +52 -0
- package/dist/ui/splitContainer.d.ts.map +1 -0
- package/dist/ui/splitContainer.js +252 -0
- package/dist/ui/splitContainer.js.map +1 -0
- package/dist/ui/splitContainer.style.d.ts +2 -0
- package/dist/ui/splitContainer.style.d.ts.map +1 -0
- package/dist/ui/splitContainer.style.js +62 -0
- package/dist/ui/splitContainer.style.js.map +1 -0
- package/dist/ui/switch.d.ts +22 -0
- package/dist/ui/switch.d.ts.map +1 -0
- package/dist/ui/switch.js +83 -0
- package/dist/ui/switch.js.map +1 -0
- package/dist/ui/switch.style.d.ts +2 -0
- package/dist/ui/switch.style.d.ts.map +1 -0
- package/dist/ui/switch.style.js +149 -0
- package/dist/ui/switch.style.js.map +1 -0
- package/dist/ui/tooltip.d.ts +24 -0
- package/dist/ui/tooltip.d.ts.map +1 -0
- package/dist/ui/tooltip.js +143 -0
- package/dist/ui/tooltip.js.map +1 -0
- package/dist/ui/tooltip.style.d.ts +2 -0
- package/dist/ui/tooltip.style.d.ts.map +1 -0
- package/dist/ui/tooltip.style.js +112 -0
- package/dist/ui/tooltip.style.js.map +1 -0
- 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 @@
|
|
|
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"]}
|