@ng-nest/ui 14.0.4 → 14.0.7

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 (179) hide show
  1. package/calendar/calendar.component.d.ts +1 -0
  2. package/calendar/calendar.property.d.ts +18 -4
  3. package/calendar/examples/en_US/default/card/README.md +6 -0
  4. package/calendar/examples/en_US/default/header/README.md +6 -0
  5. package/calendar/examples/zh_CN/default/card/README.md +6 -0
  6. package/calendar/examples/zh_CN/default/header/README.md +6 -0
  7. package/collapse/collapse.property.d.ts +6 -1
  8. package/collapse/examples/en_US/default/disabled/README.md +6 -0
  9. package/collapse/examples/zh_CN/default/disabled/README.md +6 -0
  10. package/core/config/config.d.ts +8 -0
  11. package/core/functions/convert.d.ts +1 -1
  12. package/dropdown/dropdown-portal.component.d.ts +3 -0
  13. package/dropdown/dropdown.property.d.ts +16 -1
  14. package/esm2020/badge/badge.component.mjs +3 -3
  15. package/esm2020/calendar/calendar.component.mjs +8 -4
  16. package/esm2020/calendar/calendar.property.mjs +11 -2
  17. package/esm2020/collapse/collapse-panel.component.mjs +3 -3
  18. package/esm2020/collapse/collapse.property.mjs +7 -2
  19. package/esm2020/core/config/config.mjs +1 -1
  20. package/esm2020/core/functions/convert.mjs +1 -1
  21. package/esm2020/date-picker/date-picker.component.mjs +5 -1
  22. package/esm2020/dropdown/dropdown-portal.component.mjs +6 -3
  23. package/esm2020/dropdown/dropdown.component.mjs +4 -1
  24. package/esm2020/dropdown/dropdown.property.mjs +8 -2
  25. package/esm2020/i18n/i18n.property.mjs +1 -1
  26. package/esm2020/i18n/languages/en_US.mjs +7 -2
  27. package/esm2020/i18n/languages/zh_CN.mjs +7 -2
  28. package/esm2020/i18n/languages/zh_TW.mjs +7 -2
  29. package/esm2020/image/image-group.component.mjs +18 -0
  30. package/esm2020/image/image-preview.component.mjs +136 -0
  31. package/esm2020/image/image.component.mjs +81 -0
  32. package/esm2020/image/image.module.mjs +26 -0
  33. package/esm2020/image/image.property.mjs +63 -0
  34. package/esm2020/image/ng-nest-ui-image.mjs +5 -0
  35. package/esm2020/image/public-api.mjs +6 -0
  36. package/esm2020/index.mjs +2 -1
  37. package/esm2020/input/input.component.mjs +2 -2
  38. package/esm2020/list/list.component.mjs +99 -13
  39. package/esm2020/list/list.module.mjs +8 -4
  40. package/esm2020/list/list.property.mjs +52 -2
  41. package/esm2020/loading/loading.component.mjs +3 -3
  42. package/esm2020/loading/loading.property.mjs +7 -2
  43. package/esm2020/popover/popover.directive.mjs +20 -3
  44. package/esm2020/popover/popover.property.mjs +1 -1
  45. package/esm2020/select/select.component.mjs +14 -6
  46. package/esm2020/slider/slider.component.mjs +27 -7
  47. package/esm2020/slider/slider.module.mjs +5 -4
  48. package/esm2020/slider/slider.property.mjs +13 -2
  49. package/esm2020/table/table-body.component.mjs +3 -3
  50. package/esm2020/table/table-head.component.mjs +4 -4
  51. package/esm2020/table/table.component.mjs +35 -4
  52. package/esm2020/table/table.property.mjs +8 -4
  53. package/esm2020/tabs/tabs.component.mjs +3 -3
  54. package/esm2020/tabs/tabs.property.mjs +13 -2
  55. package/esm2020/textarea/textarea.component.mjs +2 -2
  56. package/esm2020/timeline/timeline.component.mjs +6 -4
  57. package/fesm2015/ng-nest-ui-badge.mjs +2 -2
  58. package/fesm2015/ng-nest-ui-badge.mjs.map +1 -1
  59. package/fesm2015/ng-nest-ui-calendar.mjs +17 -4
  60. package/fesm2015/ng-nest-ui-calendar.mjs.map +1 -1
  61. package/fesm2015/ng-nest-ui-collapse.mjs +8 -3
  62. package/fesm2015/ng-nest-ui-collapse.mjs.map +1 -1
  63. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  64. package/fesm2015/ng-nest-ui-date-picker.mjs +4 -0
  65. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  66. package/fesm2015/ng-nest-ui-dropdown.mjs +15 -3
  67. package/fesm2015/ng-nest-ui-dropdown.mjs.map +1 -1
  68. package/fesm2015/ng-nest-ui-i18n.mjs +18 -3
  69. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  70. package/fesm2015/ng-nest-ui-image.mjs +312 -0
  71. package/fesm2015/ng-nest-ui-image.mjs.map +1 -0
  72. package/fesm2015/ng-nest-ui-input.mjs +2 -2
  73. package/fesm2015/ng-nest-ui-input.mjs.map +1 -1
  74. package/fesm2015/ng-nest-ui-list.mjs +155 -15
  75. package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
  76. package/fesm2015/ng-nest-ui-loading.mjs +8 -3
  77. package/fesm2015/ng-nest-ui-loading.mjs.map +1 -1
  78. package/fesm2015/ng-nest-ui-popover.mjs +19 -2
  79. package/fesm2015/ng-nest-ui-popover.mjs.map +1 -1
  80. package/fesm2015/ng-nest-ui-select.mjs +14 -6
  81. package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
  82. package/fesm2015/ng-nest-ui-slider.mjs +43 -11
  83. package/fesm2015/ng-nest-ui-slider.mjs.map +1 -1
  84. package/fesm2015/ng-nest-ui-table.mjs +46 -11
  85. package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
  86. package/fesm2015/ng-nest-ui-tabs.mjs +14 -3
  87. package/fesm2015/ng-nest-ui-tabs.mjs.map +1 -1
  88. package/fesm2015/ng-nest-ui-textarea.mjs +2 -2
  89. package/fesm2015/ng-nest-ui-textarea.mjs.map +1 -1
  90. package/fesm2015/ng-nest-ui-timeline.mjs +5 -3
  91. package/fesm2015/ng-nest-ui-timeline.mjs.map +1 -1
  92. package/fesm2015/ng-nest-ui.mjs +1 -0
  93. package/fesm2015/ng-nest-ui.mjs.map +1 -1
  94. package/fesm2020/ng-nest-ui-badge.mjs +2 -2
  95. package/fesm2020/ng-nest-ui-badge.mjs.map +1 -1
  96. package/fesm2020/ng-nest-ui-calendar.mjs +17 -4
  97. package/fesm2020/ng-nest-ui-calendar.mjs.map +1 -1
  98. package/fesm2020/ng-nest-ui-collapse.mjs +8 -3
  99. package/fesm2020/ng-nest-ui-collapse.mjs.map +1 -1
  100. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  101. package/fesm2020/ng-nest-ui-date-picker.mjs +4 -0
  102. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  103. package/fesm2020/ng-nest-ui-dropdown.mjs +15 -3
  104. package/fesm2020/ng-nest-ui-dropdown.mjs.map +1 -1
  105. package/fesm2020/ng-nest-ui-i18n.mjs +18 -3
  106. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  107. package/fesm2020/ng-nest-ui-image.mjs +308 -0
  108. package/fesm2020/ng-nest-ui-image.mjs.map +1 -0
  109. package/fesm2020/ng-nest-ui-input.mjs +2 -2
  110. package/fesm2020/ng-nest-ui-input.mjs.map +1 -1
  111. package/fesm2020/ng-nest-ui-list.mjs +154 -15
  112. package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
  113. package/fesm2020/ng-nest-ui-loading.mjs +8 -3
  114. package/fesm2020/ng-nest-ui-loading.mjs.map +1 -1
  115. package/fesm2020/ng-nest-ui-popover.mjs +19 -2
  116. package/fesm2020/ng-nest-ui-popover.mjs.map +1 -1
  117. package/fesm2020/ng-nest-ui-select.mjs +14 -6
  118. package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
  119. package/fesm2020/ng-nest-ui-slider.mjs +43 -11
  120. package/fesm2020/ng-nest-ui-slider.mjs.map +1 -1
  121. package/fesm2020/ng-nest-ui-table.mjs +46 -11
  122. package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
  123. package/fesm2020/ng-nest-ui-tabs.mjs +14 -3
  124. package/fesm2020/ng-nest-ui-tabs.mjs.map +1 -1
  125. package/fesm2020/ng-nest-ui-textarea.mjs +2 -2
  126. package/fesm2020/ng-nest-ui-textarea.mjs.map +1 -1
  127. package/fesm2020/ng-nest-ui-timeline.mjs +5 -3
  128. package/fesm2020/ng-nest-ui-timeline.mjs.map +1 -1
  129. package/fesm2020/ng-nest-ui.mjs +1 -0
  130. package/fesm2020/ng-nest-ui.mjs.map +1 -1
  131. package/i18n/i18n.property.d.ts +6 -0
  132. package/i18n/languages/en_US.d.ts +5 -0
  133. package/i18n/languages/zh_CN.d.ts +5 -0
  134. package/i18n/languages/zh_TW.d.ts +5 -0
  135. package/image/examples/en_US/default/README.md +4 -0
  136. package/image/examples/en_US/default/default/README.md +6 -0
  137. package/image/examples/en_US/default/fallback/README.md +6 -0
  138. package/image/examples/en_US/default/group/README.md +6 -0
  139. package/image/examples/en_US/default/placeholder/README.md +6 -0
  140. package/image/examples/zh_CN/default/README.md +4 -0
  141. package/image/examples/zh_CN/default/default/README.md +6 -0
  142. package/image/examples/zh_CN/default/fallback/README.md +6 -0
  143. package/image/examples/zh_CN/default/group/README.md +6 -0
  144. package/image/examples/zh_CN/default/placeholder/README.md +6 -0
  145. package/image/image-group.component.d.ts +8 -0
  146. package/image/image-preview.component.d.ts +39 -0
  147. package/image/image.component.d.ts +29 -0
  148. package/image/image.module.d.ts +16 -0
  149. package/image/image.property.d.ts +96 -0
  150. package/image/index.d.ts +5 -0
  151. package/image/public-api.d.ts +5 -0
  152. package/index.d.ts +1 -0
  153. package/list/examples/en_US/default/load-more/README.md +8 -0
  154. package/list/examples/en_US/default/scroll/README.md +8 -0
  155. package/list/examples/zh_CN/default/load-more/README.md +8 -0
  156. package/list/examples/zh_CN/default/scroll/README.md +8 -0
  157. package/list/list.component.d.ts +19 -1
  158. package/list/list.module.d.ts +2 -1
  159. package/list/list.property.d.ts +59 -2
  160. package/loading/loading.property.d.ts +7 -2
  161. package/package.json +9 -1
  162. package/popover/popover.directive.d.ts +4 -3
  163. package/popover/popover.property.d.ts +1 -1
  164. package/slider/examples/en_US/default/expand/README.md +7 -0
  165. package/slider/examples/zh_CN/default/expand/README.md +7 -0
  166. package/slider/slider.component.d.ts +2 -0
  167. package/slider/slider.module.d.ts +2 -1
  168. package/slider/slider.property.d.ts +11 -1
  169. package/table/examples/en_US/default/edit/README.md +7 -0
  170. package/table/examples/en_US/default/header/README.md +2 -2
  171. package/table/examples/en_US/default/search/README.md +6 -0
  172. package/table/examples/zh_CN/default/edit/README.md +7 -0
  173. package/table/examples/zh_CN/default/header/README.md +2 -2
  174. package/table/examples/zh_CN/default/search/README.md +6 -0
  175. package/table/table.component.d.ts +5 -0
  176. package/table/table.property.d.ts +13 -3
  177. package/tabs/examples/en_US/default/expand/README.md +6 -0
  178. package/tabs/examples/zh_CN/default/expand/README.md +6 -0
  179. package/tabs/tabs.property.d.ts +11 -1
