ngx-tethys 14.2.18 → 14.2.20

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.
Files changed (131) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/core/overlay/overlay.directive.d.ts +0 -1
  3. package/esm2020/color-picker/parts/inputs/inputs.component.mjs +1 -1
  4. package/esm2020/core/overlay/overlay.directive.mjs +2 -2
  5. package/esm2020/date-picker/lib/popups/inner-popup.component.mjs +1 -1
  6. package/esm2020/date-picker/picker.component.mjs +1 -1
  7. package/esm2020/input/input-search.component.mjs +1 -1
  8. package/esm2020/input/input.component.mjs +3 -11
  9. package/esm2020/input/input.directive.mjs +2 -19
  10. package/esm2020/input-number/input-number.component.mjs +1 -1
  11. package/esm2020/message/abstract/abstract-message-container.component.mjs +26 -0
  12. package/esm2020/message/abstract/abstract-message-queue.service.mjs +34 -0
  13. package/esm2020/message/abstract/abstract-message-ref.mjs +22 -0
  14. package/esm2020/message/abstract/abstract-message.component.mjs +76 -0
  15. package/esm2020/message/abstract/abstract-message.service.mjs +29 -0
  16. package/esm2020/message/abstract/index.mjs +6 -0
  17. package/esm2020/message/index.mjs +2 -1
  18. package/esm2020/message/message-container.component.mjs +9 -17
  19. package/esm2020/message/message-queue.service.mjs +4 -30
  20. package/esm2020/message/message-ref.mjs +3 -15
  21. package/esm2020/message/message.component.mjs +9 -63
  22. package/esm2020/message/message.config.mjs +1 -1
  23. package/esm2020/message/message.service.mjs +20 -42
  24. package/esm2020/notify/index.mjs +2 -3
  25. package/esm2020/notify/module.mjs +6 -8
  26. package/esm2020/notify/notify-container.component.mjs +21 -85
  27. package/esm2020/notify/notify-queue.service.mjs +29 -0
  28. package/esm2020/notify/notify-ref.mjs +3 -17
  29. package/esm2020/notify/notify.component.mjs +24 -102
  30. package/esm2020/notify/notify.config.mjs +2 -14
  31. package/esm2020/notify/notify.service.mjs +33 -158
  32. package/esm2020/select/select.component.mjs +1 -1
  33. package/esm2020/time-picker/time-picker.component.mjs +1 -1
  34. package/esm2020/tooltip/deprecated-tooltip.service.mjs +42 -0
  35. package/esm2020/tooltip/index.mjs +4 -2
  36. package/esm2020/tooltip/interface.mjs +2 -6
  37. package/esm2020/tooltip/tooltip-ref.mjs +144 -0
  38. package/esm2020/tooltip/tooltip.component.mjs +4 -1
  39. package/esm2020/tooltip/tooltip.config.mjs +7 -5
  40. package/esm2020/tooltip/tooltip.directive.mjs +51 -143
  41. package/esm2020/tooltip/tooltip.module.mjs +1 -1
  42. package/esm2020/tooltip/tooltip.service.mjs +20 -28
  43. package/esm2020/version.mjs +2 -2
  44. package/fesm2015/ngx-tethys-color-picker.mjs +1 -1
  45. package/fesm2015/ngx-tethys-color-picker.mjs.map +1 -1
  46. package/fesm2015/ngx-tethys-core.mjs +1 -1
  47. package/fesm2015/ngx-tethys-core.mjs.map +1 -1
  48. package/fesm2015/ngx-tethys-date-picker.mjs +2 -2
  49. package/fesm2015/ngx-tethys-date-picker.mjs.map +1 -1
  50. package/fesm2015/ngx-tethys-input-number.mjs +1 -1
  51. package/fesm2015/ngx-tethys-input-number.mjs.map +1 -1
  52. package/fesm2015/ngx-tethys-input.mjs +4 -29
  53. package/fesm2015/ngx-tethys-input.mjs.map +1 -1
  54. package/fesm2015/ngx-tethys-message.mjs +170 -116
  55. package/fesm2015/ngx-tethys-message.mjs.map +1 -1
  56. package/fesm2015/ngx-tethys-notify.mjs +90 -504
  57. package/fesm2015/ngx-tethys-notify.mjs.map +1 -1
  58. package/fesm2015/ngx-tethys-select.mjs +1 -1
  59. package/fesm2015/ngx-tethys-select.mjs.map +1 -1
  60. package/fesm2015/ngx-tethys-time-picker.mjs +1 -1
  61. package/fesm2015/ngx-tethys-time-picker.mjs.map +1 -1
  62. package/fesm2015/ngx-tethys-tooltip.mjs +226 -142
  63. package/fesm2015/ngx-tethys-tooltip.mjs.map +1 -1
  64. package/fesm2015/ngx-tethys.mjs +1 -1
  65. package/fesm2015/ngx-tethys.mjs.map +1 -1
  66. package/fesm2020/ngx-tethys-color-picker.mjs +1 -1
  67. package/fesm2020/ngx-tethys-color-picker.mjs.map +1 -1
  68. package/fesm2020/ngx-tethys-core.mjs +1 -1
  69. package/fesm2020/ngx-tethys-core.mjs.map +1 -1
  70. package/fesm2020/ngx-tethys-date-picker.mjs +2 -2
  71. package/fesm2020/ngx-tethys-date-picker.mjs.map +1 -1
  72. package/fesm2020/ngx-tethys-input-number.mjs +1 -1
  73. package/fesm2020/ngx-tethys-input-number.mjs.map +1 -1
  74. package/fesm2020/ngx-tethys-input.mjs +4 -29
  75. package/fesm2020/ngx-tethys-input.mjs.map +1 -1
  76. package/fesm2020/ngx-tethys-message.mjs +168 -114
  77. package/fesm2020/ngx-tethys-message.mjs.map +1 -1
  78. package/fesm2020/ngx-tethys-notify.mjs +91 -515
  79. package/fesm2020/ngx-tethys-notify.mjs.map +1 -1
  80. package/fesm2020/ngx-tethys-select.mjs +1 -1
  81. package/fesm2020/ngx-tethys-select.mjs.map +1 -1
  82. package/fesm2020/ngx-tethys-time-picker.mjs +1 -1
  83. package/fesm2020/ngx-tethys-time-picker.mjs.map +1 -1
  84. package/fesm2020/ngx-tethys-tooltip.mjs +220 -140
  85. package/fesm2020/ngx-tethys-tooltip.mjs.map +1 -1
  86. package/fesm2020/ngx-tethys.mjs +1 -1
  87. package/fesm2020/ngx-tethys.mjs.map +1 -1
  88. package/image/styles/image.scss +4 -4
  89. package/input/input.component.d.ts +1 -6
  90. package/input/input.directive.d.ts +1 -8
  91. package/message/abstract/abstract-message-container.component.d.ts +14 -0
  92. package/message/abstract/abstract-message-queue.service.d.ts +14 -0
  93. package/message/abstract/abstract-message-ref.d.ts +14 -0
  94. package/message/abstract/abstract-message.component.d.ts +36 -0
  95. package/message/abstract/abstract-message.service.d.ts +17 -0
  96. package/message/abstract/index.d.ts +5 -0
  97. package/message/index.d.ts +1 -0
  98. package/message/message-container.component.d.ts +3 -4
  99. package/message/message-queue.service.d.ts +2 -7
  100. package/message/message-ref.d.ts +2 -7
  101. package/message/message.component.d.ts +5 -15
  102. package/message/message.config.d.ts +8 -3
  103. package/message/message.service.d.ts +9 -16
  104. package/notify/index.d.ts +1 -2
  105. package/notify/module.d.ts +7 -8
  106. package/notify/notify-container.component.d.ts +10 -31
  107. package/notify/notify-queue.service.d.ts +16 -0
  108. package/notify/notify-ref.d.ts +2 -12
  109. package/notify/notify.component.d.ts +12 -27
  110. package/notify/notify.config.d.ts +19 -29
  111. package/notify/notify.service.d.ts +16 -34
  112. package/notify/styles/notify.scss +20 -19
  113. package/package.json +1 -1
  114. package/schematics/version.d.ts +1 -1
  115. package/schematics/version.js +1 -1
  116. package/tooltip/deprecated-tooltip.service.d.ts +24 -0
  117. package/tooltip/index.d.ts +3 -1
  118. package/tooltip/interface.d.ts +3 -6
  119. package/tooltip/tooltip-ref.d.ts +31 -0
  120. package/tooltip/tooltip.component.d.ts +3 -0
  121. package/tooltip/tooltip.config.d.ts +19 -10
  122. package/tooltip/tooltip.directive.d.ts +44 -28
  123. package/tooltip/tooltip.service.d.ts +12 -15
  124. package/esm2020/notify/notify-animations.mjs +0 -17
  125. package/esm2020/notify/notify-content.component.mjs +0 -61
  126. package/esm2020/notify/notify-queue.store.mjs +0 -92
  127. package/esm2020/notify/notify.options.mjs +0 -6
  128. package/notify/notify-animations.d.ts +0 -8
  129. package/notify/notify-content.component.d.ts +0 -19
  130. package/notify/notify-queue.store.d.ts +0 -22
  131. package/notify/notify.options.d.ts +0 -2
package/CHANGELOG.md CHANGED
@@ -2,6 +2,25 @@
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
+ ## [14.2.20](https://github.com/atinc/ngx-tethys/compare/14.2.19...14.2.20) (2023-02-21)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * **image:** use width / height to prevent css packing optimization #INFR-6526 ([358b39b](https://github.com/atinc/ngx-tethys/commit/358b39bae3b4e0f2aae361c0c05cfaadc64837b5)), closes [#INFR-6526](https://github.com/atinc/ngx-tethys/issues/INFR-6526)
11
+
12
+
13
+
14
+ ## [14.2.19](https://github.com/atinc/ngx-tethys/compare/14.2.18...14.2.19) (2023-02-17)
15
+
16
+
17
+ ### Features
18
+
19
+ * **input:** remove the thyAutocomplete of thyInput & thy-input #INFR-6523 ([#2538](https://github.com/atinc/ngx-tethys/issues/2538)) ([92f753e](https://github.com/atinc/ngx-tethys/commit/92f753ec05140c60bacc8a1eca832709c7b8aaf3)), closes [#INFR-6523](https://github.com/atinc/ngx-tethys/issues/INFR-6523)
20
+ * **tooltip:** add tooltip service and tooltipRef, refactor tooltip directive #INFR-6382 ([#2532](https://github.com/atinc/ngx-tethys/issues/2532)) ([27d4bf3](https://github.com/atinc/ngx-tethys/commit/27d4bf3aab5536df57241526ad5bdae7a6c18df8)), closes [#INFR-6382](https://github.com/atinc/ngx-tethys/issues/INFR-6382)
21
+
22
+
23
+
5
24
  ## [14.2.18](https://github.com/atinc/ngx-tethys/compare/14.2.17...14.2.18) (2023-02-16)
6
25
 
7
26
 
@@ -28,7 +28,6 @@ export declare abstract class ThyOverlayDirectiveBase {
28
28
  */
29
29
  protected overlayPin: boolean;
30
30
  /** create overlay, you can use popover service or overlay*/
31
- abstract createOverlay(): OverlayRef;
32
31
  abstract show(delay?: number): void;
33
32
  abstract hide(delay?: number): void;
34
33
  private clearEventListeners;
@@ -35,7 +35,7 @@ export class ThyColorInputsComponent {
35
35
  }
36
36
  }
37
37
  ThyColorInputsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyColorInputsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
