@ng-nest/ui 13.1.2 → 13.1.5

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 (217) hide show
  1. package/core/config/config.d.ts +9 -0
  2. package/date-picker/picker-date.component.d.ts +1 -1
  3. package/dialog/dialog-portal.component.d.ts +33 -5
  4. package/dialog/dialog-portal.directives.d.ts +17 -0
  5. package/dialog/dialog-ref.d.ts +11 -1
  6. package/dialog/dialog.component.d.ts +3 -5
  7. package/dialog/dialog.module.d.ts +1 -1
  8. package/dialog/dialog.property.d.ts +37 -4
  9. package/dialog/dialog.service.d.ts +1 -0
  10. package/empty/empty.component.d.ts +1 -1
  11. package/esm2020/core/config/config.mjs +1 -1
  12. package/esm2020/date-picker/picker-date.component.mjs +2 -2
  13. package/esm2020/dialog/dialog-portal.component.mjs +49 -12
  14. package/esm2020/dialog/dialog-portal.directives.mjs +47 -1
  15. package/esm2020/dialog/dialog-ref.mjs +83 -2
  16. package/esm2020/dialog/dialog.component.mjs +27 -28
  17. package/esm2020/dialog/dialog.module.mjs +10 -2
  18. package/esm2020/dialog/dialog.property.mjs +10 -3
  19. package/esm2020/dialog/dialog.service.mjs +56 -8
  20. package/esm2020/empty/empty.component.mjs +2 -2
  21. package/esm2020/i18n/i18n.property.mjs +1 -1
  22. package/esm2020/i18n/languages/ar_EG.mjs +7 -1
  23. package/esm2020/i18n/languages/bg_BG.mjs +7 -1
  24. package/esm2020/i18n/languages/ca_ES.mjs +7 -1
  25. package/esm2020/i18n/languages/cs_CZ.mjs +7 -1
  26. package/esm2020/i18n/languages/da_DK.mjs +7 -1
  27. package/esm2020/i18n/languages/de_DE.mjs +7 -1
  28. package/esm2020/i18n/languages/el_GR.mjs +7 -1
  29. package/esm2020/i18n/languages/en_GB.mjs +7 -1
  30. package/esm2020/i18n/languages/en_US.mjs +7 -1
  31. package/esm2020/i18n/languages/es_ES.mjs +7 -1
  32. package/esm2020/i18n/languages/et_EE.mjs +7 -1
  33. package/esm2020/i18n/languages/fa_IR.mjs +7 -1
  34. package/esm2020/i18n/languages/fi_FI.mjs +7 -1
  35. package/esm2020/i18n/languages/fr_BE.mjs +7 -1
  36. package/esm2020/i18n/languages/fr_FR.mjs +7 -1
  37. package/esm2020/i18n/languages/he_IL.mjs +7 -1
  38. package/esm2020/i18n/languages/hi_IN.mjs +7 -1
  39. package/esm2020/i18n/languages/hr_HR.mjs +7 -1
  40. package/esm2020/i18n/languages/hu_HU.mjs +7 -1
  41. package/esm2020/i18n/languages/hy_AM.mjs +7 -1
  42. package/esm2020/i18n/languages/id_ID.mjs +7 -1
  43. package/esm2020/i18n/languages/is_IS.mjs +7 -1
  44. package/esm2020/i18n/languages/it_IT.mjs +7 -1
  45. package/esm2020/i18n/languages/ja_JP.mjs +7 -1
  46. package/esm2020/i18n/languages/ka_GE.mjs +7 -1
  47. package/esm2020/i18n/languages/kn_IN.mjs +7 -1
  48. package/esm2020/i18n/languages/ko_KR.mjs +7 -1
  49. package/esm2020/i18n/languages/ku_IQ.mjs +7 -1
  50. package/esm2020/i18n/languages/lv_LV.mjs +7 -1
  51. package/esm2020/i18n/languages/mn_MN.mjs +7 -1
  52. package/esm2020/i18n/languages/ms_MY.mjs +7 -1
  53. package/esm2020/i18n/languages/nb_NO.mjs +7 -1
  54. package/esm2020/i18n/languages/ne_NP.mjs +7 -1
  55. package/esm2020/i18n/languages/nl_BE.mjs +7 -1
  56. package/esm2020/i18n/languages/nl_NL.mjs +7 -1
  57. package/esm2020/i18n/languages/pl_PL.mjs +7 -1
  58. package/esm2020/i18n/languages/pt_BR.mjs +7 -1
  59. package/esm2020/i18n/languages/pt_PT.mjs +7 -1
  60. package/esm2020/i18n/languages/ro_RO.mjs +7 -1
  61. package/esm2020/i18n/languages/ru_RU.mjs +7 -1
  62. package/esm2020/i18n/languages/sk_SK.mjs +7 -1
  63. package/esm2020/i18n/languages/sl_SI.mjs +7 -1
  64. package/esm2020/i18n/languages/sr_RS.mjs +7 -1
  65. package/esm2020/i18n/languages/sv_SE.mjs +7 -1
  66. package/esm2020/i18n/languages/ta_IN.mjs +7 -1
  67. package/esm2020/i18n/languages/th_TH.mjs +7 -1
  68. package/esm2020/i18n/languages/tr_TR.mjs +7 -1
  69. package/esm2020/i18n/languages/uk_UA.mjs +7 -1
  70. package/esm2020/i18n/languages/vi_VN.mjs +7 -1
  71. package/esm2020/i18n/languages/zh_CN.mjs +7 -1
  72. package/esm2020/i18n/languages/zh_TW.mjs +7 -1
  73. package/esm2020/list/list-option.component.mjs +21 -8
  74. package/esm2020/list/list.component.mjs +55 -13
  75. package/esm2020/list/list.module.mjs +5 -1
  76. package/esm2020/list/list.property.mjs +33 -5
  77. package/esm2020/page-header/page-header.component.mjs +2 -2
  78. package/esm2020/pagination/pagination.component.mjs +2 -2
  79. package/esm2020/rate/rate.component.mjs +21 -4
  80. package/esm2020/rate/rate.property.mjs +9 -3
  81. package/esm2020/resizable/resizable.directive.mjs +81 -37
  82. package/esm2020/resizable/resizable.property.mjs +1 -1
  83. package/esm2020/select/select-portal.component.mjs +26 -9
  84. package/esm2020/select/select.component.mjs +15 -3
  85. package/esm2020/select/select.module.mjs +5 -4
  86. package/esm2020/select/select.property.mjs +12 -2
  87. package/esm2020/text-retract/text-retract.component.mjs +2 -2
  88. package/esm2020/upload/upload.component.mjs +13 -9
  89. package/esm2020/upload/upload.property.mjs +30 -2
  90. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  91. package/fesm2015/ng-nest-ui-date-picker.mjs +1 -1
  92. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  93. package/fesm2015/ng-nest-ui-dialog.mjs +285 -55
  94. package/fesm2015/ng-nest-ui-dialog.mjs.map +1 -1
  95. package/fesm2015/ng-nest-ui-empty.mjs +1 -1
  96. package/fesm2015/ng-nest-ui-empty.mjs.map +1 -1
  97. package/fesm2015/ng-nest-ui-i18n.mjs +306 -0
  98. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  99. package/fesm2015/ng-nest-ui-list.mjs +107 -22
  100. package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
  101. package/fesm2015/ng-nest-ui-page-header.mjs +1 -1
  102. package/fesm2015/ng-nest-ui-page-header.mjs.map +1 -1
  103. package/fesm2015/ng-nest-ui-pagination.mjs +1 -1
  104. package/fesm2015/ng-nest-ui-pagination.mjs.map +1 -1
  105. package/fesm2015/ng-nest-ui-rate.mjs +27 -4
  106. package/fesm2015/ng-nest-ui-rate.mjs.map +1 -1
  107. package/fesm2015/ng-nest-ui-resizable.mjs +80 -36
  108. package/fesm2015/ng-nest-ui-resizable.mjs.map +1 -1
  109. package/fesm2015/ng-nest-ui-select.mjs +56 -16
  110. package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
  111. package/fesm2015/ng-nest-ui-text-retract.mjs +1 -1
  112. package/fesm2015/ng-nest-ui-text-retract.mjs.map +1 -1
  113. package/fesm2015/ng-nest-ui-upload.mjs +41 -9
  114. package/fesm2015/ng-nest-ui-upload.mjs.map +1 -1
  115. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  116. package/fesm2020/ng-nest-ui-date-picker.mjs +1 -1
  117. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  118. package/fesm2020/ng-nest-ui-dialog.mjs +277 -54
  119. package/fesm2020/ng-nest-ui-dialog.mjs.map +1 -1
  120. package/fesm2020/ng-nest-ui-empty.mjs +1 -1
  121. package/fesm2020/ng-nest-ui-empty.mjs.map +1 -1
  122. package/fesm2020/ng-nest-ui-i18n.mjs +306 -0
  123. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  124. package/fesm2020/ng-nest-ui-list.mjs +107 -22
  125. package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
  126. package/fesm2020/ng-nest-ui-page-header.mjs +1 -1
  127. package/fesm2020/ng-nest-ui-page-header.mjs.map +1 -1
  128. package/fesm2020/ng-nest-ui-pagination.mjs +1 -1
  129. package/fesm2020/ng-nest-ui-pagination.mjs.map +1 -1
  130. package/fesm2020/ng-nest-ui-rate.mjs +27 -4
  131. package/fesm2020/ng-nest-ui-rate.mjs.map +1 -1
  132. package/fesm2020/ng-nest-ui-resizable.mjs +80 -36
  133. package/fesm2020/ng-nest-ui-resizable.mjs.map +1 -1
  134. package/fesm2020/ng-nest-ui-select.mjs +56 -16
  135. package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
  136. package/fesm2020/ng-nest-ui-text-retract.mjs +1 -1
  137. package/fesm2020/ng-nest-ui-text-retract.mjs.map +1 -1
  138. package/fesm2020/ng-nest-ui-upload.mjs +41 -9
  139. package/fesm2020/ng-nest-ui-upload.mjs.map +1 -1
  140. package/i18n/i18n.property.d.ts +8 -0
  141. package/i18n/languages/ar_EG.d.ts +6 -0
  142. package/i18n/languages/bg_BG.d.ts +6 -0
  143. package/i18n/languages/ca_ES.d.ts +6 -0
  144. package/i18n/languages/cs_CZ.d.ts +6 -0
  145. package/i18n/languages/da_DK.d.ts +6 -0
  146. package/i18n/languages/de_DE.d.ts +6 -0
  147. package/i18n/languages/el_GR.d.ts +6 -0
  148. package/i18n/languages/en_GB.d.ts +6 -0
  149. package/i18n/languages/en_US.d.ts +6 -0
  150. package/i18n/languages/es_ES.d.ts +6 -0
  151. package/i18n/languages/et_EE.d.ts +6 -0
  152. package/i18n/languages/fa_IR.d.ts +6 -0
  153. package/i18n/languages/fi_FI.d.ts +6 -0
  154. package/i18n/languages/fr_BE.d.ts +6 -0
  155. package/i18n/languages/fr_FR.d.ts +6 -0
  156. package/i18n/languages/he_IL.d.ts +6 -0
  157. package/i18n/languages/hi_IN.d.ts +6 -0
  158. package/i18n/languages/hr_HR.d.ts +6 -0
  159. package/i18n/languages/hu_HU.d.ts +6 -0
  160. package/i18n/languages/hy_AM.d.ts +6 -0
  161. package/i18n/languages/id_ID.d.ts +6 -0
  162. package/i18n/languages/is_IS.d.ts +6 -0
  163. package/i18n/languages/it_IT.d.ts +6 -0
  164. package/i18n/languages/ja_JP.d.ts +6 -0
  165. package/i18n/languages/ka_GE.d.ts +6 -0
  166. package/i18n/languages/kn_IN.d.ts +6 -0
  167. package/i18n/languages/ko_KR.d.ts +6 -0
  168. package/i18n/languages/ku_IQ.d.ts +6 -0
  169. package/i18n/languages/lv_LV.d.ts +6 -0
  170. package/i18n/languages/mn_MN.d.ts +6 -0
  171. package/i18n/languages/ms_MY.d.ts +6 -0
  172. package/i18n/languages/nb_NO.d.ts +6 -0
  173. package/i18n/languages/ne_NP.d.ts +6 -0
  174. package/i18n/languages/nl_BE.d.ts +6 -0
  175. package/i18n/languages/nl_NL.d.ts +6 -0
  176. package/i18n/languages/pl_PL.d.ts +6 -0
  177. package/i18n/languages/pt_BR.d.ts +6 -0
  178. package/i18n/languages/pt_PT.d.ts +6 -0
  179. package/i18n/languages/ro_RO.d.ts +6 -0
  180. package/i18n/languages/ru_RU.d.ts +6 -0
  181. package/i18n/languages/sk_SK.d.ts +6 -0
  182. package/i18n/languages/sl_SI.d.ts +6 -0
  183. package/i18n/languages/sr_RS.d.ts +6 -0
  184. package/i18n/languages/sv_SE.d.ts +6 -0
  185. package/i18n/languages/ta_IN.d.ts +6 -0
  186. package/i18n/languages/th_TH.d.ts +6 -0
  187. package/i18n/languages/tr_TR.d.ts +6 -0
  188. package/i18n/languages/uk_UA.d.ts +6 -0
  189. package/i18n/languages/vi_VN.d.ts +6 -0
  190. package/i18n/languages/zh_CN.d.ts +6 -0
  191. package/i18n/languages/zh_TW.d.ts +6 -0
  192. package/list/examples/en_US/default/size/README.md +6 -0
  193. package/list/examples/zh_CN/default/size/README.md +6 -0
  194. package/list/list-option.component.d.ts +8 -2
  195. package/list/list.component.d.ts +7 -1
  196. package/list/list.module.d.ts +3 -2
  197. package/list/list.property.d.ts +29 -4
  198. package/package.json +1 -1
  199. package/page-header/page-header.component.d.ts +1 -1
  200. package/pagination/pagination.component.d.ts +1 -1
  201. package/rate/examples/en_US/default/color/README.md +6 -0
  202. package/rate/examples/zh_CN/default/color/README.md +6 -0
  203. package/rate/rate.component.d.ts +1 -0
  204. package/rate/rate.property.d.ts +13 -1
  205. package/resizable/resizable.directive.d.ts +5 -8
  206. package/resizable/resizable.property.d.ts +5 -0
  207. package/select/select-portal.component.d.ts +10 -1
  208. package/select/select.component.d.ts +1 -0
  209. package/select/select.module.d.ts +2 -1
  210. package/select/select.property.d.ts +11 -1
  211. package/style/core/index.css +3 -0
  212. package/style/core/index.css.map +1 -1
  213. package/style/directives/resizable/mixin.scss +5 -0
  214. package/tag/examples/zh_CN/default/bordered/README.md +1 -1
  215. package/text-retract/text-retract.component.d.ts +1 -1
  216. package/upload/upload.component.d.ts +4 -4
  217. package/upload/upload.property.d.ts +21 -1
