@recursyve/nice-ui-kit.v2 14.0.0-beta.107 → 14.0.0-beta.109
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/esm2020/lib/components/navigation/components/hint-component-base.mjs +120 -0
- package/esm2020/lib/components/navigation/directives/show-hint.directive.mjs +35 -12
- package/esm2020/lib/components/navigation/public-api.mjs +2 -1
- package/esm2020/lib/directives/draggable-list/draggable-list.directive.mjs +82 -0
- package/esm2020/lib/directives/draggable-list/draggable-list.module.mjs +18 -0
- package/esm2020/lib/directives/draggable-list/index.mjs +2 -0
- package/esm2020/lib/directives/draggable-list/public-api.mjs +3 -0
- package/esm2020/lib/directives/public-api.mjs +2 -1
- package/esm2020/lib/utils/lexorank.utils.mjs +28 -0
- package/esm2020/lib/utils/public-api.mjs +2 -1
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs +271 -11
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs +268 -11
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/lib/components/navigation/components/hint-component-base.d.ts +65 -0
- package/lib/components/navigation/directives/show-hint.directive.d.ts +7 -4
- package/lib/components/navigation/public-api.d.ts +1 -0
- package/lib/directives/draggable-list/draggable-list.directive.d.ts +22 -0
- package/lib/directives/draggable-list/draggable-list.module.d.ts +8 -0
- package/lib/directives/draggable-list/index.d.ts +1 -0
- package/lib/directives/draggable-list/public-api.d.ts +2 -0
- package/lib/directives/public-api.d.ts +1 -0
- package/lib/utils/lexorank.utils.d.ts +6 -0
- package/lib/utils/public-api.d.ts +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Directive, HostListener } from "@angular/core";
|
|
2
|
+
import { Subject } from "rxjs";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
// tslint:disable-next-line:class-name directive-class-suffix
|
|
5
|
+
export class _HintComponentBase {
|
|
6
|
+
constructor(_changeDetectorRef) {
|
|
7
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
8
|
+
/** Whether interactions on the page should close the tooltip */
|
|
9
|
+
this._closeOnInteraction = false;
|
|
10
|
+
/** Whether the tooltip is currently visible. */
|
|
11
|
+
this._isVisible = false;
|
|
12
|
+
/** Subject for notifying that the tooltip has been hidden from the view */
|
|
13
|
+
this._onHide = new Subject();
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Shows the tooltip with an animation originating from the provided origin
|
|
17
|
+
* @param delay Amount of milliseconds to the delay showing the tooltip.
|
|
18
|
+
*/
|
|
19
|
+
show(delay) {
|
|
20
|
+
// Cancel the delayed hide if it is scheduled
|
|
21
|
+
clearTimeout(this._hideTimeoutId);
|
|
22
|
+
this._showTimeoutId = setTimeout(() => {
|
|
23
|
+
this._toggleVisibility(true);
|
|
24
|
+
this._showTimeoutId = undefined;
|
|
25
|
+
}, delay);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Begins the animation to hide the tooltip after the provided delay in ms.
|
|
29
|
+
* @param delay Amount of milliseconds to delay showing the tooltip.
|
|
30
|
+
*/
|
|
31
|
+
hide(delay) {
|
|
32
|
+
// Cancel the delayed show if it is scheduled
|
|
33
|
+
clearTimeout(this._showTimeoutId);
|
|
34
|
+
this._hideTimeoutId = setTimeout(() => {
|
|
35
|
+
this._toggleVisibility(false);
|
|
36
|
+
this._hideTimeoutId = undefined;
|
|
37
|
+
}, delay);
|
|
38
|
+
}
|
|
39
|
+
/** Returns an observable that notifies when the tooltip has been hidden from view. */
|
|
40
|
+
afterHidden() {
|
|
41
|
+
return this._onHide;
|
|
42
|
+
}
|
|
43
|
+
/** Whether the tooltip is being displayed. */
|
|
44
|
+
isVisible() {
|
|
45
|
+
return this._isVisible;
|
|
46
|
+
}
|
|
47
|
+
ngOnDestroy() {
|
|
48
|
+
this._cancelPendingAnimations();
|
|
49
|
+
this._onHide.complete();
|
|
50
|
+
this._triggerElement = null;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Interactions on the HTML body should close the tooltip immediately as defined in the
|
|
54
|
+
* material design spec.
|
|
55
|
+
* https://material.io/design/components/tooltips.html#behavior
|
|
56
|
+
*/
|
|
57
|
+
_handleBodyInteraction() {
|
|
58
|
+
if (this._closeOnInteraction) {
|
|
59
|
+
this.hide(0);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Marks that the tooltip needs to be checked in the next change detection run.
|
|
64
|
+
* Mainly used for rendering the initial text before positioning a tooltip, which
|
|
65
|
+
* can be problematic in components with OnPush change detection.
|
|
66
|
+
*/
|
|
67
|
+
_markForCheck() {
|
|
68
|
+
this._changeDetectorRef.markForCheck();
|
|
69
|
+
}
|
|
70
|
+
_handleMouseLeave({ relatedTarget }) {
|
|
71
|
+
if (!relatedTarget || !this._triggerElement.contains(relatedTarget)) {
|
|
72
|
+
if (this.isVisible()) {
|
|
73
|
+
this.hide(this._mouseLeaveHideDelay);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
this._finalizeAnimation(false);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Callback for when the timeout in this.show() gets completed.
|
|
82
|
+
* This method is only needed by the mdc-tooltip, and so it is only implemented
|
|
83
|
+
* in the mdc-tooltip, not here.
|
|
84
|
+
*/
|
|
85
|
+
_onShow() { }
|
|
86
|
+
/** Cancels any pending animation sequences. */
|
|
87
|
+
_cancelPendingAnimations() {
|
|
88
|
+
clearTimeout(this._showTimeoutId);
|
|
89
|
+
clearTimeout(this._hideTimeoutId);
|
|
90
|
+
this._showTimeoutId = this._hideTimeoutId = undefined;
|
|
91
|
+
}
|
|
92
|
+
/** Handles the cleanup after an animation has finished. */
|
|
93
|
+
_finalizeAnimation(toVisible) {
|
|
94
|
+
if (toVisible) {
|
|
95
|
+
this._closeOnInteraction = true;
|
|
96
|
+
}
|
|
97
|
+
else if (!this.isVisible()) {
|
|
98
|
+
this._onHide.next();
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
/** Toggles the visibility of the tooltip element. */
|
|
102
|
+
_toggleVisibility(isVisible) {
|
|
103
|
+
// We set the classes directly here ourselves so that toggling the tooltip state
|
|
104
|
+
// isn't bound by change detection. This allows us to hide it even if the
|
|
105
|
+
// view ref has been detached from the CD tree.
|
|
106
|
+
this._isVisible = isVisible;
|
|
107
|
+
if (isVisible) {
|
|
108
|
+
this._onShow();
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
_HintComponentBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: _HintComponentBase, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
113
|
+
_HintComponentBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: _HintComponentBase, host: { listeners: { "mouseleave": "_handleMouseLeave($event)" } }, ngImport: i0 });
|
|
114
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: _HintComponentBase, decorators: [{
|
|
115
|
+
type: Directive
|
|
116
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { _handleMouseLeave: [{
|
|
117
|
+
type: HostListener,
|
|
118
|
+
args: ["mouseleave", ["$event"]]
|
|
119
|
+
}] } });
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hint-component-base.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/components/hint-component-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, HostBinding, HostListener, OnDestroy } from \"@angular/core\";\nimport { Observable, Subject } from \"rxjs\";\n\n@Directive()\n// tslint:disable-next-line:class-name directive-class-suffix\nexport abstract class _HintComponentBase implements OnDestroy {\n\n    /** The timeout ID of any current timer set to show the tooltip */\n    private _showTimeoutId: number | undefined;\n\n    /** The timeout ID of any current timer set to hide the tooltip */\n    private _hideTimeoutId: number | undefined;\n\n    /** Element that caused the tooltip to open. */\n    _triggerElement: HTMLElement;\n\n    /** Amount of milliseconds to delay the closing sequence. */\n    _mouseLeaveHideDelay: number;\n\n    /** Reference to the internal tooltip element. */\n    abstract _hint: ElementRef<HTMLElement>;\n\n    /** Whether interactions on the page should close the tooltip */\n    private _closeOnInteraction = false;\n\n    /** Whether the tooltip is currently visible. */\n    private _isVisible = false;\n\n    /** Subject for notifying that the tooltip has been hidden from the view */\n    private readonly _onHide: Subject<void> = new Subject();\n\n    constructor(private _changeDetectorRef: ChangeDetectorRef) {}\n\n    /**\n     * Shows the tooltip with an animation originating from the provided origin\n     * @param delay Amount of milliseconds to the delay showing the tooltip.\n     */\n    show(delay: number): void {\n        // Cancel the delayed hide if it is scheduled\n        clearTimeout(this._hideTimeoutId);\n\n        this._showTimeoutId = setTimeout(() => {\n            this._toggleVisibility(true);\n            this._showTimeoutId = undefined;\n        }, delay) as unknown as number;\n    }\n\n    /**\n     * Begins the animation to hide the tooltip after the provided delay in ms.\n     * @param delay Amount of milliseconds to delay showing the tooltip.\n     */\n    hide(delay: number): void {\n        // Cancel the delayed show if it is scheduled\n        clearTimeout(this._showTimeoutId);\n\n        this._hideTimeoutId = setTimeout(() => {\n            this._toggleVisibility(false);\n            this._hideTimeoutId = undefined;\n        }, delay) as unknown as number;\n    }\n\n    /** Returns an observable that notifies when the tooltip has been hidden from view. */\n    afterHidden(): Observable<void> {\n        return this._onHide;\n    }\n\n    /** Whether the tooltip is being displayed. */\n    isVisible(): boolean {\n        return this._isVisible;\n    }\n\n    ngOnDestroy() {\n        this._cancelPendingAnimations();\n        this._onHide.complete();\n        this._triggerElement = null;\n    }\n\n    /**\n     * Interactions on the HTML body should close the tooltip immediately as defined in the\n     * material design spec.\n     * https://material.io/design/components/tooltips.html#behavior\n     */\n    _handleBodyInteraction(): void {\n        if (this._closeOnInteraction) {\n            this.hide(0);\n        }\n    }\n\n    /**\n     * Marks that the tooltip needs to be checked in the next change detection run.\n     * Mainly used for rendering the initial text before positioning a tooltip, which\n     * can be problematic in components with OnPush change detection.\n     */\n    _markForCheck(): void {\n        this._changeDetectorRef.markForCheck();\n    }\n\n    @HostListener(\"mouseleave\", [\"$event\"])\n    _handleMouseLeave({relatedTarget}: MouseEvent) {\n        if (!relatedTarget || !this._triggerElement.contains(relatedTarget as Node)) {\n            if (this.isVisible()) {\n                this.hide(this._mouseLeaveHideDelay);\n            } else {\n                this._finalizeAnimation(false);\n            }\n        }\n    }\n\n    /**\n     * Callback for when the timeout in this.show() gets completed.\n     * This method is only needed by the mdc-tooltip, and so it is only implemented\n     * in the mdc-tooltip, not here.\n     */\n    protected _onShow(): void {}\n\n    /** Cancels any pending animation sequences. */\n    _cancelPendingAnimations() {\n        clearTimeout(this._showTimeoutId);\n        clearTimeout(this._hideTimeoutId);\n        this._showTimeoutId = this._hideTimeoutId = undefined;\n    }\n\n    /** Handles the cleanup after an animation has finished. */\n    private _finalizeAnimation(toVisible: boolean) {\n        if (toVisible) {\n            this._closeOnInteraction = true;\n        } else if (!this.isVisible()) {\n            this._onHide.next();\n        }\n    }\n\n    /** Toggles the visibility of the tooltip element. */\n    private _toggleVisibility(isVisible: boolean) {\n        // We set the classes directly here ourselves so that toggling the tooltip state\n        // isn't bound by change detection. This allows us to hide it even if the\n        // view ref has been detached from the CD tree.\n        this._isVisible = isVisible;\n\n        if (isVisible) {\n            this._onShow();\n        }\n    }\n}\n"]}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { FocusMonitor } from "@angular/cdk/a11y";
|
|
1
2
|
import { Overlay } from "@angular/cdk/overlay";
|
|
2
3
|
import { Platform } from "@angular/cdk/platform";
|
|
3
4
|
import { ComponentPortal } from "@angular/cdk/portal";
|
|
@@ -8,14 +9,16 @@ import { NiceNavigationHintService } from "../providers/hint.service";
|
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@angular/cdk/overlay";
|
|
10
11
|
import * as i2 from "@angular/cdk/platform";
|
|
11
|
-
import * as i3 from "
|
|
12
|
+
import * as i3 from "@angular/cdk/a11y";
|
|
13
|
+
import * as i4 from "../providers/hint.service";
|
|
12
14
|
export class NiceShowHintDirective {
|
|
13
|
-
constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform, _hintService) {
|
|
15
|
+
constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform, _focusMonitor, _hintService) {
|
|
14
16
|
this._overlay = _overlay;
|
|
15
17
|
this._elementRef = _elementRef;
|
|
16
18
|
this._viewContainerRef = _viewContainerRef;
|
|
17
19
|
this._ngZone = _ngZone;
|
|
18
20
|
this._platform = _platform;
|
|
21
|
+
this._focusMonitor = _focusMonitor;
|
|
19
22
|
this._hintService = _hintService;
|
|
20
23
|
this.shouldShow = false;
|
|
21
24
|
this._pointerExitEventsInitialized = false;
|
|
@@ -24,9 +27,18 @@ export class NiceShowHintDirective {
|
|
|
24
27
|
}
|
|
25
28
|
ngAfterViewInit() {
|
|
26
29
|
this._setupPointerEnterEventsIfNeeded();
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
+
this._focusMonitor
|
|
31
|
+
.monitor(this._elementRef)
|
|
32
|
+
.pipe(takeUntil(this.unsubscribeAll$))
|
|
33
|
+
.subscribe(origin => {
|
|
34
|
+
// Note that the focus monitor runs outside the Angular zone.
|
|
35
|
+
if (!origin) {
|
|
36
|
+
this._ngZone.run(() => this.hide());
|
|
37
|
+
}
|
|
38
|
+
else if (origin === "keyboard") {
|
|
39
|
+
this._ngZone.run(() => this.show());
|
|
40
|
+
}
|
|
41
|
+
});
|
|
30
42
|
}
|
|
31
43
|
ngOnDestroy() {
|
|
32
44
|
this.unsubscribeAll$.next();
|
|
@@ -37,15 +49,26 @@ export class NiceShowHintDirective {
|
|
|
37
49
|
return;
|
|
38
50
|
}
|
|
39
51
|
const overlayRef = this._createOverlay();
|
|
52
|
+
this._portal = this._portal || new ComponentPortal(this.item.hint.component);
|
|
40
53
|
this._detach();
|
|
41
54
|
this._hintInstance = overlayRef.attach(this._portal).instance;
|
|
55
|
+
this._hintInstance._triggerElement = this._elementRef.nativeElement;
|
|
56
|
+
this._hintInstance
|
|
57
|
+
.afterHidden()
|
|
58
|
+
.pipe(takeUntil(this.unsubscribeAll$))
|
|
59
|
+
.subscribe(() => this._detach());
|
|
42
60
|
this._hintService.setActiveHint(true);
|
|
43
61
|
}
|
|
44
62
|
hide() {
|
|
45
63
|
const instance = this._hintInstance;
|
|
46
64
|
if (instance) {
|
|
47
|
-
|
|
48
|
-
|
|
65
|
+
if (instance.isVisible()) {
|
|
66
|
+
instance.hide(0);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
instance._cancelPendingAnimations();
|
|
70
|
+
this._detach();
|
|
71
|
+
}
|
|
49
72
|
}
|
|
50
73
|
}
|
|
51
74
|
_createOverlay() {
|
|
@@ -88,10 +111,10 @@ export class NiceShowHintDirective {
|
|
|
88
111
|
.detachments()
|
|
89
112
|
.pipe(takeUntil(this.unsubscribeAll$))
|
|
90
113
|
.subscribe(() => this._detach());
|
|
91
|
-
|
|
114
|
+
this._overlayRef
|
|
92
115
|
.outsidePointerEvents()
|
|
93
116
|
.pipe(takeUntil(this.unsubscribeAll$))
|
|
94
|
-
.subscribe(() => this._hintInstance?._handleBodyInteraction())
|
|
117
|
+
.subscribe(() => this._hintInstance?._handleBodyInteraction());
|
|
95
118
|
return this._overlayRef;
|
|
96
119
|
}
|
|
97
120
|
_detach() {
|
|
@@ -150,14 +173,14 @@ export class NiceShowHintDirective {
|
|
|
150
173
|
});
|
|
151
174
|
}
|
|
152
175
|
}
|
|
153
|
-
NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i2.Platform }, { token: i3.NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
176
|
+
NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i2.Platform }, { token: i3.FocusMonitor }, { token: i4.NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
154
177
|
NiceShowHintDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: NiceShowHintDirective, selector: "[niceShowHint]", inputs: { shouldShow: "shouldShow", item: "item" }, ngImport: i0 });
|
|
155
178
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, decorators: [{
|
|
156
179
|
type: Directive,
|
|
157
180
|
args: [{ selector: "[niceShowHint]" }]
|
|
158
|
-
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i2.Platform }, { type: i3.NiceNavigationHintService }]; }, propDecorators: { shouldShow: [{
|
|
181
|
+
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i2.Platform }, { type: i3.FocusMonitor }, { type: i4.NiceNavigationHintService }]; }, propDecorators: { shouldShow: [{
|
|
159
182
|
type: Input
|
|
160
183
|
}], item: [{
|
|
161
184
|
type: Input
|
|
162
185
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-hint.directive.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/directives/show-hint.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { FlexibleConnectedPositionStrategy, Overlay, OverlayRef } from \"@angular/cdk/overlay\";\nimport { Platform } from \"@angular/cdk/platform\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { AfterViewInit, Directive, ElementRef, Input, NgZone, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { NiceNavigationItem } from \"../navigation.types\";\nimport { NiceNavigationHintService } from \"../providers/hint.service\";\n\n@Directive({ selector: \"[niceShowHint]\" })\nexport class NiceShowHintDirective implements AfterViewInit, OnDestroy {\n    @Input()\n    public shouldShow = false;\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    private _pointerExitEventsInitialized = false;\n    private _portal: ComponentPortal<any>;\n    private _hintInstance: any;\n    private _overlayRef: OverlayRef;\n\n    private readonly _passiveListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n    private readonly unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private _overlay: Overlay,\n        private _elementRef: ElementRef<HTMLElement>,\n        private _viewContainerRef: ViewContainerRef,\n        private _ngZone: NgZone,\n        private _platform: Platform,\n        private _hintService: NiceNavigationHintService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this._setupPointerEnterEventsIfNeeded();\n\n        if (this.item.hint) {\n            this._portal = new ComponentPortal<any>(this.item.hint.component, this._viewContainerRef);\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public show(): void {\n        if (!this.shouldShow || !this.item.hint || this._isHintVisible()) {\n            return;\n        }\n\n        const overlayRef = this._createOverlay();\n        this._detach();\n        this._hintInstance = overlayRef.attach(this._portal).instance;\n\n        this._hintService.setActiveHint(true);\n    }\n\n    public hide(): void {\n        const instance = this._hintInstance;\n\n        if (instance) {\n            this._detach();\n            this._hintService.setActiveHint(false);\n        }\n    }\n\n    private _createOverlay(): OverlayRef {\n        if (this._overlayRef) {\n            const existingStrategy = this._overlayRef.getConfig()\n                .positionStrategy as FlexibleConnectedPositionStrategy;\n\n            // @ts-ignore\n            if (!origin && existingStrategy._origin instanceof ElementRef) {\n                return this._overlayRef;\n            }\n\n            this._detach();\n        }\n\n        // Create connected position strategy that listens for scroll events to reposition.\n        const strategy = this._overlay\n            .position()\n            .flexibleConnectedTo(this._elementRef)\n            .withPositions([\n                {\n                    originX: \"center\",\n                    originY: \"bottom\",\n                    overlayX: \"start\",\n                    overlayY: \"top\",\n                    offsetY: 8\n                }\n            ])\n            .withFlexibleDimensions(false);\n\n        strategy.positionChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(change => {\n            if (this._hintInstance) {\n                if (change.scrollableViewProperties.isOverlayClipped) {\n                    // After position changes occur and the overlay is clipped by\n                    // a parent scrollable then close the tooltip.\n                    this._ngZone.run(() => this.hide());\n                }\n            }\n        });\n\n        this._overlayRef = this._overlay.create({\n            positionStrategy: strategy\n        });\n\n        this._overlayRef\n            .detachments()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        /*this._overlayRef\n            .outsidePointerEvents()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._hintInstance?._handleBodyInteraction());*/\n\n        return this._overlayRef;\n    }\n\n    private _detach() {\n        if (this._overlayRef && this._overlayRef.hasAttached()) {\n            this._overlayRef.detach();\n        }\n\n        this._hintInstance = null;\n    }\n\n    private _isHintVisible(): boolean {\n        return !!this._hintInstance;\n    }\n\n    private _setupPointerEnterEventsIfNeeded() {\n        // Optimization: Defer hooking up events if there's no message or the tooltip is disabled.\n        if (this._passiveListeners.length) {\n            return;\n        }\n\n        // The mouse events shouldn't be bound on mobile devices, because they can prevent the\n        // first tap from firing its click event or can cause the tooltip to open for clicks.\n        if (this._platformSupportsMouseEvents()) {\n            this._passiveListeners.push([\n                \"mouseenter\",\n                () => {\n                    this._setupPointerExitEventsIfNeeded();\n                    this.show();\n                },\n            ]);\n        }\n\n        this._addListeners(this._passiveListeners);\n    }\n\n    private _setupPointerExitEventsIfNeeded() {\n        if (this._pointerExitEventsInitialized) {\n            return;\n        }\n        this._pointerExitEventsInitialized = true;\n\n        const exitListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n        if (this._platformSupportsMouseEvents()) {\n            exitListeners.push(\n                [\n                    \"mouseleave\",\n                    event => {\n                        const newTarget = (event as MouseEvent).relatedTarget as Node | null;\n                        if (!newTarget || !this._overlayRef?.overlayElement.contains(newTarget)) {\n                            this.hide();\n                        }\n                    },\n                ]\n            );\n        }\n\n        this._addListeners(exitListeners);\n        this._passiveListeners.push(...exitListeners);\n    }\n\n    private _platformSupportsMouseEvents() {\n        return !this._platform.IOS && !this._platform.ANDROID;\n    }\n\n    private _addListeners(listeners: (readonly [string, EventListenerOrEventListenerObject])[]) {\n        listeners.forEach(([event, listener]) => {\n            this._elementRef.nativeElement.addEventListener(event, listener);\n        });\n    }\n}\n"]}
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-hint.directive.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/directives/show-hint.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from \"@angular/cdk/a11y\";\nimport { FlexibleConnectedPositionStrategy, Overlay, OverlayRef } from \"@angular/cdk/overlay\";\nimport { Platform } from \"@angular/cdk/platform\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { AfterViewInit, Directive, ElementRef, Input, NgZone, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { _HintComponentBase } from \"../components/hint-component-base\";\nimport { NiceNavigationItem } from \"../navigation.types\";\nimport { NiceNavigationHintService } from \"../providers/hint.service\";\n\n@Directive({ selector: \"[niceShowHint]\" })\nexport class NiceShowHintDirective<T extends _HintComponentBase> implements AfterViewInit, OnDestroy {\n    @Input()\n    public shouldShow = false;\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    private _pointerExitEventsInitialized = false;\n    private _portal: ComponentPortal<any>;\n    private _hintInstance: T;\n    private _overlayRef: OverlayRef;\n\n    private readonly _passiveListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n    private readonly unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private _overlay: Overlay,\n        private _elementRef: ElementRef<HTMLElement>,\n        private _viewContainerRef: ViewContainerRef,\n        private _ngZone: NgZone,\n        private _platform: Platform,\n        private _focusMonitor: FocusMonitor,\n        private _hintService: NiceNavigationHintService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this._setupPointerEnterEventsIfNeeded();\n\n        this._focusMonitor\n            .monitor(this._elementRef)\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(origin => {\n                // Note that the focus monitor runs outside the Angular zone.\n                if (!origin) {\n                    this._ngZone.run(() => this.hide());\n                } else if (origin === \"keyboard\") {\n                    this._ngZone.run(() => this.show());\n                }\n            });\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public show(): void {\n        if (!this.shouldShow || !this.item.hint || this._isHintVisible()) {\n            return;\n        }\n\n        const overlayRef = this._createOverlay();\n        this._portal = this._portal || new ComponentPortal<any>(this.item.hint.component);\n        this._detach();\n        this._hintInstance = overlayRef.attach(this._portal).instance;\n\n        this._hintInstance._triggerElement = this._elementRef.nativeElement;\n        this._hintInstance\n            .afterHidden()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        this._hintService.setActiveHint(true);\n    }\n\n    public hide(): void {\n        const instance = this._hintInstance;\n\n        if (instance) {\n            if (instance.isVisible()) {\n                instance.hide(0);\n            } else {\n                instance._cancelPendingAnimations();\n                this._detach();\n            }\n        }\n    }\n\n    private _createOverlay(): OverlayRef {\n        if (this._overlayRef) {\n            const existingStrategy = this._overlayRef.getConfig()\n                .positionStrategy as FlexibleConnectedPositionStrategy;\n\n            // @ts-ignore\n            if (!origin && existingStrategy._origin instanceof ElementRef) {\n                return this._overlayRef;\n            }\n\n            this._detach();\n        }\n\n        // Create connected position strategy that listens for scroll events to reposition.\n        const strategy = this._overlay\n            .position()\n            .flexibleConnectedTo(this._elementRef)\n            .withPositions([\n                {\n                    originX: \"center\",\n                    originY: \"bottom\",\n                    overlayX: \"start\",\n                    overlayY: \"top\",\n                    offsetY: 8\n                }\n            ])\n            .withFlexibleDimensions(false);\n\n        strategy.positionChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(change => {\n            if (this._hintInstance) {\n                if (change.scrollableViewProperties.isOverlayClipped) {\n                    // After position changes occur and the overlay is clipped by\n                    // a parent scrollable then close the tooltip.\n                    this._ngZone.run(() => this.hide());\n                }\n            }\n        });\n\n        this._overlayRef = this._overlay.create({\n            positionStrategy: strategy\n        });\n\n        this._overlayRef\n            .detachments()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        this._overlayRef\n            .outsidePointerEvents()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._hintInstance?._handleBodyInteraction());\n\n        return this._overlayRef;\n    }\n\n    private _detach() {\n        if (this._overlayRef && this._overlayRef.hasAttached()) {\n            this._overlayRef.detach();\n        }\n\n        this._hintInstance = null;\n    }\n\n    private _isHintVisible(): boolean {\n        return !!this._hintInstance;\n    }\n\n    private _setupPointerEnterEventsIfNeeded() {\n        // Optimization: Defer hooking up events if there's no message or the tooltip is disabled.\n        if (this._passiveListeners.length) {\n            return;\n        }\n\n        // The mouse events shouldn't be bound on mobile devices, because they can prevent the\n        // first tap from firing its click event or can cause the tooltip to open for clicks.\n        if (this._platformSupportsMouseEvents()) {\n            this._passiveListeners.push([\n                \"mouseenter\",\n                () => {\n                    this._setupPointerExitEventsIfNeeded();\n                    this.show();\n                },\n            ]);\n        }\n\n        this._addListeners(this._passiveListeners);\n    }\n\n    private _setupPointerExitEventsIfNeeded() {\n        if (this._pointerExitEventsInitialized) {\n            return;\n        }\n        this._pointerExitEventsInitialized = true;\n\n        const exitListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n        if (this._platformSupportsMouseEvents()) {\n            exitListeners.push(\n                [\n                    \"mouseleave\",\n                    event => {\n                        const newTarget = (event as MouseEvent).relatedTarget as Node | null;\n                        if (!newTarget || !this._overlayRef?.overlayElement.contains(newTarget)) {\n                            this.hide();\n                        }\n                    },\n                ]\n            );\n        }\n\n        this._addListeners(exitListeners);\n        this._passiveListeners.push(...exitListeners);\n    }\n\n    private _platformSupportsMouseEvents() {\n        return !this._platform.IOS && !this._platform.ANDROID;\n    }\n\n    private _addListeners(listeners: (readonly [string, EventListenerOrEventListenerObject])[]) {\n        listeners.forEach(([event, listener]) => {\n            this._elementRef.nativeElement.addEventListener(event, listener);\n        });\n    }\n}\n"]}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export * from "./components/hint-component-base";
|
|
1
2
|
export * from "./horizontal/horizontal.component";
|
|
2
3
|
export * from "./horizontal/components/basic/basic.component";
|
|
3
4
|
export * from "./horizontal/components/branch/branch.component";
|
|
@@ -16,4 +17,4 @@ export * from "./navigation.service";
|
|
|
16
17
|
export * from "./navigation.types";
|
|
17
18
|
export * from "./providers/hide-item.resolver";
|
|
18
19
|
export * from "./providers/hint.resolver";
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9uYXZpZ2F0aW9uL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG9CQUFvQixDQUFDO0FBRW5DLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvaGludC1jb21wb25lbnQtYmFzZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9ob3Jpem9udGFsLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9jb21wb25lbnRzL2Jhc2ljL2Jhc2ljLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9jb21wb25lbnRzL2JyYW5jaC9icmFuY2guY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob3Jpem9udGFsL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9jb21wb25lbnRzL3NwYWNlci9zcGFjZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92ZXJ0aWNhbC92ZXJ0aWNhbC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvYXNpZGUvYXNpZGUuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92ZXJ0aWNhbC9jb21wb25lbnRzL2Jhc2ljL2Jhc2ljLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9jb2xsYXBzYWJsZS9jb2xsYXBzYWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9ncm91cC9ncm91cC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvc3BhY2VyL3NwYWNlci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL25hdmlnYXRpb24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9uYXZpZ2F0aW9uLm1vZHVsZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbmF2aWdhdGlvbi5zZXJ2aWNlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9uYXZpZ2F0aW9uLnR5cGVzXCI7XG5cbmV4cG9ydCAqIGZyb20gXCIuL3Byb3ZpZGVycy9oaWRlLWl0ZW0ucmVzb2x2ZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Byb3ZpZGVycy9oaW50LnJlc29sdmVyXCI7XG4iXX0=
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { CdkDropList, moveItemInArray } from "@angular/cdk/drag-drop";
|
|
2
|
+
import { Directive, EventEmitter, Input, Optional, Output } from "@angular/core";
|
|
3
|
+
import { FormArrayName } from "@angular/forms";
|
|
4
|
+
import { LexoRankUtils } from "../../utils/lexorank.utils";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/forms";
|
|
7
|
+
import * as i2 from "@angular/cdk/drag-drop";
|
|
8
|
+
export class NiceDraggableListDirective {
|
|
9
|
+
constructor(formArrayName, cdkDropList) {
|
|
10
|
+
this.formArrayName = formArrayName;
|
|
11
|
+
this.cdkDropList = cdkDropList;
|
|
12
|
+
this.rankProperty = "rank";
|
|
13
|
+
this.itemsUpdated = new EventEmitter();
|
|
14
|
+
this.itemRankUpdated = new EventEmitter();
|
|
15
|
+
this.sortedItems = [];
|
|
16
|
+
}
|
|
17
|
+
ngOnInit() {
|
|
18
|
+
if (this.formArrayName) {
|
|
19
|
+
this.formArray = this.formArrayName.control;
|
|
20
|
+
this.sortItems(this.formArray.getRawValue());
|
|
21
|
+
}
|
|
22
|
+
this.cdkDropList.dropped.subscribe((event) => this.drop(event));
|
|
23
|
+
}
|
|
24
|
+
ngOnChanges(changes) {
|
|
25
|
+
if ("items" in changes && this.items) {
|
|
26
|
+
this.sortItems(this.items);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
drop(event) {
|
|
30
|
+
if (event.previousContainer === event.container) {
|
|
31
|
+
if (event.previousIndex === event.currentIndex) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
event.item.data[this.rankProperty] = this.getNextRank(event);
|
|
35
|
+
this.sortItems(this.sortedItems);
|
|
36
|
+
this.itemsUpdated.next(this.sortedItems);
|
|
37
|
+
this.itemRankUpdated.next(event.item.data);
|
|
38
|
+
if (this.formArray) {
|
|
39
|
+
this.formArray.get([event.previousIndex, this.rankProperty])?.patchValue(event.item.data[this.rankProperty]);
|
|
40
|
+
moveItemInArray(this.formArray.controls, event.previousIndex, event.currentIndex);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
// TODO: Handle container change
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
sortItems(items) {
|
|
48
|
+
if (items.length && items.some((item) => !item[this.rankProperty])) {
|
|
49
|
+
throw new Error(`All items must have a ${this.rankProperty}`);
|
|
50
|
+
}
|
|
51
|
+
this.sortedItems = [...items]
|
|
52
|
+
.map(item => ({ ...item }))
|
|
53
|
+
.sort((itemA, itemB) => LexoRankUtils.compareStringFn(itemA[this.rankProperty], itemB[this.rankProperty]));
|
|
54
|
+
this.cdkDropList.data = this.sortedItems;
|
|
55
|
+
}
|
|
56
|
+
getNextRank(event) {
|
|
57
|
+
const fromIndex = event.previousIndex;
|
|
58
|
+
const toIndex = event.currentIndex;
|
|
59
|
+
const itemAfter = this.sortedItems[fromIndex > toIndex ? toIndex : toIndex + 1];
|
|
60
|
+
const itemBefore = this.sortedItems[fromIndex > toIndex ? toIndex - 1 : toIndex];
|
|
61
|
+
return LexoRankUtils.getNewRank(itemAfter?.[this.rankProperty], itemBefore?.[this.rankProperty]);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
NiceDraggableListDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceDraggableListDirective, deps: [{ token: i1.FormArrayName, optional: true }, { token: i2.CdkDropList }], target: i0.ɵɵFactoryTarget.Directive });
|
|
65
|
+
NiceDraggableListDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: NiceDraggableListDirective, selector: "[cdkDropList][niceDraggableList]", inputs: { items: "items", rankProperty: "rankProperty" }, outputs: { itemsUpdated: "itemsUpdated", itemRankUpdated: "itemRankUpdated" }, usesOnChanges: true, ngImport: i0 });
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceDraggableListDirective, decorators: [{
|
|
67
|
+
type: Directive,
|
|
68
|
+
args: [{
|
|
69
|
+
selector: "[cdkDropList][niceDraggableList]"
|
|
70
|
+
}]
|
|
71
|
+
}], ctorParameters: function () { return [{ type: i1.FormArrayName, decorators: [{
|
|
72
|
+
type: Optional
|
|
73
|
+
}] }, { type: i2.CdkDropList }]; }, propDecorators: { items: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}], rankProperty: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], itemsUpdated: [{
|
|
78
|
+
type: Output
|
|
79
|
+
}], itemRankUpdated: [{
|
|
80
|
+
type: Output
|
|
81
|
+
}] } });
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable-list.directive.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/directives/draggable-list/draggable-list.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, CdkDropList, moveItemInArray } from \"@angular/cdk/drag-drop\";\nimport { Directive, EventEmitter, Input, OnChanges, OnInit, Optional, Output, SimpleChanges } from \"@angular/core\";\nimport { FormArray, FormArrayName } from \"@angular/forms\";\nimport { LexoRankUtils } from \"../../utils/lexorank.utils\";\n\n@Directive({\n    selector: \"[cdkDropList][niceDraggableList]\"\n})\nexport class NiceDraggableListDirective<T> implements OnInit, OnChanges {\n    @Input()\n    public items: T[];\n\n    @Input()\n    public rankProperty = \"rank\";\n\n    @Output()\n    public itemsUpdated = new EventEmitter<T[]>();\n\n    @Output()\n    public itemRankUpdated = new EventEmitter<T>();\n\n    public sortedItems: T[] = [];\n    public formArray: FormArray;\n\n    constructor(@Optional() private formArrayName: FormArrayName, private cdkDropList: CdkDropList) {}\n\n    public ngOnInit(): void {\n        if (this.formArrayName) {\n            this.formArray = this.formArrayName.control;\n            this.sortItems(this.formArray.getRawValue());\n        }\n\n        this.cdkDropList.dropped.subscribe((event) => this.drop(event));\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (\"items\" in changes && this.items) {\n            this.sortItems(this.items);\n        }\n    }\n\n    public drop(event: CdkDragDrop<any, any>): void {\n        if (event.previousContainer === event.container) {\n            if (event.previousIndex === event.currentIndex) {\n                return;\n            }\n\n            event.item.data[this.rankProperty] = this.getNextRank(event);\n            this.sortItems(this.sortedItems);\n            this.itemsUpdated.next(this.sortedItems);\n            this.itemRankUpdated.next(event.item.data);\n\n            if (this.formArray) {\n                this.formArray.get([event.previousIndex, this.rankProperty])?.patchValue(event.item.data[this.rankProperty]);\n                moveItemInArray(this.formArray.controls, event.previousIndex, event.currentIndex);\n            }\n        } else {\n            // TODO: Handle container change\n        }\n    }\n\n    private sortItems(items: any[]): void {\n        if (items.length && items.some((item) => !item[this.rankProperty])) {\n            throw new Error(`All items must have a ${this.rankProperty}`);\n        }\n\n        this.sortedItems = [...items]\n            .map(item => ({...item}))\n            .sort((itemA, itemB) => LexoRankUtils.compareStringFn(itemA[this.rankProperty], itemB[this.rankProperty]));\n        this.cdkDropList.data = this.sortedItems;\n    }\n\n    private getNextRank(event: CdkDragDrop<any, any>): string {\n        const fromIndex = event.previousIndex;\n        const toIndex = event.currentIndex;\n\n        const itemAfter = this.sortedItems[fromIndex > toIndex ? toIndex : toIndex + 1];\n        const itemBefore = this.sortedItems[fromIndex > toIndex ? toIndex - 1 : toIndex];\n        return LexoRankUtils.getNewRank(itemAfter?.[this.rankProperty], itemBefore?.[this.rankProperty]);\n    }\n}\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { DragDropModule } from "@angular/cdk/drag-drop";
|
|
2
|
+
import { NgModule } from "@angular/core";
|
|
3
|
+
import { NiceDraggableListDirective } from "./draggable-list.directive";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class NiceDraggableListModule {
|
|
6
|
+
}
|
|
7
|
+
NiceDraggableListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceDraggableListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
NiceDraggableListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.3", ngImport: i0, type: NiceDraggableListModule, declarations: [NiceDraggableListDirective], imports: [DragDropModule], exports: [NiceDraggableListDirective] });
|
|
9
|
+
NiceDraggableListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceDraggableListModule, imports: [DragDropModule] });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceDraggableListModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [DragDropModule],
|
|
14
|
+
declarations: [NiceDraggableListDirective],
|
|
15
|
+
exports: [NiceDraggableListDirective],
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZ2dhYmxlLWxpc3QubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9kaXJlY3RpdmVzL2RyYWdnYWJsZS1saXN0L2RyYWdnYWJsZS1saXN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFPeEUsTUFBTSxPQUFPLHVCQUF1Qjs7b0hBQXZCLHVCQUF1QjtxSEFBdkIsdUJBQXVCLGlCQUhqQiwwQkFBMEIsYUFEL0IsY0FBYyxhQUVkLDBCQUEwQjtxSEFFM0IsdUJBQXVCLFlBSnRCLGNBQWM7MkZBSWYsdUJBQXVCO2tCQUxuQyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDekIsWUFBWSxFQUFFLENBQUMsMEJBQTBCLENBQUM7b0JBQzFDLE9BQU8sRUFBRSxDQUFDLDBCQUEwQixDQUFDO2lCQUN4QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERyYWdEcm9wTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Nkay9kcmFnLWRyb3BcIjtcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgTmljZURyYWdnYWJsZUxpc3REaXJlY3RpdmUgfSBmcm9tIFwiLi9kcmFnZ2FibGUtbGlzdC5kaXJlY3RpdmVcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbRHJhZ0Ryb3BNb2R1bGVdLFxuICAgIGRlY2xhcmF0aW9uczogW05pY2VEcmFnZ2FibGVMaXN0RGlyZWN0aXZlXSxcbiAgICBleHBvcnRzOiBbTmljZURyYWdnYWJsZUxpc3REaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBOaWNlRHJhZ2dhYmxlTGlzdE1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from "./public-api";
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2RpcmVjdGl2ZXMvZHJhZ2dhYmxlLWxpc3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9wdWJsaWMtYXBpXCI7XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from "./draggable-list.directive";
|
|
2
|
+
export * from "./draggable-list.module";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9kcmFnZ2FibGUtbGlzdC9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2RyYWdnYWJsZS1saXN0LmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vZHJhZ2dhYmxlLWxpc3QubW9kdWxlXCI7XG4iXX0=
|
|
@@ -2,6 +2,7 @@ export * from "./autofocus";
|
|
|
2
2
|
export * from "./autogrow";
|
|
3
3
|
export * from "./chip-async-typeahead";
|
|
4
4
|
export * from "./chip-list";
|
|
5
|
+
export * from "./draggable-list";
|
|
5
6
|
export * from "./dropzone";
|
|
6
7
|
export * from "./image-error-placeholder";
|
|
7
8
|
export * from "./material";
|
|
@@ -10,4 +11,4 @@ export * from "./scroll-reset";
|
|
|
10
11
|
export * from "./scrollbar";
|
|
11
12
|
export * from "./stop-propagation";
|
|
12
13
|
export * from "./window";
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2F1dG9mb2N1c1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXV0b2dyb3dcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NoaXAtYXN5bmMtdHlwZWFoZWFkXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jaGlwLWxpc3RcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RyYWdnYWJsZS1saXN0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kcm9wem9uZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW1hZ2UtZXJyb3ItcGxhY2Vob2xkZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21hdGVyaWFsXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RhbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Njcm9sbC1yZXNldFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2Nyb2xsYmFyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zdG9wLXByb3BhZ2F0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi93aW5kb3dcIjtcbiJdfQ==
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { LexoRank } from "lexorank";
|
|
2
|
+
export class LexoRankUtils {
|
|
3
|
+
static compareStringFn(previousRank, nextRank) {
|
|
4
|
+
if (!previousRank || !nextRank) {
|
|
5
|
+
return 0;
|
|
6
|
+
}
|
|
7
|
+
return LexoRank.parse(previousRank).compareTo(LexoRank.parse(nextRank));
|
|
8
|
+
}
|
|
9
|
+
static compareFn(previousRank, nextRank) {
|
|
10
|
+
return previousRank.compareTo(nextRank);
|
|
11
|
+
}
|
|
12
|
+
static getNewRank(afterRank, beforeRank) {
|
|
13
|
+
if (afterRank && beforeRank) {
|
|
14
|
+
if (LexoRank.parse(beforeRank).equals(LexoRank.parse(afterRank))) {
|
|
15
|
+
return LexoRank.parse(afterRank).genPrev().toString();
|
|
16
|
+
}
|
|
17
|
+
return LexoRank.parse(afterRank).between(LexoRank.parse(beforeRank)).toString();
|
|
18
|
+
}
|
|
19
|
+
if (afterRank) {
|
|
20
|
+
return LexoRank.parse(afterRank).genPrev().toString();
|
|
21
|
+
}
|
|
22
|
+
if (beforeRank) {
|
|
23
|
+
return LexoRank.parse(beforeRank).genNext().toString();
|
|
24
|
+
}
|
|
25
|
+
return LexoRank.middle().toString();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGV4b3JhbmsudXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL3V0aWxzL2xleG9yYW5rLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFcEMsTUFBTSxPQUFPLGFBQWE7SUFDZixNQUFNLENBQUMsZUFBZSxDQUFDLFlBQXFCLEVBQUUsUUFBaUI7UUFDbEUsSUFBSSxDQUFDLFlBQVksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUM1QixPQUFPLENBQUMsQ0FBQztTQUNaO1FBRUQsT0FBTyxRQUFRLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDNUUsQ0FBQztJQUVNLE1BQU0sQ0FBQyxTQUFTLENBQUMsWUFBc0IsRUFBRSxRQUFrQjtRQUM5RCxPQUFPLFlBQVksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVNLE1BQU0sQ0FBQyxVQUFVLENBQUMsU0FBa0IsRUFBRSxVQUFtQjtRQUM1RCxJQUFJLFNBQVMsSUFBSSxVQUFVLEVBQUU7WUFDekIsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUU7Z0JBQzlELE9BQU8sUUFBUSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQzthQUN6RDtZQUVELE9BQU8sUUFBUSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1NBQ25GO1FBRUQsSUFBSSxTQUFTLEVBQUU7WUFDWCxPQUFPLFFBQVEsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUM7U0FDekQ7UUFFRCxJQUFJLFVBQVUsRUFBRTtZQUNaLE9BQU8sUUFBUSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUMxRDtRQUVELE9BQU8sUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3hDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExleG9SYW5rIH0gZnJvbSBcImxleG9yYW5rXCI7XG5cbmV4cG9ydCBjbGFzcyBMZXhvUmFua1V0aWxzIHtcbiAgICBwdWJsaWMgc3RhdGljIGNvbXBhcmVTdHJpbmdGbihwcmV2aW91c1Jhbms/OiBzdHJpbmcsIG5leHRSYW5rPzogc3RyaW5nKTogbnVtYmVyIHtcbiAgICAgICAgaWYgKCFwcmV2aW91c1JhbmsgfHwgIW5leHRSYW5rKSB7XG4gICAgICAgICAgICByZXR1cm4gMDtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBMZXhvUmFuay5wYXJzZShwcmV2aW91c1JhbmspLmNvbXBhcmVUbyhMZXhvUmFuay5wYXJzZShuZXh0UmFuaykpO1xuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgY29tcGFyZUZuKHByZXZpb3VzUmFuazogTGV4b1JhbmssIG5leHRSYW5rOiBMZXhvUmFuayk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiBwcmV2aW91c1JhbmsuY29tcGFyZVRvKG5leHRSYW5rKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgc3RhdGljIGdldE5ld1JhbmsoYWZ0ZXJSYW5rPzogc3RyaW5nLCBiZWZvcmVSYW5rPzogc3RyaW5nKTogc3RyaW5nIHtcbiAgICAgICAgaWYgKGFmdGVyUmFuayAmJiBiZWZvcmVSYW5rKSB7XG4gICAgICAgICAgICBpZiAoTGV4b1JhbmsucGFyc2UoYmVmb3JlUmFuaykuZXF1YWxzKExleG9SYW5rLnBhcnNlKGFmdGVyUmFuaykpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIExleG9SYW5rLnBhcnNlKGFmdGVyUmFuaykuZ2VuUHJldigpLnRvU3RyaW5nKCk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiBMZXhvUmFuay5wYXJzZShhZnRlclJhbmspLmJldHdlZW4oTGV4b1JhbmsucGFyc2UoYmVmb3JlUmFuaykpLnRvU3RyaW5nKCk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoYWZ0ZXJSYW5rKSB7XG4gICAgICAgICAgICByZXR1cm4gTGV4b1JhbmsucGFyc2UoYWZ0ZXJSYW5rKS5nZW5QcmV2KCkudG9TdHJpbmcoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChiZWZvcmVSYW5rKSB7XG4gICAgICAgICAgICByZXR1cm4gTGV4b1JhbmsucGFyc2UoYmVmb3JlUmFuaykuZ2VuTmV4dCgpLnRvU3RyaW5nKCk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gTGV4b1JhbmsubWlkZGxlKCkudG9TdHJpbmcoKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -7,6 +7,7 @@ export * from "./font-awesome.utils";
|
|
|
7
7
|
export * from "./form-data.utils";
|
|
8
8
|
export * from "./http-status.utils";
|
|
9
9
|
export * from "./keyboard.utils";
|
|
10
|
+
export * from "./lexorank.utils";
|
|
10
11
|
export * from "./modal.utils";
|
|
11
12
|
export * from "./number.utils";
|
|
12
13
|
export * from "./object.utils";
|
|
@@ -15,4 +16,4 @@ export * from "./query-params.utils";
|
|
|
15
16
|
export * from "./regex.utils";
|
|
16
17
|
export * from "./type.utils";
|
|
17
18
|
export * from "./url.utils";
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvdXRpbHMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYXJyYXkudXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2Nhc2UudXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbG9ycy51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZGF0ZS51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZmlsZS51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZm9udC1hd2Vzb21lLnV0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9mb3JtLWRhdGEudXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2h0dHAtc3RhdHVzLnV0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9rZXlib2FyZC51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGV4b3JhbmsudXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21vZGFsLnV0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9udW1iZXIudXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL29iamVjdC51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcHJvbWlzZS51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcXVlcnktcGFyYW1zLnV0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9yZWdleC51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHlwZS51dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXJsLnV0aWxzXCI7XG4iXX0=
|