38
- ThyColorInputsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyColorInputsComponent, selector: "thy-color-inputs", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, host: { properties: { "class.thy-color-inputs": "this.className" } }, ngImport: i0, template: "<div class=\"hex-column\">\n <input\n #elRef\n thySize=\"xs\"\n class=\"px-0 text-center\"\n thyInput\n [(ngModel)]=\"color.displayValue\"\n (blur)=\"onInputChange($event, 'hex')\"\n (thyEnter)=\"onInputChange($event, 'hex')\"\n />\n <span>HEX</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.red\"\n (thyBlur)=\"onInputChange($event, 'R')\"\n (thyEnter)=\"onInputChange($event, 'R')\"\n ></thy-input-number>\n <span>R</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.green\"\n (thyBlur)=\"onInputChange($event, 'G')\"\n (thyEnter)=\"onInputChange($event, 'G')\"\n ></thy-input-number>\n <span>G</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.blue\"\n (thyBlur)=\"onInputChange($event, 'B')\"\n (thyEnter)=\"onInputChange($event, 'B')\"\n ></thy-input-number>\n <span>B</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n [thyMin]=\"0\"\n [thyMax]=\"100\"\n thySize=\"xs\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"alpha\"\n (thyBlur)=\"onInputChange($event, 'A')\"\n (thyEnter)=\"onInputChange($event, 'A')\"\n ></thy-input-number>\n <span>A</span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ThyInputNumberComponent, selector: "thy-input-number", inputs: ["thyAutoFocus", "thyPlaceholder", "thyDisabled", "thyMax", "thyMin", "thyStep", "thySize", "thyPrecision", "thySuffix"], outputs: ["thyBlur", "thyFocus"] }, { kind: "directive", type: i4.ThyEnterDirective, selector: "[thyEnter]", outputs: ["thyEnter"] }] });
38
+ ThyColorInputsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyColorInputsComponent, selector: "thy-color-inputs", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, host: { properties: { "class.thy-color-inputs": "this.className" } }, ngImport: i0, template: "<div class=\"hex-column\">\n <input\n #elRef\n thySize=\"xs\"\n class=\"px-0 text-center\"\n thyInput\n [(ngModel)]=\"color.displayValue\"\n (blur)=\"onInputChange($event, 'hex')\"\n (thyEnter)=\"onInputChange($event, 'hex')\"\n />\n <span>HEX</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.red\"\n (thyBlur)=\"onInputChange($event, 'R')\"\n (thyEnter)=\"onInputChange($event, 'R')\"\n ></thy-input-number>\n <span>R</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.green\"\n (thyBlur)=\"onInputChange($event, 'G')\"\n (thyEnter)=\"onInputChange($event, 'G')\"\n ></thy-input-number>\n <span>G</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.blue\"\n (thyBlur)=\"onInputChange($event, 'B')\"\n (thyEnter)=\"onInputChange($event, 'B')\"\n ></thy-input-number>\n <span>B</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n [thyMin]=\"0\"\n [thyMax]=\"100\"\n thySize=\"xs\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"alpha\"\n (thyBlur)=\"onInputChange($event, 'A')\"\n (thyEnter)=\"onInputChange($event, 'A')\"\n ></thy-input-number>\n <span>A</span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ThyInputNumberComponent, selector: "thy-input-number", inputs: ["thyAutoFocus", "thyPlaceholder", "thyDisabled", "thyMax", "thyMin", "thyStep", "thySize", "thyPrecision", "thySuffix"], outputs: ["thyBlur", "thyFocus"] }, { kind: "directive", type: i4.ThyEnterDirective, selector: "[thyEnter]", outputs: ["thyEnter"] }] });
39
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyColorInputsComponent, decorators: [{
40
40
  type: Component,
41
41
  args: [{ selector: 'thy-color-inputs', template: "<div class=\"hex-column\">\n <input\n #elRef\n thySize=\"xs\"\n class=\"px-0 text-center\"\n thyInput\n [(ngModel)]=\"color.displayValue\"\n (blur)=\"onInputChange($event, 'hex')\"\n (thyEnter)=\"onInputChange($event, 'hex')\"\n />\n <span>HEX</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.red\"\n (thyBlur)=\"onInputChange($event, 'R')\"\n (thyEnter)=\"onInputChange($event, 'R')\"\n ></thy-input-number>\n <span>R</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.green\"\n (thyBlur)=\"onInputChange($event, 'G')\"\n (thyEnter)=\"onInputChange($event, 'G')\"\n ></thy-input-number>\n <span>G</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n thySize=\"xs\"\n [thyMin]=\"0\"\n [thyMax]=\"255\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"color.rgba.blue\"\n (thyBlur)=\"onInputChange($event, 'B')\"\n (thyEnter)=\"onInputChange($event, 'B')\"\n ></thy-input-number>\n <span>B</span>\n</div>\n<div class=\"column\">\n <thy-input-number\n [thyMin]=\"0\"\n [thyMax]=\"100\"\n thySize=\"xs\"\n class=\"px-0 text-center\"\n [(ngModel)]=\"alpha\"\n (thyBlur)=\"onInputChange($event, 'A')\"\n (thyEnter)=\"onInputChange($event, 'A')\"\n ></thy-input-number>\n <span>A</span>\n</div>\n" }]
@@ -103,7 +103,7 @@ export class ThyOverlayDirectiveBase {
103
103
  const touchendListener = () => {
104
104
  // this.hide(this.touchendHideDelay);
105
105
  setTimeout(() => {
106
- this.hide();
106
+ this.hide(0);
107
107
  }, this.touchendHideDelay);
108
108
  };
109
109
  // Reserve extensions for mobile in the future
@@ -130,4 +130,4 @@ export class ThyOverlayDirectiveBase {
130
130
  this.clearTimer();
131
131
  }
132
132
  }
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../src/core/overlay/overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, NgZone } from '@angular/core';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { Subject, fromEvent } from 'rxjs';\nimport { normalizePassiveListenerOptions, Platform } from '@angular/cdk/platform';\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport { takeUntil, take } from 'rxjs/operators';\n\nexport type ThyOverlayTrigger = 'hover' | 'focus' | 'click';\n\nconst passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });\n\nexport abstract class ThyOverlayDirectiveBase {\n    protected elementRef: ElementRef;\n    private initialized = false;\n    /** Trigger Overlay */\n    protected _trigger: ThyOverlayTrigger = 'click';\n    public get trigger() {\n        return this._trigger;\n    }\n    public set trigger(value: ThyOverlayTrigger) {\n        this._trigger = value;\n        // Trigger reinitialize when trigger changed which can't contain first\n        if (this.initialized) {\n            this.clearEventListeners();\n            this.initialize();\n        }\n    }\n\n    protected overlayRef: OverlayRef;\n    protected manualListeners = new Map<string, EventListenerOrEventListenerObject>();\n    protected ngUnsubscribe$ = new Subject<void>();\n    protected focusMonitor: FocusMonitor;\n    protected platform: Platform;\n    protected ngZone: NgZone;\n    protected showDelay? = 100;\n    protected hideDelay? = 100;\n    protected touchendHideDelay? = 0;\n    protected disabled = false;\n    protected showTimeoutId: number | null | any;\n    protected hideTimeoutId: number | null | any;\n\n    /**\n     * The overlay keep opened when the mouse moves to the overlay container\n     */\n    protected overlayPin: boolean;\n    /** create overlay, you can use popover service or overlay*/\n    abstract createOverlay(): OverlayRef;\n    abstract show(delay?: number): void;\n    abstract hide(delay?: number): void;\n\n    private clearEventListeners() {\n        this.manualListeners.forEach((listener, event) => {\n            this.elementRef.nativeElement.removeEventListener(event, listener);\n        });\n        this.manualListeners.clear();\n        this.focusMonitor.stopMonitoring(this.elementRef);\n    }\n\n    private clearTimer() {\n        if (this.showTimeoutId) {\n            clearTimeout(this.showTimeoutId);\n        }\n        if (this.hideTimeoutId) {\n            clearTimeout(this.hideTimeoutId);\n        }\n    }\n\n    constructor(elementRef: ElementRef, platform: Platform, focusMonitor: FocusMonitor, ngZone: NgZone, overlayPin?: boolean) {\n        this.elementRef = elementRef;\n        this.platform = platform;\n        this.focusMonitor = focusMonitor;\n        this.ngZone = ngZone;\n        this.overlayPin = overlayPin;\n    }\n\n    initialize() {\n        this.initialized = true;\n        const element: HTMLElement = this.elementRef.nativeElement;\n        if (!this.platform.IOS && !this.platform.ANDROID) {\n            if (this.trigger === 'hover') {\n                this.manualListeners\n                    .set('mouseenter', () => {\n                        this.show();\n                    })\n                    .set('mouseleave', (event: MouseEvent) => {\n                        // Delay 100ms to avoid the overlay being closed immediately when the cursor is moved to the overlay container\n                        this.hide();\n                        const overlayElement: HTMLElement = this.overlayRef && this.overlayRef.overlayElement;\n                        if (overlayElement && this.overlayPin) {\n                            fromEvent(overlayElement, 'mouseenter')\n                                .pipe(take(1))\n                                .subscribe(() => {\n                                    this.clearTimer();\n                                    fromEvent(overlayElement, 'mouseleave')\n                                        .pipe(take(1))\n                                        .subscribe(() => {\n                                            this.hide();\n                                        });\n                                });\n                        }\n                        // if showDelay is too long and mouseleave immediately, overlayRef is not exist, we should clearTimeout\n                        if (!this.overlayRef) {\n                            this.clearTimer();\n                        }\n                    });\n            } else if (this.trigger === 'focus') {\n                this.focusMonitor\n                    .monitor(this.elementRef)\n                    .pipe(takeUntil(this.ngUnsubscribe$))\n                    .subscribe(origin => {\n                        // Note that the focus monitor runs outside the Angular zone.\n                        if (!origin) {\n                            this.ngZone.run(() => this.hide(0));\n                        } else {\n                            this.ngZone.run(() => this.show());\n                        }\n                    });\n                // this.manualListeners.set('focus', () => this.show());\n                // this.manualListeners.set('blur', () => this.hide());\n            } else if (this.trigger === 'click') {\n                this.manualListeners.set('click', () => this.show());\n            } else if (typeof ngDevMode === 'undefined' || ngDevMode) {\n                throw new Error(`${this.trigger} is not supporteed, possible values are: hover | focus | click.`);\n            }\n        } else {\n            const touchendListener = () => {\n                // this.hide(this.touchendHideDelay);\n                setTimeout(() => {\n                    this.hide();\n                }, this.touchendHideDelay);\n            };\n            // Reserve extensions for mobile in the future\n            this.manualListeners\n                .set('touchend', touchendListener)\n                .set('touchcancel', touchendListener)\n                .set('touchstart', () => {\n                    this.show();\n                });\n        }\n\n        this.manualListeners.forEach((listener, event) =>\n            // Note: since Chrome 56 defaults document level `touchstart` listener to passive.\n            // Element touch listeners are not passive by default.\n            // We never call `preventDefault()` on events, so we're safe making them passive.\n            element.addEventListener(event, listener, passiveEventListenerOptions)\n        );\n    }\n\n    dispose(): void {\n        this.ngUnsubscribe$.next();\n        this.ngUnsubscribe$.complete();\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        this.clearEventListeners();\n        this.clearTimer();\n    }\n}\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../src/core/overlay/overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, NgZone } from '@angular/core';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport { Subject, fromEvent } from 'rxjs';\nimport { normalizePassiveListenerOptions, Platform } from '@angular/cdk/platform';\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport { takeUntil, take } from 'rxjs/operators';\n\nexport type ThyOverlayTrigger = 'hover' | 'focus' | 'click';\n\nconst passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });\n\nexport abstract class ThyOverlayDirectiveBase {\n    protected elementRef: ElementRef;\n    private initialized = false;\n    /** Trigger Overlay */\n    protected _trigger: ThyOverlayTrigger = 'click';\n    public get trigger() {\n        return this._trigger;\n    }\n    public set trigger(value: ThyOverlayTrigger) {\n        this._trigger = value;\n        // Trigger reinitialize when trigger changed which can't contain first\n        if (this.initialized) {\n            this.clearEventListeners();\n            this.initialize();\n        }\n    }\n\n    protected overlayRef: OverlayRef;\n    protected manualListeners = new Map<string, EventListenerOrEventListenerObject>();\n    protected ngUnsubscribe$ = new Subject<void>();\n    protected focusMonitor: FocusMonitor;\n    protected platform: Platform;\n    protected ngZone: NgZone;\n    protected showDelay? = 100;\n    protected hideDelay? = 100;\n    protected touchendHideDelay? = 0;\n    protected disabled = false;\n    protected showTimeoutId: number | null | any;\n    protected hideTimeoutId: number | null | any;\n\n    /**\n     * The overlay keep opened when the mouse moves to the overlay container\n     */\n    protected overlayPin: boolean;\n\n    /** create overlay, you can use popover service or overlay*/\n    // abstract createOverlay(): OverlayRef;\n\n    abstract show(delay?: number): void;\n    abstract hide(delay?: number): void;\n\n    private clearEventListeners() {\n        this.manualListeners.forEach((listener, event) => {\n            this.elementRef.nativeElement.removeEventListener(event, listener);\n        });\n        this.manualListeners.clear();\n        this.focusMonitor.stopMonitoring(this.elementRef);\n    }\n\n    private clearTimer() {\n        if (this.showTimeoutId) {\n            clearTimeout(this.showTimeoutId);\n        }\n        if (this.hideTimeoutId) {\n            clearTimeout(this.hideTimeoutId);\n        }\n    }\n\n    constructor(elementRef: ElementRef, platform: Platform, focusMonitor: FocusMonitor, ngZone: NgZone, overlayPin?: boolean) {\n        this.elementRef = elementRef;\n        this.platform = platform;\n        this.focusMonitor = focusMonitor;\n        this.ngZone = ngZone;\n        this.overlayPin = overlayPin;\n    }\n\n    initialize() {\n        this.initialized = true;\n        const element: HTMLElement = this.elementRef.nativeElement;\n        if (!this.platform.IOS && !this.platform.ANDROID) {\n            if (this.trigger === 'hover') {\n                this.manualListeners\n                    .set('mouseenter', () => {\n                        this.show();\n                    })\n                    .set('mouseleave', (event: MouseEvent) => {\n                        // Delay 100ms to avoid the overlay being closed immediately when the cursor is moved to the overlay container\n                        this.hide();\n                        const overlayElement: HTMLElement = this.overlayRef && this.overlayRef.overlayElement;\n                        if (overlayElement && this.overlayPin) {\n                            fromEvent(overlayElement, 'mouseenter')\n                                .pipe(take(1))\n                                .subscribe(() => {\n                                    this.clearTimer();\n                                    fromEvent(overlayElement, 'mouseleave')\n                                        .pipe(take(1))\n                                        .subscribe(() => {\n                                            this.hide();\n                                        });\n                                });\n                        }\n                        // if showDelay is too long and mouseleave immediately, overlayRef is not exist, we should clearTimeout\n                        if (!this.overlayRef) {\n                            this.clearTimer();\n                        }\n                    });\n            } else if (this.trigger === 'focus') {\n                this.focusMonitor\n                    .monitor(this.elementRef)\n                    .pipe(takeUntil(this.ngUnsubscribe$))\n                    .subscribe(origin => {\n                        // Note that the focus monitor runs outside the Angular zone.\n                        if (!origin) {\n                            this.ngZone.run(() => this.hide(0));\n                        } else {\n                            this.ngZone.run(() => this.show());\n                        }\n                    });\n                // this.manualListeners.set('focus', () => this.show());\n                // this.manualListeners.set('blur', () => this.hide());\n            } else if (this.trigger === 'click') {\n                this.manualListeners.set('click', () => this.show());\n            } else if (typeof ngDevMode === 'undefined' || ngDevMode) {\n                throw new Error(`${this.trigger} is not supporteed, possible values are: hover | focus | click.`);\n            }\n        } else {\n            const touchendListener = () => {\n                // this.hide(this.touchendHideDelay);\n                setTimeout(() => {\n                    this.hide(0);\n                }, this.touchendHideDelay);\n            };\n            // Reserve extensions for mobile in the future\n            this.manualListeners\n                .set('touchend', touchendListener)\n                .set('touchcancel', touchendListener)\n                .set('touchstart', () => {\n                    this.show();\n                });\n        }\n\n        this.manualListeners.forEach((listener, event) =>\n            // Note: since Chrome 56 defaults document level `touchstart` listener to passive.\n            // Element touch listeners are not passive by default.\n            // We never call `preventDefault()` on events, so we're safe making them passive.\n            element.addEventListener(event, listener, passiveEventListenerOptions)\n        );\n    }\n\n    dispose(): void {\n        this.ngUnsubscribe$.next();\n        this.ngUnsubscribe$.complete();\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        this.clearEventListeners();\n        this.clearTimer();\n    }\n}\n"]}
@@ -117,7 +117,7 @@ export class InnerPopupComponent {
117
117
  }
118
118
  }
119
119
  InnerPopupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: InnerPopupComponent, deps: [{ token: i1.DateHelperService }], target: i0.ɵɵFactoryTarget.Component });
