ngx-tethys 18.1.0 → 18.1.1
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/CHANGELOG.md +15 -0
- package/core/overlay/abstract-overlay.config.d.ts +5 -0
- package/drag-drop/drag-content.directive.d.ts +1 -0
- package/drag-drop/drag-drop.service.d.ts +1 -0
- package/drag-drop/drag-handle.directive.d.ts +1 -0
- package/drag-drop/drag.directive.d.ts +1 -0
- package/drag-drop/drop-container.directive.d.ts +2 -5
- package/drag-drop/module.d.ts +4 -0
- package/esm2022/core/overlay/abstract-overlay.config.mjs +1 -1
- package/esm2022/core/overlay/abstract-overlay.service.mjs +2 -2
- package/esm2022/dialog/dialog-container.component.mjs +2 -2
- package/esm2022/drag-drop/drag-content.directive.mjs +2 -1
- package/esm2022/drag-drop/drag-drop.service.mjs +2 -1
- package/esm2022/drag-drop/drag-handle.directive.mjs +2 -1
- package/esm2022/drag-drop/drag.directive.mjs +2 -1
- package/esm2022/drag-drop/drop-container.directive.mjs +2 -1
- package/esm2022/drag-drop/module.mjs +9 -2
- package/esm2022/property/property-item.component.mjs +3 -3
- package/esm2022/version.mjs +2 -2
- package/fesm2022/ngx-tethys-core.mjs +1 -1
- package/fesm2022/ngx-tethys-core.mjs.map +1 -1
- package/fesm2022/ngx-tethys-dialog.mjs +1 -1
- package/fesm2022/ngx-tethys-dialog.mjs.map +1 -1
- package/fesm2022/ngx-tethys-drag-drop.mjs +13 -2
- package/fesm2022/ngx-tethys-drag-drop.mjs.map +1 -1
- package/fesm2022/ngx-tethys-property.mjs +2 -2
- package/fesm2022/ngx-tethys-property.mjs.map +1 -1
- package/fesm2022/ngx-tethys.mjs +1 -1
- package/fesm2022/ngx-tethys.mjs.map +1 -1
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/styles/modules/cdk/drag-drop.scss +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,21 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [18.1.1](https://github.com/atinc/ngx-tethys/compare/18.1.0...18.1.1) (2024-11-20)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* 页面的 tooltip 有时候会导致点击有 property-item 的 弹出层时,property-item 错误的退出编辑状态 #INFR-1023 ([#3261](https://github.com/atinc/ngx-tethys/issues/3261)) ([dbf511e](https://github.com/atinc/ngx-tethys/commit/dbf511e9ed2d2d2cab62c454ce2c0d5de51068fe)), closes [#INFR-1023](https://github.com/atinc/ngx-tethys/issues/INFR-1023)
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
### Features
|
|
14
|
+
|
|
15
|
+
* **core:** support projectableNodes for ThyAbstractOverlayConfig and rename ThyStealthViewDirective to ThyStealthView #TINFR-651 ([#3230](https://github.com/atinc/ngx-tethys/issues/3230)) ([f838b96](https://github.com/atinc/ngx-tethys/commit/f838b967ae2066790617f1ace6729d4ea4025369)), closes [#TINFR-651](https://github.com/atinc/ngx-tethys/issues/TINFR-651)
|
|
16
|
+
* **drag-drop:** mark drag-drop as deprecated #TINFR-438 ([#3231](https://github.com/atinc/ngx-tethys/issues/3231)) ([7497858](https://github.com/atinc/ngx-tethys/commit/7497858e449a5d217c3117432db3648f27766e52)), closes [#TINFR-438](https://github.com/atinc/ngx-tethys/issues/TINFR-438)
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
5
20
|
# [18.1.0](https://github.com/atinc/ngx-tethys/compare/18.1.0-next.1...18.1.0) (2024-10-31)
|
|
6
21
|
|
|
7
22
|
|
|
@@ -115,6 +115,11 @@ export declare class ThyAbstractOverlayConfig<TData = unknown> {
|
|
|
115
115
|
* @default true
|
|
116
116
|
*/
|
|
117
117
|
canPush?: boolean;
|
|
118
|
+
/**
|
|
119
|
+
* Projectable nodes of thy abstract overlay config, only for component
|
|
120
|
+
* @type Node[][]
|
|
121
|
+
*/
|
|
122
|
+
projectableNodes?: Node[][];
|
|
118
123
|
}
|
|
119
124
|
export interface ThyAbstractOverlayOptions {
|
|
120
125
|
/** component name, e.g. dialog | popover | slide */
|
|
@@ -6,6 +6,7 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
/**
|
|
7
7
|
* @name thy-drop-container,[thyDropContainer]
|
|
8
8
|
* @order 30
|
|
9
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
9
10
|
*/
|
|
10
11
|
export declare class ThyDropContainerDirective<T = any> implements OnInit, AfterContentInit, IThyDropContainerDirective, OnDestroy {
|
|
11
12
|
private ngZone;
|
|
@@ -64,9 +65,5 @@ export declare class ThyDropContainerDirective<T = any> implements OnInit, After
|
|
|
64
65
|
ngOnDestroy(): void;
|
|
65
66
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThyDropContainerDirective<any>, never>;
|
|
66
67
|
static ɵdir: i0.ɵɵDirectiveDeclaration<ThyDropContainerDirective<any>, "thy-drop-container,[thyDropContainer]", never, { "dragContainer": { "alias": "thyDropContainer"; "required": false; }; "data": { "alias": "thyDropContainerData"; "required": false; }; "disabled": { "alias": "thyDropContainerDisabled"; "required": false; }; "beforeStart": { "alias": "thyBeforeDragStart"; "required": false; }; "beforeOver": { "alias": "thyBeforeDragOver"; "required": false; }; "beforeDrop": { "alias": "thyBeforeDragDrop"; "required": false; }; }, { "started": "thyDragStarted"; "ended": "thyDragEnded"; "overed": "thyDragOvered"; "dropped": "thyDragDropped"; }, ["draggables"], never, true, never>;
|
|
67
|
-
static ngAcceptInputType_disabled: boolean
|
|
68
|
-
* dragend 触发时调用
|
|
69
|
-
*/ | /**
|
|
70
|
-
* dragend 触发时调用
|
|
71
|
-
*/ string | number;
|
|
68
|
+
static ngAcceptInputType_disabled: boolean | string | number;
|
|
72
69
|
}
|
package/drag-drop/module.d.ts
CHANGED
|
@@ -3,7 +3,11 @@ import * as i1 from "./drop-container.directive";
|
|
|
3
3
|
import * as i2 from "./drag.directive";
|
|
4
4
|
import * as i3 from "./drag-handle.directive";
|
|
5
5
|
import * as i4 from "./drag-content.directive";
|
|
6
|
+
/**
|
|
7
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
8
|
+
*/
|
|
6
9
|
export declare class ThyDragDropModule {
|
|
10
|
+
constructor();
|
|
7
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThyDragDropModule, never>;
|
|
8
12
|
static ɵmod: i0.ɵɵNgModuleDeclaration<ThyDragDropModule, never, [typeof i1.ThyDropContainerDirective, typeof i2.ThyDragDirective, typeof i3.ThyDragHandleDirective, typeof i4.ThyDragContentDirective], [typeof i1.ThyDropContainerDirective, typeof i2.ThyDragDirective, typeof i3.ThyDragHandleDirective, typeof i4.ThyDragContentDirective]>;
|
|
9
13
|
static ɵinj: i0.ɵɵInjectorDeclaration<ThyDragDropModule>;
|
|
@@ -67,4 +67,4 @@ export class ThyAbstractOverlayConfig {
|
|
|
67
67
|
this.canPush = true;
|
|
68
68
|
}
|
|
69
69
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-overlay.config.js","sourceRoot":"","sources":["../../../../../src/core/overlay/abstract-overlay.config.ts"],"names":[],"mappings":"AAiBA,MAAM,OAAO,wBAAwB;IAArC;QAaI;;;WAGG;QACH,eAAU,GAAuB,EAAE,CAAC;QAKpC;;;WAGG;QACH,gBAAW,GAAI,IAAI,CAAC;QAEpB;;;WAGG;QACH,kBAAa,GAAuB,EAAE,CAAC;QAEvC;;;WAGG;QACH,qBAAgB,GAAI,IAAI,CAAC;QAEzB,wFAAwF;QACxF,iBAAY,GAAI,KAAK,CAAC;QAEtB;;;;WAIG;QACH,UAAK,GAAI,EAAE,CAAC;QAEZ;;;;WAIG;QACH,WAAM,GAAI,EAAE,CAAC;QA2Bb;;;WAGG;QACH,iBAAY,GAAkB,IAAI,CAAC;QAKnC,oDAAoD;QACpD,oBAAe,GAAmB,IAAI,CAAC;QAEvC,kDAAkD;QAClD,cAAS,GAAmB,IAAI,CAAC;QAEjC,4EAA4E;QAC5E,cAAS,GAAI,IAAI,CAAC;QAElB;;;WAGG;QACH,iBAAY,GAAI,IAAI,CAAC;QAErB;;WAEG;QACH,wBAAmB,GAAkB,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;QAE7D;;;WAGG;QACH,sBAAiB,GAAI,IAAI,CAAC;QAO1B;;;;WAIG;QACH,YAAO,GAAI,IAAI,CAAC;IAOpB,CAAC;CAAA","sourcesContent":["import { Direction } from '@angular/cdk/bidi';\nimport { ViewContainerRef } from '@angular/core';\n\nexport interface ThyAbstractOverlayPosition {\n    /** Override for the overlay's top position. */\n    top?: string;\n\n    /** Override for the overlay's bottom position. */\n    bottom?: string;\n\n    /** Override for the overlay's left position. */\n    left?: string;\n\n    /** Override for the overlay's right position. */\n    right?: string;\n}\n\nexport class ThyAbstractOverlayConfig<TData = unknown> {\n    /**\n     * 当前的组件的 viewContainerRef，指定后弹出的组件的父注入器为当前组件的注入器\n     * @description.en-us Where the attached component should live in Angular's *logical* component tree.This affects what is available for injection and the change detection order for the component instantiated inside of the overlay. This does not affect where the overlay content will be rendered.\n     */\n    viewContainerRef?: ViewContainerRef;\n\n    /**\n     * 弹出框的唯一标识\n     * @description.en-us ID for the overlay. If omitted, a unique one will be generated.\n     */\n    id?: string;\n\n    /**\n     * overlay panel 类名\n     * @description.en-us Custom class for the overlay pane.\n     */\n    panelClass?: string | string[] = '';\n\n    /** Custom class for the overlay component's host element. */\n    hostClass?: string | string[];\n\n    /**\n     * 是否有幕布\n     * @description.en-us Whether the overlay has a backdrop.\n     */\n    hasBackdrop? = true;\n\n    /**\n     * 自定义幕布的样式\n     * @description.en-us Custom class for the backdrop.\n     */\n    backdropClass?: string | string[] = '';\n\n    /**\n     * @description 点击幕布或者按ESC键是否自动关闭弹出框，hasBackdrop=true 时该参数起作用\n     * @description.en-us Whether the user can use escape or clicking on the backdrop to close the overlay.\n     */\n    backdropClosable? = true;\n\n    /** Whether the user can use escape or clicking on the backdrop to close the overlay. */\n    disableClose? = false;\n\n    /**\n     * 自定义弹出框的宽度\n     * @default 660px\n     * @description.en-us Width of the overlay.\n     */\n    width? = '';\n\n    /**\n     * 自定义弹出框的高度\n     * @default 85vh\n     * @description.en-us Height of the overlay.\n     */\n    height? = '';\n\n    /**\n     * 弹出框最小宽度\n     * @description.en-us Min-width of the overlay. If a number is provided, pixel units are assumed.\n     */\n    minWidth?: number | string;\n\n    /**\n     * 弹出框最小高度\n     * @description.en-us Min-height of the overlay. If a number is provided, pixel units are assumed.\n     */\n    minHeight?: number | string;\n\n    /**\n     * 弹出框最大宽度\n     * @description.en-us Max-width of the overlay. If a number is provided, pixel units are assumed. Defaults to 80vw\n     */\n    maxWidth?: number | string;\n\n    /**\n     * 弹出框最大高度\n     * @default 85vh\n     * @description.en-us Max-height of the overlay. If a number is provided, pixel units are assumed.\n     */\n    maxHeight?: number | string;\n\n    /**\n     * 传入的初始化状态，弹出组件的变量会自动赋值，在 ngOnInit 生命周期钩子可以获取到，构造函数获取不到\n     * @description.en-us Data being injected into the child component.\n     */\n    initialState?: TData | null = null;\n\n    /** Layout direction for the overlay's content. */\n    direction?: Direction;\n\n    /** ID of the element that describes the overlay. */\n    ariaDescribedBy?: string | null = null;\n\n    /** Aria label to assign to the overlay element */\n    ariaLabel?: string | null = null;\n\n    /** Whether the overlay should focus the first focusable element on open. */\n    autoFocus? = true;\n\n    /**\n     * Whether the overlay should restore focus to the\n     * previously-focused element, after it's closed.\n     */\n    restoreFocus? = true;\n\n    /**\n     * Control the previously-focused element focusing process.\n     */\n    restoreFocusOptions?: FocusOptions = { preventScroll: true };\n\n    /**\n     * 切换浏览器导航是否自动关闭弹出框\n     * @description.en-us Whether the overlay should close when the user goes backwards/forwards in history.Note that this usually doesn't include clicking on links (unless the user is using the `HashLocationStrategy`).\n     */\n    closeOnNavigation? = true;\n\n    /**\n     * 关闭弹窗前的回调函数，返回 false 可阻止关闭弹窗\n     */\n    canClose?: (result?: unknown) => boolean;\n\n    /**\n     * 设置当提供的位置均不适合时是否可以将覆盖层推到屏幕上\n     * @description.en-us Sets whether the overlay can be pushed on-screen if none of the provided positions fit\n     * @default true\n     */\n    canPush? = true;\n\n    /**\n     * Projectable nodes of thy abstract overlay config, only for component\n     * @type Node[][]\n     */\n    projectableNodes?: Node[][];\n}\n\nexport interface ThyAbstractOverlayOptions {\n    /** component name, e.g. dialog | popover | slide */\n    name: string;\n    /** Whether enable animation */\n    animationEnabled: boolean;\n    /** Whether dispose cdk overlay ref when close upper overlay */\n    disposeWhenClose: boolean;\n}\n"]}
|
|
@@ -37,7 +37,7 @@ export class ThyAbstractOverlayService {
|
|
|
37
37
|
}
|
|
38
38
|
else {
|
|
39
39
|
const injector = this.createInjector(config, abstractOverlayRef, containerInstance);
|
|
40
|
-
const contentRef = containerInstance.attachComponentPortal(new ComponentPortal(componentOrTemplateRef, config.viewContainerRef, injector));
|
|
40
|
+
const contentRef = containerInstance.attachComponentPortal(new ComponentPortal(componentOrTemplateRef, config.viewContainerRef, injector, undefined, config.projectableNodes));
|
|
41
41
|
if (config.initialState) {
|
|
42
42
|
const metadata = reflectComponentType(componentOrTemplateRef);
|
|
43
43
|
const inputsByTemplateName = keyBy(metadata.inputs, 'templateName');
|
|
@@ -155,4 +155,4 @@ export class ThyAbstractOverlayService {
|
|
|
155
155
|
this._afterOpened.complete();
|
|
156
156
|
}
|
|
157
157
|
}
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-overlay.service.js","sourceRoot":"","sources":["../../../../../src/core/overlay/abstract-overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceArray, concatArray, FunctionProp, keyBy } from 'ngx-tethys/util';\nimport { Subject } from 'rxjs';\n\nimport { ComponentType, Overlay, OverlayConfig, OverlayRef, ScrollStrategy } from '@angular/cdk/overlay';\nimport { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\nimport { Injector, TemplateRef, reflectComponentType } from '@angular/core';\n\nimport { ThyAbstractOverlayContainer } from './abstract-overlay-container';\nimport { ThyAbstractOverlayRef } from './abstract-overlay-ref';\nimport { ThyAbstractOverlayConfig, ThyAbstractOverlayOptions } from './abstract-overlay.config';\nimport { SafeAny } from 'ngx-tethys/types';\n\nexport type ComponentTypeOrTemplateRef<T> = ComponentType<T> | TemplateRef<T>;\n\nexport abstract class ThyAbstractOverlayService<TConfig extends ThyAbstractOverlayConfig, TContainer extends ThyAbstractOverlayContainer> {\n    private openedOverlays: ThyAbstractOverlayRef<unknown, TContainer>[] = [];\n\n    private readonly _afterAllClosed = new Subject<void>();\n\n    private readonly _afterOpened = new Subject<ThyAbstractOverlayRef<any, TContainer>>();\n\n    constructor(\n        protected options: ThyAbstractOverlayOptions, // component name, e.g: dialog | popover | slide\n        protected overlay: Overlay,\n        protected injector: Injector,\n        protected defaultConfig: TConfig,\n        public scrollStrategy?: FunctionProp<ScrollStrategy>\n    ) {}\n\n    /** Build cdk overlay config by config */\n    protected abstract buildOverlayConfig(config: TConfig): OverlayConfig;\n\n    /** Attach overlay container to overlay*/\n    protected abstract attachOverlayContainer(overlay: OverlayRef, config: TConfig): TContainer;\n\n    /** Create abstract overlay ref by cdk overlay, container and config  */\n    protected abstract createAbstractOverlayRef<T, TResult>(\n        overlayRef: OverlayRef,\n        containerInstance: TContainer,\n        config: TConfig\n    ): ThyAbstractOverlayRef<T, TContainer, TResult>;\n\n    /** Create injector for component content */\n    protected abstract createInjector<T>(\n        config: TConfig,\n        overlayRef: ThyAbstractOverlayRef<T, TContainer>,\n        containerInstance: TContainer\n    ): Injector;\n\n    /** Attach component or template ref to overlay container */\n    protected attachOverlayContent<T, TResult>(\n        componentOrTemplateRef: ComponentTypeOrTemplateRef<T>,\n        containerInstance: TContainer,\n        overlayRef: OverlayRef,\n        config: TConfig\n    ): ThyAbstractOverlayRef<T, TContainer, TResult> {\n        // Create a reference to the overlay we're creating in order to give the user a handle\n        // to modify and close it.\n        const abstractOverlayRef = this.createAbstractOverlayRef<T, TResult>(overlayRef, containerInstance, config);\n\n        // When the backdrop is clicked, we want to close it.\n        if (config.hasBackdrop) {\n            overlayRef.backdropClick().subscribe(() => {\n                if (\n                    (abstractOverlayRef.disableClose !== undefined && !abstractOverlayRef.disableClose) ||\n                    abstractOverlayRef.backdropClosable\n                ) {\n                    this.close();\n                }\n            });\n        }\n\n        if (componentOrTemplateRef instanceof TemplateRef) {\n            containerInstance.attachTemplatePortal(\n                new TemplatePortal<T>(componentOrTemplateRef, null, <any>{\n                    $implicit: config.initialState,\n                    [`${this.options.name}Ref`]: abstractOverlayRef\n                })\n            );\n        } else {\n            const injector = this.createInjector<T>(config, abstractOverlayRef, containerInstance);\n            const contentRef = containerInstance.attachComponentPortal<T>(\n                new ComponentPortal(componentOrTemplateRef, config.viewContainerRef, injector)\n            );\n            if (config.initialState) {\n                const metadata = reflectComponentType(componentOrTemplateRef);\n                const inputsByTemplateName = keyBy(metadata.inputs as SafeAny, 'templateName');\n                const inputsByPropName = keyBy(metadata.inputs as SafeAny, 'propName');\n                Object.keys(config.initialState).forEach(key => {\n                    const value = (config.initialState as SafeAny)[key];\n                    const input: { templateName?: string; propName?: string } = inputsByTemplateName[key] || inputsByPropName[key];\n                    if (input) {\n                        contentRef.setInput(input.templateName, value);\n                    } else {\n                        (contentRef.instance as SafeAny)[key] = value;\n                    }\n                });\n            }\n            if (config.hostClass) {\n                const hostClass = coerceArray(config.hostClass);\n                contentRef.location.nativeElement.classList.add(...hostClass);\n            }\n            abstractOverlayRef.componentInstance = contentRef.instance;\n        }\n\n        return abstractOverlayRef;\n    }\n\n    protected removeOpenedOverlay(overlayRef: ThyAbstractOverlayRef<any, TContainer>) {\n        const index = this.openedOverlays.indexOf(overlayRef);\n\n        if (index > -1) {\n            this.openedOverlays.splice(index, 1);\n\n            if (!this.openedOverlays.length) {\n                this._afterAllClosed.next();\n            }\n        }\n    }\n\n    protected getAbstractOverlayById(id: string): ThyAbstractOverlayRef<any, TContainer> | undefined {\n        return this.openedOverlays.find(overlay => overlay.id === id);\n    }\n\n    protected getAbstractOverlays(): ThyAbstractOverlayRef<any, TContainer>[] {\n        return this.openedOverlays;\n    }\n\n    protected buildBaseOverlayConfig(config: TConfig, defaultPanelClass?: string | string[]): OverlayConfig {\n        const overlayConfig = new OverlayConfig({\n            positionStrategy: this.overlay.position().global(),\n            hasBackdrop: config.hasBackdrop,\n            direction: config.direction,\n            width: config.width,\n            height: config.height,\n            minWidth: config.minWidth,\n            minHeight: config.minHeight,\n            maxWidth: config.maxWidth,\n            maxHeight: config.maxHeight,\n            disposeOnNavigation: config.closeOnNavigation\n        });\n\n        if (config.backdropClass) {\n            overlayConfig.backdropClass = config.backdropClass;\n        }\n\n        overlayConfig.panelClass = concatArray(config.panelClass, defaultPanelClass);\n\n        return overlayConfig;\n    }\n\n    protected openOverlay<T, TResult = unknown>(\n        componentOrTemplateRef: ComponentTypeOrTemplateRef<T>,\n        config?: TConfig\n    ): ThyAbstractOverlayRef<T, TContainer, TResult> {\n        config = { ...this.defaultConfig, ...config };\n        if (config.id && this.getAbstractOverlayById(config.id)) {\n            throw Error(`${this.options.name} with id ${config.id} exists already. The ${this.options.name} id must be unique.`);\n        }\n        const overlayConfig: OverlayConfig = this.buildOverlayConfig(config);\n        const overlayRef = this.overlay.create(overlayConfig);\n\n        const overlayContainer = this.attachOverlayContainer(overlayRef, config);\n        const abstractOverlayRef = this.attachOverlayContent<T, TResult>(componentOrTemplateRef, overlayContainer, overlayRef, config);\n\n        this.openedOverlays.push(abstractOverlayRef);\n        abstractOverlayRef.afterClosed().subscribe(() => {\n            this.removeOpenedOverlay(abstractOverlayRef);\n        });\n        this._afterOpened.next(abstractOverlayRef);\n\n        return abstractOverlayRef;\n    }\n\n    /**\n     * 所有弹出框完全关闭后的回调\n     * @returns\n     */\n    afterAllClosed() {\n        return this._afterAllClosed;\n    }\n\n    /**\n     * 打开弹出框之后的回调\n     * @returns\n     */\n    afterOpened() {\n        return this._afterOpened;\n    }\n\n    /**\n     * 关闭弹出框，若force为true，则canClose无效，强制关闭\n     * @param result\n     * @param force\n     */\n    close<T>(result?: T, force?: boolean) {\n        if (this.openedOverlays.length > 0) {\n            const lastOverlayRef = this.openedOverlays[this.openedOverlays.length - 1];\n            if (lastOverlayRef) {\n                lastOverlayRef.close(result, force);\n            }\n        }\n    }\n\n    /**\n     * 关闭所有打开的弹出框\n     */\n    closeAll() {\n        let i = this.openedOverlays.length;\n        while (i--) {\n            // 不需要操作 openedOverlays, 因为 close 会触发 afterClosed 的订阅\n            // 触发订阅后会自动从 openedOverlays 中移除\n            this.openedOverlays[i].close();\n        }\n    }\n\n    dispose(): void {\n        this.closeAll();\n        this._afterAllClosed.complete();\n        this._afterOpened.complete();\n    }\n}\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-overlay.service.js","sourceRoot":"","sources":["../../../../../src/core/overlay/abstract-overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceArray, concatArray, FunctionProp, keyBy } from 'ngx-tethys/util';\nimport { Subject } from 'rxjs';\n\nimport { ComponentType, Overlay, OverlayConfig, OverlayRef, ScrollStrategy } from '@angular/cdk/overlay';\nimport { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\nimport { Injector, TemplateRef, reflectComponentType } from '@angular/core';\n\nimport { ThyAbstractOverlayContainer } from './abstract-overlay-container';\nimport { ThyAbstractOverlayRef } from './abstract-overlay-ref';\nimport { ThyAbstractOverlayConfig, ThyAbstractOverlayOptions } from './abstract-overlay.config';\nimport { SafeAny } from 'ngx-tethys/types';\n\nexport type ComponentTypeOrTemplateRef<T> = ComponentType<T> | TemplateRef<T>;\n\nexport abstract class ThyAbstractOverlayService<TConfig extends ThyAbstractOverlayConfig, TContainer extends ThyAbstractOverlayContainer> {\n    private openedOverlays: ThyAbstractOverlayRef<unknown, TContainer>[] = [];\n\n    private readonly _afterAllClosed = new Subject<void>();\n\n    private readonly _afterOpened = new Subject<ThyAbstractOverlayRef<any, TContainer>>();\n\n    constructor(\n        protected options: ThyAbstractOverlayOptions, // component name, e.g: dialog | popover | slide\n        protected overlay: Overlay,\n        protected injector: Injector,\n        protected defaultConfig: TConfig,\n        public scrollStrategy?: FunctionProp<ScrollStrategy>\n    ) {}\n\n    /** Build cdk overlay config by config */\n    protected abstract buildOverlayConfig(config: TConfig): OverlayConfig;\n\n    /** Attach overlay container to overlay*/\n    protected abstract attachOverlayContainer(overlay: OverlayRef, config: TConfig): TContainer;\n\n    /** Create abstract overlay ref by cdk overlay, container and config  */\n    protected abstract createAbstractOverlayRef<T, TResult>(\n        overlayRef: OverlayRef,\n        containerInstance: TContainer,\n        config: TConfig\n    ): ThyAbstractOverlayRef<T, TContainer, TResult>;\n\n    /** Create injector for component content */\n    protected abstract createInjector<T>(\n        config: TConfig,\n        overlayRef: ThyAbstractOverlayRef<T, TContainer>,\n        containerInstance: TContainer\n    ): Injector;\n\n    /** Attach component or template ref to overlay container */\n    protected attachOverlayContent<T, TResult>(\n        componentOrTemplateRef: ComponentTypeOrTemplateRef<T>,\n        containerInstance: TContainer,\n        overlayRef: OverlayRef,\n        config: TConfig\n    ): ThyAbstractOverlayRef<T, TContainer, TResult> {\n        // Create a reference to the overlay we're creating in order to give the user a handle\n        // to modify and close it.\n        const abstractOverlayRef = this.createAbstractOverlayRef<T, TResult>(overlayRef, containerInstance, config);\n\n        // When the backdrop is clicked, we want to close it.\n        if (config.hasBackdrop) {\n            overlayRef.backdropClick().subscribe(() => {\n                if (\n                    (abstractOverlayRef.disableClose !== undefined && !abstractOverlayRef.disableClose) ||\n                    abstractOverlayRef.backdropClosable\n                ) {\n                    this.close();\n                }\n            });\n        }\n\n        if (componentOrTemplateRef instanceof TemplateRef) {\n            containerInstance.attachTemplatePortal(\n                new TemplatePortal<T>(componentOrTemplateRef, null, <any>{\n                    $implicit: config.initialState,\n                    [`${this.options.name}Ref`]: abstractOverlayRef\n                })\n            );\n        } else {\n            const injector = this.createInjector<T>(config, abstractOverlayRef, containerInstance);\n            const contentRef = containerInstance.attachComponentPortal<T>(\n                new ComponentPortal(componentOrTemplateRef, config.viewContainerRef, injector, undefined, config.projectableNodes)\n            );\n            if (config.initialState) {\n                const metadata = reflectComponentType(componentOrTemplateRef);\n                const inputsByTemplateName = keyBy(metadata.inputs as SafeAny, 'templateName');\n                const inputsByPropName = keyBy(metadata.inputs as SafeAny, 'propName');\n                Object.keys(config.initialState).forEach(key => {\n                    const value = (config.initialState as SafeAny)[key];\n                    const input: { templateName?: string; propName?: string } = inputsByTemplateName[key] || inputsByPropName[key];\n                    if (input) {\n                        contentRef.setInput(input.templateName, value);\n                    } else {\n                        (contentRef.instance as SafeAny)[key] = value;\n                    }\n                });\n            }\n            if (config.hostClass) {\n                const hostClass = coerceArray(config.hostClass);\n                contentRef.location.nativeElement.classList.add(...hostClass);\n            }\n            abstractOverlayRef.componentInstance = contentRef.instance;\n        }\n\n        return abstractOverlayRef;\n    }\n\n    protected removeOpenedOverlay(overlayRef: ThyAbstractOverlayRef<any, TContainer>) {\n        const index = this.openedOverlays.indexOf(overlayRef);\n\n        if (index > -1) {\n            this.openedOverlays.splice(index, 1);\n\n            if (!this.openedOverlays.length) {\n                this._afterAllClosed.next();\n            }\n        }\n    }\n\n    protected getAbstractOverlayById(id: string): ThyAbstractOverlayRef<any, TContainer> | undefined {\n        return this.openedOverlays.find(overlay => overlay.id === id);\n    }\n\n    protected getAbstractOverlays(): ThyAbstractOverlayRef<any, TContainer>[] {\n        return this.openedOverlays;\n    }\n\n    protected buildBaseOverlayConfig(config: TConfig, defaultPanelClass?: string | string[]): OverlayConfig {\n        const overlayConfig = new OverlayConfig({\n            positionStrategy: this.overlay.position().global(),\n            hasBackdrop: config.hasBackdrop,\n            direction: config.direction,\n            width: config.width,\n            height: config.height,\n            minWidth: config.minWidth,\n            minHeight: config.minHeight,\n            maxWidth: config.maxWidth,\n            maxHeight: config.maxHeight,\n            disposeOnNavigation: config.closeOnNavigation\n        });\n\n        if (config.backdropClass) {\n            overlayConfig.backdropClass = config.backdropClass;\n        }\n\n        overlayConfig.panelClass = concatArray(config.panelClass, defaultPanelClass);\n\n        return overlayConfig;\n    }\n\n    protected openOverlay<T, TResult = unknown>(\n        componentOrTemplateRef: ComponentTypeOrTemplateRef<T>,\n        config?: TConfig\n    ): ThyAbstractOverlayRef<T, TContainer, TResult> {\n        config = { ...this.defaultConfig, ...config };\n        if (config.id && this.getAbstractOverlayById(config.id)) {\n            throw Error(`${this.options.name} with id ${config.id} exists already. The ${this.options.name} id must be unique.`);\n        }\n        const overlayConfig: OverlayConfig = this.buildOverlayConfig(config);\n        const overlayRef = this.overlay.create(overlayConfig);\n\n        const overlayContainer = this.attachOverlayContainer(overlayRef, config);\n        const abstractOverlayRef = this.attachOverlayContent<T, TResult>(componentOrTemplateRef, overlayContainer, overlayRef, config);\n\n        this.openedOverlays.push(abstractOverlayRef);\n        abstractOverlayRef.afterClosed().subscribe(() => {\n            this.removeOpenedOverlay(abstractOverlayRef);\n        });\n        this._afterOpened.next(abstractOverlayRef);\n\n        return abstractOverlayRef;\n    }\n\n    /**\n     * 所有弹出框完全关闭后的回调\n     * @returns\n     */\n    afterAllClosed() {\n        return this._afterAllClosed;\n    }\n\n    /**\n     * 打开弹出框之后的回调\n     * @returns\n     */\n    afterOpened() {\n        return this._afterOpened;\n    }\n\n    /**\n     * 关闭弹出框，若force为true，则canClose无效，强制关闭\n     * @param result\n     * @param force\n     */\n    close<T>(result?: T, force?: boolean) {\n        if (this.openedOverlays.length > 0) {\n            const lastOverlayRef = this.openedOverlays[this.openedOverlays.length - 1];\n            if (lastOverlayRef) {\n                lastOverlayRef.close(result, force);\n            }\n        }\n    }\n\n    /**\n     * 关闭所有打开的弹出框\n     */\n    closeAll() {\n        let i = this.openedOverlays.length;\n        while (i--) {\n            // 不需要操作 openedOverlays, 因为 close 会触发 afterClosed 的订阅\n            // 触发订阅后会自动从 openedOverlays 中移除\n            this.openedOverlays[i].close();\n        }\n    }\n\n    dispose(): void {\n        this.closeAll();\n        this._afterAllClosed.complete();\n        this._afterOpened.complete();\n    }\n}\n"]}
|
|
@@ -70,7 +70,7 @@ export class ThyDialogContainer extends ThyAbstractOverlayContainer {
|
|
|
70
70
|
if (lastPosition) {
|
|
71
71
|
const containerElement = this.elementRef.nativeElement;
|
|
72
72
|
const transformOrigin = `${lastPosition.x - containerElement.offsetLeft}px ${lastPosition.y - containerElement.offsetTop}px 0px`;
|
|
73
|
-
containerElement.style
|
|
73
|
+
containerElement.style.transformOrigin = transformOrigin;
|
|
74
74
|
// 手动修改动画状态为从 void 到 enter, 开启动画
|
|
75
75
|
}
|
|
76
76
|
this.animationState = 'enter';
|
|
@@ -166,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
166
166
|
type: HostBinding,
|
|
167
167
|
args: [`attr.id`]
|
|
168
168
|
}] } });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-container.component.js","sourceRoot":"","sources":["../../../../src/dialog/dialog-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { reqAnimFrame, ThyAbstractOverlayContainer, ThyClickPositioner, ThyPortalOutlet } from 'ngx-tethys/core';\nimport { Observable } from 'rxjs';\nimport { filter } from 'rxjs/operators';\n\nimport { AnimationEvent } from '@angular/animations';\nimport { FocusTrap, FocusTrapFactory } from '@angular/cdk/a11y';\nimport { PortalModule } from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    NgZone,\n    OnDestroy,\n    Renderer2,\n    ViewChild,\n    inject\n} from '@angular/core';\n\nimport { thyDialogAnimations } from './dialog-animations';\nimport { ThyDialogConfig } from './dialog.config';\nimport { dialogAbstractOverlayOptions } from './dialog.options';\n\n/**\n * @private\n */\n@Component({\n    selector: 'thy-dialog-container',\n    template: ` <ng-template thyPortalOutlet></ng-template> `,\n    // Using OnPush for dialogs caused some sync issues, e.g. custom ngModel can't to detect changes\n    // Disabled until we can track them down.\n    changeDetection: ChangeDetectionStrategy.Default,\n    animations: [thyDialogAnimations.dialogContainer],\n    host: {\n        class: 'thy-dialog-container',\n        tabindex: '-1',\n        'aria-modal': 'true',\n        '[attr.id]': 'id',\n        '[attr.role]': 'config.role',\n        '[attr.aria-labelledby]': 'config.ariaLabel ? null : ariaLabelledBy',\n        '[attr.aria-label]': 'config.ariaLabel',\n        '[attr.aria-describedby]': 'config.ariaDescribedBy || null',\n        '[@dialogContainer]': 'animationState',\n        '(@dialogContainer.start)': 'onAnimationStart($event)',\n        '(@dialogContainer.done)': 'onAnimationDone($event)'\n    },\n    standalone: true,\n    imports: [PortalModule, ThyPortalOutlet]\n})\nexport class ThyDialogContainer extends ThyAbstractOverlayContainer implements OnDestroy {\n    private elementRef = inject(ElementRef);\n    private document = inject(DOCUMENT);\n    config = inject(ThyDialogConfig);\n    private clickPositioner = inject(ThyClickPositioner);\n    private focusTrapFactory = inject(FocusTrapFactory);\n    private ngZone = inject(NgZone);\n    private renderer = inject(Renderer2);\n\n    animationOpeningDone: Observable<AnimationEvent>;\n    animationClosingDone: Observable<AnimationEvent>;\n\n    @ViewChild(ThyPortalOutlet, { static: true })\n    portalOutlet: ThyPortalOutlet;\n\n    @HostBinding(`attr.id`)\n    id: string;\n\n    /** State of the dialog animation. */\n    animationState: 'void' | 'enter' | 'exit' = 'void';\n\n    /** Emits when an animation state changes. */\n    animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** ID of the element that should be considered as the dialog's label. */\n    ariaLabelledBy: string | null = null;\n\n    /** Element that was focused before the dialog was opened. Save this to restore upon close. */\n    private elementFocusedBeforeDialogWasOpened: HTMLElement | null = null;\n\n    /** The class that traps and manages focus within the dialog. */\n    private focusTrap: FocusTrap;\n\n    private savePreviouslyFocusedElement() {\n        if (this.document) {\n            this.elementFocusedBeforeDialogWasOpened = this.document.activeElement as HTMLElement;\n\n            // Note that there is no focus method when rendering on the server.\n            if (this.elementRef.nativeElement.focus) {\n                // Note: this is being run outside of the Angular zone because `element.focus()` doesn't require\n                // running change detection.\n                this.ngZone.runOutsideAngular(() =>\n                    // Move focus onto the dialog immediately in order to prevent the user from accidentally\n                    // opening multiple dialogs at the same time. Needs to be async, because the element\n                    // may not be focusable immediately.\n\n                    // Note: `element.focus()` causes re-layout and this may lead to frame drop on slower devices.\n                    // https://gist.github.com/paulirish/5d52fb081b3570c81e3a#setting-focus\n                    // `setTimeout` is a macrotask and macrotasks are executed within the current rendering frame.\n                    // Animation tasks are executed within the next rendering frame.\n                    reqAnimFrame(() => this.elementRef.nativeElement.focus())\n                );\n            }\n        }\n    }\n\n    /** Moves the focus inside the focus trap. */\n    private trapFocus() {\n        const element = this.elementRef.nativeElement;\n\n        if (!this.focusTrap) {\n            this.focusTrap = this.focusTrapFactory.create(element);\n        }\n\n        // If we were to attempt to focus immediately, then the content of the dialog would not yet be\n        // ready in instances where change detection has to run first. To deal with this, we simply\n        // wait for the microtask queue to be empty.\n        if (this.config.autoFocus) {\n            this.focusTrap.focusInitialElementWhenReady();\n        } else {\n            const activeElement = this.document.activeElement;\n\n            // Otherwise ensure that focus is on the dialog container. It's possible that a different\n            // component tried to move focus while the open animation was running. See:\n            // https://github.com/angular/components/issues/16215. Note that we only want to do this\n            // if the focus isn't inside the dialog already, because it's possible that the consumer\n            // turned off `autoFocus` in order to move focus themselves.\n            if (activeElement !== element && !element.contains(activeElement)) {\n                element.focus();\n            }\n        }\n    }\n\n    private restoreFocus() {\n        const toFocus = this.elementFocusedBeforeDialogWasOpened;\n\n        // We need the extra check, because IE can set the `activeElement` to null in some cases.\n        if (this.config.restoreFocus && toFocus && typeof toFocus.focus === 'function') {\n            toFocus.focus(this.config.restoreFocusOptions);\n        }\n\n        if (this.focusTrap) {\n            this.focusTrap.destroy();\n        }\n    }\n\n    private setTransformOrigin() {\n        this.clickPositioner.runTaskUseLastPosition(lastPosition => {\n            if (lastPosition) {\n                const containerElement: HTMLElement = this.elementRef.nativeElement;\n                const transformOrigin = `${lastPosition.x - containerElement.offsetLeft}px ${\n                    lastPosition.y - containerElement.offsetTop\n                }px 0px`;\n                containerElement.style['transform-origin'] = transformOrigin;\n                // 手动修改动画状态为从 void 到 enter, 开启动画\n            }\n            this.animationState = 'enter';\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    constructor() {\n        const changeDetectorRef = inject(ChangeDetectorRef);\n\n        super(dialogAbstractOverlayOptions, changeDetectorRef);\n        this.animationOpeningDone = this.animationStateChanged.pipe(\n            filter((event: AnimationEvent) => {\n                return event.phaseName === 'done' && event.toState === 'void';\n            })\n        );\n        this.animationClosingDone = this.animationStateChanged.pipe(\n            filter((event: AnimationEvent) => {\n                return event.phaseName === 'done' && event.toState === 'exit';\n            })\n        );\n        /* Prohibit operations on elements inside the container during animation execution */\n        this.animationStateChanged\n            .pipe(\n                filter((event: AnimationEvent) => {\n                    return event.phaseName === 'start' && event.toState === 'exit';\n                })\n            )\n            .subscribe(() => {\n                this.renderer.setStyle(this.elementRef.nativeElement, 'pointer-events', 'none');\n            });\n    }\n\n    beforeAttachPortal(): void {\n        this.setTransformOrigin();\n        this.savePreviouslyFocusedElement();\n    }\n\n    /** Callback, invoked whenever an animation on the host completes. */\n    onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'void') {\n            this.trapFocus();\n        } else if (event.toState === 'exit') {\n            this.restoreFocus();\n        }\n        this.animationStateChanged.emit(event);\n    }\n\n    /** Callback, invoked when an animation on the host starts. */\n    onAnimationStart(event: AnimationEvent) {\n        this.animationStateChanged.emit(event);\n    }\n\n    ngOnDestroy() {\n        super.destroy();\n    }\n}\n"]}
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-container.component.js","sourceRoot":"","sources":["../../../../src/dialog/dialog-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { reqAnimFrame, ThyAbstractOverlayContainer, ThyClickPositioner, ThyPortalOutlet } from 'ngx-tethys/core';\nimport { Observable } from 'rxjs';\nimport { filter } from 'rxjs/operators';\n\nimport { AnimationEvent } from '@angular/animations';\nimport { FocusTrap, FocusTrapFactory } from '@angular/cdk/a11y';\nimport { PortalModule } from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    NgZone,\n    OnDestroy,\n    Renderer2,\n    ViewChild,\n    inject\n} from '@angular/core';\n\nimport { thyDialogAnimations } from './dialog-animations';\nimport { ThyDialogConfig } from './dialog.config';\nimport { dialogAbstractOverlayOptions } from './dialog.options';\n\n/**\n * @private\n */\n@Component({\n    selector: 'thy-dialog-container',\n    template: ` <ng-template thyPortalOutlet></ng-template> `,\n    // Using OnPush for dialogs caused some sync issues, e.g. custom ngModel can't to detect changes\n    // Disabled until we can track them down.\n    changeDetection: ChangeDetectionStrategy.Default,\n    animations: [thyDialogAnimations.dialogContainer],\n    host: {\n        class: 'thy-dialog-container',\n        tabindex: '-1',\n        'aria-modal': 'true',\n        '[attr.id]': 'id',\n        '[attr.role]': 'config.role',\n        '[attr.aria-labelledby]': 'config.ariaLabel ? null : ariaLabelledBy',\n        '[attr.aria-label]': 'config.ariaLabel',\n        '[attr.aria-describedby]': 'config.ariaDescribedBy || null',\n        '[@dialogContainer]': 'animationState',\n        '(@dialogContainer.start)': 'onAnimationStart($event)',\n        '(@dialogContainer.done)': 'onAnimationDone($event)'\n    },\n    standalone: true,\n    imports: [PortalModule, ThyPortalOutlet]\n})\nexport class ThyDialogContainer extends ThyAbstractOverlayContainer implements OnDestroy {\n    private elementRef = inject(ElementRef);\n    private document = inject(DOCUMENT);\n    config = inject(ThyDialogConfig);\n    private clickPositioner = inject(ThyClickPositioner);\n    private focusTrapFactory = inject(FocusTrapFactory);\n    private ngZone = inject(NgZone);\n    private renderer = inject(Renderer2);\n\n    animationOpeningDone: Observable<AnimationEvent>;\n    animationClosingDone: Observable<AnimationEvent>;\n\n    @ViewChild(ThyPortalOutlet, { static: true })\n    portalOutlet: ThyPortalOutlet;\n\n    @HostBinding(`attr.id`)\n    id: string;\n\n    /** State of the dialog animation. */\n    animationState: 'void' | 'enter' | 'exit' = 'void';\n\n    /** Emits when an animation state changes. */\n    animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    /** ID of the element that should be considered as the dialog's label. */\n    ariaLabelledBy: string | null = null;\n\n    /** Element that was focused before the dialog was opened. Save this to restore upon close. */\n    private elementFocusedBeforeDialogWasOpened: HTMLElement | null = null;\n\n    /** The class that traps and manages focus within the dialog. */\n    private focusTrap: FocusTrap;\n\n    private savePreviouslyFocusedElement() {\n        if (this.document) {\n            this.elementFocusedBeforeDialogWasOpened = this.document.activeElement as HTMLElement;\n\n            // Note that there is no focus method when rendering on the server.\n            if (this.elementRef.nativeElement.focus) {\n                // Note: this is being run outside of the Angular zone because `element.focus()` doesn't require\n                // running change detection.\n                this.ngZone.runOutsideAngular(() =>\n                    // Move focus onto the dialog immediately in order to prevent the user from accidentally\n                    // opening multiple dialogs at the same time. Needs to be async, because the element\n                    // may not be focusable immediately.\n\n                    // Note: `element.focus()` causes re-layout and this may lead to frame drop on slower devices.\n                    // https://gist.github.com/paulirish/5d52fb081b3570c81e3a#setting-focus\n                    // `setTimeout` is a macrotask and macrotasks are executed within the current rendering frame.\n                    // Animation tasks are executed within the next rendering frame.\n                    reqAnimFrame(() => this.elementRef.nativeElement.focus())\n                );\n            }\n        }\n    }\n\n    /** Moves the focus inside the focus trap. */\n    private trapFocus() {\n        const element = this.elementRef.nativeElement;\n\n        if (!this.focusTrap) {\n            this.focusTrap = this.focusTrapFactory.create(element);\n        }\n\n        // If we were to attempt to focus immediately, then the content of the dialog would not yet be\n        // ready in instances where change detection has to run first. To deal with this, we simply\n        // wait for the microtask queue to be empty.\n        if (this.config.autoFocus) {\n            this.focusTrap.focusInitialElementWhenReady();\n        } else {\n            const activeElement = this.document.activeElement;\n\n            // Otherwise ensure that focus is on the dialog container. It's possible that a different\n            // component tried to move focus while the open animation was running. See:\n            // https://github.com/angular/components/issues/16215. Note that we only want to do this\n            // if the focus isn't inside the dialog already, because it's possible that the consumer\n            // turned off `autoFocus` in order to move focus themselves.\n            if (activeElement !== element && !element.contains(activeElement)) {\n                element.focus();\n            }\n        }\n    }\n\n    private restoreFocus() {\n        const toFocus = this.elementFocusedBeforeDialogWasOpened;\n\n        // We need the extra check, because IE can set the `activeElement` to null in some cases.\n        if (this.config.restoreFocus && toFocus && typeof toFocus.focus === 'function') {\n            toFocus.focus(this.config.restoreFocusOptions);\n        }\n\n        if (this.focusTrap) {\n            this.focusTrap.destroy();\n        }\n    }\n\n    private setTransformOrigin() {\n        this.clickPositioner.runTaskUseLastPosition(lastPosition => {\n            if (lastPosition) {\n                const containerElement: HTMLElement = this.elementRef.nativeElement;\n                const transformOrigin = `${lastPosition.x - containerElement.offsetLeft}px ${\n                    lastPosition.y - containerElement.offsetTop\n                }px 0px`;\n                containerElement.style.transformOrigin = transformOrigin;\n                // 手动修改动画状态为从 void 到 enter, 开启动画\n            }\n            this.animationState = 'enter';\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    constructor() {\n        const changeDetectorRef = inject(ChangeDetectorRef);\n\n        super(dialogAbstractOverlayOptions, changeDetectorRef);\n        this.animationOpeningDone = this.animationStateChanged.pipe(\n            filter((event: AnimationEvent) => {\n                return event.phaseName === 'done' && event.toState === 'void';\n            })\n        );\n        this.animationClosingDone = this.animationStateChanged.pipe(\n            filter((event: AnimationEvent) => {\n                return event.phaseName === 'done' && event.toState === 'exit';\n            })\n        );\n        /* Prohibit operations on elements inside the container during animation execution */\n        this.animationStateChanged\n            .pipe(\n                filter((event: AnimationEvent) => {\n                    return event.phaseName === 'start' && event.toState === 'exit';\n                })\n            )\n            .subscribe(() => {\n                this.renderer.setStyle(this.elementRef.nativeElement, 'pointer-events', 'none');\n            });\n    }\n\n    beforeAttachPortal(): void {\n        this.setTransformOrigin();\n        this.savePreviouslyFocusedElement();\n    }\n\n    /** Callback, invoked whenever an animation on the host completes. */\n    onAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'void') {\n            this.trapFocus();\n        } else if (event.toState === 'exit') {\n            this.restoreFocus();\n        }\n        this.animationStateChanged.emit(event);\n    }\n\n    /** Callback, invoked when an animation on the host starts. */\n    onAnimationStart(event: AnimationEvent) {\n        this.animationStateChanged.emit(event);\n    }\n\n    ngOnDestroy() {\n        super.destroy();\n    }\n}\n"]}
|
|
@@ -5,6 +5,7 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
* 自定义拖拽时可经过,拖拽结束时可放置的区域内容
|
|
6
6
|
* @name thy-drag-content,[thyDragContent]
|
|
7
7
|
* @order 25
|
|
8
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
8
9
|
*/
|
|
9
10
|
export class ThyDragContentDirective {
|
|
10
11
|
constructor() {
|
|
@@ -28,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
28
29
|
type: HostBinding,
|
|
29
30
|
args: ['class.thy-drag-content']
|
|
30
31
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1jb250ZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kcmFnLWRyb3AvZHJhZy1jb250ZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQUVwRDs7Ozs7R0FLRztBQUtILE1BQU0sT0FBTyx1QkFBdUI7SUFLaEM7UUFKQSxZQUFPLEdBQUcsTUFBTSxDQUEwQixVQUFVLENBQUMsQ0FBQztRQUVmLGlCQUFZLEdBQUcsSUFBSSxDQUFDO1FBR3ZELE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBRSxDQUFDO1FBRTNELElBQUksSUFBSSxFQUFFLENBQUM7WUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNsRCxDQUFDO0lBQ0wsQ0FBQzs4R0FYUSx1QkFBdUI7a0dBQXZCLHVCQUF1Qjs7MkZBQXZCLHVCQUF1QjtrQkFKbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsbUNBQW1DO29CQUM3QyxVQUFVLEVBQUUsSUFBSTtpQkFDbkI7d0RBSTBDLFlBQVk7c0JBQWxELFdBQVc7dUJBQUMsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlEcmFnRGlyZWN0aXZlIH0gZnJvbSAnLi9kcmFnLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICog6Ieq5a6a5LmJ5ouW5ou95pe25Y+v57uP6L+H77yM5ouW5ou957uT5p2f5pe25Y+v5pS+572u55qE5Yy65Z+f5YaF5a65XG4gKiBAbmFtZSB0aHktZHJhZy1jb250ZW50LFt0aHlEcmFnQ29udGVudF1cbiAqIEBvcmRlciAyNVxuICogQGRlcHJlY2F0ZWQgcGxlYXNlIHVzZSBAYW5ndWxhci9jZGsvZHJhZy1kcm9wXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAndGh5LWRyYWctY29udGVudCxbdGh5RHJhZ0NvbnRlbnRdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFRoeURyYWdDb250ZW50RGlyZWN0aXZlIHtcbiAgICBlbGVtZW50ID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKTtcblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MudGh5LWRyYWctY29udGVudCcpIGNvbnRlbnRDbGFzcyA9IHRydWU7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgY29uc3QgZHJhZyA9IGluamVjdChUaHlEcmFnRGlyZWN0aXZlLCB7IG9wdGlvbmFsOiB0cnVlIH0pITtcblxuICAgICAgICBpZiAoZHJhZykge1xuICAgICAgICAgICAgZHJhZy5kcmFnUmVmLndpdGhDb250ZW50RWxlbWVudCh0aGlzLmVsZW1lbnQpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -3,6 +3,7 @@ import * as i0 from "@angular/core";
|
|
|
3
3
|
/**
|
|
4
4
|
* 自定义可放置区域内容
|
|
5
5
|
* @order 40
|
|
6
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
6
7
|
*/
|
|
7
8
|
export class ThyDragDropService {
|
|
8
9
|
constructor() {
|
|
@@ -19,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
19
20
|
type: Injectable,
|
|
20
21
|
args: [{ providedIn: 'root' }]
|
|
21
22
|
}], ctorParameters: () => [] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1kcm9wLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZHJhZy1kcm9wL2RyYWctZHJvcC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSTNDOzs7O0dBSUc7QUFFSCxNQUFNLE9BQU8sa0JBQWtCO0lBaUIzQjtRQUxBOzs7V0FHRztRQUNJLGFBQVEsR0FBRyxJQUFJLEdBQUcsRUFBbUIsQ0FBQztJQUM5QixDQUFDOzhHQWpCUCxrQkFBa0I7a0hBQWxCLGtCQUFrQixjQURMLE1BQU07OzJGQUNuQixrQkFBa0I7a0JBRDlCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGh5RHJhZ0RpcmVjdGl2ZSB9IGZyb20gJy4vZHJhZy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVGh5RHJvcFBvc2l0aW9uIH0gZnJvbSAnLi9kcmFnLWRyb3AuY2xhc3MnO1xuXG4vKipcbiAqIOiHquWumuS5ieWPr+aUvue9ruWMuuWfn+WGheWuuVxuICogQG9yZGVyIDQwXG4gKiBAZGVwcmVjYXRlZCBwbGVhc2UgdXNlIEBhbmd1bGFyL2Nkay9kcmFnLWRyb3BcbiAqL1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRHJvcFNlcnZpY2U8VCA9IGFueT4ge1xuICAgIC8qKlxuICAgICAqIOW9k+WJjeaLluaLvemhue+8jGRyYWdFbmQg5ZCO6YeN572u5Li6IHVuZGVmaW5lZFxuICAgICAqL1xuICAgIHB1YmxpYyBwcmV2aW91c0RyYWc6IFRoeURyYWdEaXJlY3RpdmU8VD47XG5cbiAgICAvKipcbiAgICAgKiDmi5bmi73nmoTml7blgJnvvIzpkojlr7kgZHJhZ092ZXIg55qE6IqC54K55pyJ5LiJ56eN5oOF5Ya177yM5Y2z5ouW5ou95Yiw6IqC54K55LmL5LiKIGJlZm9yZSDvvIzmi5bmi73liLDoioLngrnkuIogaW4g77yM5ouW5ou95Yiw6IqC54K55LmL5LiLIGFmdGVyXG4gICAgICogQHR5cGUgVGh5RHJvcFBvc2l0aW9uXG4gICAgICovXG4gICAgcHVibGljIGRyb3BQb3NpdGlvbjogVGh5RHJvcFBvc2l0aW9uO1xuXG4gICAgLyoqXG4gICAgICog55So5LqO5ouW5Yqo6L+H56iL5a+5IGRyYWdvdmVyIOeahOWFg+e0oOiuvue9ruebuOW6lOeahOagt+W8j1xuICAgICAqIEB0eXBlIE1hcDxFbGVtZW50LCBzdHJpbmc+XG4gICAgICovXG4gICAgcHVibGljIGNsYXNzTWFwID0gbmV3IE1hcDxFbGVtZW50LCBzdHJpbmc+KCk7XG4gICAgY29uc3RydWN0b3IoKSB7fVxufVxuIl19
|
|
@@ -6,6 +6,7 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
* 自定义可拖拽区域内容
|
|
7
7
|
* @name thy-drag-handle,[thyDragHandle]
|
|
8
8
|
* @order 20
|
|
9
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
9
10
|
*/
|
|
10
11
|
export class ThyDragHandleDirective {
|
|
11
12
|
/**
|
|
@@ -39,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
39
40
|
type: Input,
|
|
40
41
|
args: [{ alias: 'thyDisabled', transform: coerceBooleanProperty }]
|
|
41
42
|
}] } });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2RyYWctZHJvcC9kcmFnLWhhbmRsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFFeEQ7Ozs7O0dBS0c7QUFLSCxNQUFNLE9BQU8sc0JBQXNCO0lBSy9COzs7T0FHRztJQUNILElBQ0ksUUFBUSxDQUFDLEtBQWM7UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDM0IsQ0FBQztJQUNELElBQUksUUFBUTtRQUNSLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUMxQixDQUFDO0lBRUQ7UUFoQkEsWUFBTyxHQUFHLE1BQU0sQ0FBMEIsVUFBVSxDQUFDLENBQUM7UUFFOUMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQWV0QixNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUUsQ0FBQztRQUUzRCxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ1AsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkMsQ0FBQztJQUNMLENBQUM7OEdBdkJRLHNCQUFzQjtrR0FBdEIsc0JBQXNCLG1IQVNXLHFCQUFxQjs7MkZBVHRELHNCQUFzQjtrQkFKbEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUNBQWlDO29CQUMzQyxVQUFVLEVBQUUsSUFBSTtpQkFDbkI7d0RBV08sUUFBUTtzQkFEWCxLQUFLO3VCQUFDLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoeURyYWdEaXJlY3RpdmUgfSBmcm9tICcuL2RyYWcuZGlyZWN0aXZlJztcbmltcG9ydCB7IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ25neC10ZXRoeXMvdXRpbCc7XG5cbi8qKlxuICog6Ieq5a6a5LmJ5Y+v5ouW5ou95Yy65Z+f5YaF5a65XG4gKiBAbmFtZSB0aHktZHJhZy1oYW5kbGUsW3RoeURyYWdIYW5kbGVdXG4gKiBAb3JkZXIgMjBcbiAqIEBkZXByZWNhdGVkIHBsZWFzZSB1c2UgQGFuZ3VsYXIvY2RrL2RyYWctZHJvcFxuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ3RoeS1kcmFnLWhhbmRsZSxbdGh5RHJhZ0hhbmRsZV0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgVGh5RHJhZ0hhbmRsZURpcmVjdGl2ZSB7XG4gICAgZWxlbWVudCA9IGluamVjdDxFbGVtZW50UmVmPEhUTUxFbGVtZW50Pj4oRWxlbWVudFJlZik7XG5cbiAgICBwcml2YXRlIF9kaXNhYmxlZCA9IGZhbHNlO1xuXG4gICAgLyoqXG4gICAgICog5piv5ZCm56aB55SoXG4gICAgICogQGRlZmF1bHQgZmFsc2VcbiAgICAgKi9cbiAgICBASW5wdXQoeyBhbGlhczogJ3RoeURpc2FibGVkJywgdHJhbnNmb3JtOiBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSlcbiAgICBzZXQgZGlzYWJsZWQodmFsdWU6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5fZGlzYWJsZWQgPSB2YWx1ZTtcbiAgICB9XG4gICAgZ2V0IGRpc2FibGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGNvbnN0IGRyYWcgPSBpbmplY3QoVGh5RHJhZ0RpcmVjdGl2ZSwgeyBvcHRpb25hbDogdHJ1ZSB9KSE7XG5cbiAgICAgICAgaWYgKGRyYWcpIHtcbiAgICAgICAgICAgIGRyYWcuZHJhZ1JlZi53aXRoSGFuZGxlcyh0aGlzKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -9,6 +9,7 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
* 拖拽项
|
|
10
10
|
* @name thy-drag,[thyDrag]
|
|
11
11
|
* @order 10
|
|
12
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
12
13
|
*/
|
|
13
14
|
export class ThyDragDirective {
|
|
14
15
|
/**
|
|
@@ -67,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
67
68
|
type: Input,
|
|
68
69
|
args: [{ alias: 'thyDragDisabled', transform: coerceBooleanProperty }]
|
|
69
70
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZHJhZy1kcm9wL2RyYWcuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFhLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEgsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFlBQVksQ0FBQztBQUNyQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLDRCQUE0QixFQUE4QixNQUFNLHdCQUF3QixDQUFDO0FBQ2xHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUV4RDs7Ozs7R0FLRztBQUtILE1BQU0sT0FBTyxnQkFBZ0I7SUFJekI7OztPQUdHO0lBQ0gsSUFDSSxRQUFRLENBQUMsSUFBTztRQUNoQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUNyQixDQUFDO0lBWUQ7OztPQUdHO0lBQ0gsSUFDSSxRQUFRLENBQUMsVUFBbUI7UUFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxVQUFVLENBQUM7UUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLFVBQVUsQ0FBQztJQUNuQyxDQUFDO0lBQ0QsSUFBSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFJRDtRQXJDQSxjQUFTLEdBQUcsTUFBTSxDQUFDLDRCQUE0QixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFFLENBQUM7UUFDOUQsZUFBVSxHQUFHLE1BQU0sQ0FBMEIsVUFBVSxDQUFDLENBQUM7UUFpQmxDLGdCQUFXLEdBQUcsSUFBSSxDQUFDO1FBRTFDLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFrQnRCLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNsQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ2pDLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM5QixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO1FBQ25DLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBd0Isa0JBQWtCLENBQUMsQ0FBQztRQUNsRSxNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFFbkMsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBSSxVQUFVLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQztJQUNwRyxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQzs4R0FuRFEsZ0JBQWdCO2tHQUFoQixnQkFBZ0IsNEtBMkJxQixxQkFBcUI7OzJGQTNCMUQsZ0JBQWdCO2tCQUo1QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO2lCQUNuQjt3REFVTyxRQUFRO3NCQURYLEtBQUs7dUJBQUMsU0FBUztnQkFTTSxJQUFJO3NCQUF6QixLQUFLO3VCQUFDLGFBQWE7Z0JBRVcsV0FBVztzQkFBekMsV0FBVzt1QkFBQyxnQkFBZ0I7Z0JBU3pCLFFBQVE7c0JBRFgsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIE5nWm9uZSwgRWxlbWVudFJlZiwgSG9zdEJpbmRpbmcsIElucHV0LCBPbkRlc3Ryb3ksIFJlbmRlcmVyMiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEcmFnUmVmIH0gZnJvbSAnLi9kcmFnLXJlZic7XG5pbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBUaHlEcmFnRHJvcFNlcnZpY2UgfSBmcm9tICcuL2RyYWctZHJvcC5zZXJ2aWNlJztcbmltcG9ydCB7IFRIWV9EUk9QX0NPTlRBSU5FUl9ESVJFQ1RJVkUsIElUaHlEcm9wQ29udGFpbmVyRGlyZWN0aXZlIH0gZnJvbSAnLi9kcm9wLWNvbnRhaW5lci5jbGFzcyc7XG5pbXBvcnQgeyBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSBmcm9tICduZ3gtdGV0aHlzL3V0aWwnO1xuXG4vKipcbiAqIOaLluaLvemhuVxuICogQG5hbWUgdGh5LWRyYWcsW3RoeURyYWddXG4gKiBAb3JkZXIgMTBcbiAqIEBkZXByZWNhdGVkIHBsZWFzZSB1c2UgQGFuZ3VsYXIvY2RrL2RyYWctZHJvcFxuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ3RoeS1kcmFnLFt0aHlEcmFnXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRGlyZWN0aXZlPFQgPSBhbnk+IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBjb250YWluZXIgPSBpbmplY3QoVEhZX0RST1BfQ09OVEFJTkVSX0RJUkVDVElWRSwgeyBvcHRpb25hbDogdHJ1ZSB9KSE7XG4gICAgcHJpdmF0ZSBlbGVtZW50UmVmID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKTtcblxuICAgIC8qKlxuICAgICAqIOWFg+aVsOaNrlxuICAgICAqIEB0eXBlIGFueVxuICAgICAqL1xuICAgIEBJbnB1dCgndGh5RHJhZycpXG4gICAgc2V0IGRyYWdEYXRhKGRhdGE6IFQpIHtcbiAgICAgICAgdGhpcy5kYXRhID0gZGF0YTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiDlhYPmlbDmja5cbiAgICAgKiBAdHlwZSBhbnlcbiAgICAgKi9cbiAgICBASW5wdXQoJ3RoeURyYWdEYXRhJykgZGF0YTogVDtcblxuICAgIEBIb3N0QmluZGluZygnYXR0ci5kcmFnZ2FibGUnKSBpc0RyYWdnYWJsZSA9IHRydWU7XG5cbiAgICBwcml2YXRlIF9kaXNhYmxlZCA9IGZhbHNlO1xuXG4gICAgLyoqXG4gICAgICog5piv5ZCm56aB55So5ouW5ou9XG4gICAgICogQGRlZmF1bHQgZmFsc2VcbiAgICAgKi9cbiAgICBASW5wdXQoeyBhbGlhczogJ3RoeURyYWdEaXNhYmxlZCcsIHRyYW5zZm9ybTogY29lcmNlQm9vbGVhblByb3BlcnR5IH0pXG4gICAgc2V0IGRpc2FibGVkKGlzRGlzYWJsZWQ6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5fZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuICAgICAgICB0aGlzLmlzRHJhZ2dhYmxlID0gIWlzRGlzYWJsZWQ7XG4gICAgfVxuICAgIGdldCBkaXNhYmxlZCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2Rpc2FibGVkO1xuICAgIH1cblxuICAgIHB1YmxpYyBkcmFnUmVmOiBEcmFnUmVmPFQ+O1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGNvbnN0IGRvY3VtZW50ID0gaW5qZWN0KERPQ1VNRU5UKTtcbiAgICAgICAgY29uc3QgY29udGFpbmVyID0gdGhpcy5jb250YWluZXI7XG4gICAgICAgIGNvbnN0IG5nWm9uZSA9IGluamVjdChOZ1pvbmUpO1xuICAgICAgICBjb25zdCBlbGVtZW50UmVmID0gdGhpcy5lbGVtZW50UmVmO1xuICAgICAgICBjb25zdCBzZXJ2aWNlID0gaW5qZWN0PFRoeURyYWdEcm9wU2VydmljZTxUPj4oVGh5RHJhZ0Ryb3BTZXJ2aWNlKTtcbiAgICAgICAgY29uc3QgcmVuZGVyZXIgPSBpbmplY3QoUmVuZGVyZXIyKTtcblxuICAgICAgICB0aGlzLmRyYWdSZWYgPSBuZXcgRHJhZ1JlZjxUPihlbGVtZW50UmVmLCB0aGlzLCBjb250YWluZXIsIHNlcnZpY2UsIGRvY3VtZW50LCBuZ1pvbmUsIHJlbmRlcmVyKTtcbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpIHtcbiAgICAgICAgdGhpcy5kcmFnUmVmLmRpc3Bvc2UoKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -8,6 +8,7 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
/**
|
|
9
9
|
* @name thy-drop-container,[thyDropContainer]
|
|
10
10
|
* @order 30
|
|
11
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
11
12
|
*/
|
|
12
13
|
export class ThyDropContainerDirective {
|
|
13
14
|
constructor() {
|
|
@@ -125,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
125
126
|
descendants: false
|
|
126
127
|
}]
|
|
127
128
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-container.directive.js","sourceRoot":"","sources":["../../../../src/drag-drop/drop-container.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    OnInit,\n    Directive,\n    Output,\n    EventEmitter,\n    ContentChildren,\n    QueryList,\n    AfterContentInit,\n    NgZone,\n    Input,\n    OnDestroy,\n    inject\n} from '@angular/core';\nimport { ThyDragDirective } from './drag.directive';\nimport { merge, Observable, defer, Subject } from 'rxjs';\nimport { takeUntil, startWith, take, switchMap } from 'rxjs/operators';\nimport { ThyDragDropEvent, ThyDragStartEvent, ThyDragEndEvent, ThyDragOverEvent } from './drag-drop.class';\nimport { THY_DROP_CONTAINER_DIRECTIVE, IThyDropContainerDirective } from './drop-container.class';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\n/**\n * @name thy-drop-container,[thyDropContainer]\n * @order 30\n */\n@Directive({\n    selector: 'thy-drop-container,[thyDropContainer]',\n    providers: [\n        {\n            provide: THY_DROP_CONTAINER_DIRECTIVE,\n            useExisting: ThyDropContainerDirective\n        }\n    ],\n    standalone: true\n})\nexport class ThyDropContainerDirective<T = any> implements OnInit, AfterContentInit, IThyDropContainerDirective, OnDestroy {\n    private ngZone = inject(NgZone);\n\n    private ngUnsubscribe$ = new Subject<void>();\n\n    /**\n     * 元数据\n     * @type any[]\n     */\n    @Input('thyDropContainer')\n    set dragContainer(data: T[]) {\n        this.data = data;\n    }\n\n    /**\n     * 元数据\n     * @type any[]\n     */\n    @Input('thyDropContainerData') data: T[];\n\n    /**\n     * 是否禁用拖拽\n     * @default false\n     */\n    @Input({ alias: 'thyDropContainerDisabled', transform: coerceBooleanProperty }) disabled: boolean;\n\n    /**\n     * 拖拽之前的回调，函数返回 false 则阻止拖拽\n     */\n    @Input('thyBeforeDragStart') beforeStart: (e: ThyDragStartEvent<T>) => boolean;\n\n    /**\n     * 拖拽时回调，函数返回 false 则阻止移入\n     */\n    @Input('thyBeforeDragOver') beforeOver: (e: ThyDragOverEvent<T>) => boolean;\n\n    /**\n     * 拖放到元素时回调，函数返回 false 则阻止放置\n     */\n    @Input('thyBeforeDragDrop') beforeDrop: (e: ThyDragDropEvent<T>) => boolean;\n\n    /**\n     * 开始拖拽时调用\n     */\n    @Output('thyDragStarted') started = new EventEmitter<ThyDragStartEvent<ThyDragDirective>>();\n\n    /**\n     * dragend 触发时调用\n     */\n    @Output('thyDragEnded') ended = new EventEmitter<ThyDragEndEvent<ThyDragDirective>>();\n\n    /**\n     * dragover 触发时调用\n     */\n    @Output('thyDragOvered') overed = new EventEmitter<ThyDragOverEvent<ThyDragDirective>>();\n\n    /**\n     * drop 触发时调用\n     */\n    @Output('thyDragDropped') dropped = new EventEmitter<ThyDragDropEvent<ThyDragDirective>>();\n\n    /**\n     * @internal\n     */\n    @ContentChildren(ThyDragDirective, {\n        descendants: false\n    })\n    draggables: QueryList<ThyDragDirective>;\n\n    ngOnInit() {}\n\n    ngAfterContentInit() {\n        this.draggables.changes.pipe(startWith(null), takeUntil(this.ngUnsubscribe$)).subscribe(() => {\n            this.draggableChanges();\n        });\n    }\n\n    private draggableChanges() {\n        this.resetDraggableChanges(item => item.dragRef.started).subscribe(event => {\n            this.started.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.ended).subscribe(event => {\n            this.ended.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.overed).subscribe(event => {\n            this.overed.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.dropped).subscribe(event => {\n            this.dropped.emit(event);\n        });\n    }\n\n    private resetDraggableChanges(fn: (item: ThyDragDirective) => Observable<any>) {\n        return defer(() => {\n            if (this.draggables) {\n                return merge(...this.draggables.map(fn));\n            }\n            return this.ngZone.onStable.asObservable().pipe(\n                take(1),\n                switchMap(() => this.resetDraggableChanges.bind(this, fn))\n            );\n        }).pipe(takeUntil(merge(this.ngUnsubscribe$, this.draggables.changes))) as Observable<any>;\n    }\n\n    ngOnDestroy(): void {\n        this.ngUnsubscribe$.next();\n        this.ngUnsubscribe$.complete();\n    }\n}\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-container.directive.js","sourceRoot":"","sources":["../../../../src/drag-drop/drop-container.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    OnInit,\n    Directive,\n    Output,\n    EventEmitter,\n    ContentChildren,\n    QueryList,\n    AfterContentInit,\n    NgZone,\n    Input,\n    OnDestroy,\n    inject\n} from '@angular/core';\nimport { ThyDragDirective } from './drag.directive';\nimport { merge, Observable, defer, Subject } from 'rxjs';\nimport { takeUntil, startWith, take, switchMap } from 'rxjs/operators';\nimport { ThyDragDropEvent, ThyDragStartEvent, ThyDragEndEvent, ThyDragOverEvent } from './drag-drop.class';\nimport { THY_DROP_CONTAINER_DIRECTIVE, IThyDropContainerDirective } from './drop-container.class';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\n/**\n * @name thy-drop-container,[thyDropContainer]\n * @order 30\n * @deprecated please use @angular/cdk/drag-drop\n */\n@Directive({\n    selector: 'thy-drop-container,[thyDropContainer]',\n    providers: [\n        {\n            provide: THY_DROP_CONTAINER_DIRECTIVE,\n            useExisting: ThyDropContainerDirective\n        }\n    ],\n    standalone: true\n})\nexport class ThyDropContainerDirective<T = any> implements OnInit, AfterContentInit, IThyDropContainerDirective, OnDestroy {\n    private ngZone = inject(NgZone);\n\n    private ngUnsubscribe$ = new Subject<void>();\n\n    /**\n     * 元数据\n     * @type any[]\n     */\n    @Input('thyDropContainer')\n    set dragContainer(data: T[]) {\n        this.data = data;\n    }\n\n    /**\n     * 元数据\n     * @type any[]\n     */\n    @Input('thyDropContainerData') data: T[];\n\n    /**\n     * 是否禁用拖拽\n     * @default false\n     */\n    @Input({ alias: 'thyDropContainerDisabled', transform: coerceBooleanProperty }) disabled: boolean;\n\n    /**\n     * 拖拽之前的回调，函数返回 false 则阻止拖拽\n     */\n    @Input('thyBeforeDragStart') beforeStart: (e: ThyDragStartEvent<T>) => boolean;\n\n    /**\n     * 拖拽时回调，函数返回 false 则阻止移入\n     */\n    @Input('thyBeforeDragOver') beforeOver: (e: ThyDragOverEvent<T>) => boolean;\n\n    /**\n     * 拖放到元素时回调，函数返回 false 则阻止放置\n     */\n    @Input('thyBeforeDragDrop') beforeDrop: (e: ThyDragDropEvent<T>) => boolean;\n\n    /**\n     * 开始拖拽时调用\n     */\n    @Output('thyDragStarted') started = new EventEmitter<ThyDragStartEvent<ThyDragDirective>>();\n\n    /**\n     * dragend 触发时调用\n     */\n    @Output('thyDragEnded') ended = new EventEmitter<ThyDragEndEvent<ThyDragDirective>>();\n\n    /**\n     * dragover 触发时调用\n     */\n    @Output('thyDragOvered') overed = new EventEmitter<ThyDragOverEvent<ThyDragDirective>>();\n\n    /**\n     * drop 触发时调用\n     */\n    @Output('thyDragDropped') dropped = new EventEmitter<ThyDragDropEvent<ThyDragDirective>>();\n\n    /**\n     * @internal\n     */\n    @ContentChildren(ThyDragDirective, {\n        descendants: false\n    })\n    draggables: QueryList<ThyDragDirective>;\n\n    ngOnInit() {}\n\n    ngAfterContentInit() {\n        this.draggables.changes.pipe(startWith(null), takeUntil(this.ngUnsubscribe$)).subscribe(() => {\n            this.draggableChanges();\n        });\n    }\n\n    private draggableChanges() {\n        this.resetDraggableChanges(item => item.dragRef.started).subscribe(event => {\n            this.started.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.ended).subscribe(event => {\n            this.ended.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.overed).subscribe(event => {\n            this.overed.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.dropped).subscribe(event => {\n            this.dropped.emit(event);\n        });\n    }\n\n    private resetDraggableChanges(fn: (item: ThyDragDirective) => Observable<any>) {\n        return defer(() => {\n            if (this.draggables) {\n                return merge(...this.draggables.map(fn));\n            }\n            return this.ngZone.onStable.asObservable().pipe(\n                take(1),\n                switchMap(() => this.resetDraggableChanges.bind(this, fn))\n            );\n        }).pipe(takeUntil(merge(this.ngUnsubscribe$, this.draggables.changes))) as Observable<any>;\n    }\n\n    ngOnDestroy(): void {\n        this.ngUnsubscribe$.next();\n        this.ngUnsubscribe$.complete();\n    }\n}\n"]}
|
|
@@ -1,10 +1,17 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
|
+
import { warnDeprecation } from 'ngx-tethys/util';
|
|
2
3
|
import { ThyDragDirective } from './drag.directive';
|
|
3
4
|
import { ThyDragHandleDirective } from './drag-handle.directive';
|
|
4
5
|
import { ThyDragContentDirective } from './drag-content.directive';
|
|
5
6
|
import { ThyDropContainerDirective } from './drop-container.directive';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
8
|
+
/**
|
|
9
|
+
* @deprecated please use @angular/cdk/drag-drop
|
|
10
|
+
*/
|
|
7
11
|
export class ThyDragDropModule {
|
|
12
|
+
constructor() {
|
|
13
|
+
warnDeprecation('`ThyDragDropModule` is deprecated, please use `@angular/cdk/drag-drop` instead.');
|
|
14
|
+
}
|
|
8
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ThyDragDropModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
9
16
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: ThyDragDropModule, imports: [ThyDropContainerDirective, ThyDragDirective, ThyDragHandleDirective, ThyDragContentDirective], exports: [ThyDropContainerDirective, ThyDragDirective, ThyDragHandleDirective, ThyDragContentDirective] }); }
|
|
10
17
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ThyDragDropModule }); }
|
|
@@ -16,5 +23,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
16
23
|
exports: [ThyDropContainerDirective, ThyDragDirective, ThyDragHandleDirective, ThyDragContentDirective],
|
|
17
24
|
providers: []
|
|
18
25
|
}]
|
|
19
|
-
}] });
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
}], ctorParameters: () => [] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2RyYWctZHJvcC9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDcEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDbkUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBRXZFOztHQUVHO0FBTUgsTUFBTSxPQUFPLGlCQUFpQjtJQUMxQjtRQUNJLGVBQWUsQ0FBQyxpRkFBaUYsQ0FBQyxDQUFDO0lBQ3ZHLENBQUM7OEdBSFEsaUJBQWlCOytHQUFqQixpQkFBaUIsWUFKaEIseUJBQXlCLEVBQUUsZ0JBQWdCLEVBQUUsc0JBQXNCLEVBQUUsdUJBQXVCLGFBQzVGLHlCQUF5QixFQUFFLGdCQUFnQixFQUFFLHNCQUFzQixFQUFFLHVCQUF1QjsrR0FHN0YsaUJBQWlCOzsyRkFBakIsaUJBQWlCO2tCQUw3QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixFQUFFLGdCQUFnQixFQUFFLHNCQUFzQixFQUFFLHVCQUF1QixDQUFDO29CQUN2RyxPQUFPLEVBQUUsQ0FBQyx5QkFBeUIsRUFBRSxnQkFBZ0IsRUFBRSxzQkFBc0IsRUFBRSx1QkFBdUIsQ0FBQztvQkFDdkcsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHdhcm5EZXByZWNhdGlvbiB9IGZyb20gJ25neC10ZXRoeXMvdXRpbCc7XG5pbXBvcnQgeyBUaHlEcmFnRGlyZWN0aXZlIH0gZnJvbSAnLi9kcmFnLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBUaHlEcmFnSGFuZGxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kcmFnLWhhbmRsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVGh5RHJhZ0NvbnRlbnREaXJlY3RpdmUgfSBmcm9tICcuL2RyYWctY29udGVudC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVGh5RHJvcENvbnRhaW5lckRpcmVjdGl2ZSB9IGZyb20gJy4vZHJvcC1jb250YWluZXIuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBwbGVhc2UgdXNlIEBhbmd1bGFyL2Nkay9kcmFnLWRyb3BcbiAqL1xuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbVGh5RHJvcENvbnRhaW5lckRpcmVjdGl2ZSwgVGh5RHJhZ0RpcmVjdGl2ZSwgVGh5RHJhZ0hhbmRsZURpcmVjdGl2ZSwgVGh5RHJhZ0NvbnRlbnREaXJlY3RpdmVdLFxuICAgIGV4cG9ydHM6IFtUaHlEcm9wQ29udGFpbmVyRGlyZWN0aXZlLCBUaHlEcmFnRGlyZWN0aXZlLCBUaHlEcmFnSGFuZGxlRGlyZWN0aXZlLCBUaHlEcmFnQ29udGVudERpcmVjdGl2ZV0sXG4gICAgcHJvdmlkZXJzOiBbXVxufSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRHJvcE1vZHVsZSB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHdhcm5EZXByZWNhdGlvbignYFRoeURyYWdEcm9wTW9kdWxlYCBpcyBkZXByZWNhdGVkLCBwbGVhc2UgdXNlIGBAYW5ndWxhci9jZGsvZHJhZy1kcm9wYCBpbnN0ZWFkLicpO1xuICAgIH1cbn1cbiJdfQ==
|