@@ -7,7 +7,9 @@ import * as i0 from "@angular/core";
7
7
  import * as i1 from "@ng-nest/ui/core";
8
8
  import * as i2 from "@angular/common";
9
9
  import * as i3 from "@ng-nest/ui/link";
10
- import * as i4 from "@ng-nest/ui/outlet";
10
+ import * as i4 from "@ng-nest/ui/button";
11
+ import * as i5 from "@ng-nest/ui/outlet";
12
+ import * as i6 from "@ng-nest/ui/dropdown";
11
13
  export class XSliderComponent extends XSliderProperty {
12
14
  constructor(renderer, elementRef, cdr, configService) {
13
15
  super();
@@ -19,6 +21,7 @@ export class XSliderComponent extends XSliderProperty {
19
21
  this.scrollClassMap = {};
20
22
  this.nodeClassMap = {};
21
23
  this.showArrow = false;
24
+ this.activatedId = '';
22
25
  this._offset = 0;
23
26
  this.direction = 'right';
24
27
  this.maxOffset = 0;
@@ -92,12 +95,19 @@ export class XSliderComponent extends XSliderProperty {
92
95
  this.setDirection(index, Number(this.activatedIndex));
93
96
  this.activatedIndex = index;
94
97
  this.activated = node;
98
+ this.activatedId = node.id;
95
99
  this.setHighlight();
96
100
  this.setTranslate();
97
101
  this.indexChange.emit(index);
98
102
  this.nodeChange.emit(node);
99
103
  }
104
+ dropdownClick(node) {
105
+ const index = this.nodes.indexOf(node);
106
+ this.nodeClick(node, index);
107
+ }
100
108
  scrollPrev() {
109
+ if (this.offset === 0)
110
+ return;
101
111
  const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];
102
112
  const currentOffset = this.offset;
103
113
  if (!currentOffset)
@@ -106,6 +116,8 @@ export class XSliderComponent extends XSliderProperty {
106
116
  this.offset = offset;
107
117
  }
108
118
  scrollNext() {
119
+ if (this.offset === this.maxOffset)
120
+ return;
109
121
  const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];
110
122
  const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];
111
123
  const currentOffset = this.offset;
@@ -151,9 +163,14 @@ export class XSliderComponent extends XSliderProperty {
151
163
  offset = currentOffset + (moveRect.bottom - sliderRect.bottom);
152
164
  }
153
165
  }
154
- this.maxOffset = Math.floor(maxOffset);
155
- offset = Math.max(offset, 0);
156
- this.offset = Math.min(offset, maxOffset);
166
+ this.maxOffset = Math.ceil(maxOffset);
167
+ offset = Math.max(Math.ceil(offset), 0);
168
+ if ([this.maxOffset + 1, this.maxOffset - 1].includes(offset)) {
169
+ this.offset = this.maxOffset;
170
+ }
171
+ else {
172
+ this.offset = Math.min(offset, this.maxOffset);
173
+ }
157
174
  }
158
175
  sizeChecked() {
159
176
  const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];