120
- InnerPopupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: InnerPopupComponent, selector: "inner-popup", inputs: { showWeek: "showWeek", isRange: "isRange", activeDate: "activeDate", rangeActiveDate: "rangeActiveDate", enablePrev: "enablePrev", enableNext: "enableNext", disabledDate: "disabledDate", dateRender: "dateRender", selectedValue: "selectedValue", hoverValue: "hoverValue", panelMode: "panelMode", showDateRangeInput: "showDateRangeInput", partType: "partType", endPanelMode: "endPanelMode", value: "value" }, outputs: { panelModeChange: "panelModeChange", headerChange: "headerChange", selectDate: "selectDate", dayHover: "dayHover" }, host: { properties: { "class.thy-calendar-picker-inner-popup": "this.className", "class.thy-calendar-picker-inner-popup-with-range-input": "this._showDateRangeInput" } }, exportAs: ["innerPopup"], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"showDateRangeInput\">\n <div class=\"{{ prefixCls }}-picker-inner-popup-range-input\">\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[0])\" placeholder=\"\u5F00\u59CB\u65E5\u671F\" />\n <span class=\"split\"></span>\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[1])\" placeholder=\"\u7ED3\u675F\u65E5\u671F\" />\n </div>\n</ng-container>\n<ng-container [ngSwitch]=\"panelMode\">\n <ng-container *ngSwitchCase=\"'decade'\">\n <div class=\"{{ prefixCls }}-decade\">\n <decade-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'decade')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'decade')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></decade-header>\n <div class=\"{{ prefixCls }}-body\">\n <decade-table [value]=\"value\" [activeDate]=\"activeDate\" (valueChange)=\"onChooseDecade($event)\"></decade-table>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"{{ prefixCls }}-year\">\n <year-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'year')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'year')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></year-header>\n <div class=\"{{ prefixCls }}-body\">\n <year-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseYear($event)\"\n [selectedValue]=\"selectedValue\"\n ></year-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"{{ prefixCls }}-month\">\n <month-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'month')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'month')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></month-header>\n <div class=\"{{ prefixCls }}-body\">\n <month-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseMonth($event)\"\n [selectedValue]=\"selectedValue\"\n ></month-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <date-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'date')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'date')\"\n [showPreBtn]=\"enablePrevNext('prev', 'date')\"\n [showNextBtn]=\"enablePrevNext('next', 'date')\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></date-header>\n <div class=\"{{ prefixCls }}-body\">\n <date-table\n [showWeek]=\"showWeek\"\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n (valueChange)=\"onSelectDate($event)\"\n showWeekNumber=\"false\"\n [disabledDate]=\"disabledDate\"\n [cellRender]=\"dateRender\"\n [selectedValue]=\"selectedValue\"\n [hoverValue]=\"hoverValue\"\n (dayHover)=\"dayHover.emit($event)\"\n ></date-table>\n </div>\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "component", type: i4.DateTableComponent, selector: "date-table", outputs: ["dayHover"], exportAs: ["dateTable"] }, { kind: "component", type: i5.DateHeaderComponent, selector: "date-header" }, { kind: "component", type: i6.YearTableComponent, selector: "year-table", outputs: ["decadePanelShow"] }, { kind: "component", type: i7.YearHeaderComponent, selector: "year-header" }, { kind: "component", type: i8.MonthTableComponent, selector: "month-table", exportAs: ["monthTable"] }, { kind: "component", type: i9.MonthHeaderComponent, selector: "month-header" }, { kind: "component", type: i10.DecadeHeaderComponent, selector: "decade-header" }, { kind: "component", type: i11.DecadeTableComponent, selector: "decade-table", exportAs: ["decadeTable"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
120
+ InnerPopupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: InnerPopupComponent, selector: "inner-popup", inputs: { showWeek: "showWeek", isRange: "isRange", activeDate: "activeDate", rangeActiveDate: "rangeActiveDate", enablePrev: "enablePrev", enableNext: "enableNext", disabledDate: "disabledDate", dateRender: "dateRender", selectedValue: "selectedValue", hoverValue: "hoverValue", panelMode: "panelMode", showDateRangeInput: "showDateRangeInput", partType: "partType", endPanelMode: "endPanelMode", value: "value" }, outputs: { panelModeChange: "panelModeChange", headerChange: "headerChange", selectDate: "selectDate", dayHover: "dayHover" }, host: { properties: { "class.thy-calendar-picker-inner-popup": "this.className", "class.thy-calendar-picker-inner-popup-with-range-input": "this._showDateRangeInput" } }, exportAs: ["innerPopup"], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"showDateRangeInput\">\n <div class=\"{{ prefixCls }}-picker-inner-popup-range-input\">\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[0])\" placeholder=\"\u5F00\u59CB\u65E5\u671F\" />\n <span class=\"split\"></span>\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[1])\" placeholder=\"\u7ED3\u675F\u65E5\u671F\" />\n </div>\n</ng-container>\n<ng-container [ngSwitch]=\"panelMode\">\n <ng-container *ngSwitchCase=\"'decade'\">\n <div class=\"{{ prefixCls }}-decade\">\n <decade-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'decade')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'decade')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></decade-header>\n <div class=\"{{ prefixCls }}-body\">\n <decade-table [value]=\"value\" [activeDate]=\"activeDate\" (valueChange)=\"onChooseDecade($event)\"></decade-table>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"{{ prefixCls }}-year\">\n <year-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'year')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'year')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></year-header>\n <div class=\"{{ prefixCls }}-body\">\n <year-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseYear($event)\"\n [selectedValue]=\"selectedValue\"\n ></year-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"{{ prefixCls }}-month\">\n <month-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'month')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'month')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></month-header>\n <div class=\"{{ prefixCls }}-body\">\n <month-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseMonth($event)\"\n [selectedValue]=\"selectedValue\"\n ></month-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <date-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'date')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'date')\"\n [showPreBtn]=\"enablePrevNext('prev', 'date')\"\n [showNextBtn]=\"enablePrevNext('next', 'date')\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></date-header>\n <div class=\"{{ prefixCls }}-body\">\n <date-table\n [showWeek]=\"showWeek\"\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n (valueChange)=\"onSelectDate($event)\"\n showWeekNumber=\"false\"\n [disabledDate]=\"disabledDate\"\n [cellRender]=\"dateRender\"\n [selectedValue]=\"selectedValue\"\n [hoverValue]=\"hoverValue\"\n (dayHover)=\"dayHover.emit($event)\"\n ></date-table>\n </div>\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }, { kind: "component", type: i4.DateTableComponent, selector: "date-table", outputs: ["dayHover"], exportAs: ["dateTable"] }, { kind: "component", type: i5.DateHeaderComponent, selector: "date-header" }, { kind: "component", type: i6.YearTableComponent, selector: "year-table", outputs: ["decadePanelShow"] }, { kind: "component", type: i7.YearHeaderComponent, selector: "year-header" }, { kind: "component", type: i8.MonthTableComponent, selector: "month-table", exportAs: ["monthTable"] }, { kind: "component", type: i9.MonthHeaderComponent, selector: "month-header" }, { kind: "component", type: i10.DecadeHeaderComponent, selector: "decade-header" }, { kind: "component", type: i11.DecadeTableComponent, selector: "decade-table", exportAs: ["decadeTable"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
121
121
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: InnerPopupComponent, decorators: [{
122
122
  type: Component,
123
123
  args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'inner-popup', exportAs: 'innerPopup', template: "<ng-container *ngIf=\"showDateRangeInput\">\n <div class=\"{{ prefixCls }}-picker-inner-popup-range-input\">\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[0])\" placeholder=\"\u5F00\u59CB\u65E5\u671F\" />\n <span class=\"split\"></span>\n <input thyInput thySize=\"sm\" [value]=\"getReadableValue(selectedValue[1])\" placeholder=\"\u7ED3\u675F\u65E5\u671F\" />\n </div>\n</ng-container>\n<ng-container [ngSwitch]=\"panelMode\">\n <ng-container *ngSwitchCase=\"'decade'\">\n <div class=\"{{ prefixCls }}-decade\">\n <decade-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'decade')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'decade')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></decade-header>\n <div class=\"{{ prefixCls }}-body\">\n <decade-table [value]=\"value\" [activeDate]=\"activeDate\" (valueChange)=\"onChooseDecade($event)\"></decade-table>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"{{ prefixCls }}-year\">\n <year-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'year')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'year')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></year-header>\n <div class=\"{{ prefixCls }}-body\">\n <year-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseYear($event)\"\n [selectedValue]=\"selectedValue\"\n ></year-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"{{ prefixCls }}-month\">\n <month-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'month')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'month')\"\n [showNextBtn]=\"false\"\n [showPreBtn]=\"false\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></month-header>\n <div class=\"{{ prefixCls }}-body\">\n <month-table\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n [disabledDate]=\"disabledDate\"\n (valueChange)=\"onChooseMonth($event)\"\n [selectedValue]=\"selectedValue\"\n ></month-table>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <date-header\n [(value)]=\"activeDate\"\n [showSuperPreBtn]=\"enableSuperPrevNext('prev', 'date')\"\n [showSuperNextBtn]=\"enableSuperPrevNext('next', 'date')\"\n [showPreBtn]=\"enablePrevNext('prev', 'date')\"\n [showNextBtn]=\"enablePrevNext('next', 'date')\"\n (panelModeChange)=\"panelModeChange.emit($event)\"\n (valueChange)=\"headerChange.emit($event)\"\n ></date-header>\n <div class=\"{{ prefixCls }}-body\">\n <date-table\n [showWeek]=\"showWeek\"\n [value]=\"value\"\n [activeDate]=\"activeDate\"\n (valueChange)=\"onSelectDate($event)\"\n showWeekNumber=\"false\"\n [disabledDate]=\"disabledDate\"\n [cellRender]=\"dateRender\"\n [selectedValue]=\"selectedValue\"\n [hoverValue]=\"hoverValue\"\n (dayHover)=\"dayHover.emit($event)\"\n ></date-table>\n </div>\n </ng-container>\n</ng-container>\n" }]
