ngx-tethys 17.0.13 → 17.0.14
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 +20 -0
- package/core/overlay/abstract-overlay.config.d.ts +6 -0
- package/esm2022/core/overlay/abstract-overlay.config.mjs +7 -1
- package/esm2022/menu/item/action/menu-item-action.component.mjs +15 -6
- package/esm2022/popover/popover.service.mjs +2 -1
- package/esm2022/tree-select/tree-select.component.mjs +10 -8
- package/esm2022/upload/file-select.component.mjs +20 -24
- package/esm2022/version.mjs +2 -2
- package/fesm2022/ngx-tethys-core.mjs +6 -0
- package/fesm2022/ngx-tethys-core.mjs.map +1 -1
- package/fesm2022/ngx-tethys-menu.mjs +12 -3
- package/fesm2022/ngx-tethys-menu.mjs.map +1 -1
- package/fesm2022/ngx-tethys-popover.mjs +1 -0
- package/fesm2022/ngx-tethys-popover.mjs.map +1 -1
- package/fesm2022/ngx-tethys-tree-select.mjs +4 -1
- package/fesm2022/ngx-tethys-tree-select.mjs.map +1 -1
- package/fesm2022/ngx-tethys-upload.mjs +19 -23
- package/fesm2022/ngx-tethys-upload.mjs.map +1 -1
- package/fesm2022/ngx-tethys.mjs +1 -1
- package/fesm2022/ngx-tethys.mjs.map +1 -1
- package/menu/item/action/menu-item-action.component.d.ts +7 -2
- package/menu/styles/menu.scss +8 -0
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/shared/option/styles/select-dropdown.scss +1 -0
- package/slider/slider.scss +12 -20
- package/styles/modules/tables.scss +20 -0
- package/styles/variables.scss +1 -1
- package/table/styles/skeleton.scss +5 -0
- package/upload/file-select.component.d.ts +5 -6
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,26 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [17.0.14](https://github.com/atinc/ngx-tethys/compare/17.0.13...17.0.14) (2024-07-18)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* **table:** fix table skeleton styles error #INFR-12877 ([#3118](https://github.com/atinc/ngx-tethys/issues/3118)) ([cf89598](https://github.com/atinc/ngx-tethys/commit/cf89598e1835f301f66ed511e1829e38b5d4a17f)), closes [#INFR-12877](https://github.com/atinc/ngx-tethys/issues/INFR-12877)
|
|
11
|
+
* **tree-select:** #INFR-12947 change treeNodes when thyVirtualScroll… ([#3124](https://github.com/atinc/ngx-tethys/issues/3124)) ([22c7e0a](https://github.com/atinc/ngx-tethys/commit/22c7e0ad501e6038dc71f774953d1ac05399baca)), closes [#INFR-12947](https://github.com/atinc/ngx-tethys/issues/INFR-12947)
|
|
12
|
+
* **upload:** error occurs when accessing the viewchild element in the setter of a static input property #INFR-1979 ([#3120](https://github.com/atinc/ngx-tethys/issues/3120)) ([3b45a23](https://github.com/atinc/ngx-tethys/commit/3b45a237d236107362201ad9903686298bcf540e)), closes [#INFR-1979](https://github.com/atinc/ngx-tethys/issues/INFR-1979)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### Features
|
|
16
|
+
|
|
17
|
+
* **form:** change form-label's color to [#333](https://github.com/atinc/ngx-tethys/issues/333) #INFR-12861 ([f390a01](https://github.com/atinc/ngx-tethys/commit/f390a0161eb613dc34103e7df5436c4caf885f93)), closes [#INFR-12861](https://github.com/atinc/ngx-tethys/issues/INFR-12861)
|
|
18
|
+
* **menu:** thyMenuItemAction click support thy-memu-item hightlight … ([#3119](https://github.com/atinc/ngx-tethys/issues/3119)) ([a4b83c5](https://github.com/atinc/ngx-tethys/commit/a4b83c5799e78c699f59e57e26063a9e7d4cfc33))
|
|
19
|
+
* **popover:** support canPush config for flexible connected position strategy #INFR-2298 ([#3123](https://github.com/atinc/ngx-tethys/issues/3123)) ([b0f4455](https://github.com/atinc/ngx-tethys/commit/b0f4455bd6895bdac0eb973473ab2bfd022e4621)), closes [#INFR-2298](https://github.com/atinc/ngx-tethys/issues/INFR-2298) [#INFR-2298](https://github.com/atinc/ngx-tethys/issues/INFR-2298)
|
|
20
|
+
* **select:** change group name's font-size to 12px #INFR-12860 ([4083418](https://github.com/atinc/ngx-tethys/commit/4083418c64a27d93b21d9ce1898f326a81d53c47)), closes [#INFR-12860](https://github.com/atinc/ngx-tethys/issues/INFR-12860)
|
|
21
|
+
* **slider:** optimize styles for slider pointer #INFR-12896 ([#3121](https://github.com/atinc/ngx-tethys/issues/3121)) ([c9f1809](https://github.com/atinc/ngx-tethys/commit/c9f1809f2a8cc24a817cd96f936aaacbf55994a1)), closes [#INFR-12896](https://github.com/atinc/ngx-tethys/issues/INFR-12896) [#INFR-12896](https://github.com/atinc/ngx-tethys/issues/INFR-12896)
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
5
25
|
## [17.0.13](https://github.com/atinc/ngx-tethys/compare/17.0.12...17.0.13) (2024-07-03)
|
|
6
26
|
|
|
7
27
|
|
|
@@ -109,6 +109,12 @@ export declare class ThyAbstractOverlayConfig<TData = unknown> {
|
|
|
109
109
|
* 关闭弹窗前的回调函数,返回 false 可阻止关闭弹窗
|
|
110
110
|
*/
|
|
111
111
|
canClose?: (result?: unknown) => boolean;
|
|
112
|
+
/**
|
|
113
|
+
* 设置当提供的位置均不适合时是否可以将覆盖层推到屏幕上
|
|
114
|
+
* @description.en-us Sets whether the overlay can be pushed on-screen if none of the provided positions fit
|
|
115
|
+
* @default true
|
|
116
|
+
*/
|
|
117
|
+
canPush?: boolean;
|
|
112
118
|
}
|
|
113
119
|
export interface ThyAbstractOverlayOptions {
|
|
114
120
|
/** component name, e.g. dialog | popover | slide */
|
|
@@ -59,6 +59,12 @@ export class ThyAbstractOverlayConfig {
|
|
|
59
59
|
* @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`).
|
|
60
60
|
*/
|
|
61
61
|
this.closeOnNavigation = true;
|
|
62
|
+
/**
|
|
63
|
+
* 设置当提供的位置均不适合时是否可以将覆盖层推到屏幕上
|
|
64
|
+
* @description.en-us Sets whether the overlay can be pushed on-screen if none of the provided positions fit
|
|
65
|
+
* @default true
|
|
66
|
+
*/
|
|
67
|
+
this.canPush = true;
|
|
62
68
|
}
|
|
63
69
|
}
|
|
64
|
-
//# 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;IACpB,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\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"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ThyPopover } from 'ngx-tethys/popover';
|
|
1
|
+
import { ThyPopover, ThyPopoverConfig } from 'ngx-tethys/popover';
|
|
3
2
|
import { coerceBooleanProperty } from 'ngx-tethys/util';
|
|
3
|
+
import { Component, ElementRef, Input, Renderer2 } from '@angular/core';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "ngx-tethys/popover";
|
|
6
6
|
/**
|
|
@@ -28,10 +28,17 @@ export class ThyMenuItemAction {
|
|
|
28
28
|
event.stopPropagation();
|
|
29
29
|
}
|
|
30
30
|
if (this._actionMenu) {
|
|
31
|
-
|
|
31
|
+
const activeClass = 'action-active';
|
|
32
|
+
const wrapDOM = event.target.closest('.thy-menu-item');
|
|
33
|
+
wrapDOM?.classList.add(activeClass);
|
|
34
|
+
const popoverRef = this.popover.open(this._actionMenu, Object.assign({
|
|
32
35
|
origin: event.currentTarget,
|
|
33
36
|
insideClosable: true,
|
|
34
|
-
placement: '
|
|
37
|
+
placement: 'bottomLeft',
|
|
38
|
+
originActiveClass: 'active'
|
|
39
|
+
}, this.thyPopoverOptions));
|
|
40
|
+
popoverRef?.afterClosed().subscribe(() => {
|
|
41
|
+
wrapDOM?.classList.remove(activeClass);
|
|
35
42
|
});
|
|
36
43
|
}
|
|
37
44
|
});
|
|
@@ -51,7 +58,7 @@ export class ThyMenuItemAction {
|
|
|
51
58
|
this.removeClickListenerFn?.();
|
|
52
59
|
}
|
|
53
60
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyMenuItemAction, deps: [{ token: i1.ThyPopover }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
54
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyMenuItemAction, isStandalone: true, selector: "thy-menu-item-action,[thy-menu-item-action],[thyMenuItemAction]", inputs: { thyActionMenu: "thyActionMenu", thyStopPropagation: ["thyStopPropagation", "thyStopPropagation", coerceBooleanProperty] }, host: { classAttribute: "thy-menu-item-action" }, ngImport: i0, template: "<ng-content></ng-content>\n" }); }
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyMenuItemAction, isStandalone: true, selector: "thy-menu-item-action,[thy-menu-item-action],[thyMenuItemAction]", inputs: { thyActionMenu: "thyActionMenu", thyStopPropagation: ["thyStopPropagation", "thyStopPropagation", coerceBooleanProperty], thyPopoverOptions: "thyPopoverOptions" }, host: { classAttribute: "thy-menu-item-action" }, ngImport: i0, template: "<ng-content></ng-content>\n" }); }
|
|
55
62
|
}
|
|
56
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyMenuItemAction, decorators: [{
|
|
57
64
|
type: Component,
|
|
@@ -63,5 +70,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
63
70
|
}], thyStopPropagation: [{
|
|
64
71
|
type: Input,
|
|
65
72
|
args: [{ transform: coerceBooleanProperty }]
|
|
73
|
+
}], thyPopoverOptions: [{
|
|
74
|
+
type: Input
|
|
66
75
|
}] } });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pdGVtLWFjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbWVudS9pdGVtL2FjdGlvbi9tZW51LWl0ZW0tYWN0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tZW51L2l0ZW0vYWN0aW9uL21lbnUtaXRlbS1hY3Rpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBR3hELE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBYSxTQUFTLEVBQWUsTUFBTSxlQUFlLENBQUM7OztBQUVoRzs7OztHQUlHO0FBU0gsTUFBTSxPQUFPLGlCQUFpQjtJQUsxQjs7T0FFRztJQUNILElBQ0ksYUFBYSxDQUFDLEtBQTRDO1FBQzFELElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUMxQixDQUFDO0lBQ0wsQ0FBQztJQWFPLGNBQWM7UUFDbEIsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDbkIsT0FBTztRQUNYLENBQUM7UUFDRCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztRQUN4QixJQUFJLENBQUMscUJBQXFCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFO1lBQzlGLElBQUksSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7Z0JBQzFCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUM1QixDQUFDO1lBQ0QsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQ25CLE1BQU0sV0FBVyxHQUFHLGVBQWUsQ0FBQztnQkFDcEMsTUFBTSxPQUFPLEdBQUksS0FBSyxDQUFDLE1BQXNCLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBQUM7Z0JBQ3hFLE9BQU8sRUFBRSxTQUFTLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUNwQyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDaEMsSUFBSSxDQUFDLFdBQVcsRUFDaEIsTUFBTSxDQUFDLE1BQU0sQ0FDVDtvQkFDSSxNQUFNLEVBQUUsS0FBSyxDQUFDLGFBQTRCO29CQUMxQyxjQUFjLEVBQUUsSUFBSTtvQkFDcEIsU0FBUyxFQUFFLFlBQVk7b0JBQ3ZCLGlCQUFpQixFQUFFLFFBQVE7aUJBQzlCLEVBQ0QsSUFBSSxDQUFDLGlCQUFpQixDQUN6QixDQUNKLENBQUM7Z0JBQ0YsVUFBVSxFQUFFLFdBQVcsRUFBRSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7b0JBQ3JDLE9BQU8sRUFBRSxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUMzQyxDQUFDLENBQUMsQ0FBQztZQUNQLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFJRCxZQUFvQixPQUFtQixFQUFVLFFBQW1CLEVBQVUsVUFBc0I7UUFBaEYsWUFBTyxHQUFQLE9BQU8sQ0FBWTtRQUFVLGFBQVEsR0FBUixRQUFRLENBQVc7UUFBVSxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBNURwRyxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQWVwQjs7V0FFRztRQUMwQyx1QkFBa0IsR0FBRyxJQUFJLENBQUM7UUF3Qy9ELDBCQUFxQixHQUF3QixJQUFJLENBQUM7SUFFNkMsQ0FBQztJQUV4RyxXQUFXO1FBQ1AsSUFBSSxDQUFDLHFCQUFxQixFQUFFLEVBQUUsQ0FBQztJQUNuQyxDQUFDOzhHQWpFUSxpQkFBaUI7a0dBQWpCLGlCQUFpQiw4TUFtQk4scUJBQXFCLHVIQ3RDN0MsNkJBQ0E7OzJGRGtCYSxpQkFBaUI7a0JBUjdCLFNBQVM7K0JBQ0ksaUVBQWlFLFFBRXJFO3dCQUNGLEtBQUssRUFBRSxzQkFBc0I7cUJBQ2hDLGNBQ1csSUFBSTtnSUFXWixhQUFhO3NCQURoQixLQUFLO2dCQVd1QyxrQkFBa0I7c0JBQTlELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUscUJBQXFCLEVBQUU7Z0JBTWxDLGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRoeVBvcG92ZXIsIFRoeVBvcG92ZXJDb25maWcgfSBmcm9tICduZ3gtdGV0aHlzL3BvcG92ZXInO1xuaW1wb3J0IHsgY29lcmNlQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnbmd4LXRldGh5cy91dGlsJztcblxuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgT25EZXN0cm95LCBSZW5kZXJlcjIsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICog6I+c5Y2V6aG55pON5L2c57uE5Lu2XG4gKiBAbmFtZSB0aHktbWVudS1pdGVtLWFjdGlvbixbdGh5LW1lbnUtaXRlbS1hY3Rpb25dLFt0aHlNZW51SXRlbUFjdGlvbl1cbiAqIEBvcmRlciAyNVxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RoeS1tZW51LWl0ZW0tYWN0aW9uLFt0aHktbWVudS1pdGVtLWFjdGlvbl0sW3RoeU1lbnVJdGVtQWN0aW9uXScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL21lbnUtaXRlbS1hY3Rpb24uY29tcG9uZW50Lmh0bWwnLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgY2xhc3M6ICd0aHktbWVudS1pdGVtLWFjdGlvbidcbiAgICB9LFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgVGh5TWVudUl0ZW1BY3Rpb24gaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICAgIF9ib3VuZEV2ZW50ID0gZmFsc2U7XG5cbiAgICBfYWN0aW9uTWVudTogQ29tcG9uZW50VHlwZTxhbnk+IHwgVGVtcGxhdGVSZWY8YW55PjtcblxuICAgIC8qKlxuICAgICAqIOiuvue9riBBY3Rpb24g6I+c5Y2VXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBzZXQgdGh5QWN0aW9uTWVudSh2YWx1ZTogQ29tcG9uZW50VHlwZTxhbnk+IHwgVGVtcGxhdGVSZWY8YW55Pikge1xuICAgICAgICB0aGlzLl9hY3Rpb25NZW51ID0gdmFsdWU7XG4gICAgICAgIGlmICh0aGlzLl9hY3Rpb25NZW51KSB7XG4gICAgICAgICAgICB0aGlzLmJpbmRDbGlja0V2ZW50KCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiDmmK/lkKbpmLvmraLkuovku7blhpLms6FcbiAgICAgKi9cbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9KSB0aHlTdG9wUHJvcGFnYXRpb24gPSB0cnVlO1xuXG4gICAgLyoqXG4gICAgICog5by55Ye65qGG55qE5Y+C5pWwXG4gICAgICogQGRlZmF1bHQgeyBwbGFjZW1lbnQ6IFwiYm90dG9tTGVmdFwiLCBpbnNpZGVDbG9zYWJsZTogdHJ1ZSB9XG4gICAgICovXG4gICAgQElucHV0KCkgdGh5UG9wb3Zlck9wdGlvbnM6IFRoeVBvcG92ZXJDb25maWc7XG5cbiAgICBwcml2YXRlIGJpbmRDbGlja0V2ZW50KCkge1xuICAgICAgICBpZiAodGhpcy5fYm91bmRFdmVudCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuX2JvdW5kRXZlbnQgPSB0cnVlO1xuICAgICAgICB0aGlzLnJlbW92ZUNsaWNrTGlzdGVuZXJGbiA9IHRoaXMucmVuZGVyZXIubGlzdGVuKHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnY2xpY2snLCBldmVudCA9PiB7XG4gICAgICAgICAgICBpZiAodGhpcy50aHlTdG9wUHJvcGFnYXRpb24pIHtcbiAgICAgICAgICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmICh0aGlzLl9hY3Rpb25NZW51KSB7XG4gICAgICAgICAgICAgICAgY29uc3QgYWN0aXZlQ2xhc3MgPSAnYWN0aW9uLWFjdGl2ZSc7XG4gICAgICAgICAgICAgICAgY29uc3Qgd3JhcERPTSA9IChldmVudC50YXJnZXQgYXMgSFRNTEVsZW1lbnQpLmNsb3Nlc3QoJy50aHktbWVudS1pdGVtJyk7XG4gICAgICAgICAgICAgICAgd3JhcERPTT8uY2xhc3NMaXN0LmFkZChhY3RpdmVDbGFzcyk7XG4gICAgICAgICAgICAgICAgY29uc3QgcG9wb3ZlclJlZiA9IHRoaXMucG9wb3Zlci5vcGVuKFxuICAgICAgICAgICAgICAgICAgICB0aGlzLl9hY3Rpb25NZW51LFxuICAgICAgICAgICAgICAgICAgICBPYmplY3QuYXNzaWduKFxuICAgICAgICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9yaWdpbjogZXZlbnQuY3VycmVudFRhcmdldCBhcyBIVE1MRWxlbWVudCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpbnNpZGVDbG9zYWJsZTogdHJ1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBwbGFjZW1lbnQ6ICdib3R0b21MZWZ0JyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBvcmlnaW5BY3RpdmVDbGFzczogJ2FjdGl2ZSdcbiAgICAgICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnRoeVBvcG92ZXJPcHRpb25zXG4gICAgICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIHBvcG92ZXJSZWY/LmFmdGVyQ2xvc2VkKCkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgd3JhcERPTT8uY2xhc3NMaXN0LnJlbW92ZShhY3RpdmVDbGFzcyk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHByaXZhdGUgcmVtb3ZlQ2xpY2tMaXN0ZW5lckZuOiBWb2lkRnVuY3Rpb24gfCBudWxsID0gbnVsbDtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcG9wb3ZlcjogVGh5UG9wb3ZlciwgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLCBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG5cbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5yZW1vdmVDbGlja0xpc3RlbmVyRm4/LigpO1xuICAgIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -28,6 +28,7 @@ export class ThyPopover extends ThyAbstractOverlayService {
|
|
|
28
28
|
const positionStrategy = new FlexibleConnectedPositionStrategy(origin, this._viewportRuler, this._document, this._platform, this._overlayContainer);
|
|
29
29
|
const positions = getFlexiblePositions(config.placement, config.offset, 'thy-popover');
|
|
30
30
|
positionStrategy.withPositions(positions);
|
|
31
|
+
positionStrategy.withPush(config.canPush);
|
|
31
32
|
positionStrategy.withGrowAfterOpen(true);
|
|
32
33
|
positionStrategy.withTransformOriginOn('.thy-popover-container');
|
|
33
34
|
positionStrategy.positionChanges.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(change => {
|
|
@@ -209,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
209
210
|
type: Inject,
|
|
210
211
|
args: [DOCUMENT]
|
|
211
212
|
}] }, { type: i2.Platform }, { type: i1.OverlayContainer }] });
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.service.js","sourceRoot":"","sources":["../../../../src/popover/popover.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentTypeOrTemplateRef, getFlexiblePositions, ThyAbstractOverlayRef, ThyAbstractOverlayService } from 'ngx-tethys/core';\nimport { FunctionProp, isFunction } from 'ngx-tethys/util';\nimport { of, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { Directionality } from '@angular/cdk/bidi';\nimport { coerceArray, coerceElement } from '@angular/cdk/coercion';\nimport {\n    FlexibleConnectedPositionStrategy,\n    FlexibleConnectedPositionStrategyOrigin,\n    Overlay,\n    OverlayConfig,\n    OverlayContainer,\n    OverlayRef,\n    PositionStrategy,\n    ScrollStrategy,\n    ViewportRuler\n} from '@angular/cdk/overlay';\nimport { Platform } from '@angular/cdk/platform';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport { ElementRef, Inject, Injectable, Injector, NgZone, OnDestroy, Optional, StaticProvider, TemplateRef } from '@angular/core';\n\nimport { ThyPopoverContainer } from './popover-container.component';\nimport { ThyInternalPopoverRef, ThyPopoverRef } from './popover-ref';\nimport {\n    THY_POPOVER_DEFAULT_CONFIG,\n    THY_POPOVER_DEFAULT_CONFIG_VALUE,\n    THY_POPOVER_SCROLL_STRATEGY,\n    ThyPopoverConfig\n} from './popover.config';\nimport { popoverAbstractOverlayOptions } from './popover.options';\nimport { SafeAny } from 'ngx-tethys/types';\n\n/**\n * @public\n * @order 10\n */\n@Injectable()\nexport class ThyPopover extends ThyAbstractOverlayService<ThyPopoverConfig, ThyPopoverContainer> implements OnDestroy {\n    private readonly ngUnsubscribe$ = new Subject();\n\n    private originInstancesMap = new Map<\n        ElementRef | HTMLElement,\n        {\n            config: ThyPopoverConfig;\n            popoverRef: ThyPopoverRef<any, any>;\n        }\n    >();\n\n    private buildPositionStrategy<TData>(config: ThyPopoverConfig<TData>): PositionStrategy {\n        const origin: FlexibleConnectedPositionStrategyOrigin = config.originPosition ? config.originPosition : config.origin;\n        // const positionStrategy = this.overlay.position().flexibleConnectedTo(origin);\n        const positionStrategy = new FlexibleConnectedPositionStrategy(\n            origin,\n            this._viewportRuler,\n            this._document,\n            this._platform,\n            this._overlayContainer\n        );\n        const positions = getFlexiblePositions(config.placement, config.offset, 'thy-popover');\n        positionStrategy.withPositions(positions);\n        positionStrategy.withGrowAfterOpen(true);\n        positionStrategy.withTransformOriginOn('.thy-popover-container');\n        positionStrategy.positionChanges.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(change => {\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.close());\n            }\n        });\n        return positionStrategy;\n    }\n\n    private buildScrollStrategy(config: ThyPopoverConfig): ScrollStrategy {\n        if (config.scrollStrategy) {\n            return config.scrollStrategy;\n        } else if (this.scrollStrategy && isFunction(this.scrollStrategy)) {\n            return this.scrollStrategy();\n        } else {\n            this.overlay.scrollStrategies.block();\n        }\n    }\n\n    protected buildOverlayConfig<TData>(config: ThyPopoverConfig<TData>): OverlayConfig {\n        const positionStrategy = this.buildPositionStrategy(config);\n        const overlayConfig = this.buildBaseOverlayConfig(config, 'thy-popover-panel');\n        overlayConfig.positionStrategy = positionStrategy;\n        overlayConfig.scrollStrategy = this.buildScrollStrategy(config);\n        return overlayConfig;\n    }\n\n    protected attachOverlayContainer(overlay: OverlayRef, config: ThyPopoverConfig<any>): ThyPopoverContainer {\n        const userInjector = config && config.viewContainerRef && config.viewContainerRef.injector;\n        const injector = Injector.create({\n            parent: userInjector || this.injector,\n            providers: [{ provide: ThyPopoverConfig, useValue: config }]\n        });\n        const containerPortal = new ComponentPortal(ThyPopoverContainer, config.viewContainerRef, injector);\n        const containerRef = overlay.attach<ThyPopoverContainer>(containerPortal);\n        return containerRef.instance;\n    }\n\n    protected createAbstractOverlayRef<T, TResult = unknown>(\n        overlayRef: OverlayRef,\n        containerInstance: ThyPopoverContainer,\n        config: ThyPopoverConfig\n    ): ThyAbstractOverlayRef<T, ThyPopoverContainer, TResult> {\n        return new ThyInternalPopoverRef(overlayRef, containerInstance, config);\n    }\n\n    protected createInjector<T>(config: ThyPopoverConfig, popoverRef: ThyPopoverRef<T>, popoverContainer: ThyPopoverContainer): Injector {\n        const userInjector = config && config.viewContainerRef && config.viewContainerRef.injector;\n\n        const injectionTokens: StaticProvider[] = [\n            { provide: ThyPopoverContainer, useValue: popoverContainer },\n            {\n                provide: ThyPopoverRef,\n                useValue: popoverRef\n            }\n        ];\n\n        if (config.direction && (!userInjector || !userInjector.get<Directionality | null>(Directionality, null))) {\n            injectionTokens.push({\n                provide: Directionality,\n                useValue: {\n                    value: config.direction,\n                    change: of()\n                }\n            });\n        }\n\n        return Injector.create({ parent: userInjector || this.injector, providers: injectionTokens });\n    }\n\n    private originElementAddActiveClass(config: ThyPopoverConfig) {\n        if (config.originActiveClass) {\n            coerceElement<HTMLElement>(config.origin).classList.add(...coerceArray(config.originActiveClass));\n        }\n    }\n\n    private originElementRemoveActiveClass(config: ThyPopoverConfig) {\n        if (config.originActiveClass) {\n            coerceElement<HTMLElement>(config.origin).classList.remove(...coerceArray(config.originActiveClass));\n        }\n    }\n\n    constructor(\n        overlay: Overlay,\n        injector: Injector,\n        @Optional()\n        @Inject(THY_POPOVER_DEFAULT_CONFIG)\n        defaultConfig: ThyPopoverConfig,\n        @Inject(THY_POPOVER_SCROLL_STRATEGY)\n        scrollStrategy: FunctionProp<ScrollStrategy>,\n        private ngZone: NgZone,\n        private _viewportRuler: ViewportRuler,\n        @Optional() @Inject(DOCUMENT) private _document: any,\n        private _platform: Platform,\n        private _overlayContainer: OverlayContainer\n    ) {\n        super(\n            popoverAbstractOverlayOptions,\n            overlay,\n            injector,\n            {\n                ...THY_POPOVER_DEFAULT_CONFIG_VALUE,\n                ...defaultConfig\n            },\n            scrollStrategy\n        );\n    }\n\n    private ensureCloseClosest(origin: HTMLElement) {\n        let closeAndEnd = false;\n        this.originInstancesMap.forEach((value, key) => {\n            if (value.config.manualClosure) {\n                if (key === origin) {\n                    value.popoverRef.close();\n                    closeAndEnd = true;\n                }\n            } else {\n                if (key === origin) {\n                    closeAndEnd = true;\n                }\n                value.popoverRef.close();\n            }\n        });\n        return closeAndEnd;\n    }\n\n    /**\n     * 打开悬浮层\n     */\n    open<T, TData = unknown, TResult = unknown>(\n        componentOrTemplateRef: ComponentTypeOrTemplateRef<T>,\n        config?: ThyPopoverConfig<TData>\n    ): ThyPopoverRef<T, TResult> {\n        const originElement = coerceElement(config.origin);\n        // 默认关闭之前的弹出框\n        // 1. 当之前的 Popover 设置 manualClosure 为 true 时, 弹出其他 Popover 时不自动关闭 manualClosure 为 true 的 Popover\n        // 2. 当前的 Origin 对应的 Popover 已经弹出，不管 manualClosure 设置为何，直接关闭并返回\n        if (this.ensureCloseClosest(originElement)) {\n            return;\n        }\n\n        const popoverRef = this.openOverlay<T, TResult>(componentOrTemplateRef, config) as ThyPopoverRef<T, TResult, TData>;\n        config = popoverRef.containerInstance.config;\n        popoverRef.afterClosed().subscribe(() => {\n            this.originElementRemoveActiveClass(config);\n            this.originInstancesMap.delete(originElement);\n        });\n\n        this.originElementAddActiveClass(config);\n        this.originInstancesMap.set(originElement, {\n            config,\n            popoverRef\n        });\n\n        return popoverRef;\n    }\n\n    /**\n     * 根据Id获取打开的悬浮层\n     */\n    getPopoverById(id: string): ThyPopoverRef<any> | undefined {\n        return this.getAbstractOverlayById(id) as ThyPopoverRef<any> | undefined;\n    }\n\n    /**\n     * 获取已经打开的悬浮层\n     */\n    getOpenedPopovers(): ThyPopoverRef<SafeAny>[] {\n        return this.getAbstractOverlays();\n    }\n\n    /**\n     * @description.en-us Finds the closest ThyPopoverRef to an element by looking at the DOM.\n     * @description 通过 Dom 元素查找最近弹出的悬浮层\n     */\n    getClosestPopover(element: HTMLElement): ThyPopoverRef<any> | undefined {\n        const parent = element.closest('.thy-popover-container');\n\n        if (parent && parent.id) {\n            return this.getPopoverById(parent.id);\n        }\n        return null;\n    }\n\n    /**\n     * 关闭悬浮层\n     */\n    close<T>(result?: T, force?: boolean) {\n        super.close(result, force);\n    }\n\n    /**\n     * @internal\n     */\n    ngOnDestroy() {\n        this.dispose();\n    }\n}\n"]}
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.service.js","sourceRoot":"","sources":["../../../../src/popover/popover.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAA8B,oBAAoB,EAAyB,yBAAyB,EAAE,MAAM,iBAAiB,CAAC;AACrI,OAAO,EAAgB,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EACH,iCAAiC,EAEjC,OAAO,EAEP,gBAAgB,EAIhB,aAAa,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAc,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAa,QAAQ,EAA+B,MAAM,eAAe,CAAC;AAEnI,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACrE,OAAO,EACH,0BAA0B,EAC1B,gCAAgC,EAChC,2BAA2B,EAC3B,gBAAgB,EACnB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,6BAA6B,EAAE,MAAM,mBAAmB,CAAC;;;;;AAGlE;;;GAGG;AAEH,MAAM,OAAO,UAAW,SAAQ,yBAAgE;IAWpF,qBAAqB,CAAQ,MAA+B;QAChE,MAAM,MAAM,GAA4C,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;QACtH,gFAAgF;QAChF,MAAM,gBAAgB,GAAG,IAAI,iCAAiC,CAC1D,MAAM,EACN,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,iBAAiB,CACzB,CAAC;QACF,MAAM,SAAS,GAAG,oBAAoB,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;QACvF,gBAAgB,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QAC1C,gBAAgB,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC1C,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACzC,gBAAgB,CAAC,qBAAqB,CAAC,wBAAwB,CAAC,CAAC;QACjE,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACrF,IAAI,MAAM,CAAC,wBAAwB,CAAC,gBAAgB,EAAE,CAAC;gBACnD,6DAA6D;gBAC7D,8CAA8C;gBAC9C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YACxC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,gBAAgB,CAAC;IAC5B,CAAC;IAEO,mBAAmB,CAAC,MAAwB;QAChD,IAAI,MAAM,CAAC,cAAc,EAAE,CAAC;YACxB,OAAO,MAAM,CAAC,cAAc,CAAC;QACjC,CAAC;aAAM,IAAI,IAAI,CAAC,cAAc,IAAI,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC;YAChE,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC;QACjC,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAC1C,CAAC;IACL,CAAC;IAES,kBAAkB,CAAQ,MAA+B;QAC/D,MAAM,gBAAgB,GAAG,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAC5D,MAAM,aAAa,GAAG,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;QAC/E,aAAa,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAClD,aAAa,CAAC,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAChE,OAAO,aAAa,CAAC;IACzB,CAAC;IAES,sBAAsB,CAAC,OAAmB,EAAE,MAA6B;QAC/E,MAAM,YAAY,GAAG,MAAM,IAAI,MAAM,CAAC,gBAAgB,IAAI,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;QAC3F,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC7B,MAAM,EAAE,YAAY,IAAI,IAAI,CAAC,QAAQ;YACrC,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;SAC/D,CAAC,CAAC;QACH,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,mBAAmB,EAAE,MAAM,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC;QACpG,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,CAAsB,eAAe,CAAC,CAAC;QAC1E,OAAO,YAAY,CAAC,QAAQ,CAAC;IACjC,CAAC;IAES,wBAAwB,CAC9B,UAAsB,EACtB,iBAAsC,EACtC,MAAwB;QAExB,OAAO,IAAI,qBAAqB,CAAC,UAAU,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;IAC5E,CAAC;IAES,cAAc,CAAI,MAAwB,EAAE,UAA4B,EAAE,gBAAqC;QACrH,MAAM,YAAY,GAAG,MAAM,IAAI,MAAM,CAAC,gBAAgB,IAAI,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC;QAE3F,MAAM,eAAe,GAAqB;YACtC,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,gBAAgB,EAAE;YAC5D;gBACI,OAAO,EAAE,aAAa;gBACtB,QAAQ,EAAE,UAAU;aACvB;SACJ,CAAC;QAEF,IAAI,MAAM,CAAC,SAAS,IAAI,CAAC,CAAC,YAAY,IAAI,CAAC,YAAY,CAAC,GAAG,CAAwB,cAAc,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC;YACxG,eAAe,CAAC,IAAI,CAAC;gBACjB,OAAO,EAAE,cAAc;gBACvB,QAAQ,EAAE;oBACN,KAAK,EAAE,MAAM,CAAC,SAAS;oBACvB,MAAM,EAAE,EAAE,EAAE;iBACf;aACJ,CAAC,CAAC;QACP,CAAC;QAED,OAAO,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,YAAY,IAAI,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;IAClG,CAAC;IAEO,2BAA2B,CAAC,MAAwB;QACxD,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;YAC3B,aAAa,CAAc,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC;QACtG,CAAC;IACL,CAAC;IAEO,8BAA8B,CAAC,MAAwB;QAC3D,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;YAC3B,aAAa,CAAc,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,WAAW,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC;QACzG,CAAC;IACL,CAAC;IAED,YACI,OAAgB,EAChB,QAAkB,EAGlB,aAA+B,EAE/B,cAA4C,EACpC,MAAc,EACd,cAA6B,EACC,SAAc,EAC5C,SAAmB,EACnB,iBAAmC;QAE3C,KAAK,CACD,6BAA6B,EAC7B,OAAO,EACP,QAAQ,EACR;YACI,GAAG,gCAAgC;YACnC,GAAG,aAAa;SACnB,EACD,cAAc,CACjB,CAAC;QAfM,WAAM,GAAN,MAAM,CAAQ;QACd,mBAAc,GAAd,cAAc,CAAe;QACC,cAAS,GAAT,SAAS,CAAK;QAC5C,cAAS,GAAT,SAAS,CAAU;QACnB,sBAAiB,GAAjB,iBAAiB,CAAkB;QAxH9B,mBAAc,GAAG,IAAI,OAAO,EAAE,CAAC;QAExC,uBAAkB,GAAG,IAAI,GAAG,EAMjC,CAAC;IA4HJ,CAAC;IAEO,kBAAkB,CAAC,MAAmB;QAC1C,IAAI,WAAW,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YAC3C,IAAI,KAAK,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;gBAC7B,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;oBACjB,KAAK,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;oBACzB,WAAW,GAAG,IAAI,CAAC;gBACvB,CAAC;YACL,CAAC;iBAAM,CAAC;gBACJ,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;oBACjB,WAAW,GAAG,IAAI,CAAC;gBACvB,CAAC;gBACD,KAAK,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YAC7B,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,WAAW,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAI,CACA,sBAAqD,EACrD,MAAgC;QAEhC,MAAM,aAAa,GAAG,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACnD,aAAa;QACb,gGAAgG;QAChG,+DAA+D;QAC/D,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,EAAE,CAAC;YACzC,OAAO;QACX,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAa,sBAAsB,EAAE,MAAM,CAAqC,CAAC;QACpH,MAAM,GAAG,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC;QAC7C,UAAU,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACpC,IAAI,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,2BAA2B,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,aAAa,EAAE;YACvC,MAAM;YACN,UAAU;SACb,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC;IACtB,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,EAAU;QACrB,OAAO,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAmC,CAAC;IAC7E,CAAC;IAED;;OAEG;IACH,iBAAiB;QACb,OAAO,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACtC,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,OAAoB;QAClC,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;QAEzD,IAAI,MAAM,IAAI,MAAM,CAAC,EAAE,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC1C,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,KAAK,CAAI,MAAU,EAAE,KAAe;QAChC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,WAAW;QACP,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;8GA/NQ,UAAU,iEAiHP,0BAA0B,6BAE1B,2BAA2B,gEAIf,QAAQ;kHAvHvB,UAAU;;2FAAV,UAAU;kBADtB,UAAU;;0BAiHF,QAAQ;;0BACR,MAAM;2BAAC,0BAA0B;;0BAEjC,MAAM;2BAAC,2BAA2B;;0BAIlC,QAAQ;;0BAAI,MAAM;2BAAC,QAAQ","sourcesContent":["import { ComponentTypeOrTemplateRef, getFlexiblePositions, ThyAbstractOverlayRef, ThyAbstractOverlayService } from 'ngx-tethys/core';\nimport { FunctionProp, isFunction } from 'ngx-tethys/util';\nimport { of, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { Directionality } from '@angular/cdk/bidi';\nimport { coerceArray, coerceElement } from '@angular/cdk/coercion';\nimport {\n    FlexibleConnectedPositionStrategy,\n    FlexibleConnectedPositionStrategyOrigin,\n    Overlay,\n    OverlayConfig,\n    OverlayContainer,\n    OverlayRef,\n    PositionStrategy,\n    ScrollStrategy,\n    ViewportRuler\n} from '@angular/cdk/overlay';\nimport { Platform } from '@angular/cdk/platform';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport { ElementRef, Inject, Injectable, Injector, NgZone, OnDestroy, Optional, StaticProvider, TemplateRef } from '@angular/core';\n\nimport { ThyPopoverContainer } from './popover-container.component';\nimport { ThyInternalPopoverRef, ThyPopoverRef } from './popover-ref';\nimport {\n    THY_POPOVER_DEFAULT_CONFIG,\n    THY_POPOVER_DEFAULT_CONFIG_VALUE,\n    THY_POPOVER_SCROLL_STRATEGY,\n    ThyPopoverConfig\n} from './popover.config';\nimport { popoverAbstractOverlayOptions } from './popover.options';\nimport { SafeAny } from 'ngx-tethys/types';\n\n/**\n * @public\n * @order 10\n */\n@Injectable()\nexport class ThyPopover extends ThyAbstractOverlayService<ThyPopoverConfig, ThyPopoverContainer> implements OnDestroy {\n    private readonly ngUnsubscribe$ = new Subject();\n\n    private originInstancesMap = new Map<\n        ElementRef | HTMLElement,\n        {\n            config: ThyPopoverConfig;\n            popoverRef: ThyPopoverRef<any, any>;\n        }\n    >();\n\n    private buildPositionStrategy<TData>(config: ThyPopoverConfig<TData>): PositionStrategy {\n        const origin: FlexibleConnectedPositionStrategyOrigin = config.originPosition ? config.originPosition : config.origin;\n        // const positionStrategy = this.overlay.position().flexibleConnectedTo(origin);\n        const positionStrategy = new FlexibleConnectedPositionStrategy(\n            origin,\n            this._viewportRuler,\n            this._document,\n            this._platform,\n            this._overlayContainer\n        );\n        const positions = getFlexiblePositions(config.placement, config.offset, 'thy-popover');\n        positionStrategy.withPositions(positions);\n        positionStrategy.withPush(config.canPush);\n        positionStrategy.withGrowAfterOpen(true);\n        positionStrategy.withTransformOriginOn('.thy-popover-container');\n        positionStrategy.positionChanges.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(change => {\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.close());\n            }\n        });\n        return positionStrategy;\n    }\n\n    private buildScrollStrategy(config: ThyPopoverConfig): ScrollStrategy {\n        if (config.scrollStrategy) {\n            return config.scrollStrategy;\n        } else if (this.scrollStrategy && isFunction(this.scrollStrategy)) {\n            return this.scrollStrategy();\n        } else {\n            this.overlay.scrollStrategies.block();\n        }\n    }\n\n    protected buildOverlayConfig<TData>(config: ThyPopoverConfig<TData>): OverlayConfig {\n        const positionStrategy = this.buildPositionStrategy(config);\n        const overlayConfig = this.buildBaseOverlayConfig(config, 'thy-popover-panel');\n        overlayConfig.positionStrategy = positionStrategy;\n        overlayConfig.scrollStrategy = this.buildScrollStrategy(config);\n        return overlayConfig;\n    }\n\n    protected attachOverlayContainer(overlay: OverlayRef, config: ThyPopoverConfig<any>): ThyPopoverContainer {\n        const userInjector = config && config.viewContainerRef && config.viewContainerRef.injector;\n        const injector = Injector.create({\n            parent: userInjector || this.injector,\n            providers: [{ provide: ThyPopoverConfig, useValue: config }]\n        });\n        const containerPortal = new ComponentPortal(ThyPopoverContainer, config.viewContainerRef, injector);\n        const containerRef = overlay.attach<ThyPopoverContainer>(containerPortal);\n        return containerRef.instance;\n    }\n\n    protected createAbstractOverlayRef<T, TResult = unknown>(\n        overlayRef: OverlayRef,\n        containerInstance: ThyPopoverContainer,\n        config: ThyPopoverConfig\n    ): ThyAbstractOverlayRef<T, ThyPopoverContainer, TResult> {\n        return new ThyInternalPopoverRef(overlayRef, containerInstance, config);\n    }\n\n    protected createInjector<T>(config: ThyPopoverConfig, popoverRef: ThyPopoverRef<T>, popoverContainer: ThyPopoverContainer): Injector {\n        const userInjector = config && config.viewContainerRef && config.viewContainerRef.injector;\n\n        const injectionTokens: StaticProvider[] = [\n            { provide: ThyPopoverContainer, useValue: popoverContainer },\n            {\n                provide: ThyPopoverRef,\n                useValue: popoverRef\n            }\n        ];\n\n        if (config.direction && (!userInjector || !userInjector.get<Directionality | null>(Directionality, null))) {\n            injectionTokens.push({\n                provide: Directionality,\n                useValue: {\n                    value: config.direction,\n                    change: of()\n                }\n            });\n        }\n\n        return Injector.create({ parent: userInjector || this.injector, providers: injectionTokens });\n    }\n\n    private originElementAddActiveClass(config: ThyPopoverConfig) {\n        if (config.originActiveClass) {\n            coerceElement<HTMLElement>(config.origin).classList.add(...coerceArray(config.originActiveClass));\n        }\n    }\n\n    private originElementRemoveActiveClass(config: ThyPopoverConfig) {\n        if (config.originActiveClass) {\n            coerceElement<HTMLElement>(config.origin).classList.remove(...coerceArray(config.originActiveClass));\n        }\n    }\n\n    constructor(\n        overlay: Overlay,\n        injector: Injector,\n        @Optional()\n        @Inject(THY_POPOVER_DEFAULT_CONFIG)\n        defaultConfig: ThyPopoverConfig,\n        @Inject(THY_POPOVER_SCROLL_STRATEGY)\n        scrollStrategy: FunctionProp<ScrollStrategy>,\n        private ngZone: NgZone,\n        private _viewportRuler: ViewportRuler,\n        @Optional() @Inject(DOCUMENT) private _document: any,\n        private _platform: Platform,\n        private _overlayContainer: OverlayContainer\n    ) {\n        super(\n            popoverAbstractOverlayOptions,\n            overlay,\n            injector,\n            {\n                ...THY_POPOVER_DEFAULT_CONFIG_VALUE,\n                ...defaultConfig\n            },\n            scrollStrategy\n        );\n    }\n\n    private ensureCloseClosest(origin: HTMLElement) {\n        let closeAndEnd = false;\n        this.originInstancesMap.forEach((value, key) => {\n            if (value.config.manualClosure) {\n                if (key === origin) {\n                    value.popoverRef.close();\n                    closeAndEnd = true;\n                }\n            } else {\n                if (key === origin) {\n                    closeAndEnd = true;\n                }\n                value.popoverRef.close();\n            }\n        });\n        return closeAndEnd;\n    }\n\n    /**\n     * 打开悬浮层\n     */\n    open<T, TData = unknown, TResult = unknown>(\n        componentOrTemplateRef: ComponentTypeOrTemplateRef<T>,\n        config?: ThyPopoverConfig<TData>\n    ): ThyPopoverRef<T, TResult> {\n        const originElement = coerceElement(config.origin);\n        // 默认关闭之前的弹出框\n        // 1. 当之前的 Popover 设置 manualClosure 为 true 时, 弹出其他 Popover 时不自动关闭 manualClosure 为 true 的 Popover\n        // 2. 当前的 Origin 对应的 Popover 已经弹出，不管 manualClosure 设置为何，直接关闭并返回\n        if (this.ensureCloseClosest(originElement)) {\n            return;\n        }\n\n        const popoverRef = this.openOverlay<T, TResult>(componentOrTemplateRef, config) as ThyPopoverRef<T, TResult, TData>;\n        config = popoverRef.containerInstance.config;\n        popoverRef.afterClosed().subscribe(() => {\n            this.originElementRemoveActiveClass(config);\n            this.originInstancesMap.delete(originElement);\n        });\n\n        this.originElementAddActiveClass(config);\n        this.originInstancesMap.set(originElement, {\n            config,\n            popoverRef\n        });\n\n        return popoverRef;\n    }\n\n    /**\n     * 根据Id获取打开的悬浮层\n     */\n    getPopoverById(id: string): ThyPopoverRef<any> | undefined {\n        return this.getAbstractOverlayById(id) as ThyPopoverRef<any> | undefined;\n    }\n\n    /**\n     * 获取已经打开的悬浮层\n     */\n    getOpenedPopovers(): ThyPopoverRef<SafeAny>[] {\n        return this.getAbstractOverlays();\n    }\n\n    /**\n     * @description.en-us Finds the closest ThyPopoverRef to an element by looking at the DOM.\n     * @description 通过 Dom 元素查找最近弹出的悬浮层\n     */\n    getClosestPopover(element: HTMLElement): ThyPopoverRef<any> | undefined {\n        const parent = element.closest('.thy-popover-container');\n\n        if (parent && parent.id) {\n            return this.getPopoverById(parent.id);\n        }\n        return null;\n    }\n\n    /**\n     * 关闭悬浮层\n     */\n    close<T>(result?: T, force?: boolean) {\n        super.close(result, force);\n    }\n\n    /**\n     * @internal\n     */\n    ngOnDestroy() {\n        this.dispose();\n    }\n}\n"]}
|