@cuby-ui/cdk 0.0.487 → 0.0.489
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/constants/empty.d.ts +10 -0
- package/constants/handlers.d.ts +8 -0
- package/constants/index.d.ts +4 -0
- package/constants/svg-node-filter.d.ts +1 -0
- package/constants/units.d.ts +17 -0
- package/date-time/index.d.ts +1 -0
- package/date-time/time.d.ts +14 -0
- package/directives/active-zone/active-zone.directive.d.ts +22 -0
- package/directives/active-zone/index.d.ts +1 -0
- package/directives/auto-resizing.directive.d.ts +18 -0
- package/directives/click-outside.directive.d.ts +9 -0
- package/directives/content-editable-value-accessor.directive.d.ts +17 -0
- package/directives/dimensions-observer.directive.d.ts +13 -0
- package/directives/drag-drop/drag-drop.directive.d.ts +42 -0
- package/directives/drag-drop/drag-drop.options.d.ts +11 -0
- package/directives/drag-drop/drag-list.directive.d.ts +10 -0
- package/directives/drag-drop/drag-pointer.directive.d.ts +8 -0
- package/directives/drag-drop/index.d.ts +4 -0
- package/directives/element.directive.d.ts +8 -0
- package/directives/focus-trap.directive.d.ts +14 -0
- package/directives/handle-scroll.directive.d.ts +23 -0
- package/directives/hovered/hovered.directive.d.ts +7 -0
- package/directives/hovered/hovered.service.d.ts +12 -0
- package/directives/hovered/index.d.ts +2 -0
- package/directives/index.d.ts +17 -0
- package/directives/item.directive.d.ts +5 -0
- package/directives/ladder-list.directive.d.ts +13 -0
- package/directives/let.context.d.ts +9 -0
- package/directives/let.directive.d.ts +9 -0
- package/directives/target.directive.d.ts +14 -0
- package/directives/typed-template.directive.d.ts +13 -0
- package/directives/typed-template.options.d.ts +3 -0
- package/esm2022/constants/empty.mjs +24 -0
- package/esm2022/constants/handlers.mjs +11 -0
- package/esm2022/constants/index.mjs +5 -0
- package/esm2022/constants/svg-node-filter.mjs +6 -0
- package/esm2022/constants/units.mjs +64 -0
- package/esm2022/cuby-ui-cdk.mjs +5 -0
- package/esm2022/date-time/index.mjs +2 -0
- package/esm2022/date-time/time.mjs +72 -0
- package/esm2022/directives/active-zone/active-zone.directive.mjs +75 -0
- package/esm2022/directives/active-zone/index.mjs +2 -0
- package/esm2022/directives/auto-resizing.directive.mjs +64 -0
- package/esm2022/directives/click-outside.directive.mjs +29 -0
- package/esm2022/directives/content-editable-value-accessor.directive.mjs +44 -0
- package/esm2022/directives/dimensions-observer.directive.mjs +32 -0
- package/esm2022/directives/drag-drop/drag-drop.directive.mjs +184 -0
- package/esm2022/directives/drag-drop/drag-drop.options.mjs +2 -0
- package/esm2022/directives/drag-drop/drag-list.directive.mjs +22 -0
- package/esm2022/directives/drag-drop/drag-pointer.directive.mjs +20 -0
- package/esm2022/directives/drag-drop/index.mjs +4 -0
- package/esm2022/directives/element.directive.mjs +19 -0
- package/esm2022/directives/focus-trap.directive.mjs +50 -0
- package/esm2022/directives/handle-scroll.directive.mjs +81 -0
- package/esm2022/directives/hovered/hovered.directive.mjs +21 -0
- package/esm2022/directives/hovered/hovered.service.mjs +32 -0
- package/esm2022/directives/hovered/index.mjs +3 -0
- package/esm2022/directives/index.mjs +18 -0
- package/esm2022/directives/item.directive.mjs +14 -0
- package/esm2022/directives/ladder-list.directive.mjs +42 -0
- package/esm2022/directives/let.context.mjs +12 -0
- package/esm2022/directives/let.directive.mjs +23 -0
- package/esm2022/directives/target.directive.mjs +36 -0
- package/esm2022/directives/typed-template.directive.mjs +27 -0
- package/esm2022/directives/typed-template.options.mjs +2 -0
- package/esm2022/index.mjs +12 -0
- package/esm2022/interfaces/dimensions.mjs +2 -0
- package/esm2022/interfaces/index.mjs +4 -0
- package/esm2022/interfaces/on-change.mjs +2 -0
- package/esm2022/interfaces/on-touched.mjs +2 -0
- package/esm2022/models/consumption-units.mjs +2 -0
- package/esm2022/models/index.mjs +2 -0
- package/esm2022/observables/if-map.mjs +5 -0
- package/esm2022/observables/index.mjs +5 -0
- package/esm2022/observables/typed-from-event.mjs +9 -0
- package/esm2022/observables/watch.mjs +6 -0
- package/esm2022/observables/zone.mjs +34 -0
- package/esm2022/pipes/filter.pipe.mjs +17 -0
- package/esm2022/pipes/index.mjs +2 -0
- package/esm2022/services/consumption-units.service.mjs +67 -0
- package/esm2022/services/destroy.service.mjs +15 -0
- package/esm2022/services/id.service.mjs +21 -0
- package/esm2022/services/index.mjs +5 -0
- package/esm2022/services/popover.service.mjs +41 -0
- package/esm2022/tokens/active-element.mjs +52 -0
- package/esm2022/tokens/animation-frame.mjs +21 -0
- package/esm2022/tokens/environment.mjs +47 -0
- package/esm2022/tokens/history.mjs +5 -0
- package/esm2022/tokens/index.mjs +11 -0
- package/esm2022/tokens/local-storage.mjs +5 -0
- package/esm2022/tokens/navigator.mjs +6 -0
- package/esm2022/tokens/removed-element.mjs +19 -0
- package/esm2022/tokens/session-storage.mjs +5 -0
- package/esm2022/tokens/user-agent.mjs +6 -0
- package/esm2022/tokens/window.mjs +11 -0
- package/esm2022/types/context.mjs +2 -0
- package/esm2022/types/date-time.mjs +2 -0
- package/esm2022/types/handler.mjs +2 -0
- package/esm2022/types/index.mjs +9 -0
- package/esm2022/types/input-type.mjs +2 -0
- package/esm2022/types/mapper.mjs +2 -0
- package/esm2022/types/matcher.mjs +2 -0
- package/esm2022/types/nullable.mjs +2 -0
- package/esm2022/types/value-of.mjs +2 -0
- package/esm2022/utils/dom/contains-or-after.mjs +9 -0
- package/esm2022/utils/dom/element-checks.mjs +20 -0
- package/esm2022/utils/dom/get-actual-target.mjs +7 -0
- package/esm2022/utils/dom/get-document-or-shadow-root.mjs +6 -0
- package/esm2022/utils/dom/get-element-obscurers.mjs +42 -0
- package/esm2022/utils/dom/index.mjs +8 -0
- package/esm2022/utils/dom/inject-element.mjs +5 -0
- package/esm2022/utils/dom/point-to-client-rect.mjs +17 -0
- package/esm2022/utils/files/files.uploader.mjs +19 -0
- package/esm2022/utils/files/index.mjs +3 -0
- package/esm2022/utils/files/take-capture-from-video.mjs +25 -0
- package/esm2022/utils/focus/blur-native-focused.mjs +9 -0
- package/esm2022/utils/focus/get-closest-focusable.mjs +22 -0
- package/esm2022/utils/focus/get-native-focused.mjs +11 -0
- package/esm2022/utils/focus/index.mjs +7 -0
- package/esm2022/utils/focus/is-native-focused.mjs +13 -0
- package/esm2022/utils/focus/is-native-keyboard-focusable.mjs +26 -0
- package/esm2022/utils/focus/is-native-mouse-focusable.mjs +6 -0
- package/esm2022/utils/index.mjs +8 -0
- package/esm2022/utils/math/clamp.mjs +11 -0
- package/esm2022/utils/math/index.mjs +2 -0
- package/esm2022/utils/miscellaneous/array-remove.mjs +4 -0
- package/esm2022/utils/miscellaneous/index.mjs +6 -0
- package/esm2022/utils/miscellaneous/is-present.mjs +4 -0
- package/esm2022/utils/miscellaneous/move-item-in-array.mjs +10 -0
- package/esm2022/utils/miscellaneous/pure.mjs +81 -0
- package/esm2022/utils/miscellaneous/px.mjs +7 -0
- package/esm2022/utils/platform/index.mjs +2 -0
- package/esm2022/utils/platform/is-ios.mjs +6 -0
- package/esm2022/utils/token/create-token.mjs +8 -0
- package/esm2022/utils/token/index.mjs +3 -0
- package/esm2022/utils/token/provide.mjs +4 -0
- package/fesm2022/cuby-ui-cdk.mjs +1644 -0
- package/fesm2022/cuby-ui-cdk.mjs.map +1 -0
- package/index.d.ts +11 -0
- package/interfaces/dimensions.d.ts +4 -0
- package/interfaces/index.d.ts +3 -0
- package/interfaces/on-change.d.ts +3 -0
- package/interfaces/on-touched.d.ts +3 -0
- package/models/consumption-units.d.ts +14 -0
- package/models/index.d.ts +1 -0
- package/observables/if-map.d.ts +3 -0
- package/observables/index.d.ts +4 -0
- package/observables/typed-from-event.d.ts +16 -0
- package/observables/watch.d.ts +3 -0
- package/observables/zone.d.ts +7 -0
- package/package.json +1 -4
- package/pipes/filter.pipe.d.ts +8 -0
- package/pipes/index.d.ts +1 -0
- package/services/consumption-units.service.d.ts +13 -0
- package/services/destroy.service.d.ts +8 -0
- package/services/id.service.d.ts +8 -0
- package/services/index.d.ts +4 -0
- package/services/popover.service.d.ts +23 -0
- package/tokens/active-element.d.ts +5 -0
- package/tokens/animation-frame.d.ts +3 -0
- package/tokens/environment.d.ts +19 -0
- package/tokens/history.d.ts +1 -0
- package/tokens/index.d.ts +10 -0
- package/tokens/local-storage.d.ts +1 -0
- package/tokens/navigator.d.ts +2 -0
- package/tokens/removed-element.d.ts +4 -0
- package/tokens/session-storage.d.ts +1 -0
- package/tokens/user-agent.d.ts +2 -0
- package/tokens/window.d.ts +1 -0
- package/types/context.d.ts +3 -0
- package/types/date-time.d.ts +1 -0
- package/types/handler.d.ts +4 -0
- package/types/index.d.ts +8 -0
- package/types/input-type.d.ts +1 -0
- package/types/mapper.d.ts +1 -0
- package/types/matcher.d.ts +2 -0
- package/types/nullable.d.ts +1 -0
- package/types/value-of.d.ts +1 -0
- package/utils/dom/contains-or-after.d.ts +1 -0
- package/utils/dom/element-checks.d.ts +6 -0
- package/utils/dom/get-actual-target.d.ts +4 -0
- package/utils/dom/get-document-or-shadow-root.d.ts +1 -0
- package/utils/dom/get-element-obscurers.d.ts +9 -0
- package/utils/dom/index.d.ts +7 -0
- package/utils/dom/inject-element.d.ts +1 -0
- package/utils/dom/point-to-client-rect.d.ts +1 -0
- package/utils/files/files.uploader.d.ts +5 -0
- package/utils/files/index.d.ts +2 -0
- package/utils/files/take-capture-from-video.d.ts +1 -0
- package/utils/focus/blur-native-focused.d.ts +1 -0
- package/utils/focus/get-closest-focusable.d.ts +7 -0
- package/utils/focus/get-native-focused.d.ts +1 -0
- package/utils/focus/index.d.ts +6 -0
- package/utils/focus/is-native-focused.d.ts +9 -0
- package/utils/focus/is-native-keyboard-focusable.d.ts +1 -0
- package/utils/focus/is-native-mouse-focusable.d.ts +1 -0
- package/utils/index.d.ts +7 -0
- package/utils/math/clamp.d.ts +8 -0
- package/utils/math/index.d.ts +1 -0
- package/utils/miscellaneous/array-remove.d.ts +1 -0
- package/utils/miscellaneous/index.d.ts +5 -0
- package/utils/miscellaneous/is-present.d.ts +1 -0
- package/utils/miscellaneous/move-item-in-array.d.ts +1 -0
- package/utils/miscellaneous/pure.d.ts +21 -0
- package/utils/miscellaneous/px.d.ts +4 -0
- package/utils/platform/index.d.ts +1 -0
- package/utils/platform/is-ios.d.ts +3 -0
- package/utils/token/create-token.d.ts +3 -0
- package/utils/token/index.d.ts +2 -0
- package/utils/token/provide.d.ts +3 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
export class CuiTime {
|
|
2
|
+
constructor(hours, minutes, seconds = 0, ms = 0) {
|
|
3
|
+
this.hours = hours;
|
|
4
|
+
this.minutes = minutes;
|
|
5
|
+
this.seconds = seconds;
|
|
6
|
+
this.ms = ms;
|
|
7
|
+
}
|
|
8
|
+
static fromString(time) {
|
|
9
|
+
const hours = this.parseHours(time);
|
|
10
|
+
const minutes = Number(time.slice(3, 5)) || 0;
|
|
11
|
+
const seconds = Number(time.slice(6, 8)) || 0;
|
|
12
|
+
const ms = Number(time.slice(9, 12)) || 0;
|
|
13
|
+
return new CuiTime(hours, minutes, seconds, ms);
|
|
14
|
+
}
|
|
15
|
+
static fromPT(time) {
|
|
16
|
+
let duration = time.trim().toUpperCase();
|
|
17
|
+
if (!duration.startsWith('P')) {
|
|
18
|
+
throw new Error('Invalid PT format: does not start with P');
|
|
19
|
+
}
|
|
20
|
+
duration = duration.substring(1);
|
|
21
|
+
if (duration.startsWith('T')) {
|
|
22
|
+
duration = duration.substring(1);
|
|
23
|
+
}
|
|
24
|
+
const regex = /(\d+(\.\d+)?)([HMS])/g;
|
|
25
|
+
let match;
|
|
26
|
+
let hours = 0, minutes = 0, seconds = 0, ms = 0;
|
|
27
|
+
while ((match = regex.exec(duration)) !== null) {
|
|
28
|
+
const value = parseFloat(match[1]);
|
|
29
|
+
const unit = match[3];
|
|
30
|
+
if (unit === 'H') {
|
|
31
|
+
hours = value;
|
|
32
|
+
}
|
|
33
|
+
else if (unit === 'M') {
|
|
34
|
+
minutes = value;
|
|
35
|
+
}
|
|
36
|
+
else if (unit === 'S') {
|
|
37
|
+
seconds = Math.floor(value);
|
|
38
|
+
ms = Math.round((value - seconds) * 1000);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return new CuiTime(hours, minutes, seconds, ms);
|
|
42
|
+
}
|
|
43
|
+
static parseHours(time) {
|
|
44
|
+
return Number(time.slice(0, 2));
|
|
45
|
+
}
|
|
46
|
+
toString(mode) {
|
|
47
|
+
const needAddMs = mode?.startsWith('HH:MM:SS.MSS') || (!mode && this.ms > 0);
|
|
48
|
+
const needAddSeconds = needAddMs || mode?.startsWith('HH:MM:SS') || (!mode && this.seconds > 0);
|
|
49
|
+
const hhMm = `${this.formatTime(this.hours)}:${this.formatTime(this.minutes)}`;
|
|
50
|
+
const ss = needAddSeconds ? `:${this.formatTime(this.seconds)}` : '';
|
|
51
|
+
const mss = needAddMs ? `.${this.formatTime(this.ms, 3)}` : '';
|
|
52
|
+
return `${hhMm}${ss}${mss}`;
|
|
53
|
+
}
|
|
54
|
+
toPT(mode) {
|
|
55
|
+
let duration = 'PT';
|
|
56
|
+
if (this.hours !== 0) {
|
|
57
|
+
duration += `${this.hours}H`;
|
|
58
|
+
}
|
|
59
|
+
if (this.minutes !== 0) {
|
|
60
|
+
duration += `${this.minutes}M`;
|
|
61
|
+
}
|
|
62
|
+
const totalSeconds = this.seconds + this.ms / 1000;
|
|
63
|
+
if (totalSeconds !== 0 || duration === 'PT') {
|
|
64
|
+
duration += `${parseFloat(totalSeconds.toFixed(3))}S`;
|
|
65
|
+
}
|
|
66
|
+
return duration;
|
|
67
|
+
}
|
|
68
|
+
formatTime(time, digits = 2) {
|
|
69
|
+
return String(time).padStart(digits, '0');
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.js","sourceRoot":"","sources":["../../../../projects/cdk/date-time/time.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiTimeMode } from '../types';\n\nexport class CuiTime {\n    constructor(\n        public readonly hours: number,\n        public readonly minutes: number,\n        public readonly seconds = 0,\n        public readonly ms = 0\n    ) {}\n\n    public static fromString(time: string): CuiTime {\n        const hours = this.parseHours(time);\n        const minutes = Number(time.slice(3, 5)) || 0;\n        const seconds = Number(time.slice(6, 8)) || 0;\n        const ms = Number(time.slice(9, 12)) || 0;\n\n        return new CuiTime(hours, minutes, seconds, ms);\n    }\n\n    public static fromPT(time: string): CuiTime {\n        let duration = time.trim().toUpperCase();\n\n        if (!duration.startsWith('P')) {\n            throw new Error('Invalid PT format: does not start with P');\n        }\n\n        duration = duration.substring(1);\n\n        if (duration.startsWith('T')) {\n            duration = duration.substring(1);\n        }\n\n        const regex = /(\\d+(\\.\\d+)?)([HMS])/g;\n        let match;\n        let hours = 0,\n            minutes = 0,\n            seconds = 0,\n            ms = 0;\n\n        while ((match = regex.exec(duration)) !== null) {\n            const value = parseFloat(match[1]);\n            const unit = match[3];\n\n            if (unit === 'H') {\n                hours = value;\n            } else if (unit === 'M') {\n                minutes = value;\n            } else if (unit === 'S') {\n                seconds = Math.floor(value);\n                ms = Math.round((value - seconds) * 1000);\n            }\n        }\n\n        return new CuiTime(hours, minutes, seconds, ms);\n    }\n\n    private static parseHours(time: string): number {\n        return Number(time.slice(0, 2));\n    }\n\n    public toString(mode?: CuiTimeMode): string {\n        const needAddMs = mode?.startsWith('HH:MM:SS.MSS') || (!mode && this.ms > 0);\n        const needAddSeconds = needAddMs || mode?.startsWith('HH:MM:SS') || (!mode && this.seconds > 0);\n        const hhMm = `${this.formatTime(this.hours)}:${this.formatTime(this.minutes)}`;\n        const ss = needAddSeconds ? `:${this.formatTime(this.seconds)}` : '';\n        const mss = needAddMs ? `.${this.formatTime(this.ms, 3)}` : '';\n\n        return `${hhMm}${ss}${mss}`;\n    }\n\n    public toPT(mode?: CuiTimeMode): string {\n        let duration = 'PT';\n        if (this.hours !== 0) {\n            duration += `${this.hours}H`;\n        }\n\n        if (this.minutes !== 0) {\n            duration += `${this.minutes}M`;\n        }\n\n        const totalSeconds = this.seconds + this.ms / 1000;\n\n        if (totalSeconds !== 0 || duration === 'PT') {\n            duration += `${parseFloat(totalSeconds.toFixed(3))}S`;\n        }\n\n        return duration;\n    }\n\n    private formatTime(time: number, digits = 2): string {\n        return String(time).padStart(digits, '0');\n    }\n}\n"]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import { Directive, inject, Input, NgZone, Output } from '@angular/core';
|
|
3
|
+
import { NgControl } from '@angular/forms';
|
|
4
|
+
import { cuiZoneOptimized } from '../../observables';
|
|
5
|
+
import { CUI_ACTIVE_ELEMENT } from '../../tokens';
|
|
6
|
+
import { cuiArrayRemove, cuiInjectElement, cuiPure } from '../../utils';
|
|
7
|
+
import { distinctUntilChanged, map, skip, startWith, tap } from 'rxjs';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class CuiActiveZone {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.control = inject(NgControl, { self: true, optional: true });
|
|
12
|
+
this.active$ = inject(CUI_ACTIVE_ELEMENT);
|
|
13
|
+
this.zone = inject(NgZone);
|
|
14
|
+
this.el = cuiInjectElement();
|
|
15
|
+
this.cuiActiveZoneParent = null;
|
|
16
|
+
this.subActiveZones = [];
|
|
17
|
+
this.directParentActiveZone = inject(CuiActiveZone, {
|
|
18
|
+
skipSelf: true,
|
|
19
|
+
optional: true
|
|
20
|
+
});
|
|
21
|
+
this.cuiActiveZoneChange = this.active$.pipe(map((element) => !!element && this.contains(element)), startWith(false), distinctUntilChanged(), skip(1), tap((active) => {
|
|
22
|
+
if (!active && typeof this.control?.valueAccessor.onTouched === 'function') {
|
|
23
|
+
this.control.valueAccessor.onTouched();
|
|
24
|
+
}
|
|
25
|
+
}), cuiZoneOptimized(this.zone));
|
|
26
|
+
this.directParentActiveZone?.addSubActiveZone(this);
|
|
27
|
+
}
|
|
28
|
+
set cuiActiveZoneParentSetter(zone) {
|
|
29
|
+
this.setZone(zone);
|
|
30
|
+
}
|
|
31
|
+
ngOnDestroy() {
|
|
32
|
+
this.directParentActiveZone?.removeSubActiveZone(this);
|
|
33
|
+
this.cuiActiveZoneParent?.removeSubActiveZone(this);
|
|
34
|
+
}
|
|
35
|
+
contains(node) {
|
|
36
|
+
return (this.el.contains(node) ||
|
|
37
|
+
this.subActiveZones.some((item, index, array) => array.indexOf(item) === index && item.contains(node)));
|
|
38
|
+
}
|
|
39
|
+
setZone(zone) {
|
|
40
|
+
this.cuiActiveZoneParent?.removeSubActiveZone(this);
|
|
41
|
+
zone?.addSubActiveZone(this);
|
|
42
|
+
this.cuiActiveZoneParent = zone;
|
|
43
|
+
}
|
|
44
|
+
addSubActiveZone(activeZone) {
|
|
45
|
+
this.subActiveZones = [...this.subActiveZones, activeZone];
|
|
46
|
+
}
|
|
47
|
+
removeSubActiveZone(activeZone) {
|
|
48
|
+
this.subActiveZones = cuiArrayRemove(this.subActiveZones, this.subActiveZones.indexOf(activeZone));
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiActiveZone, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
51
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CuiActiveZone, isStandalone: true, selector: "[cuiActiveZone]:not(ng-container), [cuiActiveZoneChange]:not(ng-container), [cuiActiveZoneParent]:not(ng-container)", inputs: { cuiActiveZoneParentSetter: ["cuiActiveZoneParent", "cuiActiveZoneParentSetter"] }, outputs: { cuiActiveZoneChange: "cuiActiveZoneChange" }, host: { listeners: { "document:mousedown.silent": "(0)" } }, exportAs: ["cuiActiveZone"], ngImport: i0 }); }
|
|
52
|
+
}
|
|
53
|
+
__decorate([
|
|
54
|
+
cuiPure,
|
|
55
|
+
__metadata("design:type", Function),
|
|
56
|
+
__metadata("design:paramtypes", [Object]),
|
|
57
|
+
__metadata("design:returntype", void 0)
|
|
58
|
+
], CuiActiveZone.prototype, "setZone", null);
|
|
59
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiActiveZone, decorators: [{
|
|
60
|
+
type: Directive,
|
|
61
|
+
args: [{
|
|
62
|
+
standalone: true,
|
|
63
|
+
selector: '[cuiActiveZone]:not(ng-container), [cuiActiveZoneChange]:not(ng-container), [cuiActiveZoneParent]:not(ng-container)',
|
|
64
|
+
exportAs: 'cuiActiveZone',
|
|
65
|
+
host: {
|
|
66
|
+
'(document:mousedown.silent)': '(0)'
|
|
67
|
+
}
|
|
68
|
+
}]
|
|
69
|
+
}], ctorParameters: () => [], propDecorators: { cuiActiveZoneChange: [{
|
|
70
|
+
type: Output
|
|
71
|
+
}], cuiActiveZoneParentSetter: [{
|
|
72
|
+
type: Input,
|
|
73
|
+
args: ['cuiActiveZoneParent']
|
|
74
|
+
}], setZone: [] } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZlLXpvbmUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2RrL2RpcmVjdGl2ZXMvYWN0aXZlLXpvbmUvYWN0aXZlLXpvbmUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDckQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xELE9BQU8sRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXhFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBV3ZFLE1BQU0sT0FBTyxhQUFhO0lBMEJ0QjtRQXpCaUIsWUFBTyxHQUFRLE1BQU0sQ0FBQyxTQUFTLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ2pFLFlBQU8sR0FBRyxNQUFNLENBQTZCLGtCQUFrQixDQUFDLENBQUM7UUFDakUsU0FBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0QixPQUFFLEdBQUcsZ0JBQWdCLEVBQUUsQ0FBQztRQUNqQyx3QkFBbUIsR0FBeUIsSUFBSSxDQUFDO1FBQ2pELG1CQUFjLEdBQTZCLEVBQUUsQ0FBQztRQUNyQywyQkFBc0IsR0FBRyxNQUFNLENBQUMsYUFBYSxFQUFFO1lBQzVELFFBQVEsRUFBRSxJQUFJO1lBQ2QsUUFBUSxFQUFFLElBQUk7U0FDakIsQ0FBQyxDQUFDO1FBR2Esd0JBQW1CLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQ25ELEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQ3JELFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFDaEIsb0JBQW9CLEVBQUUsRUFDdEIsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUNQLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQ1gsSUFBSSxDQUFDLE1BQU0sSUFBSSxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsYUFBYSxDQUFDLFNBQVMsS0FBSyxVQUFVLEVBQUUsQ0FBQztnQkFDekUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDM0MsQ0FBQztRQUNMLENBQUMsQ0FBQyxFQUNGLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FDOUIsQ0FBQztRQUdFLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBRUQsSUFDVyx5QkFBeUIsQ0FBQyxJQUEwQjtRQUMzRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxXQUFXO1FBQ2QsSUFBSSxDQUFDLHNCQUFzQixFQUFFLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3ZELElBQUksQ0FBQyxtQkFBbUIsRUFBRSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBRU0sUUFBUSxDQUFDLElBQVU7UUFDdEIsT0FBTyxDQUNILElBQUksQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQztZQUN0QixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQ3pHLENBQUM7SUFDTixDQUFDO0lBR08sT0FBTyxDQUFDLElBQTBCO1FBQ3RDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwRCxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDN0IsSUFBSSxDQUFDLG1CQUFtQixHQUFHLElBQUksQ0FBQztJQUNwQyxDQUFDO0lBRU8sZ0JBQWdCLENBQUMsVUFBeUI7UUFDOUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRU8sbUJBQW1CLENBQUMsVUFBeUI7UUFDakQsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBQ3ZHLENBQUM7K0dBNURRLGFBQWE7bUdBQWIsYUFBYTs7QUFnRGQ7SUFEUCxPQUFPOzs7OzRDQUtQOzRGQXBEUSxhQUFhO2tCQVR6QixTQUFTO21CQUFDO29CQUNQLFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQ0oscUhBQXFIO29CQUN6SCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsSUFBSSxFQUFFO3dCQUNGLDZCQUE2QixFQUFFLEtBQUs7cUJBQ3ZDO2lCQUNKO3dEQWNtQixtQkFBbUI7c0JBRGxDLE1BQU07Z0JBbUJJLHlCQUF5QjtzQkFEbkMsS0FBSzt1QkFBQyxxQkFBcUI7Z0JBa0JwQixPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBJbnB1dCwgTmdab25lLCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IGN1aVpvbmVPcHRpbWl6ZWQgfSBmcm9tICcuLi8uLi9vYnNlcnZhYmxlcyc7XG5pbXBvcnQgeyBDVUlfQUNUSVZFX0VMRU1FTlQgfSBmcm9tICcuLi8uLi90b2tlbnMnO1xuaW1wb3J0IHsgY3VpQXJyYXlSZW1vdmUsIGN1aUluamVjdEVsZW1lbnQsIGN1aVB1cmUgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBtYXAsIHNraXAsIHN0YXJ0V2l0aCwgdGFwIH0gZnJvbSAncnhqcyc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6XG4gICAgICAgICdbY3VpQWN0aXZlWm9uZV06bm90KG5nLWNvbnRhaW5lciksIFtjdWlBY3RpdmVab25lQ2hhbmdlXTpub3QobmctY29udGFpbmVyKSwgW2N1aUFjdGl2ZVpvbmVQYXJlbnRdOm5vdChuZy1jb250YWluZXIpJyxcbiAgICBleHBvcnRBczogJ2N1aUFjdGl2ZVpvbmUnLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJyhkb2N1bWVudDptb3VzZWRvd24uc2lsZW50KSc6ICcoMCknXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBDdWlBY3RpdmVab25lIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbnRyb2w6IGFueSA9IGluamVjdChOZ0NvbnRyb2wsIHsgc2VsZjogdHJ1ZSwgb3B0aW9uYWw6IHRydWUgfSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBhY3RpdmUkID0gaW5qZWN0PE9ic2VydmFibGU8RWxlbWVudCB8IG51bGw+PihDVUlfQUNUSVZFX0VMRU1FTlQpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgem9uZSA9IGluamVjdChOZ1pvbmUpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZWwgPSBjdWlJbmplY3RFbGVtZW50KCk7XG4gICAgcHJpdmF0ZSBjdWlBY3RpdmVab25lUGFyZW50OiBDdWlBY3RpdmVab25lIHwgbnVsbCA9IG51bGw7XG4gICAgcHJpdmF0ZSBzdWJBY3RpdmVab25lczogcmVhZG9ubHkgQ3VpQWN0aXZlWm9uZVtdID0gW107XG4gICAgcHJpdmF0ZSByZWFkb25seSBkaXJlY3RQYXJlbnRBY3RpdmVab25lID0gaW5qZWN0KEN1aUFjdGl2ZVpvbmUsIHtcbiAgICAgICAgc2tpcFNlbGY6IHRydWUsXG4gICAgICAgIG9wdGlvbmFsOiB0cnVlXG4gICAgfSk7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgcmVhZG9ubHkgY3VpQWN0aXZlWm9uZUNoYW5nZSA9IHRoaXMuYWN0aXZlJC5waXBlKFxuICAgICAgICBtYXAoKGVsZW1lbnQpID0+ICEhZWxlbWVudCAmJiB0aGlzLmNvbnRhaW5zKGVsZW1lbnQpKSxcbiAgICAgICAgc3RhcnRXaXRoKGZhbHNlKSxcbiAgICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKSxcbiAgICAgICAgc2tpcCgxKSxcbiAgICAgICAgdGFwKChhY3RpdmUpID0+IHtcbiAgICAgICAgICAgIGlmICghYWN0aXZlICYmIHR5cGVvZiB0aGlzLmNvbnRyb2w/LnZhbHVlQWNjZXNzb3Iub25Ub3VjaGVkID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5jb250cm9sLnZhbHVlQWNjZXNzb3Iub25Ub3VjaGVkKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pLFxuICAgICAgICBjdWlab25lT3B0aW1pemVkKHRoaXMuem9uZSlcbiAgICApO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHRoaXMuZGlyZWN0UGFyZW50QWN0aXZlWm9uZT8uYWRkU3ViQWN0aXZlWm9uZSh0aGlzKTtcbiAgICB9XG5cbiAgICBASW5wdXQoJ2N1aUFjdGl2ZVpvbmVQYXJlbnQnKVxuICAgIHB1YmxpYyBzZXQgY3VpQWN0aXZlWm9uZVBhcmVudFNldHRlcih6b25lOiBDdWlBY3RpdmVab25lIHwgbnVsbCkge1xuICAgICAgICB0aGlzLnNldFpvbmUoem9uZSk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRpcmVjdFBhcmVudEFjdGl2ZVpvbmU/LnJlbW92ZVN1YkFjdGl2ZVpvbmUodGhpcyk7XG4gICAgICAgIHRoaXMuY3VpQWN0aXZlWm9uZVBhcmVudD8ucmVtb3ZlU3ViQWN0aXZlWm9uZSh0aGlzKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY29udGFpbnMobm9kZTogTm9kZSk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgdGhpcy5lbC5jb250YWlucyhub2RlKSB8fFxuICAgICAgICAgICAgdGhpcy5zdWJBY3RpdmVab25lcy5zb21lKChpdGVtLCBpbmRleCwgYXJyYXkpID0+IGFycmF5LmluZGV4T2YoaXRlbSkgPT09IGluZGV4ICYmIGl0ZW0uY29udGFpbnMobm9kZSkpXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgQGN1aVB1cmVcbiAgICBwcml2YXRlIHNldFpvbmUoem9uZTogQ3VpQWN0aXZlWm9uZSB8IG51bGwpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jdWlBY3RpdmVab25lUGFyZW50Py5yZW1vdmVTdWJBY3RpdmVab25lKHRoaXMpO1xuICAgICAgICB6b25lPy5hZGRTdWJBY3RpdmVab25lKHRoaXMpO1xuICAgICAgICB0aGlzLmN1aUFjdGl2ZVpvbmVQYXJlbnQgPSB6b25lO1xuICAgIH1cblxuICAgIHByaXZhdGUgYWRkU3ViQWN0aXZlWm9uZShhY3RpdmVab25lOiBDdWlBY3RpdmVab25lKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc3ViQWN0aXZlWm9uZXMgPSBbLi4udGhpcy5zdWJBY3RpdmVab25lcywgYWN0aXZlWm9uZV07XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZW1vdmVTdWJBY3RpdmVab25lKGFjdGl2ZVpvbmU6IEN1aUFjdGl2ZVpvbmUpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zdWJBY3RpdmVab25lcyA9IGN1aUFycmF5UmVtb3ZlKHRoaXMuc3ViQWN0aXZlWm9uZXMsIHRoaXMuc3ViQWN0aXZlWm9uZXMuaW5kZXhPZihhY3RpdmVab25lKSk7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './active-zone.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jZGsvZGlyZWN0aXZlcy9hY3RpdmUtem9uZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY3RpdmUtem9uZS5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostListener, inject } from '@angular/core';
|
|
2
|
+
import { NgControl, NgModel } from '@angular/forms';
|
|
3
|
+
import { takeUntil } from 'rxjs';
|
|
4
|
+
import { CUI_WINDOW } from '../tokens';
|
|
5
|
+
import { CuiDestroyService } from '../services';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class CuiAutoResizingDirective {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.window = inject(CUI_WINDOW);
|
|
10
|
+
this.element = inject(ElementRef).nativeElement;
|
|
11
|
+
this.ngControl = inject(NgControl, { self: true, optional: true });
|
|
12
|
+
this.ngModel = inject(NgModel, { self: true, optional: true });
|
|
13
|
+
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
14
|
+
this.elementStyles = this.element.style;
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.initNgControlValueChangeSubscription();
|
|
18
|
+
this.initNgModelValueChangeSubscription();
|
|
19
|
+
}
|
|
20
|
+
ngAfterViewChecked() {
|
|
21
|
+
this.resize();
|
|
22
|
+
}
|
|
23
|
+
onInput() {
|
|
24
|
+
this.resize();
|
|
25
|
+
}
|
|
26
|
+
initNgControlValueChangeSubscription() {
|
|
27
|
+
if (!this.ngControl) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
this.ngControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(this.resize.bind(this));
|
|
31
|
+
}
|
|
32
|
+
initNgModelValueChangeSubscription() {
|
|
33
|
+
if (!this.ngModel) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
this.ngModel.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(this.resize.bind(this));
|
|
37
|
+
}
|
|
38
|
+
resize() {
|
|
39
|
+
const { maxHeight: computedMaxHeight, borderTopWidth, borderBottomWidth } = this.window.getComputedStyle(this.element);
|
|
40
|
+
this.elementStyles.height = 'auto';
|
|
41
|
+
this.elementStyles.height =
|
|
42
|
+
this.element.scrollHeight + parseFloat(borderTopWidth) + parseFloat(borderBottomWidth) + 'px';
|
|
43
|
+
if (parseFloat(this.element.style.height) < parseFloat(computedMaxHeight)) {
|
|
44
|
+
this.elementStyles.overflow = 'hidden';
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
this.elementStyles.overflowY = 'scroll';
|
|
48
|
+
this.elementStyles.height = computedMaxHeight;
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiAutoResizingDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
51
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CuiAutoResizingDirective, isStandalone: true, selector: "textarea[cuiAutoResizing]", host: { listeners: { "input": "onInput()" } }, providers: [CuiDestroyService], ngImport: i0 }); }
|
|
52
|
+
}
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiAutoResizingDirective, decorators: [{
|
|
54
|
+
type: Directive,
|
|
55
|
+
args: [{
|
|
56
|
+
standalone: true,
|
|
57
|
+
selector: 'textarea[cuiAutoResizing]',
|
|
58
|
+
providers: [CuiDestroyService]
|
|
59
|
+
}]
|
|
60
|
+
}], propDecorators: { onInput: [{
|
|
61
|
+
type: HostListener,
|
|
62
|
+
args: ['input']
|
|
63
|
+
}] } });
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0by1yZXNpemluZy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jZGsvZGlyZWN0aXZlcy9hdXRvLXJlc2l6aW5nLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVFLE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVqQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFPaEQsTUFBTSxPQUFPLHdCQUF3QjtJQUxyQztRQU1xQixXQUFNLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzVCLFlBQU8sR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsYUFBNEIsQ0FBQztRQUMxRCxjQUFTLEdBQUcsTUFBTSxDQUFDLFNBQVMsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDOUQsWUFBTyxHQUFHLE1BQU0sQ0FBQyxPQUFPLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQzFELGFBQVEsR0FBRyxNQUFNLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUVyRCxrQkFBYSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO0tBb0R2RDtJQWxEVSxRQUFRO1FBQ1gsSUFBSSxDQUFDLG9DQUFvQyxFQUFFLENBQUM7UUFDNUMsSUFBSSxDQUFDLGtDQUFrQyxFQUFFLENBQUM7SUFDOUMsQ0FBQztJQUVNLGtCQUFrQjtRQUNyQixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDbEIsQ0FBQztJQUdTLE9BQU87UUFDYixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDbEIsQ0FBQztJQUVPLG9DQUFvQztRQUN4QyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2xCLE9BQU87UUFDWCxDQUFDO1FBRUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFhLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUNsRyxDQUFDO0lBRU8sa0NBQWtDO1FBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDaEIsT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ2hHLENBQUM7SUFFTyxNQUFNO1FBQ1YsTUFBTSxFQUNGLFNBQVMsRUFBRSxpQkFBaUIsRUFDNUIsY0FBYyxFQUNkLGlCQUFpQixFQUNwQixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRS9DLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNuQyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU07WUFDckIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEdBQUcsVUFBVSxDQUFDLGNBQWMsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUVsRyxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxVQUFVLENBQUMsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1lBQ3hFLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztZQUV2QyxPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztRQUN4QyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxpQkFBaUIsQ0FBQztJQUNsRCxDQUFDOytHQTFEUSx3QkFBd0I7bUdBQXhCLHdCQUF3Qix1SEFGdEIsQ0FBQyxpQkFBaUIsQ0FBQzs7NEZBRXJCLHdCQUF3QjtrQkFMcEMsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsU0FBUyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQ2pDOzhCQW9CYSxPQUFPO3NCQURoQixZQUFZO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEFmdGVyVmlld0NoZWNrZWQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDb250cm9sLCBOZ01vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IENVSV9XSU5ET1cgfSBmcm9tICcuLi90b2tlbnMnO1xuaW1wb3J0IHsgQ3VpRGVzdHJveVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICd0ZXh0YXJlYVtjdWlBdXRvUmVzaXppbmddJyxcbiAgICBwcm92aWRlcnM6IFtDdWlEZXN0cm95U2VydmljZV1cbn0pXG5leHBvcnQgY2xhc3MgQ3VpQXV0b1Jlc2l6aW5nRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdDaGVja2VkIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHdpbmRvdyA9IGluamVjdChDVUlfV0lORE9XKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnQgPSBpbmplY3QoRWxlbWVudFJlZikubmF0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudDtcbiAgICBwcml2YXRlIHJlYWRvbmx5IG5nQ29udHJvbCA9IGluamVjdChOZ0NvbnRyb2wsIHsgc2VsZjogdHJ1ZSwgb3B0aW9uYWw6IHRydWUgfSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBuZ01vZGVsID0gaW5qZWN0KE5nTW9kZWwsIHsgc2VsZjogdHJ1ZSwgb3B0aW9uYWw6IHRydWUgfSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBkZXN0cm95JCA9IGluamVjdChDdWlEZXN0cm95U2VydmljZSwgeyBzZWxmOiB0cnVlIH0pO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50U3R5bGVzID0gdGhpcy5lbGVtZW50LnN0eWxlO1xuXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmluaXROZ0NvbnRyb2xWYWx1ZUNoYW5nZVN1YnNjcmlwdGlvbigpO1xuICAgICAgICB0aGlzLmluaXROZ01vZGVsVmFsdWVDaGFuZ2VTdWJzY3JpcHRpb24oKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgbmdBZnRlclZpZXdDaGVja2VkKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnJlc2l6ZSgpO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2lucHV0JylcbiAgICBwcm90ZWN0ZWQgb25JbnB1dCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5yZXNpemUoKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGluaXROZ0NvbnRyb2xWYWx1ZUNoYW5nZVN1YnNjcmlwdGlvbigpOiB2b2lkIHtcbiAgICAgICAgaWYgKCF0aGlzLm5nQ29udHJvbCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5uZ0NvbnRyb2wudmFsdWVDaGFuZ2VzIS5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3kkKSkuc3Vic2NyaWJlKHRoaXMucmVzaXplLmJpbmQodGhpcykpO1xuICAgIH1cblxuICAgIHByaXZhdGUgaW5pdE5nTW9kZWxWYWx1ZUNoYW5nZVN1YnNjcmlwdGlvbigpOiB2b2lkIHtcbiAgICAgICAgaWYgKCF0aGlzLm5nTW9kZWwpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMubmdNb2RlbC52YWx1ZUNoYW5nZXMhLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKS5zdWJzY3JpYmUodGhpcy5yZXNpemUuYmluZCh0aGlzKSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZXNpemUoKTogdm9pZCB7XG4gICAgICAgIGNvbnN0IHtcbiAgICAgICAgICAgIG1heEhlaWdodDogY29tcHV0ZWRNYXhIZWlnaHQsXG4gICAgICAgICAgICBib3JkZXJUb3BXaWR0aCxcbiAgICAgICAgICAgIGJvcmRlckJvdHRvbVdpZHRoXG4gICAgICAgIH0gPSB0aGlzLndpbmRvdy5nZXRDb21wdXRlZFN0eWxlKHRoaXMuZWxlbWVudCk7XG5cbiAgICAgICAgdGhpcy5lbGVtZW50U3R5bGVzLmhlaWdodCA9ICdhdXRvJztcbiAgICAgICAgdGhpcy5lbGVtZW50U3R5bGVzLmhlaWdodCA9XG4gICAgICAgICAgICB0aGlzLmVsZW1lbnQuc2Nyb2xsSGVpZ2h0ICsgcGFyc2VGbG9hdChib3JkZXJUb3BXaWR0aCkgKyBwYXJzZUZsb2F0KGJvcmRlckJvdHRvbVdpZHRoKSArICdweCc7XG5cbiAgICAgICAgaWYgKHBhcnNlRmxvYXQodGhpcy5lbGVtZW50LnN0eWxlLmhlaWdodCkgPCBwYXJzZUZsb2F0KGNvbXB1dGVkTWF4SGVpZ2h0KSkge1xuICAgICAgICAgICAgdGhpcy5lbGVtZW50U3R5bGVzLm92ZXJmbG93ID0gJ2hpZGRlbic7XG5cbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuZWxlbWVudFN0eWxlcy5vdmVyZmxvd1kgPSAnc2Nyb2xsJztcbiAgICAgICAgdGhpcy5lbGVtZW50U3R5bGVzLmhlaWdodCA9IGNvbXB1dGVkTWF4SGVpZ2h0O1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Directive, ElementRef, EventEmitter, HostListener, inject, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CuiClickOutsideDirective {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.element = inject(ElementRef).nativeElement;
|
|
6
|
+
this.cuiClickOutside = new EventEmitter();
|
|
7
|
+
}
|
|
8
|
+
onClickOutside(target) {
|
|
9
|
+
if (this.element.contains(target)) {
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
this.cuiClickOutside.emit(target);
|
|
13
|
+
}
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiClickOutsideDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
15
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CuiClickOutsideDirective, isStandalone: true, selector: "(cuiClickOutside)", outputs: { cuiClickOutside: "cuiClickOutside" }, host: { listeners: { "document:click": "onClickOutside($event.target)" } }, ngImport: i0 }); }
|
|
16
|
+
}
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiClickOutsideDirective, decorators: [{
|
|
18
|
+
type: Directive,
|
|
19
|
+
args: [{
|
|
20
|
+
standalone: true,
|
|
21
|
+
selector: '(cuiClickOutside)'
|
|
22
|
+
}]
|
|
23
|
+
}], propDecorators: { cuiClickOutside: [{
|
|
24
|
+
type: Output
|
|
25
|
+
}], onClickOutside: [{
|
|
26
|
+
type: HostListener,
|
|
27
|
+
args: ['document:click', ['$event.target']]
|
|
28
|
+
}] } });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jZGsvZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTWxHLE1BQU0sT0FBTyx3QkFBd0I7SUFKckM7UUFLcUIsWUFBTyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFHckQsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBZSxDQUFDO0tBVTVEO0lBUGEsY0FBYyxDQUFDLE1BQW1CO1FBQ3hDLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUNoQyxPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7K0dBYlEsd0JBQXdCO21HQUF4Qix3QkFBd0I7OzRGQUF4Qix3QkFBd0I7a0JBSnBDLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxtQkFBbUI7aUJBQ2hDOzhCQUtVLGVBQWU7c0JBRHJCLE1BQU07Z0JBSUcsY0FBYztzQkFEdkIsWUFBWTt1QkFBQyxnQkFBZ0IsRUFBRSxDQUFDLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBIb3N0TGlzdGVuZXIsIGluamVjdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICcoY3VpQ2xpY2tPdXRzaWRlKSdcbn0pXG5leHBvcnQgY2xhc3MgQ3VpQ2xpY2tPdXRzaWRlRGlyZWN0aXZlIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnQgPSBpbmplY3QoRWxlbWVudFJlZikubmF0aXZlRWxlbWVudDtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBjdWlDbGlja091dHNpZGUgPSBuZXcgRXZlbnRFbWl0dGVyPEhUTUxFbGVtZW50PigpO1xuXG4gICAgQEhvc3RMaXN0ZW5lcignZG9jdW1lbnQ6Y2xpY2snLCBbJyRldmVudC50YXJnZXQnXSlcbiAgICBwcm90ZWN0ZWQgb25DbGlja091dHNpZGUodGFyZ2V0OiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5lbGVtZW50LmNvbnRhaW5zKHRhcmdldCkpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuY3VpQ2xpY2tPdXRzaWRlLmVtaXQodGFyZ2V0KTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostListener, inject } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { cuiProvide } from '../utils/token';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class CuiContentEditableValueAccessorDirective {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.element = inject(ElementRef).nativeElement;
|
|
8
|
+
}
|
|
9
|
+
writeValue(value) {
|
|
10
|
+
this.element.innerText = value ?? '';
|
|
11
|
+
}
|
|
12
|
+
registerOnChange(fn) {
|
|
13
|
+
this.onChange = fn;
|
|
14
|
+
}
|
|
15
|
+
registerOnTouched(fn) {
|
|
16
|
+
this.onTouched = fn;
|
|
17
|
+
}
|
|
18
|
+
setDisabledState(isDisabled) {
|
|
19
|
+
this.element.contentEditable = String(!isDisabled);
|
|
20
|
+
}
|
|
21
|
+
onInput() {
|
|
22
|
+
this.onChange(this.element.innerHTML === '<br>' ? '' : this.element.innerText);
|
|
23
|
+
}
|
|
24
|
+
onBlur() {
|
|
25
|
+
this.onTouched();
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiContentEditableValueAccessorDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
28
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CuiContentEditableValueAccessorDirective, isStandalone: true, selector: "[contenteditable][formControlName], [contenteditable][formControl], [contenteditable][ngModel]", host: { listeners: { "input": "onInput()", "blur": "onBlur()" } }, providers: [cuiProvide(NG_VALUE_ACCESSOR, CuiContentEditableValueAccessorDirective, true)], ngImport: i0 }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiContentEditableValueAccessorDirective, decorators: [{
|
|
31
|
+
type: Directive,
|
|
32
|
+
args: [{
|
|
33
|
+
standalone: true,
|
|
34
|
+
selector: '[contenteditable][formControlName], [contenteditable][formControl], [contenteditable][ngModel]',
|
|
35
|
+
providers: [cuiProvide(NG_VALUE_ACCESSOR, CuiContentEditableValueAccessorDirective, true)]
|
|
36
|
+
}]
|
|
37
|
+
}], propDecorators: { onInput: [{
|
|
38
|
+
type: HostListener,
|
|
39
|
+
args: ['input']
|
|
40
|
+
}], onBlur: [{
|
|
41
|
+
type: HostListener,
|
|
42
|
+
args: ['blur']
|
|
43
|
+
}] } });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC1lZGl0YWJsZS12YWx1ZS1hY2Nlc3Nvci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jZGsvZGlyZWN0aXZlcy9jb250ZW50LWVkaXRhYmxlLXZhbHVlLWFjY2Vzc29yLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBSW5ELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFPNUMsTUFBTSxPQUFPLHdDQUF3QztJQUxyRDtRQU1xQixZQUFPLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLGFBQTRCLENBQUM7S0E4QjlFO0lBekJVLFVBQVUsQ0FBQyxLQUEwQjtRQUN4QyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDO0lBQ3pDLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxFQUF1QjtRQUMzQyxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRU0saUJBQWlCLENBQUMsRUFBZ0I7UUFDckMsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVNLGdCQUFnQixDQUFDLFVBQW1CO1FBQ3ZDLElBQUksQ0FBQyxPQUFPLENBQUMsZUFBZSxHQUFHLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFHUyxPQUFPO1FBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNuRixDQUFDO0lBR1MsTUFBTTtRQUNaLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNyQixDQUFDOytHQTlCUSx3Q0FBd0M7bUdBQXhDLHdDQUF3QyxnTkFGdEMsQ0FBQyxVQUFVLENBQUMsaUJBQWlCLEVBQUUsd0NBQXdDLEVBQUUsSUFBSSxDQUFDLENBQUM7OzRGQUVqRix3Q0FBd0M7a0JBTHBELFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxnR0FBZ0c7b0JBQzFHLFNBQVMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsNENBQTRDLElBQUksQ0FBQyxDQUFDO2lCQUM3Rjs4QkF3QmEsT0FBTztzQkFEaEIsWUFBWTt1QkFBQyxPQUFPO2dCQU1YLE1BQU07c0JBRGYsWUFBWTt1QkFBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBDb250cm9sVmFsdWVBY2Nlc3NvciB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgdHlwZSB7IEN1aU51bGxhYmxlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHR5cGUgeyBDdWlPbkNoYW5nZSwgQ3VpT25Ub3VjaGVkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBjdWlQcm92aWRlIH0gZnJvbSAnLi4vdXRpbHMvdG9rZW4nO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnW2NvbnRlbnRlZGl0YWJsZV1bZm9ybUNvbnRyb2xOYW1lXSwgW2NvbnRlbnRlZGl0YWJsZV1bZm9ybUNvbnRyb2xdLCBbY29udGVudGVkaXRhYmxlXVtuZ01vZGVsXScsXG4gICAgcHJvdmlkZXJzOiBbY3VpUHJvdmlkZShOR19WQUxVRV9BQ0NFU1NPUiwgQ3VpQ29udGVudEVkaXRhYmxlVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSwgdHJ1ZSldXG59KVxuZXhwb3J0IGNsYXNzIEN1aUNvbnRlbnRFZGl0YWJsZVZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50ID0gaW5qZWN0KEVsZW1lbnRSZWYpLm5hdGl2ZUVsZW1lbnQgYXMgSFRNTEVsZW1lbnQ7XG5cbiAgICBwcm90ZWN0ZWQgb25DaGFuZ2UhOiBDdWlPbkNoYW5nZTxzdHJpbmc+O1xuICAgIHByb3RlY3RlZCBvblRvdWNoZWQhOiBDdWlPblRvdWNoZWQ7XG5cbiAgICBwdWJsaWMgd3JpdGVWYWx1ZSh2YWx1ZTogQ3VpTnVsbGFibGU8c3RyaW5nPik6IHZvaWQge1xuICAgICAgICB0aGlzLmVsZW1lbnQuaW5uZXJUZXh0ID0gdmFsdWUgPz8gJyc7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZ2lzdGVyT25DaGFuZ2UoZm46IEN1aU9uQ2hhbmdlPHN0cmluZz4pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICAgIH1cblxuICAgIHB1YmxpYyByZWdpc3Rlck9uVG91Y2hlZChmbjogQ3VpT25Ub3VjaGVkKTogdm9pZCB7XG4gICAgICAgIHRoaXMub25Ub3VjaGVkID0gZm47XG4gICAgfVxuXG4gICAgcHVibGljIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgICAgICB0aGlzLmVsZW1lbnQuY29udGVudEVkaXRhYmxlID0gU3RyaW5nKCFpc0Rpc2FibGVkKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdpbnB1dCcpXG4gICAgcHJvdGVjdGVkIG9uSW5wdXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMub25DaGFuZ2UodGhpcy5lbGVtZW50LmlubmVySFRNTCA9PT0gJzxicj4nID8gJycgOiB0aGlzLmVsZW1lbnQuaW5uZXJUZXh0KTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdibHVyJylcbiAgICBwcm90ZWN0ZWQgb25CbHVyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uVG91Y2hlZCgpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Directive, ElementRef, EventEmitter, inject, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CuiDimensionsObserverDirective {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.element = inject(ElementRef).nativeElement;
|
|
6
|
+
this.observer = new ResizeObserver((entries) => {
|
|
7
|
+
entries.forEach(() => this.cuiResizeObserver.emit({
|
|
8
|
+
width: this.element.offsetWidth,
|
|
9
|
+
height: this.element.offsetHeight
|
|
10
|
+
}));
|
|
11
|
+
});
|
|
12
|
+
this.cuiResizeObserver = new EventEmitter();
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
this.observer.observe(this.element);
|
|
16
|
+
}
|
|
17
|
+
ngOnDestroy() {
|
|
18
|
+
this.observer.disconnect();
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDimensionsObserverDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
21
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CuiDimensionsObserverDirective, isStandalone: true, selector: "[cuiResizeObserver]", outputs: { cuiResizeObserver: "cuiResizeObserver" }, ngImport: i0 }); }
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDimensionsObserverDirective, decorators: [{
|
|
24
|
+
type: Directive,
|
|
25
|
+
args: [{
|
|
26
|
+
standalone: true,
|
|
27
|
+
selector: '[cuiResizeObserver]'
|
|
28
|
+
}]
|
|
29
|
+
}], propDecorators: { cuiResizeObserver: [{
|
|
30
|
+
type: Output
|
|
31
|
+
}] } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9ucy1vYnNlcnZlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jZGsvZGlyZWN0aXZlcy9kaW1lbnNpb25zLW9ic2VydmVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRcEYsTUFBTSxPQUFPLDhCQUE4QjtJQUozQztRQUtxQixZQUFPLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLGFBQTRCLENBQUM7UUFFMUQsYUFBUSxHQUFHLElBQUksY0FBYyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDdkQsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FDakIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQztnQkFDeEIsS0FBSyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVztnQkFDL0IsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWTthQUNwQyxDQUFDLENBQ0wsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO1FBR0ksc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQWlCLENBQUM7S0FTaEU7SUFQVSxRQUFRO1FBQ1gsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUMvQixDQUFDOytHQXJCUSw4QkFBOEI7bUdBQTlCLDhCQUE4Qjs7NEZBQTlCLDhCQUE4QjtrQkFKMUMsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLHFCQUFxQjtpQkFDbEM7OEJBY1UsaUJBQWlCO3NCQUR2QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPbkluaXQsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIGluamVjdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB0eXBlIHsgQ3VpRGltZW5zaW9ucyB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnW2N1aVJlc2l6ZU9ic2VydmVyXSdcbn0pXG5leHBvcnQgY2xhc3MgQ3VpRGltZW5zaW9uc09ic2VydmVyRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZWxlbWVudCA9IGluamVjdChFbGVtZW50UmVmKS5uYXRpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50O1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBvYnNlcnZlciA9IG5ldyBSZXNpemVPYnNlcnZlcigoZW50cmllcykgPT4ge1xuICAgICAgICBlbnRyaWVzLmZvckVhY2goKCkgPT5cbiAgICAgICAgICAgIHRoaXMuY3VpUmVzaXplT2JzZXJ2ZXIuZW1pdCh7XG4gICAgICAgICAgICAgICAgd2lkdGg6IHRoaXMuZWxlbWVudC5vZmZzZXRXaWR0aCxcbiAgICAgICAgICAgICAgICBoZWlnaHQ6IHRoaXMuZWxlbWVudC5vZmZzZXRIZWlnaHRcbiAgICAgICAgICAgIH0pXG4gICAgICAgICk7XG4gICAgfSk7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgY3VpUmVzaXplT2JzZXJ2ZXIgPSBuZXcgRXZlbnRFbWl0dGVyPEN1aURpbWVuc2lvbnM+KCk7XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMub2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLmVsZW1lbnQpO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { Directive, ElementRef, inject, input, NgZone, output, Renderer2, signal } from '@angular/core';
|
|
3
|
+
import { CuiDragListDirective } from './drag-list.directive';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class CuiDragDropDirective {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.zone = inject(NgZone);
|
|
8
|
+
this.document = inject(DOCUMENT);
|
|
9
|
+
this.renderer = inject(Renderer2);
|
|
10
|
+
this.element = inject(ElementRef).nativeElement;
|
|
11
|
+
this.dragListDirective = inject(CuiDragListDirective);
|
|
12
|
+
this.PLACEHOLDER_CLASS = 'cui-drag-drop-placeholder';
|
|
13
|
+
this.listId = this.dragListDirective.listId;
|
|
14
|
+
this.itemAttribute = `${this.listId}-drag-item`;
|
|
15
|
+
this.abortController = new AbortController();
|
|
16
|
+
this.hostAbortController = new AbortController();
|
|
17
|
+
this.draggingElement = signal(null);
|
|
18
|
+
this.placeholderElement = signal(null);
|
|
19
|
+
this.dragData = signal({});
|
|
20
|
+
this.disabled = input(false);
|
|
21
|
+
this.elementDragged = output();
|
|
22
|
+
this.initDragItem();
|
|
23
|
+
this.initPointerEvents(this.element);
|
|
24
|
+
}
|
|
25
|
+
ngOnDestroy() {
|
|
26
|
+
this.destroyEvents();
|
|
27
|
+
}
|
|
28
|
+
changePointerEvents(element) {
|
|
29
|
+
this.hostAbortController.abort();
|
|
30
|
+
this.hostAbortController = new AbortController();
|
|
31
|
+
this.initPointerEvents(element);
|
|
32
|
+
}
|
|
33
|
+
onDrag(clientX, clientY) {
|
|
34
|
+
if (!this.draggingElement()) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const elementsFromPoint = this.document.elementsFromPoint(clientX, clientY);
|
|
38
|
+
const elementFromPoint = elementsFromPoint.find((element) => element.closest(`#${this.listId}`));
|
|
39
|
+
if (!elementFromPoint) {
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const targetElement = elementFromPoint.closest(`[${this.itemAttribute}]`);
|
|
43
|
+
if (!targetElement || targetElement === this.draggingElement()) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
this.configurateDragData(targetElement, clientY);
|
|
47
|
+
}
|
|
48
|
+
onDragStart(event) {
|
|
49
|
+
if (this.disabled()) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
let isClicked = true;
|
|
53
|
+
const elementClientRect = this.element.getBoundingClientRect();
|
|
54
|
+
const shiftX = event.clientX - elementClientRect.left;
|
|
55
|
+
const shiftY = event.clientY - elementClientRect.top;
|
|
56
|
+
this.prevIndex = this.calculatePreviousIndex();
|
|
57
|
+
this.document.addEventListener('pointermove', ({ clientX, clientY }) => {
|
|
58
|
+
if (isClicked) {
|
|
59
|
+
this.prepareMoving();
|
|
60
|
+
isClicked = false;
|
|
61
|
+
}
|
|
62
|
+
const draggingElement = this.draggingElement();
|
|
63
|
+
this.renderer.setStyle(draggingElement, 'left', clientX - shiftX + 'px');
|
|
64
|
+
this.renderer.setStyle(draggingElement, 'top', clientY - shiftY + 'px');
|
|
65
|
+
this.onDrag(clientX, clientY);
|
|
66
|
+
}, { signal: this.abortController.signal });
|
|
67
|
+
}
|
|
68
|
+
onDragEnd() {
|
|
69
|
+
const { targetElement, pointer } = this.dragData();
|
|
70
|
+
if (targetElement && pointer) {
|
|
71
|
+
this.elementDragged.emit({
|
|
72
|
+
index: this.index,
|
|
73
|
+
prevIndex: this.prevIndex,
|
|
74
|
+
targetElement,
|
|
75
|
+
pointer
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
// remove document events
|
|
79
|
+
this.abortController.abort();
|
|
80
|
+
this.abortController = new AbortController();
|
|
81
|
+
this.removeDragElement();
|
|
82
|
+
this.removePlaceholder();
|
|
83
|
+
this.dragData.set({});
|
|
84
|
+
}
|
|
85
|
+
initDragItem() {
|
|
86
|
+
this.renderer.setAttribute(this.element, this.itemAttribute, 'true');
|
|
87
|
+
}
|
|
88
|
+
initPointerEvents(element) {
|
|
89
|
+
const signal = this.hostAbortController.signal;
|
|
90
|
+
this.zone.runOutsideAngular(() => {
|
|
91
|
+
element.addEventListener('pointerup', this.onDragEnd.bind(this), { signal });
|
|
92
|
+
element.addEventListener('pointerdown', this.onDragStart.bind(this), { signal });
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
destroyEvents() {
|
|
96
|
+
this.hostAbortController.abort();
|
|
97
|
+
this.abortController.abort();
|
|
98
|
+
}
|
|
99
|
+
prepareMoving() {
|
|
100
|
+
const placeholderElement = this.createPlaceholderElement();
|
|
101
|
+
const draggingElement = this.createDragElement();
|
|
102
|
+
this.document.addEventListener('pointerup', this.onDragEnd.bind(this), {
|
|
103
|
+
signal: this.abortController.signal
|
|
104
|
+
});
|
|
105
|
+
this.element.after(placeholderElement);
|
|
106
|
+
this.draggingElement.set(draggingElement);
|
|
107
|
+
this.element.remove();
|
|
108
|
+
this.document.body.append(draggingElement);
|
|
109
|
+
}
|
|
110
|
+
configurateDragData(targetElement, clientY) {
|
|
111
|
+
const placeholderElement = this.placeholderElement();
|
|
112
|
+
const boundingRect = targetElement.getBoundingClientRect();
|
|
113
|
+
const middleY = boundingRect.top + boundingRect.height / 2;
|
|
114
|
+
if (clientY < middleY) {
|
|
115
|
+
targetElement.before(placeholderElement);
|
|
116
|
+
this.dragData.set({ targetElement, pointer: 'BEFORE' });
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
targetElement.after(placeholderElement);
|
|
120
|
+
this.dragData.set({ targetElement, pointer: 'AFTER' });
|
|
121
|
+
}
|
|
122
|
+
this.index = this.calculateIndex(placeholderElement);
|
|
123
|
+
}
|
|
124
|
+
createDragElement() {
|
|
125
|
+
const width = this.element.clientWidth;
|
|
126
|
+
const draggingElement = this.element.cloneNode(true);
|
|
127
|
+
this.renderer.setStyle(draggingElement, 'position', 'fixed');
|
|
128
|
+
this.renderer.setStyle(draggingElement, 'display', 'block');
|
|
129
|
+
this.renderer.setStyle(draggingElement, 'margin', '0');
|
|
130
|
+
this.renderer.setStyle(draggingElement, 'width', `${width}px`);
|
|
131
|
+
return draggingElement;
|
|
132
|
+
}
|
|
133
|
+
createPlaceholderElement() {
|
|
134
|
+
const element = this.placeholderElement();
|
|
135
|
+
if (element) {
|
|
136
|
+
return element;
|
|
137
|
+
}
|
|
138
|
+
const placeholderElement = this.renderer.createElement('div');
|
|
139
|
+
this.renderer.addClass(placeholderElement, this.PLACEHOLDER_CLASS);
|
|
140
|
+
this.placeholderElement.set(placeholderElement);
|
|
141
|
+
return placeholderElement;
|
|
142
|
+
}
|
|
143
|
+
removeDragElement() {
|
|
144
|
+
const draggingElement = this.draggingElement();
|
|
145
|
+
if (!draggingElement) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
draggingElement.remove();
|
|
149
|
+
this.draggingElement.set(null);
|
|
150
|
+
}
|
|
151
|
+
removePlaceholder() {
|
|
152
|
+
const placeholderElement = this.placeholderElement();
|
|
153
|
+
if (!placeholderElement) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
placeholderElement.after(this.element);
|
|
157
|
+
placeholderElement.remove();
|
|
158
|
+
this.placeholderElement.set(null);
|
|
159
|
+
}
|
|
160
|
+
calculateIndex(placeholderElement) {
|
|
161
|
+
const childNodes = placeholderElement.parentElement.childNodes;
|
|
162
|
+
const elements = Array.from(childNodes).filter((node) => node instanceof HTMLElement);
|
|
163
|
+
return elements.indexOf(placeholderElement);
|
|
164
|
+
}
|
|
165
|
+
calculatePreviousIndex() {
|
|
166
|
+
let index = 0;
|
|
167
|
+
let currentElement = this.element;
|
|
168
|
+
while (currentElement && currentElement.previousElementSibling) {
|
|
169
|
+
index++;
|
|
170
|
+
currentElement = currentElement.previousElementSibling;
|
|
171
|
+
}
|
|
172
|
+
return index;
|
|
173
|
+
}
|
|
174
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDragDropDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
175
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: CuiDragDropDirective, isStandalone: true, selector: "[cuiDragDrop]", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { elementDragged: "elementDragged" }, ngImport: i0 }); }
|
|
176
|
+
}
|
|
177
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDragDropDirective, decorators: [{
|
|
178
|
+
type: Directive,
|
|
179
|
+
args: [{
|
|
180
|
+
selector: '[cuiDragDrop]',
|
|
181
|
+
standalone: true
|
|
182
|
+
}]
|
|
183
|
+
}], ctorParameters: () => [] });
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-drop.directive.js","sourceRoot":"","sources":["../../../../../projects/cdk/directives/drag-drop/drag-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport type { OnDestroy } from '@angular/core';\r\nimport { Directive, ElementRef, inject, input, NgZone, output, Renderer2, signal } from '@angular/core';\r\nimport type { CuiNullable } from '../../types';\r\n\r\nimport type { CuiDragData, CuiDragDropData } from './drag-drop.options';\r\nimport { CuiDragListDirective } from './drag-list.directive';\r\n\r\n@Directive({\r\n    selector: '[cuiDragDrop]',\r\n    standalone: true\r\n})\r\nexport class CuiDragDropDirective implements OnDestroy {\r\n    private readonly zone = inject(NgZone);\r\n    private readonly document = inject(DOCUMENT);\r\n    private readonly renderer = inject(Renderer2);\r\n    private readonly element = inject(ElementRef).nativeElement;\r\n    private readonly dragListDirective = inject(CuiDragListDirective);\r\n\r\n    private readonly PLACEHOLDER_CLASS = 'cui-drag-drop-placeholder';\r\n\r\n    private readonly listId = this.dragListDirective.listId;\r\n    private readonly itemAttribute = `${this.listId}-drag-item`;\r\n\r\n    private index!: number;\r\n    private prevIndex!: number;\r\n    private abortController = new AbortController();\r\n    private hostAbortController = new AbortController();\r\n\r\n    protected readonly draggingElement = signal<CuiNullable<HTMLElement>>(null);\r\n    protected readonly placeholderElement = signal<CuiNullable<HTMLElement>>(null);\r\n    protected readonly dragData = signal<CuiDragData>({});\r\n\r\n    public readonly disabled = input(false);\r\n\r\n    public readonly elementDragged = output<CuiDragDropData>();\r\n\r\n    constructor() {\r\n        this.initDragItem();\r\n        this.initPointerEvents(this.element);\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.destroyEvents();\r\n    }\r\n\r\n    public changePointerEvents(element: HTMLElement): void {\r\n        this.hostAbortController.abort();\r\n        this.hostAbortController = new AbortController();\r\n\r\n        this.initPointerEvents(element);\r\n    }\r\n\r\n    private onDrag(clientX: number, clientY: number): void {\r\n        if (!this.draggingElement()) {\r\n            return;\r\n        }\r\n\r\n        const elementsFromPoint = this.document.elementsFromPoint(clientX, clientY);\r\n        const elementFromPoint = elementsFromPoint.find((element) => element.closest(`#${this.listId}`));\r\n\r\n        if (!elementFromPoint) {\r\n            return;\r\n        }\r\n\r\n        const targetElement = elementFromPoint.closest<HTMLElement>(`[${this.itemAttribute}]`);\r\n\r\n        if (!targetElement || targetElement === this.draggingElement()) {\r\n            return;\r\n        }\r\n\r\n        this.configurateDragData(targetElement, clientY);\r\n    }\r\n\r\n    private onDragStart(event: MouseEvent): void {\r\n        if (this.disabled()) {\r\n            return;\r\n        }\r\n\r\n        let isClicked = true;\r\n\r\n        const elementClientRect = this.element.getBoundingClientRect();\r\n        const shiftX = event.clientX - elementClientRect.left;\r\n        const shiftY = event.clientY - elementClientRect.top;\r\n\r\n        this.prevIndex = this.calculatePreviousIndex();\r\n\r\n        this.document.addEventListener(\r\n            'pointermove',\r\n            ({ clientX, clientY }) => {\r\n                if (isClicked) {\r\n                    this.prepareMoving();\r\n\r\n                    isClicked = false;\r\n                }\r\n\r\n                const draggingElement = this.draggingElement();\r\n\r\n                this.renderer.setStyle(draggingElement, 'left', clientX - shiftX + 'px');\r\n                this.renderer.setStyle(draggingElement, 'top', clientY - shiftY + 'px');\r\n                this.onDrag(clientX, clientY);\r\n            },\r\n            { signal: this.abortController.signal }\r\n        );\r\n    }\r\n\r\n    private onDragEnd(): void {\r\n        const { targetElement, pointer } = this.dragData();\r\n\r\n        if (targetElement && pointer) {\r\n            this.elementDragged.emit({\r\n                index: this.index,\r\n                prevIndex: this.prevIndex,\r\n                targetElement,\r\n                pointer\r\n            });\r\n        }\r\n\r\n        // remove document events\r\n        this.abortController.abort();\r\n        this.abortController = new AbortController();\r\n\r\n        this.removeDragElement();\r\n        this.removePlaceholder();\r\n        this.dragData.set({});\r\n    }\r\n\r\n    private initDragItem(): void {\r\n        this.renderer.setAttribute(this.element, this.itemAttribute, 'true');\r\n    }\r\n\r\n    private initPointerEvents(element: HTMLElement): void {\r\n        const signal = this.hostAbortController.signal;\r\n\r\n        this.zone.runOutsideAngular(() => {\r\n            element.addEventListener('pointerup', this.onDragEnd.bind(this), { signal });\r\n            element.addEventListener('pointerdown', this.onDragStart.bind(this), { signal });\r\n        });\r\n    }\r\n\r\n    private destroyEvents(): void {\r\n        this.hostAbortController.abort();\r\n        this.abortController.abort();\r\n    }\r\n\r\n    private prepareMoving(): void {\r\n        const placeholderElement = this.createPlaceholderElement();\r\n        const draggingElement = this.createDragElement();\r\n\r\n        this.document.addEventListener('pointerup', this.onDragEnd.bind(this), {\r\n            signal: this.abortController.signal\r\n        });\r\n\r\n        this.element.after(placeholderElement);\r\n        this.draggingElement.set(draggingElement);\r\n\r\n        this.element.remove();\r\n        this.document.body.append(draggingElement);\r\n    }\r\n\r\n    private configurateDragData(targetElement: HTMLElement, clientY: number): void {\r\n        const placeholderElement = this.placeholderElement();\r\n        const boundingRect = targetElement.getBoundingClientRect();\r\n        const middleY = boundingRect.top + boundingRect.height / 2;\r\n\r\n        if (clientY < middleY) {\r\n            targetElement.before(placeholderElement!);\r\n            this.dragData.set({ targetElement, pointer: 'BEFORE' });\r\n        } else {\r\n            targetElement.after(placeholderElement!);\r\n            this.dragData.set({ targetElement, pointer: 'AFTER' });\r\n        }\r\n\r\n        this.index = this.calculateIndex(placeholderElement!);\r\n    }\r\n\r\n    private createDragElement(): HTMLElement {\r\n        const width = this.element.clientWidth;\r\n        const draggingElement = this.element.cloneNode(true) as HTMLElement;\r\n\r\n        this.renderer.setStyle(draggingElement, 'position', 'fixed');\r\n        this.renderer.setStyle(draggingElement, 'display', 'block');\r\n        this.renderer.setStyle(draggingElement, 'margin', '0');\r\n        this.renderer.setStyle(draggingElement, 'width', `${width}px`);\r\n\r\n        return draggingElement;\r\n    }\r\n\r\n    private createPlaceholderElement(): HTMLElement {\r\n        const element = this.placeholderElement();\r\n\r\n        if (element) {\r\n            return element;\r\n        }\r\n\r\n        const placeholderElement = this.renderer.createElement('div');\r\n\r\n        this.renderer.addClass(placeholderElement, this.PLACEHOLDER_CLASS);\r\n        this.placeholderElement.set(placeholderElement);\r\n\r\n        return placeholderElement;\r\n    }\r\n\r\n    private removeDragElement(): void {\r\n        const draggingElement = this.draggingElement();\r\n\r\n        if (!draggingElement) {\r\n            return;\r\n        }\r\n\r\n        draggingElement.remove();\r\n        this.draggingElement.set(null);\r\n    }\r\n\r\n    private removePlaceholder(): void {\r\n        const placeholderElement = this.placeholderElement();\r\n\r\n        if (!placeholderElement) {\r\n            return;\r\n        }\r\n\r\n        placeholderElement.after(this.element);\r\n        placeholderElement.remove();\r\n        this.placeholderElement.set(null);\r\n    }\r\n\r\n    private calculateIndex(placeholderElement: HTMLElement): number {\r\n        const childNodes = placeholderElement.parentElement!.childNodes;\r\n        const elements = Array.from(childNodes).filter((node) => node instanceof HTMLElement);\r\n\r\n        return elements.indexOf(placeholderElement!);\r\n    }\r\n\r\n    private calculatePreviousIndex(): number {\r\n        let index = 0;\r\n        let currentElement: Element = this.element;\r\n\r\n        while (currentElement && currentElement.previousElementSibling) {\r\n            index++;\r\n            currentElement = currentElement.previousElementSibling;\r\n        }\r\n\r\n        return index;\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1kcm9wLm9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jZGsvZGlyZWN0aXZlcy9kcmFnLWRyb3AvZHJhZy1kcm9wLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ3VpRHJhZ0Ryb3BEYXRhIHtcclxuICAgIHJlYWRvbmx5IGluZGV4OiBudW1iZXI7XHJcbiAgICByZWFkb25seSBwcmV2SW5kZXg6IG51bWJlcjtcclxuICAgIHJlYWRvbmx5IHBvaW50ZXI6IEN1aURyb3BQb2ludGVyO1xyXG4gICAgcmVhZG9ubHkgdGFyZ2V0RWxlbWVudDogSFRNTEVsZW1lbnQ7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VpRHJhZ0RhdGEge1xyXG4gICAgcmVhZG9ubHkgcG9pbnRlcj86IEN1aURyb3BQb2ludGVyO1xyXG4gICAgcmVhZG9ubHkgdGFyZ2V0RWxlbWVudD86IEhUTUxFbGVtZW50O1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBDdWlEcm9wUG9pbnRlciA9ICdCRUZPUkUnIHwgJ0FGVEVSJztcclxuIl19
|