@@ -123,7 +123,7 @@ export class ThyPickerComponent {
123
123
  }
124
124
  }
125
125
  ThyPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyPickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DateHelperService }], target: i0.ɵɵFactoryTarget.Component });
126
- ThyPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyPickerComponent, selector: "thy-picker", inputs: { isRange: "isRange", open: "open", disabled: "disabled", placeholder: "placeholder", readonly: "readonly", allowClear: "allowClear", autoFocus: "autoFocus", className: "className", format: "format", size: "size", value: "value", suffixIcon: "suffixIcon", placement: "placement", flexible: "flexible", flexibleDateGranularity: "flexibleDateGranularity" }, outputs: { valueChange: "valueChange", openChange: "openChange" }, viewQueries: [{ propertyName: "origin", first: true, predicate: ["origin"], descendants: true, static: true }, { propertyName: "cdkConnectedOverlay", first: true, predicate: CdkConnectedOverlay, descendants: true, static: true }, { propertyName: "pickerInput", first: true, predicate: ["pickerInput"], descendants: true, static: true }], exportAs: ["thyPicker"], ngImport: i0, template: "<span\n cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n class=\"{{ prefixCls }}-picker {{ size ? prefixCls + '-picker-' + size : '' }} {{ className }}\"\n (click)=\"onClickInputBox()\"\n>\n <ng-container>\n <input\n #pickerInput\n thyInput\n class=\"form-control-{{ size }} form-control {{ prefixCls }}-picker-input\"\n [thySize]=\"size\"\n [class.thy-input-disabled]=\"disabled\"\n [class.thy-input-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n readonly\n value=\"{{ getReadableValue() }}\"\n placeholder=\"{{ getPlaceholder() }}\"\n />\n <ng-container *ngTemplateOutlet=\"tplRightRest\"></ng-container>\n </ng-container>\n</span>\n\n<!-- Right operator icons -->\n<ng-template #tplRightRest>\n <span class=\"{{ prefixCls }}-picker-clear\">\n <thy-icon\n thyIconName=\"close-circle-bold-fill\"\n *ngIf=\"!disabled && !isEmptyValue(value) && allowClear && !readonly\"\n (click)=\"onClickClear($event)\"\n ngClass=\"remove-link remove-link-{{ size }}\"\n ></thy-icon>\n </span>\n <span class=\"{{ prefixCls }}-picker-icon\">\n <thy-icon [thyIconName]=\"suffixIcon\" ngClass=\"remove-link-{{ size }}\"></thy-icon>\n </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"realOpenState\"\n [cdkConnectedOverlayHasBackdrop]=\"!isOpenHandledByUser()\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n (positionChange)=\"onPositionChange($event)\"\n (backdropClick)=\"onClickBackdrop()\"\n (detach)=\"onOverlayDetach()\"\n>\n <div style=\"position: relative;\">\n <!-- Compatible for overlay that not support offset dynamically and immediately -->\n <ng-content></ng-content>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i3.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
126
+ ThyPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyPickerComponent, selector: "thy-picker", inputs: { isRange: "isRange", open: "open", disabled: "disabled", placeholder: "placeholder", readonly: "readonly", allowClear: "allowClear", autoFocus: "autoFocus", className: "className", format: "format", size: "size", value: "value", suffixIcon: "suffixIcon", placement: "placement", flexible: "flexible", flexibleDateGranularity: "flexibleDateGranularity" }, outputs: { valueChange: "valueChange", openChange: "openChange" }, viewQueries: [{ propertyName: "origin", first: true, predicate: ["origin"], descendants: true, static: true }, { propertyName: "cdkConnectedOverlay", first: true, predicate: CdkConnectedOverlay, descendants: true, static: true }, { propertyName: "pickerInput", first: true, predicate: ["pickerInput"], descendants: true, static: true }], exportAs: ["thyPicker"], ngImport: i0, template: "<span\n cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n class=\"{{ prefixCls }}-picker {{ size ? prefixCls + '-picker-' + size : '' }} {{ className }}\"\n (click)=\"onClickInputBox()\"\n>\n <ng-container>\n <input\n #pickerInput\n thyInput\n class=\"form-control-{{ size }} form-control {{ prefixCls }}-picker-input\"\n [thySize]=\"size\"\n [class.thy-input-disabled]=\"disabled\"\n [class.thy-input-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n readonly\n value=\"{{ getReadableValue() }}\"\n placeholder=\"{{ getPlaceholder() }}\"\n />\n <ng-container *ngTemplateOutlet=\"tplRightRest\"></ng-container>\n </ng-container>\n</span>\n\n<!-- Right operator icons -->\n<ng-template #tplRightRest>\n <span class=\"{{ prefixCls }}-picker-clear\">\n <thy-icon\n thyIconName=\"close-circle-bold-fill\"\n *ngIf=\"!disabled && !isEmptyValue(value) && allowClear && !readonly\"\n (click)=\"onClickClear($event)\"\n ngClass=\"remove-link remove-link-{{ size }}\"\n ></thy-icon>\n </span>\n <span class=\"{{ prefixCls }}-picker-icon\">\n <thy-icon [thyIconName]=\"suffixIcon\" ngClass=\"remove-link-{{ size }}\"></thy-icon>\n </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"realOpenState\"\n [cdkConnectedOverlayHasBackdrop]=\"!isOpenHandledByUser()\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n (positionChange)=\"onPositionChange($event)\"\n (backdropClick)=\"onClickBackdrop()\"\n (detach)=\"onOverlayDetach()\"\n>\n <div style=\"position: relative;\">\n <!-- Compatible for overlay that not support offset dynamically and immediately -->\n <ng-content></ng-content>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i3.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
127
127
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyPickerComponent, decorators: [{
128
128
  type: Component,
129
129
  args: [{ selector: 'thy-picker', exportAs: 'thyPicker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span\n cdkOverlayOrigin\n #origin=\"cdkOverlayOrigin\"\n class=\"{{ prefixCls }}-picker {{ size ? prefixCls + '-picker-' + size : '' }} {{ className }}\"\n (click)=\"onClickInputBox()\"\n>\n <ng-container>\n <input\n #pickerInput\n thyInput\n class=\"form-control-{{ size }} form-control {{ prefixCls }}-picker-input\"\n [thySize]=\"size\"\n [class.thy-input-disabled]=\"disabled\"\n [class.thy-input-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n readonly\n value=\"{{ getReadableValue() }}\"\n placeholder=\"{{ getPlaceholder() }}\"\n />\n <ng-container *ngTemplateOutlet=\"tplRightRest\"></ng-container>\n </ng-container>\n</span>\n\n<!-- Right operator icons -->\n<ng-template #tplRightRest>\n <span class=\"{{ prefixCls }}-picker-clear\">\n <thy-icon\n thyIconName=\"close-circle-bold-fill\"\n *ngIf=\"!disabled && !isEmptyValue(value) && allowClear && !readonly\"\n (click)=\"onClickClear($event)\"\n ngClass=\"remove-link remove-link-{{ size }}\"\n ></thy-icon>\n </span>\n <span class=\"{{ prefixCls }}-picker-icon\">\n <thy-icon [thyIconName]=\"suffixIcon\" ngClass=\"remove-link-{{ size }}\"></thy-icon>\n </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"realOpenState\"\n [cdkConnectedOverlayHasBackdrop]=\"!isOpenHandledByUser()\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n (positionChange)=\"onPositionChange($event)\"\n (backdropClick)=\"onClickBackdrop()\"\n (detach)=\"onOverlayDetach()\"\n>\n <div style=\"position: relative;\">\n <!-- Compatible for overlay that not support offset dynamically and immediately -->\n <ng-content></ng-content>\n </div>\n</ng-template>\n" }]
@@ -105,7 +105,7 @@ export class ThyInputSearchComponent extends _MixinBase {
105
105
  }
106
106
  }
107
107
  ThyInputSearchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputSearchComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
108
- ThyInputSearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputSearchComponent, selector: "thy-input-search", inputs: { name: "name", placeholder: "placeholder", thyTheme: "thyTheme", thySearchFocus: "thySearchFocus", thyIconPosition: "thyIconPosition", thySize: "thySize" }, outputs: { clear: "clear", thyClear: "thyClear" }, host: { properties: { "class.thy-input-search-ellipse": "thyTheme === \"ellipse\"", "class.thy-input-search-transparent": "thyTheme === \"transparent\"", "class.form-control-active": "focused" }, classAttribute: "thy-input form-control thy-input-search" }, providers: [CUSTOM_INPUT_SEARCH_CONTROL_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0, template: "<thy-icon class=\"input-prepend\" *ngIf=\"iconPosition === 'before'\" thyIconName=\"search\"></thy-icon>\n<input\n class=\"input-search-control\"\n thyInput\n [name]=\"name\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutofocus]=\"autoFocus\"\n [(ngModel)]=\"searchText\"\n (ngModelChange)=\"searchModelChange()\"\n (focus)=\"focused = true\"\n (blur)=\"focused = false && onTouchedCallback()\"\n [thySize]=\"thySize\"\n/>\n<ng-container *ngIf=\"iconPosition === 'after'\">\n <div class=\"input-append input-append-divider\">\n <a class=\"close\" *ngIf=\"searchText; else onlyIcon\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n </a>\n <ng-template #onlyIcon>\n <thy-icon class=\"text-placeholder\" thyIconName=\"search\"></thy-icon>\n </ng-template>\n </div>\n</ng-container>\n\n<a *ngIf=\"searchText && iconPosition === 'before'\" class=\"close input-append\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n</a>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
108
+ ThyInputSearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputSearchComponent, selector: "thy-input-search", inputs: { name: "name", placeholder: "placeholder", thyTheme: "thyTheme", thySearchFocus: "thySearchFocus", thyIconPosition: "thyIconPosition", thySize: "thySize" }, outputs: { clear: "clear", thyClear: "thyClear" }, host: { properties: { "class.thy-input-search-ellipse": "thyTheme === \"ellipse\"", "class.thy-input-search-transparent": "thyTheme === \"transparent\"", "class.form-control-active": "focused" }, classAttribute: "thy-input form-control thy-input-search" }, providers: [CUSTOM_INPUT_SEARCH_CONTROL_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0, template: "<thy-icon class=\"input-prepend\" *ngIf=\"iconPosition === 'before'\" thyIconName=\"search\"></thy-icon>\n<input\n class=\"input-search-control\"\n thyInput\n [name]=\"name\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutofocus]=\"autoFocus\"\n [(ngModel)]=\"searchText\"\n (ngModelChange)=\"searchModelChange()\"\n (focus)=\"focused = true\"\n (blur)=\"focused = false && onTouchedCallback()\"\n [thySize]=\"thySize\"\n/>\n<ng-container *ngIf=\"iconPosition === 'after'\">\n <div class=\"input-append input-append-divider\">\n <a class=\"close\" *ngIf=\"searchText; else onlyIcon\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n </a>\n <ng-template #onlyIcon>\n <thy-icon class=\"text-placeholder\" thyIconName=\"search\"></thy-icon>\n </ng-template>\n </div>\n</ng-container>\n\n<a *ngIf=\"searchText && iconPosition === 'before'\" class=\"close input-append\" href=\"javascript:;\" (click)=\"clearSearchText($event)\">\n <thy-icon thyIconName=\"close\"></thy-icon>\n</a>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
109
109
  __decorate([
110
110
  InputBoolean(),
111
111
  __metadata("design:type", Boolean),
@@ -56,12 +56,6 @@ export class ThyInputComponent {
56
56
  set thyType(value) {
57
57
  this.type = value;
58
58
  }
59
- /**
60
- * 输入字段是否应该启用自动完成功能
61
- */
62
- set thyAutocomplete(value) {
63
- this.autocomplete = value;
64
- }
65
59
  ngOnInit() {
66
60
  this.ngZone.onStable.pipe(take(1)).subscribe(() => {
67
61
  if (this.isPassword(this.type)) {
@@ -102,14 +96,14 @@ export class ThyInputComponent {
102
96
  }
103
97
  }
104
98
  ThyInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
105
- ThyInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputComponent, selector: "thy-input", inputs: { placeholder: "placeholder", thySize: "thySize", thyAutofocus: "thyAutofocus", thyType: "thyType", type: "type", thyLabelText: "thyLabelText", readonly: "readonly", thyAutocomplete: "thyAutocomplete" }, outputs: { focus: "focus", blur: "blur" }, host: { properties: { "class.form-control-active": "focused", "class.disabled": "disabled" }, classAttribute: "thy-input form-control" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], queries: [{ propertyName: "appendTemplate", first: true, predicate: ["append"], descendants: true }, { propertyName: "prependTemplate", first: true, predicate: ["prepend"], descendants: true }], viewQueries: [{ propertyName: "eyeTemplate", first: true, predicate: ["eye"], descendants: true, static: true }], ngImport: i0, template: "<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n #input\n thyInput\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutofocus\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutocomplete]=\"autocomplete\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onModelChange()\"\n (focus)=\"onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n </a>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }], encapsulation: i0.ViewEncapsulation.None });
99
+ ThyInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputComponent, selector: "thy-input", inputs: { placeholder: "placeholder", thySize: "thySize", thyAutofocus: "thyAutofocus", thyType: "thyType", type: "type", thyLabelText: "thyLabelText", readonly: "readonly" }, outputs: { focus: "focus", blur: "blur" }, host: { properties: { "class.form-control-active": "focused", "class.disabled": "disabled" }, classAttribute: "thy-input form-control" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], queries: [{ propertyName: "appendTemplate", first: true, predicate: ["append"], descendants: true }, { propertyName: "prependTemplate", first: true, predicate: ["prepend"], descendants: true }], viewQueries: [{ propertyName: "eyeTemplate", first: true, predicate: ["eye"], descendants: true, static: true }], ngImport: i0, template: "<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n #input\n thyInput\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutofocus\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onModelChange()\"\n (focus)=\"onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n </a>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }], encapsulation: i0.ViewEncapsulation.None });
106
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputComponent, decorators: [{
107
101
  type: Component,
108
102
  args: [{ selector: 'thy-input', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], encapsulation: ViewEncapsulation.None, host: {
109
103
  class: 'thy-input form-control',
110
104
  '[class.form-control-active]': 'focused',
111
105
  '[class.disabled]': 'disabled'
112
- }, template: "<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n #input\n thyInput\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutofocus\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [thyAutocomplete]=\"autocomplete\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onModelChange()\"\n (focus)=\"onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n </a>\n</ng-template>\n" }]
106
+ }, template: "<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n #input\n thyInput\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutofocus\"\n [type]=\"type\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onModelChange()\"\n (focus)=\"onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n </a>\n</ng-template>\n" }]
113
107
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { placeholder: [{
114
108
  type: Input
115
109
  }], thySize: [{
@@ -124,8 +118,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
124
118
  type: Input
125
119
  }], readonly: [{
126
120
  type: Input
127
- }], thyAutocomplete: [{
128
- type: Input
129
121
  }], focus: [{
130
122
  type: Output
131
123
  }], blur: [{
@@ -140,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
140
132
  type: ViewChild,
141
133
  args: ['eye', { static: true }]
142
134
  }] } });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../src/input/input.component.ts","../../../../src/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    EventEmitter,\n    forwardRef,\n    Input,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    NgZone,\n    OnInit\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { take } from 'rxjs/operators';\nimport { ThyInputSize } from './input.directive';\n\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ThyInputComponent),\n    multi: true\n};\n\nconst noop = () => {};\n\nconst password = 'password';\n\n/**\n * 内部集成输入框组件，建议 thy-input-group 和 thyInput 组合使用\n * @name thy-input\n * @order 50\n */\n@Component({\n    selector: 'thy-input',\n    templateUrl: './input.component.html',\n    providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'thy-input form-control',\n        '[class.form-control-active]': 'focused',\n        '[class.disabled]': 'disabled'\n    }\n})\nexport class ThyInputComponent implements ControlValueAccessor, OnInit {\n    /**\n     * Placeholder\n     */\n    @Input() placeholder = '';\n\n    /**\n     * 输入框大小\n     * @type 'xs' | 'sm' | 'md' | 'default' | 'lg'\n     * @default default\n     */\n    @Input() thySize: ThyInputSize;\n\n    /**\n     * 是否自动聚焦\n     * @default false\n     */\n    @Input() thyAutofocus = false;\n\n    /**\n     * 输入框类型\n     * @type 'number' | 'input'\n     */\n    @Input()\n    set thyType(value: string) {\n        this.type = value;\n    }\n\n    /**\n     * @deprecated please use thyType\n     */\n    @Input() type: string;\n\n    /**\n     * 输入 Label 文本\n     */\n    @Input() thyLabelText: string;\n\n    /**\n     * 是否只读\n     */\n    @Input() readonly = false;\n\n    /**\n     *  输入字段是否应该启用自动完成功能\n     */\n    @Input()\n    set thyAutocomplete(value: boolean) {\n        this.autocomplete = value;\n    }\n\n    /**\n     * focus 聚焦事件\n     */\n    @Output() focus: EventEmitter<Event> = new EventEmitter<Event>();\n\n    /**\n     * blur 失焦事件\n     */\n    @Output() blur: EventEmitter<Event> = new EventEmitter<Event>();\n\n    /**\n     * 后置模板\n     */\n    @ContentChild('append') appendTemplate: TemplateRef<any>;\n\n    /**\n     * 前置模板\n     */\n    @ContentChild('prepend') prependTemplate: TemplateRef<any>;\n\n    @ViewChild('eye', { static: true }) eyeTemplate: TemplateRef<any>;\n\n    public _type = 'text';\n\n    public value: string;\n\n    public autocomplete: boolean;\n\n    public showLabel: boolean;\n\n    public focused = false;\n\n    public disabled = false;\n\n    private onTouchedCallback: () => void = noop;\n\n    private onChangeCallback: (_: any) => void = noop;\n\n    constructor(private ngZone: NgZone) {}\n\n    ngOnInit() {\n        this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n            if (this.isPassword(this.type)) {\n                this.appendTemplate = this.eyeTemplate;\n            }\n        });\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeCallback = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    onModelChange() {\n        this.onChangeCallback(this.value);\n    }\n\n    onInputFocus(event: Event) {\n        this.focused = true;\n        this.showLabel = true;\n        this.focus.emit(event);\n    }\n\n    onInputBlur(event: Event) {\n        this.focused = false;\n        this.showLabel = false;\n        this.blur.emit(event);\n    }\n\n    isPassword(value: string) {\n        return value === password;\n    }\n\n    togglePasswordType() {\n        this.type = this.isPassword(this.type) ? 'text' : 'password';\n    }\n}\n","<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n  <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n  #input\n  thyInput\n  [thySize]=\"thySize\"\n  [thyAutofocus]=\"thyAutofocus\"\n  [type]=\"type\"\n  [placeholder]=\"placeholder\"\n  [disabled]=\"disabled\"\n  [thyAutocomplete]=\"autocomplete\"\n  [(ngModel)]=\"value\"\n  (ngModelChange)=\"onModelChange()\"\n  (focus)=\"onInputFocus($event)\"\n  (blur)=\"onInputBlur($event)\"\n  [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n  <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n  <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n    <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n    <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n  </a>\n</ng-template>\n"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../src/input/input.component.ts","../../../../src/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    EventEmitter,\n    forwardRef,\n    Input,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    NgZone,\n    OnInit\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { take } from 'rxjs/operators';\nimport { ThyInputSize } from './input.directive';\n\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ThyInputComponent),\n    multi: true\n};\n\nconst noop = () => {};\n\nconst password = 'password';\n\n/**\n * 内部集成输入框组件，建议 thy-input-group 和 thyInput 组合使用\n * @name thy-input\n * @order 50\n */\n@Component({\n    selector: 'thy-input',\n    templateUrl: './input.component.html',\n    providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'thy-input form-control',\n        '[class.form-control-active]': 'focused',\n        '[class.disabled]': 'disabled'\n    }\n})\nexport class ThyInputComponent implements ControlValueAccessor, OnInit {\n    /**\n     * Placeholder\n     */\n    @Input() placeholder = '';\n\n    /**\n     * 输入框大小\n     * @type 'xs' | 'sm' | 'md' | 'default' | 'lg'\n     * @default default\n     */\n    @Input() thySize: ThyInputSize;\n\n    /**\n     * 是否自动聚焦\n     * @default false\n     */\n    @Input() thyAutofocus = false;\n\n    /**\n     * 输入框类型\n     * @type 'number' | 'input'\n     */\n    @Input()\n    set thyType(value: string) {\n        this.type = value;\n    }\n\n    /**\n     * @deprecated please use thyType\n     */\n    @Input() type: string;\n\n    /**\n     * 输入 Label 文本\n     */\n    @Input() thyLabelText: string;\n\n    /**\n     * 是否只读\n     */\n    @Input() readonly = false;\n\n    /**\n     * focus 聚焦事件\n     */\n    @Output() focus: EventEmitter<Event> = new EventEmitter<Event>();\n\n    /**\n     * blur 失焦事件\n     */\n    @Output() blur: EventEmitter<Event> = new EventEmitter<Event>();\n\n    /**\n     * 后置模板\n     */\n    @ContentChild('append') appendTemplate: TemplateRef<any>;\n\n    /**\n     * 前置模板\n     */\n    @ContentChild('prepend') prependTemplate: TemplateRef<any>;\n\n    @ViewChild('eye', { static: true }) eyeTemplate: TemplateRef<any>;\n\n    public _type = 'text';\n\n    public value: string;\n\n    public showLabel: boolean;\n\n    public focused = false;\n\n    public disabled = false;\n\n    private onTouchedCallback: () => void = noop;\n\n    private onChangeCallback: (_: any) => void = noop;\n\n    constructor(private ngZone: NgZone) {}\n\n    ngOnInit() {\n        this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n            if (this.isPassword(this.type)) {\n                this.appendTemplate = this.eyeTemplate;\n            }\n        });\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeCallback = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedCallback = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    onModelChange() {\n        this.onChangeCallback(this.value);\n    }\n\n    onInputFocus(event: Event) {\n        this.focused = true;\n        this.showLabel = true;\n        this.focus.emit(event);\n    }\n\n    onInputBlur(event: Event) {\n        this.focused = false;\n        this.showLabel = false;\n        this.blur.emit(event);\n    }\n\n    isPassword(value: string) {\n        return value === password;\n    }\n\n    togglePasswordType() {\n        this.type = this.isPassword(this.type) ? 'text' : 'password';\n    }\n}\n","<div #prepend class=\"input-prepend\" *ngIf=\"prependTemplate\">\n  <ng-template *ngTemplateOutlet=\"prependTemplate\"></ng-template>\n</div>\n<input\n  #input\n  thyInput\n  [thySize]=\"thySize\"\n  [thyAutofocus]=\"thyAutofocus\"\n  [type]=\"type\"\n  [placeholder]=\"placeholder\"\n  [disabled]=\"disabled\"\n  [(ngModel)]=\"value\"\n  (ngModelChange)=\"onModelChange()\"\n  (focus)=\"onInputFocus($event)\"\n  (blur)=\"onInputBlur($event)\"\n  [readonly]=\"readonly\"\n/>\n<span class=\"input-label input-label-{{ thySize }}\" [class.active]=\"showLabel\">{{ thyLabelText }}</span>\n<div #append class=\"input-append\" *ngIf=\"appendTemplate\">\n  <ng-template *ngTemplateOutlet=\"appendTemplate\"></ng-template>\n</div>\n\n<ng-template #eye>\n  <a href=\"javascript:;\" class=\"link-secondary input-password-icon\" (click)=\"togglePasswordType()\">\n    <thy-icon *ngIf=\"isPassword(type)\" thyIconName=\"eye\"></thy-icon>\n    <thy-icon *ngIf=\"!isPassword(type)\" thyIconName=\"eye-invisible\"></thy-icon>\n  </a>\n</ng-template>\n"]}
@@ -1,6 +1,5 @@
1
1
  import { Directive, ElementRef, HostBinding, Input, Optional, Renderer2, Self } from '@angular/core';
2
2
  import { NgControl } from '@angular/forms';
3
- import { coerceBooleanProperty } from 'ngx-tethys/util';
4
3
  import { useHostRenderer } from '@tethys/cdk/dom';
5
4
  import * as i0 from "@angular/core";
6
5
  import * as i1 from "@angular/forms";
@@ -37,16 +36,6 @@ export class ThyInputDirective {
37
36
  this.hostRenderer.updateClass([]);
38
37
  }
39
38
  }
40
- /**
41
- * 输入字段是否应该启用自动完成功能
42
- * @default false
43
- */
44
- set thyAutocomplete(value) {
45
- this.autocomplete = coerceBooleanProperty(value);
46
- if (this.initialized) {
47
- this.setAutocomplete();
48
- }
49
- }
50
39
  get ngControl() {
51
40
  return this.control;
52
41
  }
@@ -55,14 +44,10 @@ export class ThyInputDirective {
55
44
  }
56
45
  ngOnInit() {
57
46
  this.initialized = true;
58
- this.setAutocomplete();
59
- }
60
- setAutocomplete() {
61
- this.render.setAttribute(this.elementRef.nativeElement, 'autocomplete', this.autocomplete ? 'on' : 'off');
62
47
  }
63
48
  }
64
49
  ThyInputDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive });
65
- ThyInputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: { thySize: "thySize", thyAutocomplete: "thyAutocomplete" }, host: { properties: { "class.form-control": "this.isFormControl" } }, exportAs: ["thyInput"], ngImport: i0 });
50
+ ThyInputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: { thySize: "thySize" }, host: { properties: { "class.form-control": "this.isFormControl" } }, exportAs: ["thyInput"], ngImport: i0 });
66
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyInputDirective, decorators: [{
67
52
  type: Directive,
68
53
  args: [{
@@ -78,7 +63,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
78
63
  args: ['class.form-control']
79
64
  }], thySize: [{
80
65
  type: Input
81
- }], thyAutocomplete: [{
82
- type: Input
83
66
  }] } });
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2lucHV0L2lucHV0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLFFBQVEsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdHLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQUlsRCxNQUFNLGlCQUFpQixHQUFHO0lBQ3RCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3ZCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3ZCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3ZCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0NBQzFCLENBQUM7QUFFRjs7OztHQUlHO0FBS0gsTUFBTSxPQUFPLGlCQUFpQjtJQTJDMUIsWUFBb0IsVUFBc0IsRUFBVSxNQUFpQixFQUE4QixPQUFrQjtRQUFqRyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQVUsV0FBTSxHQUFOLE1BQU0sQ0FBVztRQUE4QixZQUFPLEdBQVAsT0FBTyxDQUFXO1FBMUNsRixrQkFBYSxHQUFHLElBQUksQ0FBQztRQUloRCxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUVwQixpQkFBWSxHQUFHLGVBQWUsRUFBRSxDQUFDO0lBb0MrRSxDQUFDO0lBbEN6SDs7OztPQUlHO0lBQ0gsSUFDSSxPQUFPLENBQUMsSUFBa0I7UUFDMUIsSUFBSSxJQUFJLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDakMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztTQUMxRDthQUFNO1lBQ0gsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDckM7SUFDTCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsSUFDSSxlQUFlLENBQUMsS0FBYztRQUM5QixJQUFJLENBQUMsWUFBWSxHQUFHLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2pELElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNsQixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7U0FDMUI7SUFDTCxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO0lBQ3pDLENBQUM7SUFJRCxRQUFRO1FBQ0osSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7UUFDeEIsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFTyxlQUFlO1FBQ25CLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFLGNBQWMsRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlHLENBQUM7OzhHQXBEUSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUo3QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1REFBdUQ7b0JBQ2pFLFFBQVEsRUFBRSxVQUFVO2lCQUN2Qjs7MEJBNEMyRSxRQUFROzswQkFBSSxJQUFJOzRDQTFDckQsYUFBYTtzQkFBL0MsV0FBVzt1QkFBQyxvQkFBb0I7Z0JBYzdCLE9BQU87c0JBRFYsS0FBSztnQkFjRixlQUFlO3NCQURsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgSW5wdXQsIE9uSW5pdCwgT3B0aW9uYWwsIFJlbmRlcmVyMiwgU2VsZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgY29lcmNlQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnbmd4LXRldGh5cy91dGlsJztcbmltcG9ydCB7IHVzZUhvc3RSZW5kZXJlciB9IGZyb20gJ0B0ZXRoeXMvY2RrL2RvbSc7XG5cbmV4cG9ydCB0eXBlIFRoeUlucHV0U2l6ZSA9ICd4cycgfCAnc20nIHwgJ21kJyB8ICdsZycgfCAnJztcblxuY29uc3QgaW5wdXRHcm91cFNpemVNYXAgPSB7XG4gICAgeHM6IFsnZm9ybS1jb250cm9sLXhzJ10sXG4gICAgc206IFsnZm9ybS1jb250cm9sLXNtJ10sXG4gICAgbWQ6IFsnZm9ybS1jb250cm9sLW1kJ10sXG4gICAgbGc6IFsnZm9ybS1jb250cm9sLWxnJ11cbn07XG5cbi8qKlxuICog6L6T5YWl5qGG5oyH5LukXG4gKiBAbmFtZSB0aHlJbnB1dFxuICogQG9yZGVyIDEwXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnaW5wdXRbdGh5SW5wdXRdLCBzZWxlY3RbdGh5SW5wdXRdLCB0ZXh0YXJlYVt0aHlJbnB1dF0nLFxuICAgIGV4cG9ydEFzOiAndGh5SW5wdXQnXG59KVxuZXhwb3J0IGNsYXNzIFRoeUlucHV0RGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmZvcm0tY29udHJvbCcpIGlzRm9ybUNvbnRyb2wgPSB0cnVlO1xuXG4gICAgcHJpdmF0ZSBhdXRvY29tcGxldGU6IGJvb2xlYW47XG5cbiAgICBwcml2YXRlIGluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgICBwcml2YXRlIGhvc3RSZW5kZXJlciA9IHVzZUhvc3RSZW5kZXJlcigpO1xuXG4gICAgLyoqXG4gICAgICog6L6T5YWl5qGG5aSn5bCPXG4gICAgICogQHR5cGUgJ3hzJyB8ICdzbScgfCAnbWQnIHwgJ2RlZmF1bHQnIHwgJ2xnJ1xuICAgICAqIEBkZWZhdWx0IGRlZmF1bHRcbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIHNldCB0aHlTaXplKHNpemU6IFRoeUlucHV0U2l6ZSkge1xuICAgICAgICBpZiAoc2l6ZSAmJiBpbnB1dEdyb3VwU2l6ZU1hcFtzaXplXSkge1xuICAgICAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIudXBkYXRlQ2xhc3MoaW5wdXRHcm91cFNpemVNYXBbc2l6ZV0pO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIudXBkYXRlQ2xhc3MoW10pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICog6L6T5YWl5a2X5q615piv5ZCm5bqU6K+l5ZCv55So6Ieq5Yqo5a6M5oiQ5Yqf6IO9XG4gICAgICogQGRlZmF1bHQgZmFsc2VcbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIHNldCB0aHlBdXRvY29tcGxldGUodmFsdWU6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5hdXRvY29tcGxldGUgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkodmFsdWUpO1xuICAgICAgICBpZiAodGhpcy5pbml0aWFsaXplZCkge1xuICAgICAgICAgICAgdGhpcy5zZXRBdXRvY29tcGxldGUoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGdldCBuZ0NvbnRyb2woKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRyb2w7XG4gICAgfVxuXG4gICAgZ2V0IG5hdGl2ZUVsZW1lbnQoKTogSFRNTElucHV0RWxlbWVudCB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudDtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIHByaXZhdGUgcmVuZGVyOiBSZW5kZXJlcjIsIEBPcHRpb25hbCgpIEBTZWxmKCkgcHJpdmF0ZSBjb250cm9sOiBOZ0NvbnRyb2wpIHt9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5pbml0aWFsaXplZCA9IHRydWU7XG4gICAgICAgIHRoaXMuc2V0QXV0b2NvbXBsZXRlKCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBzZXRBdXRvY29tcGxldGUoKSB7XG4gICAgICAgIHRoaXMucmVuZGVyLnNldEF0dHJpYnV0ZSh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2F1dG9jb21wbGV0ZScsIHRoaXMuYXV0b2NvbXBsZXRlID8gJ29uJyA6ICdvZmYnKTtcbiAgICB9XG59XG4iXX0=
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2lucHV0L2lucHV0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLFFBQVEsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdHLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQUlsRCxNQUFNLGlCQUFpQixHQUFHO0lBQ3RCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3ZCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3ZCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3ZCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0NBQzFCLENBQUM7QUFFRjs7OztHQUlHO0FBS0gsTUFBTSxPQUFPLGlCQUFpQjtJQTZCMUIsWUFBb0IsVUFBc0IsRUFBVSxNQUFpQixFQUE4QixPQUFrQjtRQUFqRyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQVUsV0FBTSxHQUFOLE1BQU0sQ0FBVztRQUE4QixZQUFPLEdBQVAsT0FBTyxDQUFXO1FBNUJsRixrQkFBYSxHQUFHLElBQUksQ0FBQztRQUVoRCxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUVwQixpQkFBWSxHQUFHLGVBQWUsRUFBRSxDQUFDO0lBd0IrRSxDQUFDO0lBdEJ6SDs7OztPQUlHO0lBQ0gsSUFDSSxPQUFPLENBQUMsSUFBa0I7UUFDMUIsSUFBSSxJQUFJLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDakMsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztTQUMxRDthQUFNO1lBQ0gsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDckM7SUFDTCxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO0lBQ3pDLENBQUM7SUFJRCxRQUFRO1FBQ0osSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDNUIsQ0FBQzs7OEdBakNRLGlCQUFpQjtrR0FBakIsaUJBQWlCOzJGQUFqQixpQkFBaUI7a0JBSjdCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHVEQUF1RDtvQkFDakUsUUFBUSxFQUFFLFVBQVU7aUJBQ3ZCOzswQkE4QjJFLFFBQVE7OzBCQUFJLElBQUk7NENBNUJyRCxhQUFhO3NCQUEvQyxXQUFXO3VCQUFDLG9CQUFvQjtnQkFZN0IsT0FBTztzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgSW5wdXQsIE9uSW5pdCwgT3B0aW9uYWwsIFJlbmRlcmVyMiwgU2VsZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgdXNlSG9zdFJlbmRlcmVyIH0gZnJvbSAnQHRldGh5cy9jZGsvZG9tJztcblxuZXhwb3J0IHR5cGUgVGh5SW5wdXRTaXplID0gJ3hzJyB8ICdzbScgfCAnbWQnIHwgJ2xnJyB8ICcnO1xuXG5jb25zdCBpbnB1dEdyb3VwU2l6ZU1hcCA9IHtcbiAgICB4czogWydmb3JtLWNvbnRyb2wteHMnXSxcbiAgICBzbTogWydmb3JtLWNvbnRyb2wtc20nXSxcbiAgICBtZDogWydmb3JtLWNvbnRyb2wtbWQnXSxcbiAgICBsZzogWydmb3JtLWNvbnRyb2wtbGcnXVxufTtcblxuLyoqXG4gKiDovpPlhaXmoYbmjIfku6RcbiAqIEBuYW1lIHRoeUlucHV0XG4gKiBAb3JkZXIgMTBcbiAqL1xuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdpbnB1dFt0aHlJbnB1dF0sIHNlbGVjdFt0aHlJbnB1dF0sIHRleHRhcmVhW3RoeUlucHV0XScsXG4gICAgZXhwb3J0QXM6ICd0aHlJbnB1dCdcbn0pXG5leHBvcnQgY2xhc3MgVGh5SW5wdXREaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBIb3N0QmluZGluZygnY2xhc3MuZm9ybS1jb250cm9sJykgaXNGb3JtQ29udHJvbCA9IHRydWU7XG5cbiAgICBwcml2YXRlIGluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgICBwcml2YXRlIGhvc3RSZW5kZXJlciA9IHVzZUhvc3RSZW5kZXJlcigpO1xuXG4gICAgLyoqXG4gICAgICog6L6T5YWl5qGG5aSn5bCPXG4gICAgICogQHR5cGUgJ3hzJyB8ICdzbScgfCAnbWQnIHwgJ2RlZmF1bHQnIHwgJ2xnJ1xuICAgICAqIEBkZWZhdWx0IGRlZmF1bHRcbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIHNldCB0aHlTaXplKHNpemU6IFRoeUlucHV0U2l6ZSkge1xuICAgICAgICBpZiAoc2l6ZSAmJiBpbnB1dEdyb3VwU2l6ZU1hcFtzaXplXSkge1xuICAgICAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIudXBkYXRlQ2xhc3MoaW5wdXRHcm91cFNpemVNYXBbc2l6ZV0pO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIudXBkYXRlQ2xhc3MoW10pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgZ2V0IG5nQ29udHJvbCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udHJvbDtcbiAgICB9XG5cbiAgICBnZXQgbmF0aXZlRWxlbWVudCgpOiBIVE1MSW5wdXRFbGVtZW50IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXI6IFJlbmRlcmVyMiwgQE9wdGlvbmFsKCkgQFNlbGYoKSBwcml2YXRlIGNvbnRyb2w6IE5nQ29udHJvbCkge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmluaXRpYWxpemVkID0gdHJ1ZTtcbiAgICB9XG59XG4iXX0=
@@ -249,7 +249,7 @@ ThyInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0"
249
249
  useExisting: forwardRef(() => ThyInputNumberComponent),