@@ -171,6 +188,9 @@ export class XSliderComponent extends XSliderProperty {
171
188
  setActivated() {
172
189
  if (this.nodes.length > 0) {
173
190
  this.activated = this.nodes[Number(this.activatedIndex)];
191
+ if (this.activated) {
192
+ this.activatedId = this.activated.id;
193
+ }
174
194
  }
175
195
  this.setHighlight();
176
196
  this.setTranslate();
@@ -204,10 +224,10 @@ export class XSliderComponent extends XSliderProperty {
204
224
  }
205
225
  }
206
226
  /** @nocollapse */ XSliderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
207
- /** @nocollapse */ XSliderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSliderComponent, selector: "x-slider", viewQueries: [{ propertyName: "sliderScroll", first: true, predicate: ["sliderScroll"], descendants: true }, { propertyName: "sliderNodes", first: true, predicate: ["sliderNodes"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\" [class.x-slider-activated]=\"getActivated(i)\" [class.x-slider-disabled]=\"node.disabled\" [title]=\"node.label\">\r\n <x-link (click)=\"nodeClick(node, i)\" [ngClass]=\"nodeClassMap\">\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.XLinkComponent, selector: "x-link" }, { kind: "directive", type: i4.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
227
+ /** @nocollapse */ XSliderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSliderComponent, selector: "x-slider", viewQueries: [{ propertyName: "sliderScroll", first: true, predicate: ["sliderScroll"], descendants: true }, { propertyName: "sliderNodes", first: true, predicate: ["sliderNodes"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link (click)=\"nodeClick(node, i)\" [ngClass]=\"nodeClassMap\">\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.XLinkComponent, selector: "x-link" }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i5.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i6.XDropdownComponent, selector: "x-dropdown" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
208
228
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderComponent, decorators: [{
209
229
  type: Component,
210
- args: [{ selector: `${XSliderPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\" [class.x-slider-activated]=\"getActivated(i)\" [class.x-slider-disabled]=\"node.disabled\" [title]=\"node.label\">\r\n <x-link (click)=\"nodeClick(node, i)\" [ngClass]=\"nodeClassMap\">\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"] }]
230
+ args: [{ selector: `${XSliderPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link (click)=\"nodeClick(node, i)\" [ngClass]=\"nodeClassMap\">\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"] }]
211
231
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { sliderScroll: [{
212
232
  type: ViewChild,
213
233
  args: ['sliderScroll']
@@ -215,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
215
235
  type: ViewChild,
216
236
  args: ['sliderNodes']
217
237
  }] } });
218
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider/slider.component.ts","../../../../../lib/ng-nest/ui/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  SimpleChange\r\n} from '@angular/core';\r\nimport { XSliderPrefix, XSliderNode, XSliderProperty } from './slider.property';\r\nimport { XClassMap, XIsChange, XResize, XPosition, XIsUndefined, XIsEmpty, XSetData, XConfigService } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XSliderPrefix}`,\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XSliderComponent extends XSliderProperty implements OnInit, OnChanges, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderScroll') sliderScroll!: ElementRef;\r\n  @ViewChild('sliderNodes') sliderNodes!: ElementRef;\r\n  nodes: XSliderNode[] = [];\r\n  activated!: XSliderNode;\r\n  scrollClassMap: XClassMap = {};\r\n  nodeClassMap: XClassMap = {};\r\n  showArrow = false;\r\n  private _offset: number = 0;\r\n  get offset(): number {\r\n    return this._offset;\r\n  }\r\n  set offset(value: number) {\r\n    this._offset = Math.floor(value);\r\n    this.transform = `translate${this.dir}(-${this._offset}px)`;\r\n    this.cdr.detectChanges();\r\n  }\r\n  direction: XPosition = 'right';\r\n  maxOffset: number = 0;\r\n  get dir(): 'X' | 'Y' {\r\n    return this.layout === 'row' ? 'X' : 'Y';\r\n  }\r\n  get sizeName() {\r\n    return this.layout === 'row' ? 'Width' : 'Height';\r\n  }\r\n  transform?: string;\r\n  highlightBox = {\r\n    width: '',\r\n    height: '',\r\n    left: '',\r\n    top: ''\r\n  };\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data, layout, justify, nodeJustify, activatedIndex } = changes;\r\n    XIsChange(data) && this.setData();\r\n    XIsChange(layout) && this.setChange(this.classMap, layout);\r\n    XIsChange(justify) && this.setChange(this.scrollClassMap, justify, 'x-justify');\r\n    XIsChange(nodeJustify) && this.setChange(this.nodeClassMap, nodeJustify, 'x-justify');\r\n    XIsChange(activatedIndex) && this.setDirection(activatedIndex.currentValue, activatedIndex.previousValue) && this.setActivated();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setSubscribe();\r\n    this.setActivated();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XSliderPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n    this.scrollClassMap[`x-justify-${this.justify}`] = !XIsEmpty(this.justify);\r\n    this.nodeClassMap = {\r\n      [`x-justify-${this.nodeJustify}`]: !XIsEmpty(this.nodeJustify),\r\n      [`x-size-${this.size}`]: !XIsEmpty(this.size)\r\n    };\r\n  }\r\n\r\n  setChange(map: XClassMap, change: SimpleChange, prefix = XSliderPrefix) {\r\n    map[`${prefix}-${change.previousValue}`] = false;\r\n    map[`${prefix}-${change.currentValue}`] = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setSubscribe() {\r\n    XResize(this.sliderScroll.nativeElement, this.sliderNodes.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.sizeChecked();\r\n        this.setActivated();\r\n      });\r\n  }\r\n\r\n  nodeClick(node: XSliderNode, index: number) {\r\n    if (node.disabled) return;\r\n    this.setDirection(index, Number(this.activatedIndex));\r\n    this.activatedIndex = index;\r\n    this.activated = node;\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n    this.indexChange.emit(index);\r\n    this.nodeChange.emit(node);\r\n  }\r\n\r\n  scrollPrev() {\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (!currentOffset) return;\r\n    const offset = currentOffset > scrollSize ? currentOffset - scrollSize : 0;\r\n    this.offset = offset;\r\n  }\r\n\r\n  scrollNext() {\r\n    const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (sliderSize - currentOffset <= scrollSize) return;\r\n    const offset = sliderSize - currentOffset > scrollSize * 2 ? currentOffset + scrollSize : sliderSize - scrollSize;\r\n    this.offset = offset;\r\n  }\r\n\r\n  setDirection(index: number, before: number) {\r\n    const increase = index > before;\r\n    this.direction = this.layout === 'row' ? (increase ? 'right' : 'left') : increase ? 'bottom' : 'top';\r\n    return this.direction;\r\n  }\r\n\r\n  setTranslate() {\r\n    if (XIsUndefined(this.sliderScroll) || XIsUndefined(this.sliderNodes)) return;\r\n    const sliderRect = this.sliderScroll.nativeElement?.getBoundingClientRect();\r\n    const sliderNodesRect = this.sliderNodes.nativeElement?.getBoundingClientRect();\r\n    let moveIndex = ['bottom', 'right'].indexOf(this.direction) !== -1 ? Number(this.activatedIndex) + 2 : Number(this.activatedIndex);\r\n    moveIndex = moveIndex > this.nodes.length ? this.nodes.length : moveIndex === 0 ? 1 : moveIndex;\r\n    let moveEle = this.sliderNodes.nativeElement?.querySelector(`li:nth-child(${moveIndex})`);\r\n    let maxOffset = 0;\r\n    if (XIsEmpty(moveEle)) return;\r\n    const moveRect = moveEle.getBoundingClientRect();\r\n    const currentOffset = this.offset;\r\n    let offset = currentOffset;\r\n    if (this.layout === 'row') {\r\n      maxOffset = sliderNodesRect.width - sliderRect.width;\r\n      if (moveRect.left < sliderRect.left) {\r\n        offset = currentOffset - (sliderRect.left - moveRect.left);\r\n      }\r\n      if (moveRect.right > sliderRect.right) {\r\n        offset = currentOffset + moveRect.right - sliderRect.right;\r\n      }\r\n    } else {\r\n      maxOffset = sliderNodesRect.height - sliderRect.height;\r\n      if (moveRect.top < sliderRect.top) {\r\n        offset = currentOffset - (sliderRect.top - moveRect.top);\r\n      }\r\n      if (moveRect.bottom > sliderRect.bottom) {\r\n        offset = currentOffset + (moveRect.bottom - sliderRect.bottom);\r\n      }\r\n    }\r\n    this.maxOffset = Math.floor(maxOffset);\r\n    offset = Math.max(offset, 0);\r\n    this.offset = Math.min(offset, maxOffset);\r\n  }\r\n\r\n  sizeChecked() {\r\n    const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const showArrow = this.nodes.length > 1 && size > scrollSize;\r\n    if (this.showArrow !== showArrow) {\r\n      this.showArrow = showArrow;\r\n      this.classMap[`${XSliderPrefix}-show-arrow`] = this.showArrow;\r\n      if (!this.showArrow) {\r\n        this.offset = 0;\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  setActivated() {\r\n    if (this.nodes.length > 0) {\r\n      this.activated = this.nodes[Number(this.activatedIndex)];\r\n    }\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n  }\r\n\r\n  setHighlight() {\r\n    if (XIsUndefined(this.sliderNodes)) return;\r\n    const activeEle = this.sliderNodes.nativeElement.querySelector(`li:nth-child(${Number(this.activatedIndex) + 1})`);\r\n    if (!activeEle) return;\r\n    this.highlightBox = {\r\n      width: `${activeEle.offsetWidth}px`,\r\n      height: `${activeEle.offsetHeight}px`,\r\n      left: `${activeEle.offsetLeft}px`,\r\n      top: `${activeEle.offsetTop}px`\r\n    };\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setData() {\r\n    XSetData<XSliderNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.cdr.detectChanges();\r\n      setTimeout(() => this.setActivated());\r\n    });\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.activatedIndex) === index;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XSliderNode) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n  <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n  <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n    <ul #sliderNodes [style.transform]=\"transform\">\r\n      <li *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\" [class.x-slider-activated]=\"getActivated(i)\" [class.x-slider-disabled]=\"node.disabled\" [title]=\"node.label\">\r\n        <x-link (click)=\"nodeClick(node, i)\" [ngClass]=\"nodeClassMap\">\r\n          <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n          <ng-container *ngIf=\"!nodeTpl\">\r\n            <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n          </ng-container>\r\n        </x-link>\r\n      </li>\r\n      <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n    </ul>\r\n  </div>\r\n  <x-link\r\n    *ngIf=\"showArrow\"\r\n    [disabled]=\"offset === maxOffset\"\r\n    class=\"x-slider-arrow-right\"\r\n    icon=\"fto-chevron-right\"\r\n    (click)=\"scrollNext()\"\r\n  ></x-link>\r\n</div>\r\n"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider/slider.component.ts","../../../../../lib/ng-nest/ui/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  SimpleChange\r\n} from '@angular/core';\r\nimport { XSliderPrefix, XSliderNode, XSliderProperty } from './slider.property';\r\nimport { XClassMap, XIsChange, XResize, XPosition, XIsUndefined, XIsEmpty, XSetData, XConfigService } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XSliderPrefix}`,\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XSliderComponent extends XSliderProperty implements OnInit, OnChanges, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderScroll') sliderScroll!: ElementRef;\r\n  @ViewChild('sliderNodes') sliderNodes!: ElementRef;\r\n  nodes: XSliderNode[] = [];\r\n  activated!: XSliderNode;\r\n  scrollClassMap: XClassMap = {};\r\n  nodeClassMap: XClassMap = {};\r\n  showArrow = false;\r\n  activatedId = '';\r\n  private _offset: number = 0;\r\n  get offset(): number {\r\n    return this._offset;\r\n  }\r\n  set offset(value: number) {\r\n    this._offset = Math.floor(value);\r\n    this.transform = `translate${this.dir}(-${this._offset}px)`;\r\n    this.cdr.detectChanges();\r\n  }\r\n  direction: XPosition = 'right';\r\n  maxOffset: number = 0;\r\n  get dir(): 'X' | 'Y' {\r\n    return this.layout === 'row' ? 'X' : 'Y';\r\n  }\r\n  get sizeName() {\r\n    return this.layout === 'row' ? 'Width' : 'Height';\r\n  }\r\n  transform?: string;\r\n  highlightBox = {\r\n    width: '',\r\n    height: '',\r\n    left: '',\r\n    top: ''\r\n  };\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data, layout, justify, nodeJustify, activatedIndex } = changes;\r\n    XIsChange(data) && this.setData();\r\n    XIsChange(layout) && this.setChange(this.classMap, layout);\r\n    XIsChange(justify) && this.setChange(this.scrollClassMap, justify, 'x-justify');\r\n    XIsChange(nodeJustify) && this.setChange(this.nodeClassMap, nodeJustify, 'x-justify');\r\n    XIsChange(activatedIndex) && this.setDirection(activatedIndex.currentValue, activatedIndex.previousValue) && this.setActivated();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setSubscribe();\r\n    this.setActivated();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XSliderPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n    this.scrollClassMap[`x-justify-${this.justify}`] = !XIsEmpty(this.justify);\r\n    this.nodeClassMap = {\r\n      [`x-justify-${this.nodeJustify}`]: !XIsEmpty(this.nodeJustify),\r\n      [`x-size-${this.size}`]: !XIsEmpty(this.size)\r\n    };\r\n  }\r\n\r\n  setChange(map: XClassMap, change: SimpleChange, prefix = XSliderPrefix) {\r\n    map[`${prefix}-${change.previousValue}`] = false;\r\n    map[`${prefix}-${change.currentValue}`] = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setSubscribe() {\r\n    XResize(this.sliderScroll.nativeElement, this.sliderNodes.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.sizeChecked();\r\n        this.setActivated();\r\n      });\r\n  }\r\n\r\n  nodeClick(node: XSliderNode, index: number) {\r\n    if (node.disabled) return;\r\n    this.setDirection(index, Number(this.activatedIndex));\r\n    this.activatedIndex = index;\r\n    this.activated = node;\r\n    this.activatedId = node.id;\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n    this.indexChange.emit(index);\r\n    this.nodeChange.emit(node);\r\n  }\r\n\r\n  dropdownClick(node: XSliderNode) {\r\n    const index = this.nodes.indexOf(node);\r\n    this.nodeClick(node, index);\r\n  }\r\n\r\n  scrollPrev() {\r\n    if (this.offset === 0) return;\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (!currentOffset) return;\r\n    const offset = currentOffset > scrollSize ? currentOffset - scrollSize : 0;\r\n    this.offset = offset;\r\n  }\r\n\r\n  scrollNext() {\r\n    if (this.offset === this.maxOffset) return;\r\n    const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (sliderSize - currentOffset <= scrollSize) return;\r\n    const offset = sliderSize - currentOffset > scrollSize * 2 ? currentOffset + scrollSize : sliderSize - scrollSize;\r\n    this.offset = offset;\r\n  }\r\n\r\n  setDirection(index: number, before: number) {\r\n    const increase = index > before;\r\n    this.direction = this.layout === 'row' ? (increase ? 'right' : 'left') : increase ? 'bottom' : 'top';\r\n    return this.direction;\r\n  }\r\n\r\n  setTranslate() {\r\n    if (XIsUndefined(this.sliderScroll) || XIsUndefined(this.sliderNodes)) return;\r\n    const sliderRect = this.sliderScroll.nativeElement?.getBoundingClientRect();\r\n    const sliderNodesRect = this.sliderNodes.nativeElement?.getBoundingClientRect();\r\n    let moveIndex = ['bottom', 'right'].indexOf(this.direction) !== -1 ? Number(this.activatedIndex) + 2 : Number(this.activatedIndex);\r\n    moveIndex = moveIndex > this.nodes.length ? this.nodes.length : moveIndex === 0 ? 1 : moveIndex;\r\n    let moveEle = this.sliderNodes.nativeElement?.querySelector(`li:nth-child(${moveIndex})`);\r\n    let maxOffset = 0;\r\n    if (XIsEmpty(moveEle)) return;\r\n    const moveRect = moveEle.getBoundingClientRect();\r\n    const currentOffset = this.offset;\r\n    let offset = currentOffset;\r\n    if (this.layout === 'row') {\r\n      maxOffset = sliderNodesRect.width - sliderRect.width;\r\n      if (moveRect.left < sliderRect.left) {\r\n        offset = currentOffset - (sliderRect.left - moveRect.left);\r\n      }\r\n      if (moveRect.right > sliderRect.right) {\r\n        offset = currentOffset + moveRect.right - sliderRect.right;\r\n      }\r\n    } else {\r\n      maxOffset = sliderNodesRect.height - sliderRect.height;\r\n      if (moveRect.top < sliderRect.top) {\r\n        offset = currentOffset - (sliderRect.top - moveRect.top);\r\n      }\r\n      if (moveRect.bottom > sliderRect.bottom) {\r\n        offset = currentOffset + (moveRect.bottom - sliderRect.bottom);\r\n      }\r\n    }\r\n    this.maxOffset = Math.ceil(maxOffset);\r\n    offset = Math.max(Math.ceil(offset), 0);\r\n    if ([this.maxOffset + 1, this.maxOffset - 1].includes(offset)) {\r\n      this.offset = this.maxOffset;\r\n    } else {\r\n      this.offset = Math.min(offset, this.maxOffset);\r\n    }\r\n  }\r\n\r\n  sizeChecked() {\r\n    const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const showArrow = this.nodes.length > 1 && size > scrollSize;\r\n    if (this.showArrow !== showArrow) {\r\n      this.showArrow = showArrow;\r\n      this.classMap[`${XSliderPrefix}-show-arrow`] = this.showArrow;\r\n      if (!this.showArrow) {\r\n        this.offset = 0;\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  setActivated() {\r\n    if (this.nodes.length > 0) {\r\n      this.activated = this.nodes[Number(this.activatedIndex)];\r\n      if (this.activated) {\r\n        this.activatedId = this.activated.id;\r\n      }\r\n    }\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n  }\r\n\r\n  setHighlight() {\r\n    if (XIsUndefined(this.sliderNodes)) return;\r\n    const activeEle = this.sliderNodes.nativeElement.querySelector(`li:nth-child(${Number(this.activatedIndex) + 1})`);\r\n    if (!activeEle) return;\r\n    this.highlightBox = {\r\n      width: `${activeEle.offsetWidth}px`,\r\n      height: `${activeEle.offsetHeight}px`,\r\n      left: `${activeEle.offsetLeft}px`,\r\n      top: `${activeEle.offsetTop}px`\r\n    };\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setData() {\r\n    XSetData<XSliderNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.cdr.detectChanges();\r\n      setTimeout(() => this.setActivated());\r\n    });\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.activatedIndex) === index;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XSliderNode) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n  <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n  <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n    <ul #sliderNodes [style.transform]=\"transform\">\r\n      <li\r\n        *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n        [class.x-slider-activated]=\"getActivated(i)\"\r\n        [class.x-slider-disabled]=\"node.disabled\"\r\n        [title]=\"node.label\"\r\n      >\r\n        <x-link (click)=\"nodeClick(node, i)\" [ngClass]=\"nodeClassMap\">\r\n          <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n          <ng-container *ngIf=\"!nodeTpl\">\r\n            <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n          </ng-container>\r\n        </x-link>\r\n      </li>\r\n      <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n    </ul>\r\n  </div>\r\n  <x-link\r\n    *ngIf=\"showArrow\"\r\n    [disabled]=\"offset === maxOffset\"\r\n    class=\"x-slider-arrow-right\"\r\n    icon=\"fto-chevron-right\"\r\n    (click)=\"scrollNext()\"\r\n  ></x-link>\r\n  <x-dropdown\r\n    *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n    class=\"x-slider-all\"\r\n    [data]=\"nodes\"\r\n    trigger=\"click\"\r\n    [(activatedId)]=\"activatedId\"\r\n    (nodeClick)=\"dropdownClick($event)\"\r\n    [portalMaxHeight]=\"expandMaxHeight\"\r\n  >\r\n    <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n  </x-dropdown>\r\n</div>\r\n"]}
@@ -5,18 +5,19 @@ import { XLinkModule } from '@ng-nest/ui/link';
5
5
  import { XButtonModule } from '@ng-nest/ui/button';
6
6
  import { XOutletModule } from '@ng-nest/ui/outlet';
7
7
  import { XSliderProperty } from './slider.property';
8
+ import { XDropdownModule } from '@ng-nest/ui/dropdown';
8
9
  import * as i0 from "@angular/core";
9
10
  export class XSliderModule {
10
11
  }
11
12
  /** @nocollapse */ XSliderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
- /** @nocollapse */ XSliderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: XSliderModule, declarations: [XSliderComponent, XSliderProperty], imports: [CommonModule, XLinkModule, XButtonModule, XOutletModule], exports: [XSliderComponent] });
13
- /** @nocollapse */ XSliderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderModule, imports: [CommonModule, XLinkModule, XButtonModule, XOutletModule] });
13
+ /** @nocollapse */ XSliderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: XSliderModule, declarations: [XSliderComponent, XSliderProperty], imports: [CommonModule, XLinkModule, XButtonModule, XOutletModule, XDropdownModule], exports: [XSliderComponent] });
14
+ /** @nocollapse */ XSliderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderModule, imports: [CommonModule, XLinkModule, XButtonModule, XOutletModule, XDropdownModule] });
14
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderModule, decorators: [{
15
16
  type: NgModule,
16
17
  args: [{
17
18
  declarations: [XSliderComponent, XSliderProperty],
18
19
  exports: [XSliderComponent],
19
- imports: [CommonModule, XLinkModule, XButtonModule, XOutletModule]
20
+ imports: [CommonModule, XLinkModule, XButtonModule, XOutletModule, XDropdownModule]
20
21
  }]
21
22
  }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3NsaWRlci9zbGlkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFPcEQsTUFBTSxPQUFPLGFBQWE7OzZIQUFiLGFBQWE7OEhBQWIsYUFBYSxpQkFKVCxnQkFBZ0IsRUFBRSxlQUFlLGFBRXRDLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLGFBQWEsYUFEdkQsZ0JBQWdCOzhIQUdmLGFBQWEsWUFGZCxZQUFZLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxhQUFhOzJGQUV0RCxhQUFhO2tCQUx6QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGdCQUFnQixFQUFFLGVBQWUsQ0FBQztvQkFDakQsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7b0JBQzNCLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLGFBQWEsQ0FBQztpQkFDbkUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBYU2xpZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9zbGlkZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgWExpbmtNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9saW5rJztcclxuaW1wb3J0IHsgWEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2J1dHRvbic7XHJcbmltcG9ydCB7IFhPdXRsZXRNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9vdXRsZXQnO1xyXG5pbXBvcnQgeyBYU2xpZGVyUHJvcGVydHkgfSBmcm9tICcuL3NsaWRlci5wcm9wZXJ0eSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1hTbGlkZXJDb21wb25lbnQsIFhTbGlkZXJQcm9wZXJ0eV0sXHJcbiAgZXhwb3J0czogW1hTbGlkZXJDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFhMaW5rTW9kdWxlLCBYQnV0dG9uTW9kdWxlLCBYT3V0bGV0TW9kdWxlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgWFNsaWRlck1vZHVsZSB7fVxyXG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3NsaWRlci9zbGlkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBT3ZELE1BQU0sT0FBTyxhQUFhOzs2SEFBYixhQUFhOzhIQUFiLGFBQWEsaUJBSlQsZ0JBQWdCLEVBQUUsZUFBZSxhQUV0QyxZQUFZLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsZUFBZSxhQUR4RSxnQkFBZ0I7OEhBR2YsYUFBYSxZQUZkLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxlQUFlOzJGQUV2RSxhQUFhO2tCQUx6QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGdCQUFnQixFQUFFLGVBQWUsQ0FBQztvQkFDakQsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7b0JBQzNCLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxlQUFlLENBQUM7aUJBQ3BGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgWFNsaWRlckNvbXBvbmVudCB9IGZyb20gJy4vc2xpZGVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFhMaW5rTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvbGluayc7XHJcbmltcG9ydCB7IFhCdXR0b25Nb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9idXR0b24nO1xyXG5pbXBvcnQgeyBYT3V0bGV0TW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvb3V0bGV0JztcclxuaW1wb3J0IHsgWFNsaWRlclByb3BlcnR5IH0gZnJvbSAnLi9zbGlkZXIucHJvcGVydHknO1xyXG5pbXBvcnQgeyBYRHJvcGRvd25Nb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9kcm9wZG93bic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1hTbGlkZXJDb21wb25lbnQsIFhTbGlkZXJQcm9wZXJ0eV0sXHJcbiAgZXhwb3J0czogW1hTbGlkZXJDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFhMaW5rTW9kdWxlLCBYQnV0dG9uTW9kdWxlLCBYT3V0bGV0TW9kdWxlLCBYRHJvcGRvd25Nb2R1bGVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYU2xpZGVyTW9kdWxlIHt9XHJcbiJdfQ==
@@ -53,7 +53,7 @@ export class XSliderProperty extends XProperty {
53
53
  }
54
54
  }