@@ -1,13 +1,25 @@
1
1
  import { BasePortalOutlet, CdkPortalOutlet } from '@angular/cdk/portal';
2
- import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, HostListener, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, HostBinding, HostListener, QueryList, ViewChild, ViewEncapsulation } from '@angular/core';
3
3
  import { XMoveBoxAnimation } from '@ng-nest/ui/core';
4
+ import { CdkDrag, CdkDragHandle } from '@angular/cdk/drag-drop';
4
5
  import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/cdk/portal";
6
+ import * as i1 from "@angular/cdk/drag-drop";
7
+ import * as i2 from "@ng-nest/ui/resizable";
8
+ import * as i3 from "@angular/cdk/portal";
6
9
  export class XDialogPortalComponent extends BasePortalOutlet {
7
- constructor() {
10
+ constructor(renderer) {
8
11
  super();
9
- this._has = true;
12
+ this.renderer = renderer;
10
13
  this.animationChanged = new EventEmitter();
14
+ this.offsetLeft = 0;
15
+ this.offsetTop = 0;
16
+ this.minWidth = '0rem';
17
+ this.minHeight = '0rem';
18
+ this.initHeight = 0;
19
+ this.initContentHeight = 0;
20
+ this.defaultMaximize = false;
21
+ this.distance = { x: 0, y: 0 };
22
+ this.dialogBox = {};
11
23
  }
12
24
  done({ toState, totalTime }) {
13
25
  this.animationChanged.next({ action: 'done', state: toState, totalTime });
@@ -15,6 +27,17 @@ export class XDialogPortalComponent extends BasePortalOutlet {
15
27
  start({ toState, totalTime }) {
16
28
  this.animationChanged.next({ action: 'start', state: toState, totalTime });
17
29
  }
30
+ ngOnInit() {
31
+ this.dialogBox['draggable'] = this.defaultMaximize ? this.dialogBox['draggable'] : this.option.draggable;
32
+ this.dialogBox['resizable'] = this.defaultMaximize ? this.dialogBox['resizable'] : this.option.resizable;
33
+ }
34
+ ngAfterViewInit() {
35
+ let list = new QueryList();
36
+ for (let item of this.dialogRef.dragHandleRefs) {
37
+ list.reset([...list.toArray(), new CdkDragHandle(item, this.dragRef)]);
38
+ }
39
+ this.dragRef._handles = list;
40
+ }
18
41
  attachComponentPortal(portal) {
19
42
  if (this.portalOutlet.hasAttached()) {
20
43
  throw Error('dialog portal has attached');
@@ -27,16 +50,24 @@ export class XDialogPortalComponent extends BasePortalOutlet {
27
50
  }
28
51
  return this.portalOutlet.attachTemplatePortal(portal);
29
52
  }
53
+ resizing(event) {
54
+ const contentHeight = Number(this.initContentHeight) + Number(event.clientHeight) - Number(this.initHeight);
55
+ this.renderer.setStyle(this.dialogContent, 'max-height', 'initial');
56
+ this.renderer.setStyle(this.dialogContent, 'flex', 'initial');
57
+ if (['top-start', 'top-end', 'bottom', 'top', 'bottom-start', 'bottom-end'].includes(event.direction)) {
58
+ this.renderer.setStyle(this.dialogContent, 'height', `${contentHeight}px`);
59
+ }
60
+ }
61
+ onDragEnded(event) {
62
+ this.distance = { x: this.distance.x + event.distance.x, y: this.distance.y + event.distance.y };
63
+ }
30
64
  }
31
- /** @nocollapse */ /** @nocollapse */ XDialogPortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogPortalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
32
- /** @nocollapse */ /** @nocollapse */ XDialogPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XDialogPortalComponent, selector: "x-dialog-portal", host: { listeners: { "@x-move-box-animation.done": "done($event)", "@x-move-box-animation.start": "start($event)" }, properties: { "class.x-dialog-portal": "this._has", "@x-move-box-animation": "this.placement" } }, viewQueries: [{ propertyName: "portalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template cdkPortalOutlet></ng-template>\r\n", styles: [".x-dialog-portal{margin:0;padding:0;width:100%;height:100%;overflow:auto;display:block;padding:1rem;box-sizing:border-box;min-height:inherit;max-height:inherit;background-color:var(--x-background);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);border:.0625rem solid transparent;border-radius:var(--x-border-radius)}.x-dialog-portal-title{display:block;margin:0 0 .5rem;font-weight:600;color:var(--x-text-300);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.x-dialog-portal-content{display:block;margin:0 -1rem;padding:0 1rem;max-height:70vh;overflow:auto;color:var(--x-text-300);font-size:calc(var(--x-font-size) - .0625rem);line-height:1.325rem}.x-dialog-portal-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;box-sizing:content-box;margin-bottom:-1rem;min-height:4rem}.x-dialog-portal-actions[align=center]{justify-content:center}.x-dialog-portal-actions[align=start]{justify-content:flex-start}.x-dialog-portal-actions x-button:not(:first-child){margin-left:1rem}\n"], directives: [{ type: i1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [XMoveBoxAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
65
+ /** @nocollapse */ /** @nocollapse */ XDialogPortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogPortalComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
66
+ /** @nocollapse */ /** @nocollapse */ XDialogPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XDialogPortalComponent, selector: "x-dialog-portal", host: { listeners: { "@x-move-box-animation.done": "done($event)", "@x-move-box-animation.start": "start($event)" }, properties: { "@x-move-box-animation": "this.placement" } }, queries: [{ propertyName: "handles", predicate: CdkDragHandle, descendants: true }], viewQueries: [{ propertyName: "portalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true, static: true }, { propertyName: "dragRef", first: true, predicate: CdkDrag, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"x-dialog-portal\"\r\n #dragRef\r\n cdkDrag\r\n [cdkDragDisabled]=\"!option.draggable && !dialogBox['draggable']\"\r\n [cdkDragBoundary]=\"'.cdk-overlay-container'\"\r\n [cdkDragFreeDragPosition]=\"dialogBox['distance']\"\r\n [xResizable]=\"option.resizable && dialogBox['resizable']!\"\r\n (resizing)=\"resizing($event)\"\r\n (cdkDragEnded)=\"onDragEnded($event)\"\r\n [offsetLeft]=\"offsetLeft\"\r\n [offsetTop]=\"offsetTop\"\r\n [style.minWidth]=\"dialogBox['minWidth']\"\r\n [style.minHeight]=\"dialogBox['minHeight']\"\r\n>\r\n <ng-template cdkPortalOutlet></ng-template>\r\n</div>\r\n", styles: [".x-dialog-portal{margin:0;padding:0;width:100%;height:100%;display:block;padding:1rem;box-sizing:border-box;min-height:inherit;max-height:inherit;background-color:var(--x-background);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);border:.0625rem solid transparent;border-radius:var(--x-border-radius)}.x-dialog-portal-title{font-weight:600;color:var(--x-text-300);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:3rem;line-height:3rem;display:block;align-items:center;margin:-1rem -1rem 0;padding:0 1rem}.x-dialog-portal-content{display:block;margin:0 -1rem;padding:0 1rem;max-height:70vh;overflow:auto;color:var(--x-text-300);font-size:calc(var(--x-font-size) - .0625rem);line-height:1.325rem}.x-dialog-portal-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;box-sizing:content-box;margin:0 -1rem -1rem;padding:0 1rem;height:4rem}.x-dialog-portal-actions[align=center]{justify-content:center}.x-dialog-portal-actions[align=start]{justify-content:flex-start}.x-dialog-portal-actions x-button:not(:first-child){margin-left:1rem}.x-dialog-portal-drag-handle{cursor:move}.x-dialog-portal-fullscreen{margin:0!important}.x-dialog-portal-fullscreen .x-dialog-portal{left:0!important;top:0!important}.x-dialog-portal-fullscreen .x-dialog-portal-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important}x-dialog-portal{width:100%;height:100%}\n"], directives: [{ type: i1.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { type: i2.XResizableDirective, selector: "[xResizable]" }, { type: i3.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [XMoveBoxAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
33
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogPortalComponent, decorators: [{
34
68
  type: Component,
35
- args: [{ selector: 'x-dialog-portal', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XMoveBoxAnimation], template: "<ng-template cdkPortalOutlet></ng-template>\r\n", styles: [".x-dialog-portal{margin:0;padding:0;width:100%;height:100%;overflow:auto;display:block;padding:1rem;box-sizing:border-box;min-height:inherit;max-height:inherit;background-color:var(--x-background);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);border:.0625rem solid transparent;border-radius:var(--x-border-radius)}.x-dialog-portal-title{display:block;margin:0 0 .5rem;font-weight:600;color:var(--x-text-300);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.x-dialog-portal-content{display:block;margin:0 -1rem;padding:0 1rem;max-height:70vh;overflow:auto;color:var(--x-text-300);font-size:calc(var(--x-font-size) - .0625rem);line-height:1.325rem}.x-dialog-portal-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;box-sizing:content-box;margin-bottom:-1rem;min-height:4rem}.x-dialog-portal-actions[align=center]{justify-content:center}.x-dialog-portal-actions[align=start]{justify-content:flex-start}.x-dialog-portal-actions x-button:not(:first-child){margin-left:1rem}\n"] }]
36
- }], ctorParameters: function () { return []; }, propDecorators: { _has: [{
37
- type: HostBinding,
38
- args: ['class.x-dialog-portal']
39
- }], placement: [{
69
+ args: [{ selector: 'x-dialog-portal', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XMoveBoxAnimation], template: "<div\r\n class=\"x-dialog-portal\"\r\n #dragRef\r\n cdkDrag\r\n [cdkDragDisabled]=\"!option.draggable && !dialogBox['draggable']\"\r\n [cdkDragBoundary]=\"'.cdk-overlay-container'\"\r\n [cdkDragFreeDragPosition]=\"dialogBox['distance']\"\r\n [xResizable]=\"option.resizable && dialogBox['resizable']!\"\r\n (resizing)=\"resizing($event)\"\r\n (cdkDragEnded)=\"onDragEnded($event)\"\r\n [offsetLeft]=\"offsetLeft\"\r\n [offsetTop]=\"offsetTop\"\r\n [style.minWidth]=\"dialogBox['minWidth']\"\r\n [style.minHeight]=\"dialogBox['minHeight']\"\r\n>\r\n <ng-template cdkPortalOutlet></ng-template>\r\n</div>\r\n", styles: [".x-dialog-portal{margin:0;padding:0;width:100%;height:100%;display:block;padding:1rem;box-sizing:border-box;min-height:inherit;max-height:inherit;background-color:var(--x-background);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);border:.0625rem solid transparent;border-radius:var(--x-border-radius)}.x-dialog-portal-title{font-weight:600;color:var(--x-text-300);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:3rem;line-height:3rem;display:block;align-items:center;margin:-1rem -1rem 0;padding:0 1rem}.x-dialog-portal-content{display:block;margin:0 -1rem;padding:0 1rem;max-height:70vh;overflow:auto;color:var(--x-text-300);font-size:calc(var(--x-font-size) - .0625rem);line-height:1.325rem}.x-dialog-portal-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;box-sizing:content-box;margin:0 -1rem -1rem;padding:0 1rem;height:4rem}.x-dialog-portal-actions[align=center]{justify-content:center}.x-dialog-portal-actions[align=start]{justify-content:flex-start}.x-dialog-portal-actions x-button:not(:first-child){margin-left:1rem}.x-dialog-portal-drag-handle{cursor:move}.x-dialog-portal-fullscreen{margin:0!important}.x-dialog-portal-fullscreen .x-dialog-portal{left:0!important;top:0!important}.x-dialog-portal-fullscreen .x-dialog-portal-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important}x-dialog-portal{width:100%;height:100%}\n"] }]
70
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { placement: [{
40
71
  type: HostBinding,
41
72
  args: ['@x-move-box-animation']
42
73
  }], done: [{
@@ -48,5 +79,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
48
79
  }], portalOutlet: [{
49
80
  type: ViewChild,
50
81
  args: [CdkPortalOutlet, { static: true }]
82
+ }], dragRef: [{
83
+ type: ViewChild,
84
+ args: [CdkDrag, { static: true }]
85
+ }], handles: [{
86
+ type: ContentChildren,
87
+ args: [CdkDragHandle, { descendants: true }]
51
88
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXBvcnRhbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9kaWFsb2cvZGlhbG9nLXBvcnRhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9kaWFsb2cvZGlhbG9nLXBvcnRhbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFtQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3pHLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUdULFlBQVksRUFDWixXQUFXLEVBQ1gsWUFBWSxFQUNaLFNBQVMsRUFDVCxpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztBQVlyRCxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsZ0JBQWdCO0lBYTFEO1FBQ0UsS0FBSyxFQUFFLENBQUM7UUFiNEIsU0FBSSxHQUFHLElBQUksQ0FBQztRQVVsRCxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBeUIsQ0FBQztJQUk3RCxDQUFDO0lBWnVELElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQWtCO1FBQ2pHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxPQUFnQyxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7SUFDckcsQ0FBQztJQUN3RCxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFrQjtRQUNuRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsT0FBZ0MsRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ3RHLENBQUM7SUFTRCxxQkFBcUIsQ0FBSSxNQUEwQjtRQUNqRCxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLEVBQUU7WUFDbkMsTUFBTSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztTQUMzQztRQUNELE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBQ0Qsb0JBQW9CLENBQUksTUFBeUI7UUFDL0MsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxFQUFFO1lBQ25DLE1BQU0sS0FBSyxDQUFDLDRCQUE0QixDQUFDLENBQUM7U0FDM0M7UUFDRCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEQsQ0FBQzs7eUpBNUJVLHNCQUFzQjs2SUFBdEIsc0JBQXNCLDZUQVN0QixlQUFlLHFGQ2pDNUIsaURBQ0EsNnJDRHFCYyxDQUFDLGlCQUFpQixDQUFDOzJGQUVwQixzQkFBc0I7a0JBUmxDLFNBQVM7K0JBQ0UsaUJBQWlCLGlCQUdaLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsQ0FBQyxpQkFBaUIsQ0FBQzswRUFHTyxJQUFJO3NCQUF6QyxXQUFXO3VCQUFDLHVCQUF1QjtnQkFDUyxTQUFTO3NCQUFyRCxXQUFXO3VCQUFDLHVCQUF1QjtnQkFDb0IsSUFBSTtzQkFBM0QsWUFBWTt1QkFBQyw0QkFBNEIsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFHRyxLQUFLO3NCQUE3RCxZQUFZO3VCQUFDLDZCQUE2QixFQUFFLENBQUMsUUFBUSxDQUFDO2dCQUdULFlBQVk7c0JBQXpELFNBQVM7dUJBQUMsZUFBZSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VQb3J0YWxPdXRsZXQsIENka1BvcnRhbE91dGxldCwgQ29tcG9uZW50UG9ydGFsLCBUZW1wbGF0ZVBvcnRhbCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xyXG5pbXBvcnQge1xyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRSZWYsXHJcbiAgRW1iZWRkZWRWaWV3UmVmLFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBIb3N0QmluZGluZyxcclxuICBIb3N0TGlzdGVuZXIsXHJcbiAgVmlld0NoaWxkLFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFhNb3ZlQm94QW5pbWF0aW9uIH0gZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcbmltcG9ydCB7IFhEaWFsb2dBbmltYXRpb25FdmVudCwgWERpYWxvZ0FuaW1hdGlvblN0YXRlIH0gZnJvbSAnLi9kaWFsb2cucHJvcGVydHknO1xyXG5pbXBvcnQgeyBBbmltYXRpb25FdmVudCB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd4LWRpYWxvZy1wb3J0YWwnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kaWFsb2ctcG9ydGFsLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9kaWFsb2ctcG9ydGFsLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBhbmltYXRpb25zOiBbWE1vdmVCb3hBbmltYXRpb25dXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYRGlhbG9nUG9ydGFsQ29tcG9uZW50IGV4dGVuZHMgQmFzZVBvcnRhbE91dGxldCB7XHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy54LWRpYWxvZy1wb3J0YWwnKSBfaGFzID0gdHJ1ZTtcclxuICBASG9zdEJpbmRpbmcoJ0B4LW1vdmUtYm94LWFuaW1hdGlvbicpIHB1YmxpYyBwbGFjZW1lbnQ/OiBYRGlhbG9nQW5pbWF0aW9uU3RhdGU7XHJcbiAgQEhvc3RMaXN0ZW5lcignQHgtbW92ZS1ib3gtYW5pbWF0aW9uLmRvbmUnLCBbJyRldmVudCddKSBkb25lKHsgdG9TdGF0ZSwgdG90YWxUaW1lIH06IEFuaW1hdGlvbkV2ZW50KSB7XHJcbiAgICB0aGlzLmFuaW1hdGlvbkNoYW5nZWQubmV4dCh7IGFjdGlvbjogJ2RvbmUnLCBzdGF0ZTogdG9TdGF0ZSBhcyBYRGlhbG9nQW5pbWF0aW9uU3RhdGUsIHRvdGFsVGltZSB9KTtcclxuICB9XHJcbiAgQEhvc3RMaXN0ZW5lcignQHgtbW92ZS1ib3gtYW5pbWF0aW9uLnN0YXJ0JywgWyckZXZlbnQnXSkgc3RhcnQoeyB0b1N0YXRlLCB0b3RhbFRpbWUgfTogQW5pbWF0aW9uRXZlbnQpIHtcclxuICAgIHRoaXMuYW5pbWF0aW9uQ2hhbmdlZC5uZXh0KHsgYWN0aW9uOiAnc3RhcnQnLCBzdGF0ZTogdG9TdGF0ZSBhcyBYRGlhbG9nQW5pbWF0aW9uU3RhdGUsIHRvdGFsVGltZSB9KTtcclxuICB9XHJcbiAgQFZpZXdDaGlsZChDZGtQb3J0YWxPdXRsZXQsIHsgc3RhdGljOiB0cnVlIH0pIHBvcnRhbE91dGxldCE6IENka1BvcnRhbE91dGxldDtcclxuXHJcbiAgYW5pbWF0aW9uQ2hhbmdlZCA9IG5ldyBFdmVudEVtaXR0ZXI8WERpYWxvZ0FuaW1hdGlvbkV2ZW50PigpO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgfVxyXG5cclxuICBhdHRhY2hDb21wb25lbnRQb3J0YWw8VD4ocG9ydGFsOiBDb21wb25lbnRQb3J0YWw8VD4pOiBDb21wb25lbnRSZWY8VD4ge1xyXG4gICAgaWYgKHRoaXMucG9ydGFsT3V0bGV0Lmhhc0F0dGFjaGVkKCkpIHtcclxuICAgICAgdGhyb3cgRXJyb3IoJ2RpYWxvZyBwb3J0YWwgaGFzIGF0dGFjaGVkJyk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdGhpcy5wb3J0YWxPdXRsZXQuYXR0YWNoQ29tcG9uZW50UG9ydGFsKHBvcnRhbCk7XHJcbiAgfVxyXG4gIGF0dGFjaFRlbXBsYXRlUG9ydGFsPEM+KHBvcnRhbDogVGVtcGxhdGVQb3J0YWw8Qz4pOiBFbWJlZGRlZFZpZXdSZWY8Qz4ge1xyXG4gICAgaWYgKHRoaXMucG9ydGFsT3V0bGV0Lmhhc0F0dGFjaGVkKCkpIHtcclxuICAgICAgdGhyb3cgRXJyb3IoJ2RpYWxvZyBwb3J0YWwgaGFzIGF0dGFjaGVkJyk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdGhpcy5wb3J0YWxPdXRsZXQuYXR0YWNoVGVtcGxhdGVQb3J0YWwocG9ydGFsKTtcclxuICB9XHJcbn1cclxuIiwiPG5nLXRlbXBsYXRlIGNka1BvcnRhbE91dGxldD48L25nLXRlbXBsYXRlPlxyXG4iXX0=
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/dialog/dialog-portal.component.ts","../../../../../lib/ng-nest/ui/dialog/dialog-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BasePortalOutlet, CdkPortalOutlet, ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ComponentRef,\r\n  ContentChildren,\r\n  EmbeddedViewRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  QueryList,\r\n  Renderer2,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { XMoveBoxAnimation } from '@ng-nest/ui/core';\r\nimport { XDialogAnimationEvent, XDialogAnimationState, XDialogRefOption } from './dialog.property';\r\nimport { AnimationEvent } from '@angular/animations';\r\nimport { CdkDrag, CdkDragEnd, CdkDragHandle } from '@angular/cdk/drag-drop';\r\nimport { XDialogRef } from './dialog-ref';\r\nimport { XResizableEvent } from '@ng-nest/ui/resizable';\r\n\r\n@Component({\r\n  selector: 'x-dialog-portal',\r\n  templateUrl: './dialog-portal.component.html',\r\n  styleUrls: ['./dialog-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XMoveBoxAnimation]\r\n})\r\nexport class XDialogPortalComponent extends BasePortalOutlet {\r\n  // @HostBinding('class.x-dialog-portal') _has = true;\r\n  @HostBinding('@x-move-box-animation') public placement?: XDialogAnimationState;\r\n  @HostListener('@x-move-box-animation.done', ['$event']) done({ toState, totalTime }: AnimationEvent) {\r\n    this.animationChanged.next({ action: 'done', state: toState as XDialogAnimationState, totalTime });\r\n  }\r\n  @HostListener('@x-move-box-animation.start', ['$event']) start({ toState, totalTime }: AnimationEvent) {\r\n    this.animationChanged.next({ action: 'start', state: toState as XDialogAnimationState, totalTime });\r\n  }\r\n  @ViewChild(CdkPortalOutlet, { static: true }) portalOutlet!: CdkPortalOutlet;\r\n  @ViewChild(CdkDrag, { static: true }) dragRef!: CdkDrag;\r\n\r\n  @ContentChildren(CdkDragHandle, { descendants: true }) handles!: QueryList<CdkDragHandle>;\r\n\r\n  animationChanged = new EventEmitter<XDialogAnimationEvent>();\r\n\r\n  option!: XDialogRefOption;\r\n  dialogRef!: XDialogRef<any>;\r\n\r\n  offsetLeft = 0;\r\n  offsetTop = 0;\r\n  minWidth = '0rem';\r\n  minHeight = '0rem';\r\n  initHeight = 0;\r\n  initContentHeight = 0;\r\n  dialogContent?: HTMLElement;\r\n  defaultMaximize = false;\r\n  overlayElement?: HTMLElement;\r\n  hostElement?: HTMLElement;\r\n  distance = { x: 0, y: 0 };\r\n\r\n  dialogBox: { [key: string]: any } = {};\r\n\r\n  constructor(private renderer: Renderer2) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.dialogBox['draggable'] = this.defaultMaximize ? this.dialogBox['draggable'] : this.option.draggable;\r\n    this.dialogBox['resizable'] = this.defaultMaximize ? this.dialogBox['resizable'] : this.option.resizable;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    let list = new QueryList<CdkDragHandle>();\r\n    for (let item of this.dialogRef.dragHandleRefs) {\r\n      list.reset([...list.toArray(), new CdkDragHandle(item, this.dragRef)]);\r\n    }\r\n    this.dragRef._handles = list;\r\n  }\r\n\r\n  attachComponentPortal<T>(portal: ComponentPortal<T>): ComponentRef<T> {\r\n    if (this.portalOutlet.hasAttached()) {\r\n      throw Error('dialog portal has attached');\r\n    }\r\n    return this.portalOutlet.attachComponentPortal(portal);\r\n  }\r\n  attachTemplatePortal<C>(portal: TemplatePortal<C>): EmbeddedViewRef<C> {\r\n    if (this.portalOutlet.hasAttached()) {\r\n      throw Error('dialog portal has attached');\r\n    }\r\n    return this.portalOutlet.attachTemplatePortal(portal);\r\n  }\r\n\r\n  resizing(event: XResizableEvent) {\r\n    const contentHeight = Number(this.initContentHeight) + Number(event.clientHeight) - Number(this.initHeight);\r\n    this.renderer.setStyle(this.dialogContent, 'max-height', 'initial');\r\n    this.renderer.setStyle(this.dialogContent, 'flex', 'initial');\r\n    if (['top-start', 'top-end', 'bottom', 'top', 'bottom-start', 'bottom-end'].includes(event.direction as string)) {\r\n      this.renderer.setStyle(this.dialogContent, 'height', `${contentHeight}px`);\r\n    }\r\n  }\r\n\r\n  onDragEnded(event: CdkDragEnd) {\r\n    this.distance = { x: this.distance.x + event.distance.x, y: this.distance.y + event.distance.y };\r\n  }\r\n}\r\n","<div\r\n  class=\"x-dialog-portal\"\r\n  #dragRef\r\n  cdkDrag\r\n  [cdkDragDisabled]=\"!option.draggable && !dialogBox['draggable']\"\r\n  [cdkDragBoundary]=\"'.cdk-overlay-container'\"\r\n  [cdkDragFreeDragPosition]=\"dialogBox['distance']\"\r\n  [xResizable]=\"option.resizable && dialogBox['resizable']!\"\r\n  (resizing)=\"resizing($event)\"\r\n  (cdkDragEnded)=\"onDragEnded($event)\"\r\n  [offsetLeft]=\"offsetLeft\"\r\n  [offsetTop]=\"offsetTop\"\r\n  [style.minWidth]=\"dialogBox['minWidth']\"\r\n  [style.minHeight]=\"dialogBox['minHeight']\"\r\n>\r\n  <ng-template cdkPortalOutlet></ng-template>\r\n</div>\r\n"]}
@@ -70,4 +70,50 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
70
70
  type: HostBinding,
71
71
  args: ['class.x-dialog-portal-actions']
72
72
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXBvcnRhbC5kaXJlY3RpdmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvZGlhbG9nL2RpYWxvZy1wb3J0YWwuZGlyZWN0aXZlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFNL0UsTUFBTSxPQUFPLHFCQUFxQjtJQUloQyxZQUErQixTQUEwQjtRQUExQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUFHLENBQUM7SUFIMUIsWUFBWTtRQUM3QyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDM0MsQ0FBQzs7d0pBSFUscUJBQXFCOzRJQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2lCQUM3Qjs7MEJBS2MsUUFBUTs0Q0FIYyxZQUFZO3NCQUE5QyxZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQzs7QUFTbkMsTUFBTSxPQUFPLHFCQUFxQjtJQUhsQztRQUk4QyxTQUFJLEdBQUcsSUFBSSxDQUFDO0tBQ3pEOzt3SkFGWSxxQkFBcUI7NElBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCO2tCQUhqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCOzhCQUU2QyxJQUFJO3NCQUEvQyxXQUFXO3VCQUFDLDZCQUE2Qjs7QUFNNUMsTUFBTSxPQUFPLHVCQUF1QjtJQUhwQztRQUlnRCxTQUFJLEdBQUcsSUFBSSxDQUFDO0tBQzNEOzswSkFGWSx1QkFBdUI7OElBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQ0FBc0M7aUJBQ2pEOzhCQUUrQyxJQUFJO3NCQUFqRCxXQUFXO3VCQUFDLCtCQUErQjs7QUFNOUMsTUFBTSxPQUFPLHVCQUF1QjtJQUhwQztRQUlnRCxTQUFJLEdBQUcsSUFBSSxDQUFDO0tBQzNEOzswSkFGWSx1QkFBdUI7OElBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQ0FBc0M7aUJBQ2pEOzhCQUUrQyxJQUFJO3NCQUFqRCxXQUFXO3VCQUFDLCtCQUErQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdEJpbmRpbmcsIEhvc3RMaXN0ZW5lciwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgWERpYWxvZ1JlZiB9IGZyb20gJy4vZGlhbG9nLXJlZic7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogYFt4LWRpYWxvZy1jbG9zZV1gXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYRGlhbG9nQ2xvc2VEaXJlY3RpdmUge1xyXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSkgb25DbG9zZUNsaWNrKCkge1xyXG4gICAgdGhpcy5kaWFsb2dSZWYgJiYgdGhpcy5kaWFsb2dSZWYuY2xvc2UoKTtcclxuICB9XHJcbiAgY29uc3RydWN0b3IoQE9wdGlvbmFsKCkgcHVibGljIGRpYWxvZ1JlZjogWERpYWxvZ1JlZjxhbnk+KSB7fVxyXG59XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogYFt4LWRpYWxvZy10aXRsZV1gXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYRGlhbG9nVGl0bGVEaXJlY3RpdmUge1xyXG4gIEBIb3N0QmluZGluZygnY2xhc3MueC1kaWFsb2ctcG9ydGFsLXRpdGxlJykgX2hhcyA9IHRydWU7XHJcbn1cclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiBgW3gtZGlhbG9nLWNvbnRlbnRdLCB4LWRpYWxvZy1jb250ZW50YFxyXG59KVxyXG5leHBvcnQgY2xhc3MgWERpYWxvZ0NvbnRlbnREaXJlY3RpdmUge1xyXG4gIEBIb3N0QmluZGluZygnY2xhc3MueC1kaWFsb2ctcG9ydGFsLWNvbnRlbnQnKSBfaGFzID0gdHJ1ZTtcclxufVxyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6IGBbeC1kaWFsb2ctYWN0aW9uc10sIHgtZGlhbG9nLWFjdGlvbnNgXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYRGlhbG9nQWN0aW9uc0RpcmVjdGl2ZSB7XHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy54LWRpYWxvZy1wb3J0YWwtYWN0aW9ucycpIF9oYXMgPSB0cnVlO1xyXG59XHJcbiJdfQ==
73
+ export class XDialogDragHandleDirective {
74
+ constructor(dialogRef, elementRef) {
75
+ this.dialogRef = dialogRef;
76
+ this.elementRef = elementRef;
77
+ }
78
+ get getDraggable() {
79
+ return !this.dialogRef.fullscreen && this.dialogRef.option.draggable;
80
+ }
81
+ ngOnInit() {
82
+ this.dialogRef.dragHandleRefs.push(this.elementRef);
83
+ }
84
+ }
85
+ /** @nocollapse */ /** @nocollapse */ XDialogDragHandleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogDragHandleDirective, deps: [{ token: i1.XDialogRef, optional: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
86
+ /** @nocollapse */ /** @nocollapse */ XDialogDragHandleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: XDialogDragHandleDirective, selector: "[x-dialog-drag-handle], x-dialog-drag-handle", host: { properties: { "class.x-dialog-portal-drag-handle": "this.getDraggable" } }, ngImport: i0 });
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogDragHandleDirective, decorators: [{
88
+ type: Directive,
89
+ args: [{
90
+ selector: `[x-dialog-drag-handle], x-dialog-drag-handle`
91
+ }]
92
+ }], ctorParameters: function () { return [{ type: i1.XDialogRef, decorators: [{
93
+ type: Optional
94
+ }] }, { type: i0.ElementRef }]; }, propDecorators: { getDraggable: [{
95
+ type: HostBinding,
96
+ args: ['class.x-dialog-portal-drag-handle']
97
+ }] } });
98
+ export class XDialogFullscreenDirective {
99
+ constructor(dialogRef) {
100
+ this.dialogRef = dialogRef;
101
+ }
102
+ onFullscreenClick() {
103
+ this.dialogRef && this.dialogRef.onFullscreen();
104
+ }
105
+ }
106
+ /** @nocollapse */ /** @nocollapse */ XDialogFullscreenDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogFullscreenDirective, deps: [{ token: i1.XDialogRef, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
107
+ /** @nocollapse */ /** @nocollapse */ XDialogFullscreenDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: XDialogFullscreenDirective, selector: "[x-dialog-fullscreen], x-dialog-fullscreen", host: { listeners: { "click": "onFullscreenClick($event)" } }, ngImport: i0 });
108
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogFullscreenDirective, decorators: [{
109
+ type: Directive,
110
+ args: [{
111
+ selector: `[x-dialog-fullscreen], x-dialog-fullscreen`
112
+ }]
113
+ }], ctorParameters: function () { return [{ type: i1.XDialogRef, decorators: [{
114
+ type: Optional
115
+ }] }]; }, propDecorators: { onFullscreenClick: [{
116
+ type: HostListener,
117
+ args: ['click', ['$event']]
118
+ }] } });
119
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXBvcnRhbC5kaXJlY3RpdmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvZGlhbG9nL2RpYWxvZy1wb3J0YWwuZGlyZWN0aXZlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFdBQVcsRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFNM0YsTUFBTSxPQUFPLHFCQUFxQjtJQUloQyxZQUErQixTQUEwQjtRQUExQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUFHLENBQUM7SUFIMUIsWUFBWTtRQUM3QyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDM0MsQ0FBQzs7d0pBSFUscUJBQXFCOzRJQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2lCQUM3Qjs7MEJBS2MsUUFBUTs0Q0FIYyxZQUFZO3NCQUE5QyxZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQzs7QUFTbkMsTUFBTSxPQUFPLHFCQUFxQjtJQUhsQztRQUk4QyxTQUFJLEdBQUcsSUFBSSxDQUFDO0tBQ3pEOzt3SkFGWSxxQkFBcUI7NElBQXJCLHFCQUFxQjsyRkFBckIscUJBQXFCO2tCQUhqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCOzhCQUU2QyxJQUFJO3NCQUEvQyxXQUFXO3VCQUFDLDZCQUE2Qjs7QUFNNUMsTUFBTSxPQUFPLHVCQUF1QjtJQUhwQztRQUlnRCxTQUFJLEdBQUcsSUFBSSxDQUFDO0tBQzNEOzswSkFGWSx1QkFBdUI7OElBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQ0FBc0M7aUJBQ2pEOzhCQUUrQyxJQUFJO3NCQUFqRCxXQUFXO3VCQUFDLCtCQUErQjs7QUFNOUMsTUFBTSxPQUFPLHVCQUF1QjtJQUhwQztRQUlnRCxTQUFJLEdBQUcsSUFBSSxDQUFDO0tBQzNEOzswSkFGWSx1QkFBdUI7OElBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQ0FBc0M7aUJBQ2pEOzhCQUUrQyxJQUFJO3NCQUFqRCxXQUFXO3VCQUFDLCtCQUErQjs7QUFNOUMsTUFBTSxPQUFPLDBCQUEwQjtJQUlyQyxZQUErQixTQUEwQixFQUFVLFVBQXNCO1FBQTFELGNBQVMsR0FBVCxTQUFTLENBQWlCO1FBQVUsZUFBVSxHQUFWLFVBQVUsQ0FBWTtJQUFHLENBQUM7SUFIN0YsSUFBc0QsWUFBWTtRQUNoRSxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDO0lBQ3ZFLENBQUM7SUFHRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0RCxDQUFDOzs2SkFSVSwwQkFBMEI7aUpBQTFCLDBCQUEwQjsyRkFBMUIsMEJBQTBCO2tCQUh0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSw4Q0FBOEM7aUJBQ3pEOzswQkFLYyxRQUFRO3FFQUhpQyxZQUFZO3NCQUFqRSxXQUFXO3VCQUFDLG1DQUFtQzs7QUFhbEQsTUFBTSxPQUFPLDBCQUEwQjtJQUlyQyxZQUErQixTQUEwQjtRQUExQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUFHLENBQUM7SUFIMUIsaUJBQWlCO1FBQ2xELElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUNsRCxDQUFDOzs2SkFIVSwwQkFBMEI7aUpBQTFCLDBCQUEwQjsyRkFBMUIsMEJBQTBCO2tCQUh0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSw0Q0FBNEM7aUJBQ3ZEOzswQkFLYyxRQUFROzRDQUhjLGlCQUFpQjtzQkFBbkQsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RCaW5kaW5nLCBIb3N0TGlzdGVuZXIsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFhEaWFsb2dSZWYgfSBmcm9tICcuL2RpYWxvZy1yZWYnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6IGBbeC1kaWFsb2ctY2xvc2VdYFxyXG59KVxyXG5leHBvcnQgY2xhc3MgWERpYWxvZ0Nsb3NlRGlyZWN0aXZlIHtcclxuICBASG9zdExpc3RlbmVyKCdjbGljaycsIFsnJGV2ZW50J10pIG9uQ2xvc2VDbGljaygpIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmICYmIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XHJcbiAgfVxyXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIHB1YmxpYyBkaWFsb2dSZWY6IFhEaWFsb2dSZWY8YW55Pikge31cclxufVxyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6IGBbeC1kaWFsb2ctdGl0bGVdYFxyXG59KVxyXG5leHBvcnQgY2xhc3MgWERpYWxvZ1RpdGxlRGlyZWN0aXZlIHtcclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLngtZGlhbG9nLXBvcnRhbC10aXRsZScpIF9oYXMgPSB0cnVlO1xyXG59XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogYFt4LWRpYWxvZy1jb250ZW50XSwgeC1kaWFsb2ctY29udGVudGBcclxufSlcclxuZXhwb3J0IGNsYXNzIFhEaWFsb2dDb250ZW50RGlyZWN0aXZlIHtcclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLngtZGlhbG9nLXBvcnRhbC1jb250ZW50JykgX2hhcyA9IHRydWU7XHJcbn1cclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiBgW3gtZGlhbG9nLWFjdGlvbnNdLCB4LWRpYWxvZy1hY3Rpb25zYFxyXG59KVxyXG5leHBvcnQgY2xhc3MgWERpYWxvZ0FjdGlvbnNEaXJlY3RpdmUge1xyXG4gIEBIb3N0QmluZGluZygnY2xhc3MueC1kaWFsb2ctcG9ydGFsLWFjdGlvbnMnKSBfaGFzID0gdHJ1ZTtcclxufVxyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6IGBbeC1kaWFsb2ctZHJhZy1oYW5kbGVdLCB4LWRpYWxvZy1kcmFnLWhhbmRsZWBcclxufSlcclxuZXhwb3J0IGNsYXNzIFhEaWFsb2dEcmFnSGFuZGxlRGlyZWN0aXZlIHtcclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLngtZGlhbG9nLXBvcnRhbC1kcmFnLWhhbmRsZScpIGdldCBnZXREcmFnZ2FibGUoKSB7XHJcbiAgICByZXR1cm4gIXRoaXMuZGlhbG9nUmVmLmZ1bGxzY3JlZW4gJiYgdGhpcy5kaWFsb2dSZWYub3B0aW9uLmRyYWdnYWJsZTtcclxuICB9XHJcbiAgY29uc3RydWN0b3IoQE9wdGlvbmFsKCkgcHVibGljIGRpYWxvZ1JlZjogWERpYWxvZ1JlZjxhbnk+LCBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5kaWFsb2dSZWYuZHJhZ0hhbmRsZVJlZnMucHVzaCh0aGlzLmVsZW1lbnRSZWYpO1xyXG4gIH1cclxufVxyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6IGBbeC1kaWFsb2ctZnVsbHNjcmVlbl0sIHgtZGlhbG9nLWZ1bGxzY3JlZW5gXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYRGlhbG9nRnVsbHNjcmVlbkRpcmVjdGl2ZSB7XHJcbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKSBvbkZ1bGxzY3JlZW5DbGljaygpIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmICYmIHRoaXMuZGlhbG9nUmVmLm9uRnVsbHNjcmVlbigpO1xyXG4gIH1cclxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBwdWJsaWMgZGlhbG9nUmVmOiBYRGlhbG9nUmVmPGFueT4pIHt9XHJcbn1cclxuIl19
@@ -1,9 +1,15 @@
1
1
  import { filter, take } from 'rxjs';
2
+ import { PortalResizablePrefix } from '@ng-nest/ui/portal';
2
3
  // TODO: add more function
3
4
  export class XDialogRef {
4
- constructor(overlayRef, containerInstance) {
5
+ constructor(overlayRef, containerInstance, renderer, portalService) {
5
6
  this.overlayRef = overlayRef;
6
7
  this.containerInstance = containerInstance;
8
+ this.renderer = renderer;
9
+ this.portalService = portalService;
10
+ this.fullscreen = false;
11
+ this.dragHandleRefs = [];
12
+ this._isFristFullscreen = true;
7
13
  }
8
14
  close() {
9
15
  this.containerInstance.animationChanged
@@ -13,5 +19,80 @@ export class XDialogRef {
13
19
  });
14
20
  this.containerInstance.placement = 'void';
15
21
  }
22
+ onFullscreen() {
23
+ let { dialogBox, dialogRef, overlayElement, distance, hostElement, defaultMaximize } = this.containerInstance;
24
+ if (!dialogRef.fullscreen) {
25
+ dialogRef.overlayRef.updateSize({
26
+ width: '100%',
27
+ height: '100%',
28
+ minWidth: '100%',
29
+ minHeight: '100%'
30
+ });
31
+ dialogRef.fullscreen = true;
32
+ dialogBox['minWidth'] = '100%';
33
+ dialogBox['minHeight'] = '100%';
34
+ dialogBox['draggable'] = false;
35
+ dialogBox['resizable'] = false;
36
+ if (this.option.resizable) {
37
+ this.renderer.setStyle(overlayElement, 'margin', '0 0 0 0');
38
+ }
39
+ if (this.option.draggable) {
40
+ dialogBox['distance'] = { x: 0, y: 0 };
41
+ }
42
+ this.renderer.addClass(overlayElement, 'x-dialog-portal-fullscreen');
43
+ }
44
+ else {
45
+ dialogBox['minWidth'] = this.option.minWidth;
46
+ dialogBox['minHeight'] = this.option.minHeight;
47
+ if (this._isFristFullscreen && defaultMaximize) {
48
+ this.option.draggable = dialogBox['draggable'];
49
+ this.option.resizable = dialogBox['resizable'];
50
+ }
51
+ else {
52
+ dialogBox['draggable'] = this.option.draggable;
53
+ dialogBox['resizable'] = this.option.resizable;
54
+ }
55
+ dialogRef.overlayRef?.updateSize({
56
+ width: dialogBox['width'],
57
+ height: dialogBox['height'],
58
+ minWidth: dialogBox['minWidth'],
59
+ minHeight: dialogBox['minHeight']
60
+ });
61
+ dialogRef.fullscreen = false;
62
+ if (this.option.draggable) {
63
+ dialogBox['distance'] = { ...distance };
64
+ }
65
+ if (this.option.resizable) {
66
+ if (dialogBox['marginTop']) {
67
+ this.renderer.setStyle(overlayElement, 'margin-top', `${dialogBox['marginTop']}`);
68
+ }
69
+ if (dialogBox['marginLeft']) {
70
+ this.renderer.setStyle(overlayElement, 'margin-left', `${dialogBox['marginLeft']}`);
71
+ }
72
+ if (dialogBox['marginRight']) {
73
+ this.renderer.setStyle(overlayElement, 'margin-right', `${dialogBox['marginRight']}`);
74
+ }
75
+ if (dialogBox['marginBottom']) {
76
+ this.renderer.setStyle(overlayElement, 'margin-bottom', `${dialogBox['marginBottom']}`);
77
+ }
78
+ }
79
+ this.renderer.removeClass(overlayElement, 'x-dialog-portal-fullscreen');
80
+ if (this._isFristFullscreen && defaultMaximize) {
81
+ dialogRef.overlayRef?.updatePositionStrategy(this.portalService.setPlace(this.option.placement, this.option.offset));
82
+ this.renderer.addClass(hostElement, PortalResizablePrefix);
83
+ setTimeout(() => {
84
+ Object.assign(dialogBox, this.portalService.setResizable(overlayElement, this.option.placement));
85
+ this.containerInstance.offsetLeft = overlayElement.offsetLeft;
86
+ this.containerInstance.offsetTop = overlayElement.offsetTop;
87
+ const dialogDraggable = overlayElement?.querySelector('.x-dialog-portal');
88
+ this.containerInstance.initHeight = dialogDraggable.clientHeight;
89
+ this.containerInstance.dialogContent = overlayElement?.querySelector('.x-dialog-portal-content');
90
+ this.containerInstance.initContentHeight = this.containerInstance.dialogContent?.clientHeight;
91
+ this.containerInstance.dialogBox = dialogBox;
92
+ });
93
+ }
94
+ }
95
+ this._isFristFullscreen = false;
96
+ }
16
97
  }
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2RpYWxvZy9kaWFsb2ctcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBR3BDLDBCQUEwQjtBQUMxQixNQUFNLE9BQU8sVUFBVTtJQUVyQixZQUFtQixVQUFzQixFQUFTLGlCQUF5QztRQUF4RSxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQVMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUF3QjtJQUFHLENBQUM7SUFDL0YsS0FBSztRQUNILElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxnQkFBZ0I7YUFDcEMsSUFBSSxDQUNILE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLEtBQUssS0FBSyxNQUFNLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxNQUFNLENBQUMsRUFDcEUsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUNSO2FBQ0EsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUM7UUFDTCxJQUFJLENBQUMsaUJBQWlCLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQztJQUM1QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBmaWx0ZXIsIHRha2UgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgWERpYWxvZ1BvcnRhbENvbXBvbmVudCB9IGZyb20gJy4vZGlhbG9nLXBvcnRhbC5jb21wb25lbnQnO1xyXG5cclxuLy8gVE9ETzogYWRkIG1vcmUgZnVuY3Rpb25cclxuZXhwb3J0IGNsYXNzIFhEaWFsb2dSZWY8Qz4ge1xyXG4gIGNvbXBvbmVudEluc3RhbmNlITogQztcclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgb3ZlcmxheVJlZjogT3ZlcmxheVJlZiwgcHVibGljIGNvbnRhaW5lckluc3RhbmNlOiBYRGlhbG9nUG9ydGFsQ29tcG9uZW50KSB7fVxyXG4gIGNsb3NlKCkge1xyXG4gICAgdGhpcy5jb250YWluZXJJbnN0YW5jZS5hbmltYXRpb25DaGFuZ2VkXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIGZpbHRlcigoZXZlbnQpID0+IGV2ZW50LnN0YXRlID09PSAndm9pZCcgJiYgZXZlbnQuYWN0aW9uID09PSAnZG9uZScpLFxyXG4gICAgICAgIHRha2UoMSlcclxuICAgICAgKVxyXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuZGV0YWNoKCk7XHJcbiAgICAgIH0pO1xyXG4gICAgdGhpcy5jb250YWluZXJJbnN0YW5jZS5wbGFjZW1lbnQgPSAndm9pZCc7XHJcbiAgfVxyXG59XHJcbiJdfQ==
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-ref.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/dialog/dialog-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import { OverlayRef } from '@angular/cdk/overlay';\r\nimport { ElementRef, Renderer2 } from '@angular/core';\r\nimport { filter, take } from 'rxjs';\r\nimport { PortalResizablePrefix, XPortalService } from '@ng-nest/ui/portal';\r\nimport { XDialogPortalComponent } from './dialog-portal.component';\r\nimport { XDialogRefOption } from './dialog.property';\r\n\r\n// TODO: add more function\r\nexport class XDialogRef<C> {\r\n  componentInstance!: C;\r\n  option!: XDialogRefOption;\r\n  fullscreen = false;\r\n  dragHandleRefs: ElementRef<HTMLElement>[] = [];\r\n  private _isFristFullscreen = true;\r\n  constructor(\r\n    public overlayRef: OverlayRef,\r\n    public containerInstance: XDialogPortalComponent,\r\n    public renderer: Renderer2,\r\n    public portalService: XPortalService\r\n  ) {}\r\n\r\n  close() {\r\n    this.containerInstance.animationChanged\r\n      .pipe(\r\n        filter((event) => event.state === 'void' && event.action === 'done'),\r\n        take(1)\r\n      )\r\n      .subscribe(() => {\r\n        this.overlayRef.detach();\r\n      });\r\n    this.containerInstance.placement = 'void';\r\n  }\r\n\r\n  onFullscreen() {\r\n    let { dialogBox, dialogRef, overlayElement, distance, hostElement, defaultMaximize } = this.containerInstance;\r\n    if (!dialogRef.fullscreen) {\r\n      dialogRef.overlayRef.updateSize({\r\n        width: '100%',\r\n        height: '100%',\r\n        minWidth: '100%',\r\n        minHeight: '100%'\r\n      });\r\n      dialogRef.fullscreen = true;\r\n      dialogBox['minWidth'] = '100%';\r\n      dialogBox['minHeight'] = '100%';\r\n      dialogBox['draggable'] = false;\r\n      dialogBox['resizable'] = false;\r\n      if (this.option.resizable) {\r\n        this.renderer.setStyle(overlayElement, 'margin', '0 0 0 0');\r\n      }\r\n      if (this.option.draggable) {\r\n        dialogBox['distance'] = { x: 0, y: 0 };\r\n      }\r\n      this.renderer.addClass(overlayElement, 'x-dialog-portal-fullscreen');\r\n    } else {\r\n      dialogBox['minWidth'] = this.option.minWidth;\r\n      dialogBox['minHeight'] = this.option.minHeight;\r\n      if (this._isFristFullscreen && defaultMaximize) {\r\n        this.option.draggable = dialogBox['draggable'];\r\n        this.option.resizable = dialogBox['resizable'];\r\n      } else {\r\n        dialogBox['draggable'] = this.option.draggable;\r\n        dialogBox['resizable'] = this.option.resizable;\r\n      }\r\n\r\n      dialogRef.overlayRef?.updateSize({\r\n        width: dialogBox['width'],\r\n        height: dialogBox['height'],\r\n        minWidth: dialogBox['minWidth'],\r\n        minHeight: dialogBox['minHeight']\r\n      });\r\n      dialogRef.fullscreen = false;\r\n      if (this.option.draggable) {\r\n        dialogBox['distance'] = { ...distance };\r\n      }\r\n      if (this.option.resizable) {\r\n        if (dialogBox['marginTop']) {\r\n          this.renderer.setStyle(overlayElement, 'margin-top', `${dialogBox['marginTop']}`);\r\n        }\r\n        if (dialogBox['marginLeft']) {\r\n          this.renderer.setStyle(overlayElement, 'margin-left', `${dialogBox['marginLeft']}`);\r\n        }\r\n        if (dialogBox['marginRight']) {\r\n          this.renderer.setStyle(overlayElement, 'margin-right', `${dialogBox['marginRight']}`);\r\n        }\r\n        if (dialogBox['marginBottom']) {\r\n          this.renderer.setStyle(overlayElement, 'margin-bottom', `${dialogBox['marginBottom']}`);\r\n        }\r\n      }\r\n      this.renderer.removeClass(overlayElement, 'x-dialog-portal-fullscreen');\r\n      if (this._isFristFullscreen && defaultMaximize) {\r\n        dialogRef.overlayRef?.updatePositionStrategy(this.portalService.setPlace(this.option.placement, this.option.offset!));\r\n        this.renderer.addClass(hostElement, PortalResizablePrefix);\r\n        setTimeout(() => {\r\n          Object.assign(dialogBox, this.portalService.setResizable(overlayElement!, this.option.placement));\r\n          this.containerInstance.offsetLeft = overlayElement!.offsetLeft;\r\n          this.containerInstance.offsetTop = overlayElement!.offsetTop;\r\n          const dialogDraggable = overlayElement?.querySelector('.x-dialog-portal')!;\r\n          this.containerInstance.initHeight = dialogDraggable.clientHeight;\r\n          this.containerInstance.dialogContent = overlayElement?.querySelector('.x-dialog-portal-content')!;\r\n          this.containerInstance.initContentHeight = this.containerInstance.dialogContent?.clientHeight;\r\n          this.containerInstance.dialogBox = dialogBox;\r\n        });\r\n      }\r\n    }\r\n    this._isFristFullscreen = false;\r\n  }\r\n}\r\n"]}
@@ -31,6 +31,7 @@ export class XDialogComponent extends XDialogProperty {
31
31
  this.contentBox = {};
32
32
  this.distance = { x: 0, y: 0 };
33
33
  this.viewInit = false;
34
+ this.action = null;
34
35
  this._unSubject = new Subject();
35
36
  this.scrollStrategy = this.protalService.overlay.scrollStrategies.block();
36
37
  }
@@ -73,8 +74,7 @@ export class XDialogComponent extends XDialogProperty {
73
74
  this.create();
74
75
  }
75
76
  else {
76
- this.detach();
77
- // this.visibleChange.emit(false);
77
+ this.onClose('close', false);
78
78
  }
79
79
  }
80
80
  create() {
@@ -114,7 +114,7 @@ export class XDialogComponent extends XDialogProperty {
114
114
  });
115
115
  }
116
116
  if (this.hasBackdrop && this.backdropClose && this.dialogRef?.overlayRef) {
117
- this.backdropClick$ = this.dialogRef.overlayRef.backdropClick().subscribe(() => this.onClose());
117
+ this.backdropClick$ = this.dialogRef.overlayRef.backdropClick().subscribe(() => this.onClose('close'));
118
118
  }
119
119
  }
120
120
  setWidthHeight() {
@@ -127,24 +127,29 @@ export class XDialogComponent extends XDialogProperty {
127
127
  this.maximize = false;
128
128
  }
129
129
  }
130
- detach() {
131
- if (this.portalAttached()) {
132
- this.visible = false;
133
- this.visibleChange.emit(this.visible);
134
- this.dialogRef?.overlayRef?.detach();
135
- this.unsubscribe();
136
- this.close.emit();
137
- }
138
- }
139
130
  portalAttached() {
140
131
  return this.dialogRef?.overlayRef?.hasAttached();
141
132
  }
142
- onClose() {
143
- if (XIsFunction(this.beforeClose)) {
144
- this.beforeClose();
133
+ onClose(action, execFunction = true) {
134
+ if (!this.portalAttached())
135
+ return;
136
+ if (XIsFunction(this.beforeClose) && execFunction) {
137
+ this.beforeClose(action);
138
+ this.action = action;
145
139
  }
146
140
  else {
147
- this.detach();
141
+ this.visible = false;
142
+ this.visibleChange.emit(this.visible);
143
+ this.dialogRef?.overlayRef?.detach();
144
+ this.unsubscribe();
145
+ if ([action, this.action].includes('confirm')) {
146
+ this.confirm.emit();
147
+ }
148
+ if ([action, this.action].includes('cancel')) {
149
+ this.cancel.emit();
150
+ }
151
+ this.action = null;
152
+ this.close.emit();
148
153
  }
149
154
  }
150
155
  onDragEnded($event) {
@@ -208,14 +213,6 @@ export class XDialogComponent extends XDialogProperty {
208
213
  }
209
214
  }
210
215
  }
211
- onCancel() {
212
- this.onClose();
213
- this.cancel.emit();
214
- }
215
- onConfirm() {
216
- this.onClose();
217
- this.confirm.emit();
218
- }
219
216
  moveDone($event) {
220
217
  if ($event.toState === 'void') {
221
218
  this.closeDone.emit($event);
@@ -235,16 +232,18 @@ export class XDialogComponent extends XDialogProperty {
235
232
  const contentHeight = Number(this.initContentHeight) + Number(event.clientHeight) - Number(this.initHeight);
236
233
  this.renderer.setStyle(this.dialogContent, 'max-height', 'initial');
237
234
  this.renderer.setStyle(this.dialogContent, 'flex', 'initial');
238
- this.renderer.setStyle(this.dialogContent, 'height', `${contentHeight}px`);
235
+ if (['top-start', 'top-end', 'bottom', 'top', 'bottom-start', 'bottom-end'].includes(event.direction)) {
236
+ this.renderer.setStyle(this.dialogContent, 'height', `${contentHeight}px`);
237
+ }
239
238
  }
240
239
  }
241
240
  /** @nocollapse */ /** @nocollapse */ XDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }, { token: i1.XPortalService }, { token: i2.Overlay }, { token: i3.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
242
- /** @nocollapse */ /** @nocollapse */ XDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XDialogComponent, selector: "x-dialog", viewQueries: [{ propertyName: "dialogTpl", first: true, predicate: ["dialogTpl"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-template #dialogTpl>\r\n <div\r\n class=\"x-dialog\"\r\n [@x-move-box-animation]=\"placement\"\r\n (@x-move-box-animation.done)=\"moveDone($event)\"\r\n [class.x-dialog-maximize]=\"isMaximize\"\r\n [class.x-dialog-resizable]=\"resizable\"\r\n [class.x-dialog-default-maximize]=\"isDefaultMaximize\"\r\n >\r\n <x-alert\r\n [draggable]=\"draggable && dialogBox['draggable']\"\r\n [resizable]=\"resizable && dialogBox['resizable']\"\r\n [dragFreeDragPosition]=\"dialogBox['distance']\"\r\n [offsetLeft]=\"offsetLeft\"\r\n [offsetTop]=\"offsetTop\"\r\n [minWidth]=\"dialogBox['minWidth']\"\r\n [minHeight]=\"dialogBox['minHeight']\"\r\n [dragBoundary]=\"'.cdk-overlay-container'\"\r\n [title]=\"title\"\r\n [content]=\"contentTpl\"\r\n [type]=\"type\"\r\n [effect]=\"effect\"\r\n [hideClose]=\"hideClose\"\r\n [closeText]=\"closeText\"\r\n [operationTpl]=\"operationTpl\"\r\n (close)=\"onClose()\"\r\n (dragEnded)=\"onDragEnded($event)\"\r\n (resizing)=\"onResizing($event)\"\r\n showIcon=\"false\"\r\n duration=\"0\"\r\n manual\r\n disabledAnimation\r\n ></x-alert>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #contentTpl>\r\n <div class=\"x-dialog-inner\">\r\n <div class=\"x-dialog-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"x-dialog-buttons\" [class.x-dialog-buttons-center]=\"buttonsCenter\">\r\n <ng-container *xOutlet=\"footer\">\r\n <x-buttons space=\"1\" *ngIf=\"showCancel || showConfirm\">\r\n <x-button *ngIf=\"showCancel\" (click)=\"onCancel()\">{{ getCancelText }}</x-button>\r\n <x-button *ngIf=\"showConfirm\" type=\"primary\" (click)=\"onConfirm()\">{{ getConfirmText }}</x-button>\r\n </x-buttons>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #operationTpl>\r\n <ng-container *ngIf=\"maximize || resizable\">\r\n <x-button size=\"small\" [icon]=\"isMaximize ? 'fto-minimize' : 'fto-maximize'\" [onlyIcon]=\"true\" (click)=\"onSize()\"></x-button>\r\n </ng-container>\r\n</ng-template>\r\n", styles: [".x-dialog{margin:0;padding:0;width:100%;height:100%}.x-dialog>x-alert{height:100%}.x-dialog>x-alert .x-alert{min-height:100%;height:-moz-fit-content;height:fit-content;align-items:inherit;padding:0}.x-dialog>x-alert .x-alert-inner{min-height:100%;display:flex;flex-direction:column}.x-dialog>x-alert .x-alert-title{padding:1rem 1rem 0}.x-dialog>x-alert .x-alert-content{flex:1;display:flex;flex-direction:column;padding:0 1rem .5rem}.x-dialog-inner{display:flex;flex-direction:column;margin:.5rem 0;flex:1}.x-dialog-buttons{display:flex;justify-content:flex-end}.x-dialog-buttons>x-buttons{margin-top:1rem;align-self:flex-end}.x-dialog-buttons-center{justify-content:center}.x-dialog-content{display:inline-flex;flex-direction:column;flex:1;max-height:70vh;overflow:auto}.x-dialog-maximize>x-alert .x-alert{left:0!important;top:0!important}.x-dialog-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important}.x-dialog-default-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important;flex:initial}.x-dialog-container x-dialog{width:100%}\n"], components: [{ type: i4.XAlertComponent, selector: "x-alert" }, { type: i5.XButtonsComponent, selector: "x-buttons" }, { type: i5.XButtonComponent, selector: "x-button" }], directives: [{ type: i6.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [XMoveBoxAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
241
+ /** @nocollapse */ /** @nocollapse */ XDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XDialogComponent, selector: "x-dialog", viewQueries: [{ propertyName: "dialogTpl", first: true, predicate: ["dialogTpl"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-template #dialogTpl>\r\n <div\r\n class=\"x-dialog\"\r\n [@x-move-box-animation]=\"placement\"\r\n (@x-move-box-animation.done)=\"moveDone($event)\"\r\n [class.x-dialog-maximize]=\"isMaximize\"\r\n [class.x-dialog-resizable]=\"resizable\"\r\n [class.x-dialog-default-maximize]=\"isDefaultMaximize\"\r\n >\r\n <x-alert\r\n [draggable]=\"draggable && dialogBox['draggable']\"\r\n [resizable]=\"resizable && dialogBox['resizable']\"\r\n [dragFreeDragPosition]=\"dialogBox['distance']\"\r\n [offsetLeft]=\"offsetLeft\"\r\n [offsetTop]=\"offsetTop\"\r\n [minWidth]=\"dialogBox['minWidth']\"\r\n [minHeight]=\"dialogBox['minHeight']\"\r\n [dragBoundary]=\"'.cdk-overlay-container'\"\r\n [title]=\"title\"\r\n [content]=\"contentTpl\"\r\n [type]=\"type\"\r\n [effect]=\"effect\"\r\n [hideClose]=\"hideClose\"\r\n [closeText]=\"closeText\"\r\n [operationTpl]=\"operationTpl\"\r\n (close)=\"onClose('close')\"\r\n (dragEnded)=\"onDragEnded($event)\"\r\n (resizing)=\"onResizing($event)\"\r\n showIcon=\"false\"\r\n duration=\"0\"\r\n manual\r\n disabledAnimation\r\n ></x-alert>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #contentTpl>\r\n <div class=\"x-dialog-inner\">\r\n <div class=\"x-dialog-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"x-dialog-buttons\" [class.x-dialog-buttons-center]=\"buttonsCenter\">\r\n <ng-container *xOutlet=\"footer\">\r\n <x-buttons space=\"1\" *ngIf=\"showCancel || showConfirm\">\r\n <x-button *ngIf=\"showCancel\" (click)=\"onClose('cancel')\">{{ getCancelText }}</x-button>\r\n <x-button *ngIf=\"showConfirm\" type=\"primary\" (click)=\"onClose('confirm')\">{{ getConfirmText }}</x-button>\r\n </x-buttons>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #operationTpl>\r\n <ng-container *ngIf=\"maximize || resizable\">\r\n <x-button size=\"small\" [icon]=\"isMaximize ? 'fto-minimize' : 'fto-maximize'\" [onlyIcon]=\"true\" (click)=\"onSize()\"></x-button>\r\n </ng-container>\r\n</ng-template>\r\n", styles: [".x-dialog{margin:0;padding:0;width:100%;height:100%}.x-dialog>x-alert{height:100%}.x-dialog>x-alert .x-alert{min-height:100%;height:-moz-fit-content;height:fit-content;align-items:inherit;padding:0}.x-dialog>x-alert .x-alert-inner{min-height:100%;display:flex;flex-direction:column}.x-dialog>x-alert .x-alert-title{padding:1rem 1rem 0}.x-dialog>x-alert .x-alert-content{flex:1;display:flex;flex-direction:column;padding:0 1rem .5rem}.x-dialog-inner{display:flex;flex-direction:column;margin:.5rem 0;flex:1}.x-dialog-buttons{display:flex;justify-content:flex-end}.x-dialog-buttons>x-buttons{margin-top:1rem;align-self:flex-end}.x-dialog-buttons-center{justify-content:center}.x-dialog-content{display:inline-flex;flex-direction:column;flex:1;max-height:70vh;overflow:auto;min-height:2rem}.x-dialog-maximize>x-alert .x-alert{left:0!important;top:0!important}.x-dialog-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important}.x-dialog-default-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important;flex:initial}.x-dialog-container x-dialog{width:100%}\n"], components: [{ type: i4.XAlertComponent, selector: "x-alert" }, { type: i5.XButtonsComponent, selector: "x-buttons" }, { type: i5.XButtonComponent, selector: "x-button" }], directives: [{ type: i6.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [XMoveBoxAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
243
242
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XDialogComponent, decorators: [{
244
243
  type: Component,
245
- args: [{ selector: `${XDialogPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XMoveBoxAnimation], template: "<ng-template #dialogTpl>\r\n <div\r\n class=\"x-dialog\"\r\n [@x-move-box-animation]=\"placement\"\r\n (@x-move-box-animation.done)=\"moveDone($event)\"\r\n [class.x-dialog-maximize]=\"isMaximize\"\r\n [class.x-dialog-resizable]=\"resizable\"\r\n [class.x-dialog-default-maximize]=\"isDefaultMaximize\"\r\n >\r\n <x-alert\r\n [draggable]=\"draggable && dialogBox['draggable']\"\r\n [resizable]=\"resizable && dialogBox['resizable']\"\r\n [dragFreeDragPosition]=\"dialogBox['distance']\"\r\n [offsetLeft]=\"offsetLeft\"\r\n [offsetTop]=\"offsetTop\"\r\n [minWidth]=\"dialogBox['minWidth']\"\r\n [minHeight]=\"dialogBox['minHeight']\"\r\n [dragBoundary]=\"'.cdk-overlay-container'\"\r\n [title]=\"title\"\r\n [content]=\"contentTpl\"\r\n [type]=\"type\"\r\n [effect]=\"effect\"\r\n [hideClose]=\"hideClose\"\r\n [closeText]=\"closeText\"\r\n [operationTpl]=\"operationTpl\"\r\n (close)=\"onClose()\"\r\n (dragEnded)=\"onDragEnded($event)\"\r\n (resizing)=\"onResizing($event)\"\r\n showIcon=\"false\"\r\n duration=\"0\"\r\n manual\r\n disabledAnimation\r\n ></x-alert>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #contentTpl>\r\n <div class=\"x-dialog-inner\">\r\n <div class=\"x-dialog-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"x-dialog-buttons\" [class.x-dialog-buttons-center]=\"buttonsCenter\">\r\n <ng-container *xOutlet=\"footer\">\r\n <x-buttons space=\"1\" *ngIf=\"showCancel || showConfirm\">\r\n <x-button *ngIf=\"showCancel\" (click)=\"onCancel()\">{{ getCancelText }}</x-button>\r\n <x-button *ngIf=\"showConfirm\" type=\"primary\" (click)=\"onConfirm()\">{{ getConfirmText }}</x-button>\r\n </x-buttons>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #operationTpl>\r\n <ng-container *ngIf=\"maximize || resizable\">\r\n <x-button size=\"small\" [icon]=\"isMaximize ? 'fto-minimize' : 'fto-maximize'\" [onlyIcon]=\"true\" (click)=\"onSize()\"></x-button>\r\n </ng-container>\r\n</ng-template>\r\n", styles: [".x-dialog{margin:0;padding:0;width:100%;height:100%}.x-dialog>x-alert{height:100%}.x-dialog>x-alert .x-alert{min-height:100%;height:-moz-fit-content;height:fit-content;align-items:inherit;padding:0}.x-dialog>x-alert .x-alert-inner{min-height:100%;display:flex;flex-direction:column}.x-dialog>x-alert .x-alert-title{padding:1rem 1rem 0}.x-dialog>x-alert .x-alert-content{flex:1;display:flex;flex-direction:column;padding:0 1rem .5rem}.x-dialog-inner{display:flex;flex-direction:column;margin:.5rem 0;flex:1}.x-dialog-buttons{display:flex;justify-content:flex-end}.x-dialog-buttons>x-buttons{margin-top:1rem;align-self:flex-end}.x-dialog-buttons-center{justify-content:center}.x-dialog-content{display:inline-flex;flex-direction:column;flex:1;max-height:70vh;overflow:auto}.x-dialog-maximize>x-alert .x-alert{left:0!important;top:0!important}.x-dialog-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important}.x-dialog-default-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important;flex:initial}.x-dialog-container x-dialog{width:100%}\n"] }]
244
+ args: [{ selector: `${XDialogPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XMoveBoxAnimation], template: "<ng-template #dialogTpl>\r\n <div\r\n class=\"x-dialog\"\r\n [@x-move-box-animation]=\"placement\"\r\n (@x-move-box-animation.done)=\"moveDone($event)\"\r\n [class.x-dialog-maximize]=\"isMaximize\"\r\n [class.x-dialog-resizable]=\"resizable\"\r\n [class.x-dialog-default-maximize]=\"isDefaultMaximize\"\r\n >\r\n <x-alert\r\n [draggable]=\"draggable && dialogBox['draggable']\"\r\n [resizable]=\"resizable && dialogBox['resizable']\"\r\n [dragFreeDragPosition]=\"dialogBox['distance']\"\r\n [offsetLeft]=\"offsetLeft\"\r\n [offsetTop]=\"offsetTop\"\r\n [minWidth]=\"dialogBox['minWidth']\"\r\n [minHeight]=\"dialogBox['minHeight']\"\r\n [dragBoundary]=\"'.cdk-overlay-container'\"\r\n [title]=\"title\"\r\n [content]=\"contentTpl\"\r\n [type]=\"type\"\r\n [effect]=\"effect\"\r\n [hideClose]=\"hideClose\"\r\n [closeText]=\"closeText\"\r\n [operationTpl]=\"operationTpl\"\r\n (close)=\"onClose('close')\"\r\n (dragEnded)=\"onDragEnded($event)\"\r\n (resizing)=\"onResizing($event)\"\r\n showIcon=\"false\"\r\n duration=\"0\"\r\n manual\r\n disabledAnimation\r\n ></x-alert>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #contentTpl>\r\n <div class=\"x-dialog-inner\">\r\n <div class=\"x-dialog-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"x-dialog-buttons\" [class.x-dialog-buttons-center]=\"buttonsCenter\">\r\n <ng-container *xOutlet=\"footer\">\r\n <x-buttons space=\"1\" *ngIf=\"showCancel || showConfirm\">\r\n <x-button *ngIf=\"showCancel\" (click)=\"onClose('cancel')\">{{ getCancelText }}</x-button>\r\n <x-button *ngIf=\"showConfirm\" type=\"primary\" (click)=\"onClose('confirm')\">{{ getConfirmText }}</x-button>\r\n </x-buttons>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #operationTpl>\r\n <ng-container *ngIf=\"maximize || resizable\">\r\n <x-button size=\"small\" [icon]=\"isMaximize ? 'fto-minimize' : 'fto-maximize'\" [onlyIcon]=\"true\" (click)=\"onSize()\"></x-button>\r\n </ng-container>\r\n</ng-template>\r\n", styles: [".x-dialog{margin:0;padding:0;width:100%;height:100%}.x-dialog>x-alert{height:100%}.x-dialog>x-alert .x-alert{min-height:100%;height:-moz-fit-content;height:fit-content;align-items:inherit;padding:0}.x-dialog>x-alert .x-alert-inner{min-height:100%;display:flex;flex-direction:column}.x-dialog>x-alert .x-alert-title{padding:1rem 1rem 0}.x-dialog>x-alert .x-alert-content{flex:1;display:flex;flex-direction:column;padding:0 1rem .5rem}.x-dialog-inner{display:flex;flex-direction:column;margin:.5rem 0;flex:1}.x-dialog-buttons{display:flex;justify-content:flex-end}.x-dialog-buttons>x-buttons{margin-top:1rem;align-self:flex-end}.x-dialog-buttons-center{justify-content:center}.x-dialog-content{display:inline-flex;flex-direction:column;flex:1;max-height:70vh;overflow:auto;min-height:2rem}.x-dialog-maximize>x-alert .x-alert{left:0!important;top:0!important}.x-dialog-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important}.x-dialog-default-maximize .x-dialog-content{max-height:calc(100vh - 7rem)!important;height:calc(100vh - 7rem)!important;flex:initial}.x-dialog-container x-dialog{width:100%}\n"] }]
246
245
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }, { type: i1.XPortalService }, { type: i2.Overlay }, { type: i3.XI18nService }]; }, propDecorators: { dialogTpl: [{
247
246
  type: ViewChild,
248
247
  args: ['dialogTpl', { static: false }]
249
248
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/dialog/dialog.component.ts","../../../../../lib/ng-nest/ui/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  TemplateRef,\r\n  ViewContainerRef,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport { XMoveBoxAnimation, XIsChange, XIsFunction } from '@ng-nest/ui/core';\r\nimport { XDialogPrefix, XDialogOverlayRef, XDialogProperty, XDialogContainer } from './dialog.property';\r\nimport { PortalResizablePrefix, XPortalService } from '@ng-nest/ui/portal';\r\nimport { Subscription, Subject } from 'rxjs';\r\nimport { BlockScrollStrategy, Overlay } from '@angular/cdk/overlay';\r\nimport { XI18nDialog, XI18nService } from '@ng-nest/ui/i18n';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { CdkDragEnd } from '@angular/cdk/drag-drop';\r\nimport { XResizableEvent } from '@ng-nest/ui/resizable';\r\n\r\n@Component({\r\n  selector: `${XDialogPrefix}`,\r\n  templateUrl: './dialog.component.html',\r\n  styleUrls: ['./dialog.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XMoveBoxAnimation]\r\n})\r\nexport class XDialogComponent extends XDialogProperty implements OnChanges, OnDestroy {\r\n  @ViewChild('dialogTpl', { static: false }) dialogTpl!: TemplateRef<void>;\r\n  dialogRef!: XDialogOverlayRef;\r\n  backdropClick$!: Subscription;\r\n  scrollStrategy: BlockScrollStrategy;\r\n  locale: XI18nDialog = {};\r\n  overlayElement?: HTMLElement;\r\n  dialogContent?: HTMLElement;\r\n  initHeight? = 0;\r\n  initContentHeight? = 0;\r\n  isMaximize = false;\r\n  isDefaultMaximize = false;\r\n  dialogBox: { [key: string]: any } = {};\r\n  contentBox: XResizableEvent = {};\r\n  distance = { x: 0, y: 0 };\r\n  viewInit = false;\r\n\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get getCancelText() {\r\n    return this.cancelText || this.locale.cancelText;\r\n  }\r\n\r\n  get getConfirmText() {\r\n    return this.confirmText || this.locale.confirmText;\r\n  }\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public viewContainerRef: ViewContainerRef,\r\n    public protalService: XPortalService,\r\n    public overlay: Overlay,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n    this.scrollStrategy = this.protalService.overlay.scrollStrategies.block();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.dialog as XI18nDialog),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n    this.dialogBox['draggable'] = this.draggable;\r\n    this.dialogBox['resizable'] = this.resizable;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { visible } = changes;\r\n    XIsChange(visible) && this.setVisible();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribe();\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.viewInit = true;\r\n    setTimeout(() => this.visible && this.create());\r\n  }\r\n\r\n  unsubscribe() {\r\n    this.backdropClick$?.unsubscribe();\r\n  }\r\n\r\n  setVisible() {\r\n    if (!this.viewInit) return;\r\n    if (this.visible) {\r\n      this.create();\r\n    } else {\r\n      this.detach();\r\n      // this.visibleChange.emit(false);\r\n    }\r\n  }\r\n\r\n  create() {\r\n    this.dialogRef = this.protalService.attach({\r\n      content: this.dialogTpl,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: {\r\n        panelClass: [XDialogContainer, this.className],\r\n        hasBackdrop: Boolean(this.hasBackdrop),\r\n        scrollStrategy: this.overlay.scrollStrategies.block(),\r\n        width: this.width,\r\n        height: this.height,\r\n        minWidth: this.minWidth,\r\n        minHeight: this.minHeight,\r\n        positionStrategy: this.protalService.setPlace(this.placement, this.offset)\r\n      }\r\n    });\r\n    const { hostElement, overlayElement } = this.dialogRef.overlayRef!;\r\n    this.overlayElement = overlayElement;\r\n    this.setWidthHeight();\r\n    Object.assign(this.dialogBox, {\r\n      width: this.width,\r\n      height: this.height,\r\n      minWidth: this.minWidth,\r\n      minHeight: this.minHeight\r\n    });\r\n    if (this.resizable && !this.isDefaultMaximize) {\r\n      this.renderer.addClass(hostElement, PortalResizablePrefix);\r\n      setTimeout(() => {\r\n        Object.assign(this.dialogBox, this.protalService.setResizable(this.overlayElement!, this.placement));\r\n        this.offsetLeft = this.overlayElement!.offsetLeft;\r\n        this.offsetTop = this.overlayElement!.offsetTop;\r\n        const dialogDraggable = this.overlayElement?.querySelector('.x-alert-draggable')!;\r\n        this.initHeight = dialogDraggable.clientHeight;\r\n        this.dialogContent = this.overlayElement?.querySelector('.x-dialog-content')!;\r\n        this.initContentHeight = this.dialogContent.clientHeight;\r\n      });\r\n    }\r\n    if (this.hasBackdrop && this.backdropClose && this.dialogRef?.overlayRef) {\r\n      this.backdropClick$ = this.dialogRef.overlayRef.backdropClick().subscribe(() => this.onClose());\r\n    }\r\n  }\r\n\r\n  setWidthHeight() {\r\n    const ws = ['100%', '100vw'];\r\n    const hs = ['100%', '100vh'];\r\n    if (ws.includes(this.width as string) && hs.includes(this.height as string)) {\r\n      this.isDefaultMaximize = true;\r\n      this.resizable = false;\r\n      this.draggable = false;\r\n      this.maximize = false;\r\n    }\r\n  }\r\n\r\n  detach() {\r\n    if (this.portalAttached()) {\r\n      this.visible = false;\r\n      this.visibleChange.emit(this.visible);\r\n      this.dialogRef?.overlayRef?.detach();\r\n      this.unsubscribe();\r\n      this.close.emit();\r\n    }\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.dialogRef?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  onClose() {\r\n    if (XIsFunction(this.beforeClose)) {\r\n      this.beforeClose();\r\n    } else {\r\n      this.detach();\r\n    }\r\n  }\r\n\r\n  onDragEnded($event: CdkDragEnd) {\r\n    this.distance = { x: this.distance.x + $event.distance.x, y: this.distance.y + $event.distance.y };\r\n  }\r\n\r\n  onSize() {\r\n    if (!this.dialogRef) return;\r\n    this.isMaximize = !this.isMaximize;\r\n    if (this.isMaximize) {\r\n      this.onMaximize();\r\n    } else {\r\n      this.onMinimize();\r\n    }\r\n  }\r\n\r\n  onMaximize() {\r\n    this.dialogRef.overlayRef?.updateSize({\r\n      width: '100%',\r\n      height: '100%',\r\n      minWidth: '100%',\r\n      minHeight: '100%'\r\n    });\r\n    this.dialogBox['minWidth'] = '100%';\r\n    this.dialogBox['minHeight'] = '100%';\r\n    this.dialogBox['draggable'] = false;\r\n    this.dialogBox['resizable'] = false;\r\n    if (this.resizable) {\r\n      this.renderer.setStyle(this.overlayElement, 'margin', '0 0 0 0');\r\n    }\r\n    if (this.draggable) {\r\n      this.dialogBox['distance'] = { x: 0, y: 0 };\r\n    }\r\n  }\r\n\r\n  onMinimize() {\r\n    this.dialogBox['minWidth'] = this.minWidth;\r\n    this.dialogBox['minHeight'] = this.minHeight;\r\n    this.dialogBox['draggable'] = this.draggable;\r\n    this.dialogBox['resizable'] = this.resizable;\r\n    this.dialogRef.overlayRef?.updateSize({\r\n      width: this.dialogBox['width'],\r\n      height: this.dialogBox['height'],\r\n      minWidth: this.dialogBox['minWidth'],\r\n      minHeight: this.dialogBox['minHeight']\r\n    });\r\n    if (this.draggable) {\r\n      this.dialogBox['distance'] = { ...this.distance };\r\n    }\r\n    if (this.resizable) {\r\n      if (this.dialogBox['marginTop']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-top', `${this.dialogBox['marginTop']}`);\r\n      }\r\n      if (this.dialogBox['marginLeft']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-left', `${this.dialogBox['marginLeft']}`);\r\n      }\r\n      if (this.dialogBox['marginRight']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-right', `${this.dialogBox['marginRight']}`);\r\n      }\r\n      if (this.dialogBox['marginBottom']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-bottom', `${this.dialogBox['marginBottom']}`);\r\n      }\r\n    }\r\n  }\r\n\r\n  onCancel() {\r\n    this.onClose();\r\n    this.cancel.emit();\r\n  }\r\n\r\n  onConfirm() {\r\n    this.onClose();\r\n    this.confirm.emit();\r\n  }\r\n\r\n  moveDone($event: { toState: string }) {\r\n    if ($event.toState === 'void') {\r\n      this.closeDone.emit($event);\r\n      this.isMaximize = false;\r\n      this.dialogBox = {\r\n        draggable: this.draggable,\r\n        resizable: this.resizable\r\n      };\r\n      this.distance = { x: 0, y: 0 };\r\n      this.dialogRef?.overlayRef?.dispose();\r\n    } else {\r\n      this.showDone.emit($event);\r\n    }\r\n  }\r\n\r\n  onResizing(event: XResizableEvent) {\r\n    const contentHeight = Number(this.initContentHeight) + Number(event.clientHeight) - Number(this.initHeight);\r\n    this.renderer.setStyle(this.dialogContent, 'max-height', 'initial');\r\n    this.renderer.setStyle(this.dialogContent, 'flex', 'initial');\r\n    this.renderer.setStyle(this.dialogContent, 'height', `${contentHeight}px`);\r\n  }\r\n}\r\n","<ng-template #dialogTpl>\r\n  <div\r\n    class=\"x-dialog\"\r\n    [@x-move-box-animation]=\"placement\"\r\n    (@x-move-box-animation.done)=\"moveDone($event)\"\r\n    [class.x-dialog-maximize]=\"isMaximize\"\r\n    [class.x-dialog-resizable]=\"resizable\"\r\n    [class.x-dialog-default-maximize]=\"isDefaultMaximize\"\r\n  >\r\n    <x-alert\r\n      [draggable]=\"draggable && dialogBox['draggable']\"\r\n      [resizable]=\"resizable && dialogBox['resizable']\"\r\n      [dragFreeDragPosition]=\"dialogBox['distance']\"\r\n      [offsetLeft]=\"offsetLeft\"\r\n      [offsetTop]=\"offsetTop\"\r\n      [minWidth]=\"dialogBox['minWidth']\"\r\n      [minHeight]=\"dialogBox['minHeight']\"\r\n      [dragBoundary]=\"'.cdk-overlay-container'\"\r\n      [title]=\"title\"\r\n      [content]=\"contentTpl\"\r\n      [type]=\"type\"\r\n      [effect]=\"effect\"\r\n      [hideClose]=\"hideClose\"\r\n      [closeText]=\"closeText\"\r\n      [operationTpl]=\"operationTpl\"\r\n      (close)=\"onClose()\"\r\n      (dragEnded)=\"onDragEnded($event)\"\r\n      (resizing)=\"onResizing($event)\"\r\n      showIcon=\"false\"\r\n      duration=\"0\"\r\n      manual\r\n      disabledAnimation\r\n    ></x-alert>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #contentTpl>\r\n  <div class=\"x-dialog-inner\">\r\n    <div class=\"x-dialog-content\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n    <div class=\"x-dialog-buttons\" [class.x-dialog-buttons-center]=\"buttonsCenter\">\r\n      <ng-container *xOutlet=\"footer\">\r\n        <x-buttons space=\"1\" *ngIf=\"showCancel || showConfirm\">\r\n          <x-button *ngIf=\"showCancel\" (click)=\"onCancel()\">{{ getCancelText }}</x-button>\r\n          <x-button *ngIf=\"showConfirm\" type=\"primary\" (click)=\"onConfirm()\">{{ getConfirmText }}</x-button>\r\n        </x-buttons>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #operationTpl>\r\n  <ng-container *ngIf=\"maximize || resizable\">\r\n    <x-button size=\"small\" [icon]=\"isMaximize ? 'fto-minimize' : 'fto-maximize'\" [onlyIcon]=\"true\" (click)=\"onSize()\"></x-button>\r\n  </ng-container>\r\n</ng-template>\r\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/dialog/dialog.component.ts","../../../../../lib/ng-nest/ui/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  TemplateRef,\r\n  ViewContainerRef,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport { XMoveBoxAnimation, XIsChange, XIsFunction } from '@ng-nest/ui/core';\r\nimport { XDialogPrefix, XDialogOverlayRef, XDialogProperty, XDialogContainer, XDialogAction } from './dialog.property';\r\nimport { PortalResizablePrefix, XPortalService } from '@ng-nest/ui/portal';\r\nimport { Subscription, Subject } from 'rxjs';\r\nimport { BlockScrollStrategy, Overlay } from '@angular/cdk/overlay';\r\nimport { XI18nDialog, XI18nService } from '@ng-nest/ui/i18n';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { CdkDragEnd } from '@angular/cdk/drag-drop';\r\nimport { XResizableEvent } from '@ng-nest/ui/resizable';\r\n\r\n@Component({\r\n  selector: `${XDialogPrefix}`,\r\n  templateUrl: './dialog.component.html',\r\n  styleUrls: ['./dialog.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XMoveBoxAnimation]\r\n})\r\nexport class XDialogComponent extends XDialogProperty implements OnChanges, OnDestroy {\r\n  @ViewChild('dialogTpl', { static: false }) dialogTpl!: TemplateRef<void>;\r\n  dialogRef!: XDialogOverlayRef;\r\n  backdropClick$!: Subscription;\r\n  scrollStrategy: BlockScrollStrategy;\r\n  locale: XI18nDialog = {};\r\n  overlayElement?: HTMLElement;\r\n  dialogContent?: HTMLElement;\r\n  initHeight? = 0;\r\n  initContentHeight? = 0;\r\n  isMaximize = false;\r\n  isDefaultMaximize = false;\r\n  dialogBox: { [key: string]: any } = {};\r\n  contentBox: XResizableEvent = {};\r\n  distance = { x: 0, y: 0 };\r\n  viewInit = false;\r\n  action: XDialogAction | null = null;\r\n\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get getCancelText() {\r\n    return this.cancelText || this.locale.cancelText;\r\n  }\r\n\r\n  get getConfirmText() {\r\n    return this.confirmText || this.locale.confirmText;\r\n  }\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public viewContainerRef: ViewContainerRef,\r\n    public protalService: XPortalService,\r\n    public overlay: Overlay,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n    this.scrollStrategy = this.protalService.overlay.scrollStrategies.block();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.dialog as XI18nDialog),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n    this.dialogBox['draggable'] = this.draggable;\r\n    this.dialogBox['resizable'] = this.resizable;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { visible } = changes;\r\n    XIsChange(visible) && this.setVisible();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribe();\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.viewInit = true;\r\n    setTimeout(() => this.visible && this.create());\r\n  }\r\n\r\n  unsubscribe() {\r\n    this.backdropClick$?.unsubscribe();\r\n  }\r\n\r\n  setVisible() {\r\n    if (!this.viewInit) return;\r\n    if (this.visible) {\r\n      this.create();\r\n    } else {\r\n      this.onClose('close', false);\r\n    }\r\n  }\r\n\r\n  create() {\r\n    this.dialogRef = this.protalService.attach({\r\n      content: this.dialogTpl,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: {\r\n        panelClass: [XDialogContainer, this.className],\r\n        hasBackdrop: Boolean(this.hasBackdrop),\r\n        scrollStrategy: this.overlay.scrollStrategies.block(),\r\n        width: this.width,\r\n        height: this.height,\r\n        minWidth: this.minWidth,\r\n        minHeight: this.minHeight,\r\n        positionStrategy: this.protalService.setPlace(this.placement, this.offset)\r\n      }\r\n    });\r\n    const { hostElement, overlayElement } = this.dialogRef.overlayRef!;\r\n    this.overlayElement = overlayElement;\r\n    this.setWidthHeight();\r\n    Object.assign(this.dialogBox, {\r\n      width: this.width,\r\n      height: this.height,\r\n      minWidth: this.minWidth,\r\n      minHeight: this.minHeight\r\n    });\r\n    if (this.resizable && !this.isDefaultMaximize) {\r\n      this.renderer.addClass(hostElement, PortalResizablePrefix);\r\n      setTimeout(() => {\r\n        Object.assign(this.dialogBox, this.protalService.setResizable(this.overlayElement!, this.placement));\r\n        this.offsetLeft = this.overlayElement!.offsetLeft;\r\n        this.offsetTop = this.overlayElement!.offsetTop;\r\n        const dialogDraggable = this.overlayElement?.querySelector('.x-alert-draggable')!;\r\n        this.initHeight = dialogDraggable.clientHeight;\r\n        this.dialogContent = this.overlayElement?.querySelector('.x-dialog-content')!;\r\n        this.initContentHeight = this.dialogContent.clientHeight;\r\n      });\r\n    }\r\n    if (this.hasBackdrop && this.backdropClose && this.dialogRef?.overlayRef) {\r\n      this.backdropClick$ = this.dialogRef.overlayRef.backdropClick().subscribe(() => this.onClose('close'));\r\n    }\r\n  }\r\n\r\n  setWidthHeight() {\r\n    const ws = ['100%', '100vw'];\r\n    const hs = ['100%', '100vh'];\r\n    if (ws.includes(this.width as string) && hs.includes(this.height as string)) {\r\n      this.isDefaultMaximize = true;\r\n      this.resizable = false;\r\n      this.draggable = false;\r\n      this.maximize = false;\r\n    }\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.dialogRef?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  onClose(action: XDialogAction, execFunction = true) {\r\n    if (!this.portalAttached()) return;\r\n    if (XIsFunction(this.beforeClose) && execFunction) {\r\n      this.beforeClose(action);\r\n      this.action = action;\r\n    } else {\r\n      this.visible = false;\r\n      this.visibleChange.emit(this.visible);\r\n      this.dialogRef?.overlayRef?.detach();\r\n      this.unsubscribe();\r\n      if ([action, this.action].includes('confirm')) {\r\n        this.confirm.emit();\r\n      }\r\n      if ([action, this.action].includes('cancel')) {\r\n        this.cancel.emit();\r\n      }\r\n      this.action = null;\r\n      this.close.emit();\r\n    }\r\n  }\r\n\r\n  onDragEnded($event: CdkDragEnd) {\r\n    this.distance = { x: this.distance.x + $event.distance.x, y: this.distance.y + $event.distance.y };\r\n  }\r\n\r\n  onSize() {\r\n    if (!this.dialogRef) return;\r\n    this.isMaximize = !this.isMaximize;\r\n    if (this.isMaximize) {\r\n      this.onMaximize();\r\n    } else {\r\n      this.onMinimize();\r\n    }\r\n  }\r\n\r\n  onMaximize() {\r\n    this.dialogRef.overlayRef?.updateSize({\r\n      width: '100%',\r\n      height: '100%',\r\n      minWidth: '100%',\r\n      minHeight: '100%'\r\n    });\r\n    this.dialogBox['minWidth'] = '100%';\r\n    this.dialogBox['minHeight'] = '100%';\r\n    this.dialogBox['draggable'] = false;\r\n    this.dialogBox['resizable'] = false;\r\n    if (this.resizable) {\r\n      this.renderer.setStyle(this.overlayElement, 'margin', '0 0 0 0');\r\n    }\r\n    if (this.draggable) {\r\n      this.dialogBox['distance'] = { x: 0, y: 0 };\r\n    }\r\n  }\r\n\r\n  onMinimize() {\r\n    this.dialogBox['minWidth'] = this.minWidth;\r\n    this.dialogBox['minHeight'] = this.minHeight;\r\n    this.dialogBox['draggable'] = this.draggable;\r\n    this.dialogBox['resizable'] = this.resizable;\r\n    this.dialogRef.overlayRef?.updateSize({\r\n      width: this.dialogBox['width'],\r\n      height: this.dialogBox['height'],\r\n      minWidth: this.dialogBox['minWidth'],\r\n      minHeight: this.dialogBox['minHeight']\r\n    });\r\n    if (this.draggable) {\r\n      this.dialogBox['distance'] = { ...this.distance };\r\n    }\r\n    if (this.resizable) {\r\n      if (this.dialogBox['marginTop']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-top', `${this.dialogBox['marginTop']}`);\r\n      }\r\n      if (this.dialogBox['marginLeft']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-left', `${this.dialogBox['marginLeft']}`);\r\n      }\r\n      if (this.dialogBox['marginRight']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-right', `${this.dialogBox['marginRight']}`);\r\n      }\r\n      if (this.dialogBox['marginBottom']) {\r\n        this.renderer.setStyle(this.overlayElement, 'margin-bottom', `${this.dialogBox['marginBottom']}`);\r\n      }\r\n    }\r\n  }\r\n\r\n  moveDone($event: { toState: string }) {\r\n    if ($event.toState === 'void') {\r\n      this.closeDone.emit($event);\r\n      this.isMaximize = false;\r\n      this.dialogBox = {\r\n        draggable: this.draggable,\r\n        resizable: this.resizable\r\n      };\r\n      this.distance = { x: 0, y: 0 };\r\n      this.dialogRef?.overlayRef?.dispose();\r\n    } else {\r\n      this.showDone.emit($event);\r\n    }\r\n  }\r\n\r\n  onResizing(event: XResizableEvent) {\r\n    const contentHeight = Number(this.initContentHeight) + Number(event.clientHeight) - Number(this.initHeight);\r\n    this.renderer.setStyle(this.dialogContent, 'max-height', 'initial');\r\n    this.renderer.setStyle(this.dialogContent, 'flex', 'initial');\r\n    if (['top-start', 'top-end', 'bottom', 'top', 'bottom-start', 'bottom-end'].includes(event.direction as string)) {\r\n      this.renderer.setStyle(this.dialogContent, 'height', `${contentHeight}px`);\r\n    }\r\n  }\r\n}\r\n","<ng-template #dialogTpl>\r\n  <div\r\n    class=\"x-dialog\"\r\n    [@x-move-box-animation]=\"placement\"\r\n    (@x-move-box-animation.done)=\"moveDone($event)\"\r\n    [class.x-dialog-maximize]=\"isMaximize\"\r\n    [class.x-dialog-resizable]=\"resizable\"\r\n    [class.x-dialog-default-maximize]=\"isDefaultMaximize\"\r\n  >\r\n    <x-alert\r\n      [draggable]=\"draggable && dialogBox['draggable']\"\r\n      [resizable]=\"resizable && dialogBox['resizable']\"\r\n      [dragFreeDragPosition]=\"dialogBox['distance']\"\r\n      [offsetLeft]=\"offsetLeft\"\r\n      [offsetTop]=\"offsetTop\"\r\n      [minWidth]=\"dialogBox['minWidth']\"\r\n      [minHeight]=\"dialogBox['minHeight']\"\r\n      [dragBoundary]=\"'.cdk-overlay-container'\"\r\n      [title]=\"title\"\r\n      [content]=\"contentTpl\"\r\n      [type]=\"type\"\r\n      [effect]=\"effect\"\r\n      [hideClose]=\"hideClose\"\r\n      [closeText]=\"closeText\"\r\n      [operationTpl]=\"operationTpl\"\r\n      (close)=\"onClose('close')\"\r\n      (dragEnded)=\"onDragEnded($event)\"\r\n      (resizing)=\"onResizing($event)\"\r\n      showIcon=\"false\"\r\n      duration=\"0\"\r\n      manual\r\n      disabledAnimation\r\n    ></x-alert>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #contentTpl>\r\n  <div class=\"x-dialog-inner\">\r\n    <div class=\"x-dialog-content\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n    <div class=\"x-dialog-buttons\" [class.x-dialog-buttons-center]=\"buttonsCenter\">\r\n      <ng-container *xOutlet=\"footer\">\r\n        <x-buttons space=\"1\" *ngIf=\"showCancel || showConfirm\">\r\n          <x-button *ngIf=\"showCancel\" (click)=\"onClose('cancel')\">{{ getCancelText }}</x-button>\r\n          <x-button *ngIf=\"showConfirm\" type=\"primary\" (click)=\"onClose('confirm')\">{{ getConfirmText }}</x-button>\r\n        </x-buttons>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #operationTpl>\r\n  <ng-container *ngIf=\"maximize || resizable\">\r\n    <x-button size=\"small\" [icon]=\"isMaximize ? 'fto-minimize' : 'fto-maximize'\" [onlyIcon]=\"true\" (click)=\"onSize()\"></x-button>\r\n  </ng-container>\r\n</ng-template>\r\n"]}