250
250
  multi: true
251
251
  }
252
- ], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"input-number-handler-wrap\" [class.input-number-disabled]=\"thyDisabled\">\n <span\n unselectable=\"unselectable\"\n class=\"input-number-handler input-number-handler-up\"\n (mousedown)=\"up($event)\"\n (mouseup)=\"stop()\"\n (mouseleave)=\"stop()\"\n [class.disabled]=\"disabledUp\"\n >\n <thy-icon thyIconName=\"angle-up\"></thy-icon>\n </span>\n <span\n unselectable=\"unselectable\"\n class=\"input-number-handler input-number-handler-down\"\n (mousedown)=\"down($event)\"\n (mouseup)=\"stop()\"\n (mouseleave)=\"stop()\"\n [class.disabled]=\"disabledDown\"\n >\n <thy-icon thyIconName=\"angle-down\"></thy-icon>\n </span>\n</div>\n<input\n thyInput\n #input\n autocomplete=\"off\"\n class=\"input-number-input form-control\"\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutoFocus\"\n [disabled]=\"thyDisabled\"\n [attr.min]=\"thyMin\"\n [attr.max]=\"thyMax\"\n [placeholder]=\"thyPlaceholder\"\n [attr.step]=\"thyStep\"\n (keydown)=\"onKeyDown($event)\"\n (keyup)=\"stop()\"\n [(ngModel)]=\"displayValue\"\n (ngModelChange)=\"onModelChange($event)\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n/>\n", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i3.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i4.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize", "thyAutocomplete"], exportAs: ["thyInput"] }, { kind: "directive", type: i5.ThyMinDirective, selector: "[min][formControlName],[min][formControl],[min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i5.ThyMaxDirective, selector: "[max][formControlName],[max][formControl],[max][ngModel]", inputs: ["max"] }] });
252
+ ], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"input-number-handler-wrap\" [class.input-number-disabled]=\"thyDisabled\">\n <span\n unselectable=\"unselectable\"\n class=\"input-number-handler input-number-handler-up\"\n (mousedown)=\"up($event)\"\n (mouseup)=\"stop()\"\n (mouseleave)=\"stop()\"\n [class.disabled]=\"disabledUp\"\n >\n <thy-icon thyIconName=\"angle-up\"></thy-icon>\n </span>\n <span\n unselectable=\"unselectable\"\n class=\"input-number-handler input-number-handler-down\"\n (mousedown)=\"down($event)\"\n (mouseup)=\"stop()\"\n (mouseleave)=\"stop()\"\n [class.disabled]=\"disabledDown\"\n >\n <thy-icon thyIconName=\"angle-down\"></thy-icon>\n </span>\n</div>\n<input\n thyInput\n #input\n autocomplete=\"off\"\n class=\"input-number-input form-control\"\n [thySize]=\"thySize\"\n [thyAutofocus]=\"thyAutoFocus\"\n [disabled]=\"thyDisabled\"\n [attr.min]=\"thyMin\"\n [attr.max]=\"thyMax\"\n [placeholder]=\"thyPlaceholder\"\n [attr.step]=\"thyStep\"\n (keydown)=\"onKeyDown($event)\"\n (keyup)=\"stop()\"\n [(ngModel)]=\"displayValue\"\n (ngModelChange)=\"onModelChange($event)\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n/>\n", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "component", type: i3.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i4.ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }, { kind: "directive", type: i5.ThyMinDirective, selector: "[min][formControlName],[min][formControl],[min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i5.ThyMaxDirective, selector: "[max][formControlName],[max][formControl],[max][ngModel]", inputs: ["max"] }] });
253
253
  __decorate([
254
254
  InputBoolean(),
255
255
  __metadata("design:type", Boolean)
@@ -0,0 +1,26 @@
1
+ import { coerceCssPixelValue } from '@angular/cdk/coercion';
2
+ import { Directive, ElementRef, HostBinding } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * @internal
6
+ */
7
+ export class ThyAbstractMessageContainerComponent {
8
+ constructor(elementRef, defaultConfig) {
9
+ this.elementRef = elementRef;
10
+ this.offset = coerceCssPixelValue(defaultConfig.offset);
11
+ }
12
+ toOverlayTop() {
13
+ const globalOverlayWrapper = this.elementRef.nativeElement.closest('.cdk-global-overlay-wrapper');
14
+ const overlayContainer = globalOverlayWrapper.parentElement;
15
+ overlayContainer.appendChild(globalOverlayWrapper);
16
+ }
17
+ }
18
+ ThyAbstractMessageContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyAbstractMessageContainerComponent, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
19
+ ThyAbstractMessageContainerComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ThyAbstractMessageContainerComponent, host: { properties: { "style.top": "this.offset" } }, ngImport: i0 });
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThyAbstractMessageContainerComponent, decorators: [{
21
+ type: Directive
22
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined }]; }, propDecorators: { offset: [{
23
+ type: HostBinding,
24
+ args: ['style.top']
25
+ }] } });
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtbWVzc2FnZS1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL21lc3NhZ2UvYWJzdHJhY3QvYWJzdHJhY3QtbWVzc2FnZS1jb250YWluZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVELE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHbkU7O0dBRUc7QUFFSCxNQUFNLE9BQU8sb0NBQW9DO0lBRzdDLFlBQW9CLFVBQXNCLEVBQUUsYUFBcUM7UUFBN0QsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QyxJQUFJLENBQUMsTUFBTSxHQUFHLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsWUFBWTtRQUNSLE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLDZCQUE2QixDQUFDLENBQUM7UUFDbEcsTUFBTSxnQkFBZ0IsR0FBRyxvQkFBb0IsQ0FBQyxhQUFhLENBQUM7UUFDNUQsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDdkQsQ0FBQzs7aUlBWFEsb0NBQW9DO3FIQUFwQyxvQ0FBb0M7MkZBQXBDLG9DQUFvQztrQkFEaEQsU0FBUztzSEFFb0IsTUFBTTtzQkFBL0IsV0FBVzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29lcmNlQ3NzUGl4ZWxWYWx1ZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RCaW5kaW5nIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlHbG9iYWxNZXNzYWdlQ29uZmlnIH0gZnJvbSAnLi4vbWVzc2FnZS5jb25maWcnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBjbGFzcyBUaHlBYnN0cmFjdE1lc3NhZ2VDb250YWluZXJDb21wb25lbnQge1xuICAgIEBIb3N0QmluZGluZygnc3R5bGUudG9wJykgb2Zmc2V0OiBzdHJpbmc7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIGRlZmF1bHRDb25maWc6IFRoeUdsb2JhbE1lc3NhZ2VDb25maWcpIHtcbiAgICAgICAgdGhpcy5vZmZzZXQgPSBjb2VyY2VDc3NQaXhlbFZhbHVlKGRlZmF1bHRDb25maWcub2Zmc2V0KTtcbiAgICB9XG5cbiAgICB0b092ZXJsYXlUb3AoKSB7XG4gICAgICAgIGNvbnN0IGdsb2JhbE92ZXJsYXlXcmFwcGVyID0gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY2xvc2VzdCgnLmNkay1nbG9iYWwtb3ZlcmxheS13cmFwcGVyJyk7XG4gICAgICAgIGNvbnN0IG92ZXJsYXlDb250YWluZXIgPSBnbG9iYWxPdmVybGF5V3JhcHBlci5wYXJlbnRFbGVtZW50O1xuICAgICAgICBvdmVybGF5Q29udGFpbmVyLmFwcGVuZENoaWxkKGdsb2JhbE92ZXJsYXlXcmFwcGVyKTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,34 @@
1
+ import { BehaviorSubject } from 'rxjs';
2
+ /**
3
+ * @internal
4
+ */
5
+ export class ThyAbstractMessageQueue {
6
+ constructor(defaultConfig) {
7
+ this.queues$ = new BehaviorSubject([]);
8
+ this.defaultConfig = defaultConfig;
9
+ }
10
+ get queues() {
11
+ return this.queues$.getValue();
12
+ }
13
+ add(messageRef) {
14
+ const queues = this.queues$.getValue();
15
+ if (this.queues.length >= this.defaultConfig.maxStack) {
16
+ const closedRef = queues.shift();
17
+ closedRef.close();
18
+ }
19
+ this.queues$.next([...queues, messageRef]);
20
+ }
21
+ remove(id) {
22
+ if (!id) {
23
+ this.queues.forEach(item => item.close());
24
+ this.queues$.next([]);
25
+ }
26
+ else {
27
+ const removeItem = this.queues.find(item => item.id === id);
28
+ removeItem?.close();
29
+ const afterRemovedQueues = this.queues.filter(item => item.id !== id);
30
+ this.queues$.next(afterRemovedQueues);
31
+ }
32
+ }
33
+ }
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtbWVzc2FnZS1xdWV1ZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL21lc3NhZ2UvYWJzdHJhY3QvYWJzdHJhY3QtbWVzc2FnZS1xdWV1ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFJdkM7O0dBRUc7QUFDSCxNQUFNLE9BQU8sdUJBQXVCO0lBU2hDLFlBQVksYUFBcUM7UUFSakQsWUFBTyxHQUFHLElBQUksZUFBZSxDQUFnQixFQUFFLENBQUMsQ0FBQztRQVM3QyxJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQztJQUN2QyxDQUFDO0lBTkQsSUFBSSxNQUFNO1FBQ04sT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFNRCxHQUFHLENBQUMsVUFBdUI7UUFDdkIsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN2QyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFO1lBQ25ELE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNqQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDckI7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsTUFBTSxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELE1BQU0sQ0FBQyxFQUFVO1FBQ2IsSUFBSSxDQUFDLEVBQUUsRUFBRTtZQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7WUFDMUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDekI7YUFBTTtZQUNILE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUM1RCxVQUFVLEVBQUUsS0FBSyxFQUFFLENBQUM7WUFDcEIsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7WUFDdEUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsQ0FBQztTQUN6QztJQUNMLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVGh5R2xvYmFsTWVzc2FnZUNvbmZpZyB9IGZyb20gJy4uL21lc3NhZ2UuY29uZmlnJztcbmltcG9ydCB7IFRoeUFic3RyYWN0TWVzc2FnZVJlZiB9IGZyb20gJy4vYWJzdHJhY3QtbWVzc2FnZS1yZWYnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgVGh5QWJzdHJhY3RNZXNzYWdlUXVldWU8VFJlZmVyZW5jZXMgZXh0ZW5kcyBUaHlBYnN0cmFjdE1lc3NhZ2VSZWYgPSBUaHlBYnN0cmFjdE1lc3NhZ2VSZWY+IHtcbiAgICBxdWV1ZXMkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxUUmVmZXJlbmNlc1tdPihbXSk7XG5cbiAgICBwcm90ZWN0ZWQgZGVmYXVsdENvbmZpZzogVGh5R2xvYmFsTWVzc2FnZUNvbmZpZztcblxuICAgIGdldCBxdWV1ZXMoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnF1ZXVlcyQuZ2V0VmFsdWUoKTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcihkZWZhdWx0Q29uZmlnOiBUaHlHbG9iYWxNZXNzYWdlQ29uZmlnKSB7XG4gICAgICAgIHRoaXMuZGVmYXVsdENvbmZpZyA9IGRlZmF1bHRDb25maWc7XG4gICAgfVxuXG4gICAgYWRkKG1lc3NhZ2VSZWY6IFRSZWZlcmVuY2VzKSB7XG4gICAgICAgIGNvbnN0IHF1ZXVlcyA9IHRoaXMucXVldWVzJC5nZXRWYWx1ZSgpO1xuICAgICAgICBpZiAodGhpcy5xdWV1ZXMubGVuZ3RoID49IHRoaXMuZGVmYXVsdENvbmZpZy5tYXhTdGFjaykge1xuICAgICAgICAgICAgY29uc3QgY2xvc2VkUmVmID0gcXVldWVzLnNoaWZ0KCk7XG4gICAgICAgICAgICBjbG9zZWRSZWYuY2xvc2UoKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnF1ZXVlcyQubmV4dChbLi4ucXVldWVzLCBtZXNzYWdlUmVmXSk7XG4gICAgfVxuXG4gICAgcmVtb3ZlKGlkOiBzdHJpbmcpIHtcbiAgICAgICAgaWYgKCFpZCkge1xuICAgICAgICAgICAgdGhpcy5xdWV1ZXMuZm9yRWFjaChpdGVtID0+IGl0ZW0uY2xvc2UoKSk7XG4gICAgICAgICAgICB0aGlzLnF1ZXVlcyQubmV4dChbXSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb25zdCByZW1vdmVJdGVtID0gdGhpcy5xdWV1ZXMuZmluZChpdGVtID0+IGl0ZW0uaWQgPT09IGlkKTtcbiAgICAgICAgICAgIHJlbW92ZUl0ZW0/LmNsb3NlKCk7XG4gICAgICAgICAgICBjb25zdCBhZnRlclJlbW92ZWRRdWV1ZXMgPSB0aGlzLnF1ZXVlcy5maWx0ZXIoaXRlbSA9PiBpdGVtLmlkICE9PSBpZCk7XG4gICAgICAgICAgICB0aGlzLnF1ZXVlcyQubmV4dChhZnRlclJlbW92ZWRRdWV1ZXMpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -0,0 +1,22 @@
1
+ import { Subject } from 'rxjs';
2
+ export class ThyAbstractMessageRef {
3
+ constructor(config, overlayRef, queueService) {
4
+ this._afterClosed = new Subject();
5
+ this.id = config.id;
6
+ this.config = config;
7
+ this.overlayRef = overlayRef;
8
+ this.queueService = queueService;
9
+ }
10
+ close() {
11
+ this.queueService.queues$.next(this.queueService.queues.filter(item => item.id !== this.id));
12
+ this._afterClosed.next();
13
+ this._afterClosed.complete();
14
+ }
15
+ afterClosed() {
16
+ return this._afterClosed.asObservable();
17
+ }
18
+ getOverlayRef() {
19
+ return this.overlayRef;
20
+ }
21
+ }
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtbWVzc2FnZS1yZWYuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbWVzc2FnZS9hYnN0cmFjdC9hYnN0cmFjdC1tZXNzYWdlLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBSS9CLE1BQU0sT0FBTyxxQkFBcUI7SUFXOUIsWUFBWSxNQUFlLEVBQUUsVUFBc0IsRUFBRSxZQUFxQztRQUZsRixpQkFBWSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFHdkMsSUFBSSxDQUFDLEVBQUUsR0FBRyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO1FBQzdCLElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxLQUFLO1FBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDN0YsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN6QixJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxXQUFXO1FBQ1AsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzVDLENBQUM7SUFFRCxhQUFhO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQzNCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBUaHlNZXNzYWdlQmFzZUNvbmZpZyB9IGZyb20gJy4uL21lc3NhZ2UuY29uZmlnJztcbmltcG9ydCB7IFRoeUFic3RyYWN0TWVzc2FnZVF1ZXVlIH0gZnJvbSAnLi9hYnN0cmFjdC1tZXNzYWdlLXF1ZXVlLnNlcnZpY2UnO1xuXG5leHBvcnQgY2xhc3MgVGh5QWJzdHJhY3RNZXNzYWdlUmVmPFRDb25maWcgZXh0ZW5kcyBUaHlNZXNzYWdlQmFzZUNvbmZpZyA9IFRoeU1lc3NhZ2VCYXNlQ29uZmlnPiB7XG4gICAgaWQ6IHN0cmluZztcblxuICAgIGNvbmZpZzogVENvbmZpZztcblxuICAgIHByaXZhdGUgb3ZlcmxheVJlZjogT3ZlcmxheVJlZjtcblxuICAgIHByaXZhdGUgcXVldWVTZXJ2aWNlOiBUaHlBYnN0cmFjdE1lc3NhZ2VRdWV1ZTtcblxuICAgIHByaXZhdGUgX2FmdGVyQ2xvc2VkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAgIGNvbnN0cnVjdG9yKGNvbmZpZzogVENvbmZpZywgb3ZlcmxheVJlZjogT3ZlcmxheVJlZiwgcXVldWVTZXJ2aWNlOiBUaHlBYnN0cmFjdE1lc3NhZ2VRdWV1ZSkge1xuICAgICAgICB0aGlzLmlkID0gY29uZmlnLmlkO1xuICAgICAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcbiAgICAgICAgdGhpcy5vdmVybGF5UmVmID0gb3ZlcmxheVJlZjtcbiAgICAgICAgdGhpcy5xdWV1ZVNlcnZpY2UgPSBxdWV1ZVNlcnZpY2U7XG4gICAgfVxuXG4gICAgY2xvc2UoKSB7XG4gICAgICAgIHRoaXMucXVldWVTZXJ2aWNlLnF1ZXVlcyQubmV4dCh0aGlzLnF1ZXVlU2VydmljZS5xdWV1ZXMuZmlsdGVyKGl0ZW0gPT4gaXRlbS5pZCAhPT0gdGhpcy5pZCkpO1xuICAgICAgICB0aGlzLl9hZnRlckNsb3NlZC5uZXh0KCk7XG4gICAgICAgIHRoaXMuX2FmdGVyQ2xvc2VkLmNvbXBsZXRlKCk7XG4gICAgfVxuXG4gICAgYWZ0ZXJDbG9zZWQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9hZnRlckNsb3NlZC5hc09ic2VydmFibGUoKTtcbiAgICB9XG5cbiAgICBnZXRPdmVybGF5UmVmKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5vdmVybGF5UmVmO1xuICAgIH1cbn1cbiJdfQ==