55
55
  /** @nocollapse */ XSliderProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
56
- /** @nocollapse */ XSliderProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSliderProperty, selector: "ng-component", inputs: { data: "data", animated: "animated", activatedIndex: "activatedIndex", layout: "layout", justify: "justify", nodeJustify: "nodeJustify", nodeTpl: "nodeTpl", size: "size" }, outputs: { indexChange: "indexChange", nodeChange: "nodeChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
56
+ /** @nocollapse */ XSliderProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSliderProperty, selector: "ng-component", inputs: { data: "data", animated: "animated", activatedIndex: "activatedIndex", layout: "layout", justify: "justify", nodeJustify: "nodeJustify", nodeTpl: "nodeTpl", size: "size", showExpand: "showExpand", expandMaxHeight: "expandMaxHeight" }, outputs: { indexChange: "indexChange", nodeChange: "nodeChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
57
57
  __decorate([
58
58
  XDataConvert()
59
59
  ], XSliderProperty.prototype, "data", void 0);
@@ -67,6 +67,13 @@ __decorate([
67
67
  __decorate([
68
68
  XWithConfig(X_CONFIG_NAME, 'medium')
69
69
  ], XSliderProperty.prototype, "size", void 0);
70
+ __decorate([
71
+ XWithConfig(X_CONFIG_NAME, false),
72
+ XInputBoolean()
73
+ ], XSliderProperty.prototype, "showExpand", void 0);
74
+ __decorate([
75
+ XWithConfig(X_CONFIG_NAME, '15rem')
76
+ ], XSliderProperty.prototype, "expandMaxHeight", void 0);
70
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderProperty, decorators: [{
71
78
  type: Component,
72
79
  args: [{ template: '' }]
@@ -86,9 +93,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
86
93
  type: Input
87
94
  }], size: [{
88
95
  type: Input
96
+ }], showExpand: [{
97
+ type: Input
98
+ }], expandMaxHeight: [{
99
+ type: Input
89
100
  }], indexChange: [{
90
101
  type: Output
91
102
  }], nodeChange: [{
92
103
  type: Output
93
104
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLnByb3BlcnR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvc2xpZGVyL3NsaWRlci5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUdMLFNBQVMsRUFFVCxZQUFZLEVBQ1osYUFBYSxFQUNiLFlBQVksRUFLWixXQUFXLEVBQ1osTUFBTSxrQkFBa0IsQ0FBQztBQUMxQixPQUFPLEVBQWUsS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVwRjs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLFVBQVUsQ0FBQztBQUN4QyxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUM7QUFFL0I7O0dBRUc7QUFFSCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxTQUFTO0lBRDlDOztRQUVFOzs7V0FHRztRQUNzQixTQUFJLEdBQXVCLEVBQUUsQ0FBQztRQU12RDs7O1dBR0c7UUFDc0IsbUJBQWMsR0FBWSxDQUFDLENBQUM7UUFDckQ7OztXQUdHO1FBQ00sV0FBTSxHQUFtQixLQUFLLENBQUM7UUFDeEM7OztXQUdHO1FBQ00sWUFBTyxHQUFjLE9BQU8sQ0FBQztRQUN0Qzs7O1dBR0c7UUFDTSxnQkFBVyxHQUFjLFFBQVEsQ0FBQztRQVczQzs7O1dBR0c7UUFDTyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFDbkQ7OztXQUdHO1FBQ08sZUFBVSxHQUFHLElBQUksWUFBWSxFQUFlLENBQUM7S0FDeEQ7OytIQW5EWSxlQUFlO21IQUFmLGVBQWUsb1VBREwsRUFBRTtBQU1FO0lBQWYsWUFBWSxFQUFFOzZDQUErQjtBQUtlO0lBQTVELFdBQVcsQ0FBVyxhQUFhLEVBQUUsSUFBSSxDQUFDO0lBQUUsYUFBYSxFQUFFO2lEQUFxQjtBQUtqRTtJQUFmLFlBQVksRUFBRTt1REFBNkI7QUF5QkM7SUFBNUMsV0FBVyxDQUFRLGFBQWEsRUFBRSxRQUFRLENBQUM7NkNBQWM7MkZBeEN4RCxlQUFlO2tCQUQzQixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRTs4QkFNQSxJQUFJO3NCQUE1QixLQUFLO2dCQUtnRSxRQUFRO3NCQUE3RSxLQUFLO2dCQUttQixjQUFjO3NCQUF0QyxLQUFLO2dCQUtHLE1BQU07c0JBQWQsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUs7Z0JBS0csV0FBVztzQkFBbkIsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUs7Z0JBS2dELElBQUk7c0JBQXpELEtBQUs7Z0JBS0ksV0FBVztzQkFBcEIsTUFBTTtnQkFLRyxVQUFVO3NCQUFuQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBYRGF0YSxcclxuICBYVGVtcGxhdGUsXHJcbiAgWFByb3BlcnR5LFxyXG4gIFhJZGVudGl0eVByb3BlcnR5LFxyXG4gIFhEYXRhQ29udmVydCxcclxuICBYSW5wdXRCb29sZWFuLFxyXG4gIFhJbnB1dE51bWJlcixcclxuICBYSnVzdGlmeSxcclxuICBYU2l6ZSxcclxuICBYTnVtYmVyLFxyXG4gIFhCb29sZWFuLFxyXG4gIFhXaXRoQ29uZmlnXHJcbn0gZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcbmltcG9ydCB7IFRlbXBsYXRlUmVmLCBJbnB1dCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIFNsaWRlclxyXG4gKiBAc2VsZWN0b3IgeC1zbGlkZXJcclxuICogQGRlY29yYXRvciBjb21wb25lbnRcclxuICovXHJcbmV4cG9ydCBjb25zdCBYU2xpZGVyUHJlZml4ID0gJ3gtc2xpZGVyJztcclxuY29uc3QgWF9DT05GSUdfTkFNRSA9ICdzbGlkZXInO1xyXG5cclxuLyoqXHJcbiAqIFNsaWRlciBQcm9wZXJ0eVxyXG4gKi9cclxuQENvbXBvbmVudCh7IHRlbXBsYXRlOiAnJyB9KVxyXG5leHBvcnQgY2xhc3MgWFNsaWRlclByb3BlcnR5IGV4dGVuZHMgWFByb3BlcnR5IHtcclxuICAvKipcclxuICAgKiBAemhfQ04g6IqC54K55pWw5o2uXHJcbiAgICogQGVuX1VTIE5vZGUgZGF0YVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYRGF0YUNvbnZlcnQoKSBkYXRhOiBYRGF0YTxYU2xpZGVyTm9kZT4gPSBbXTtcclxuICAvKipcclxuICAgKiBAemhfQ04g5ruR5Yqo5Yqo55S7XHJcbiAgICogQGVuX1VTIFNsaWRpbmcgYW5pbWF0aW9uXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhCb29sZWFuPihYX0NPTkZJR19OQU1FLCB0cnVlKSBAWElucHV0Qm9vbGVhbigpIGFuaW1hdGVkPzogWEJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOW9k+WJjea/gOa0u+eahOe0ouW8lVxyXG4gICAqIEBlbl9VUyBDdXJyZW50bHkgYWN0aXZlIGluZGV4XHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhJbnB1dE51bWJlcigpIGFjdGl2YXRlZEluZGV4OiBYTnVtYmVyID0gMDtcclxuICAvKipcclxuICAgKiBAemhfQ04g5o6S5YiX5pa55byPXHJcbiAgICogQGVuX1VTIEFycmFuZ2VtZW50XHJcbiAgICovXHJcbiAgQElucHV0KCkgbGF5b3V0PzogWFNsaWRlckxheW91dCA9ICdyb3cnO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlr7npvZDmlrnlvI9cclxuICAgKiBAZW5fVVMgQWxpZ25tZW50XHJcbiAgICovXHJcbiAgQElucHV0KCkganVzdGlmeT86IFhKdXN0aWZ5ID0gJ3N0YXJ0JztcclxuICAvKipcclxuICAgKiBAemhfQ04g6IqC54K55paH5a2X5a+56b2Q5pa55byPXHJcbiAgICogQGVuX1VTIE5vZGUgdGV4dCBhbGlnbm1lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBub2RlSnVzdGlmeT86IFhKdXN0aWZ5ID0gJ2NlbnRlcic7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOiKgueCueiHquWumuS5ieaooeadv1xyXG4gICAqIEBlbl9VUyBOb2RlIGN1c3RvbSB0ZW1wbGF0ZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIG5vZGVUcGwhOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlsLrlr7hcclxuICAgKiBAZW5fVVMgU2l6ZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYV2l0aENvbmZpZzxYU2l6ZT4oWF9DT05GSUdfTkFNRSwgJ21lZGl1bScpIHNpemU/OiBYU2l6ZTtcclxuICAvKipcclxuICAgKiBAemhfQ04g5r+A5rS757Si5byV5Y+Y5YyW5LqL5Lu2XHJcbiAgICogQGVuX1VTIEFjdGl2YXRlIGluZGV4IGNoYW5nZSBldmVudFxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSBpbmRleENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmv4DmtLvoioLngrnmlLnlj5jkuovku7ZcclxuICAgKiBAZW5fVVMgQWN0aXZhdGUgbm9kZSBjaGFuZ2UgZXZlbnRcclxuICAgKi9cclxuICBAT3V0cHV0KCkgbm9kZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8WFNsaWRlck5vZGU+KCk7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04gU2xpZGVyIOaVsOaNruWvueixoVxyXG4gKiBAZW5fVVMgU2xpZGVyIGRhdGEgb2JqZWN0XHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFhTbGlkZXJOb2RlIGV4dGVuZHMgWElkZW50aXR5UHJvcGVydHkge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmoIfpopjvvIzmlK/mjIHmqKHmnb9cclxuICAgKiBAZW5fVVMgVGl0bGUsIHN1cHBvcnQgdGVtcGxhdGVcclxuICAgKi9cclxuICBsYWJlbD86IFhUZW1wbGF0ZTtcclxuICAvKipcclxuICAgKiBAemhfQ04g56aB55So6IqC54K5XHJcbiAgICogQGVuX1VTIE5vZGUgZGlzYWJsZWRcclxuICAgKi9cclxuICBkaXNhYmxlZD86IGJvb2xlYW47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04g5biD5bGA5pa55byPXHJcbiAqIEBlbl9VUyBMYXlvdXRcclxuICovXHJcbmV4cG9ydCB0eXBlIFhTbGlkZXJMYXlvdXQgPSAncm93JyB8ICdjb2x1bW4nO1xyXG4iXX0=
105
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLnByb3BlcnR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvc2xpZGVyL3NsaWRlci5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUdMLFNBQVMsRUFFVCxZQUFZLEVBQ1osYUFBYSxFQUNiLFlBQVksRUFLWixXQUFXLEVBQ1osTUFBTSxrQkFBa0IsQ0FBQztBQUMxQixPQUFPLEVBQWUsS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVwRjs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLFVBQVUsQ0FBQztBQUN4QyxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUM7QUFFL0I7O0dBRUc7QUFFSCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxTQUFTO0lBRDlDOztRQUVFOzs7V0FHRztRQUNzQixTQUFJLEdBQXVCLEVBQUUsQ0FBQztRQU12RDs7O1dBR0c7UUFDc0IsbUJBQWMsR0FBWSxDQUFDLENBQUM7UUFDckQ7OztXQUdHO1FBQ00sV0FBTSxHQUFtQixLQUFLLENBQUM7UUFDeEM7OztXQUdHO1FBQ00sWUFBTyxHQUFjLE9BQU8sQ0FBQztRQUN0Qzs7O1dBR0c7UUFDTSxnQkFBVyxHQUFjLFFBQVEsQ0FBQztRQXFCM0M7OztXQUdHO1FBQ08sZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBQ25EOzs7V0FHRztRQUNPLGVBQVUsR0FBRyxJQUFJLFlBQVksRUFBZSxDQUFDO0tBQ3hEOzsrSEE3RFksZUFBZTttSEFBZixlQUFlLGtZQURMLEVBQUU7QUFNRTtJQUFmLFlBQVksRUFBRTs2Q0FBK0I7QUFLZTtJQUE1RCxXQUFXLENBQVcsYUFBYSxFQUFFLElBQUksQ0FBQztJQUFFLGFBQWEsRUFBRTtpREFBcUI7QUFLakU7SUFBZixZQUFZLEVBQUU7dURBQTZCO0FBeUJDO0lBQTVDLFdBQVcsQ0FBUSxhQUFhLEVBQUUsUUFBUSxDQUFDOzZDQUFjO0FBS0k7SUFBN0QsV0FBVyxDQUFXLGFBQWEsRUFBRSxLQUFLLENBQUM7SUFBRSxhQUFhLEVBQUU7bURBQXVCO0FBS3ZDO0lBQTVDLFdBQVcsQ0FBUyxhQUFhLEVBQUUsT0FBTyxDQUFDO3dEQUEwQjsyRkFsRHBFLGVBQWU7a0JBRDNCLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFOzhCQU1BLElBQUk7c0JBQTVCLEtBQUs7Z0JBS2dFLFFBQVE7c0JBQTdFLEtBQUs7Z0JBS21CLGNBQWM7c0JBQXRDLEtBQUs7Z0JBS0csTUFBTTtzQkFBZCxLQUFLO2dCQUtHLE9BQU87c0JBQWYsS0FBSztnQkFLRyxXQUFXO3NCQUFuQixLQUFLO2dCQUtHLE9BQU87c0JBQWYsS0FBSztnQkFLZ0QsSUFBSTtzQkFBekQsS0FBSztnQkFLaUUsVUFBVTtzQkFBaEYsS0FBSztnQkFLZ0QsZUFBZTtzQkFBcEUsS0FBSztnQkFLSSxXQUFXO3NCQUFwQixNQUFNO2dCQUtHLFVBQVU7c0JBQW5CLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIFhEYXRhLFxyXG4gIFhUZW1wbGF0ZSxcclxuICBYUHJvcGVydHksXHJcbiAgWElkZW50aXR5UHJvcGVydHksXHJcbiAgWERhdGFDb252ZXJ0LFxyXG4gIFhJbnB1dEJvb2xlYW4sXHJcbiAgWElucHV0TnVtYmVyLFxyXG4gIFhKdXN0aWZ5LFxyXG4gIFhTaXplLFxyXG4gIFhOdW1iZXIsXHJcbiAgWEJvb2xlYW4sXHJcbiAgWFdpdGhDb25maWdcclxufSBmcm9tICdAbmctbmVzdC91aS9jb3JlJztcclxuaW1wb3J0IHsgVGVtcGxhdGVSZWYsIElucHV0LCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogU2xpZGVyXHJcbiAqIEBzZWxlY3RvciB4LXNsaWRlclxyXG4gKiBAZGVjb3JhdG9yIGNvbXBvbmVudFxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IFhTbGlkZXJQcmVmaXggPSAneC1zbGlkZXInO1xyXG5jb25zdCBYX0NPTkZJR19OQU1FID0gJ3NsaWRlcic7XHJcblxyXG4vKipcclxuICogU2xpZGVyIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYU2xpZGVyUHJvcGVydHkgZXh0ZW5kcyBYUHJvcGVydHkge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDoioLngrnmlbDmja5cclxuICAgKiBAZW5fVVMgTm9kZSBkYXRhXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhEYXRhQ29udmVydCgpIGRhdGE6IFhEYXRhPFhTbGlkZXJOb2RlPiA9IFtdO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmu5HliqjliqjnlLtcclxuICAgKiBAZW5fVVMgU2xpZGluZyBhbmltYXRpb25cclxuICAgKi9cclxuICBASW5wdXQoKSBAWFdpdGhDb25maWc8WEJvb2xlYW4+KFhfQ09ORklHX05BTUUsIHRydWUpIEBYSW5wdXRCb29sZWFuKCkgYW5pbWF0ZWQ/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5b2T5YmN5r+A5rS755qE57Si5byVXHJcbiAgICogQGVuX1VTIEN1cnJlbnRseSBhY3RpdmUgaW5kZXhcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0TnVtYmVyKCkgYWN0aXZhdGVkSW5kZXg6IFhOdW1iZXIgPSAwO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmjpLliJfmlrnlvI9cclxuICAgKiBAZW5fVVMgQXJyYW5nZW1lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBsYXlvdXQ/OiBYU2xpZGVyTGF5b3V0ID0gJ3Jvdyc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWvuem9kOaWueW8j1xyXG4gICAqIEBlbl9VUyBBbGlnbm1lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBqdXN0aWZ5PzogWEp1c3RpZnkgPSAnc3RhcnQnO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDoioLngrnmloflrZflr7npvZDmlrnlvI9cclxuICAgKiBAZW5fVVMgTm9kZSB0ZXh0IGFsaWdubWVudFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIG5vZGVKdXN0aWZ5PzogWEp1c3RpZnkgPSAnY2VudGVyJztcclxuICAvKipcclxuICAgKiBAemhfQ04g6IqC54K56Ieq5a6a5LmJ5qih5p2/XHJcbiAgICogQGVuX1VTIE5vZGUgY3VzdG9tIHRlbXBsYXRlXHJcbiAgICovXHJcbiAgQElucHV0KCkgbm9kZVRwbCE6IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWwuuWvuFxyXG4gICAqIEBlbl9VUyBTaXplXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhTaXplPihYX0NPTkZJR19OQU1FLCAnbWVkaXVtJykgc2l6ZT86IFhTaXplO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDoioLngrnmmL7npLrkuI3kuIvnmoTml7blgJnmmL7npLrlsZXlvIDmiYDmnInnmoTmjInpkq7vvIzmjpLliJfmlrnlvI/kuLogcm93IOeahOaXtuWAmeeUn+aViFxyXG4gICAqIEBlbl9VUyBXaGVuIHRoZSBub2RlIGlzIG5vdCBkaXNwbGF5ZWQsIGRpc3BsYXkgYWxsIHRoZSBidXR0b25zLCBhbmQgdGhlIGFycmFuZ2VtZW50IGlzIGVmZmVjdGl2ZSB3aGVuIHRoZSBhcnJhbmdlbWVudCBpcyByb3dcclxuICAgKi9cclxuICBASW5wdXQoKSBAWFdpdGhDb25maWc8WEJvb2xlYW4+KFhfQ09ORklHX05BTUUsIGZhbHNlKSBAWElucHV0Qm9vbGVhbigpIHNob3dFeHBhbmQ/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5bGV5byA5omA5pyJ5by55qGG55qE5pyA5aSn6auY5bqmXHJcbiAgICogQGVuX1VTIEV4cGFuZCB0aGUgbWF4aW11bSBoZWlnaHQgb2YgYWxsIGJvbWIgZnJhbWVzXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPHN0cmluZz4oWF9DT05GSUdfTkFNRSwgJzE1cmVtJykgZXhwYW5kTWF4SGVpZ2h0Pzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmv4DmtLvntKLlvJXlj5jljJbkuovku7ZcclxuICAgKiBAZW5fVVMgQWN0aXZhdGUgaW5kZXggY2hhbmdlIGV2ZW50XHJcbiAgICovXHJcbiAgQE91dHB1dCgpIGluZGV4Q2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOa/gOa0u+iKgueCueaUueWPmOS6i+S7tlxyXG4gICAqIEBlbl9VUyBBY3RpdmF0ZSBub2RlIGNoYW5nZSBldmVudFxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSBub2RlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxYU2xpZGVyTm9kZT4oKTtcclxufVxyXG5cclxuLyoqXHJcbiAqIEB6aF9DTiBTbGlkZXIg5pWw5o2u5a+56LGhXHJcbiAqIEBlbl9VUyBTbGlkZXIgZGF0YSBvYmplY3RcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgWFNsaWRlck5vZGUgZXh0ZW5kcyBYSWRlbnRpdHlQcm9wZXJ0eSB7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOagh+mimO+8jOaUr+aMgeaooeadv1xyXG4gICAqIEBlbl9VUyBUaXRsZSwgc3VwcG9ydCB0ZW1wbGF0ZVxyXG4gICAqL1xyXG4gIGxhYmVsPzogWFRlbXBsYXRlO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDnpoHnlKjoioLngrlcclxuICAgKiBAZW5fVVMgTm9kZSBkaXNhYmxlZFxyXG4gICAqL1xyXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcclxufVxyXG5cclxuLyoqXHJcbiAqIEB6aF9DTiDluIPlsYDmlrnlvI9cclxuICogQGVuX1VTIExheW91dFxyXG4gKi9cclxuZXhwb3J0IHR5cGUgWFNsaWRlckxheW91dCA9ICdyb3cnIHwgJ2NvbHVtbic7XHJcbiJdfQ==