@acorex/components 5.2.2 → 5.3.0

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 (147) hide show
  1. package/esm2020/lib/alert/alert-button.component.mjs +2 -3
  2. package/esm2020/lib/alert/alert.component.mjs +33 -23
  3. package/esm2020/lib/alert/alert.module.mjs +6 -22
  4. package/esm2020/lib/alert/index.mjs +1 -5
  5. package/esm2020/lib/base/components.class.mjs +17 -0
  6. package/esm2020/lib/base/events.class.mjs +1 -1
  7. package/esm2020/lib/base/index.mjs +2 -1
  8. package/esm2020/lib/base/mixin/base-components.class.mjs +5 -5
  9. package/esm2020/lib/base/mixin/base-menu-mixin.class.mjs +4 -3
  10. package/esm2020/lib/base/mixin/color-look-mixing.class.mjs +1 -1
  11. package/esm2020/lib/base/mixin/datalist-component.class.mjs +2 -1
  12. package/esm2020/lib/base/styles.class.mjs +1 -1
  13. package/esm2020/lib/button/button-group.component.mjs +1 -1
  14. package/esm2020/lib/button/button-item.class.mjs +1 -1
  15. package/esm2020/lib/button/button.module.mjs +4 -5
  16. package/esm2020/lib/calendar/calendar.component.mjs +4 -4
  17. package/esm2020/lib/calendar/calendar.module.mjs +4 -5
  18. package/esm2020/lib/checkbox/checkbox.module.mjs +5 -5
  19. package/esm2020/lib/datepicker/datepicker.component.mjs +11 -7
  20. package/esm2020/lib/datepicker/datepicker.module.mjs +4 -7
  21. package/esm2020/lib/decorators/close-button.component.mjs +40 -0
  22. package/esm2020/lib/decorators/decorators.module.mjs +37 -7
  23. package/esm2020/lib/decorators/footer.component.mjs +24 -0
  24. package/esm2020/lib/decorators/header.component.mjs +3 -5
  25. package/esm2020/lib/decorators/icon.component.mjs +28 -0
  26. package/esm2020/lib/decorators/index.mjs +5 -1
  27. package/esm2020/lib/decorators/prefix.component.mjs +3 -3
  28. package/esm2020/lib/decorators/suffix.component.mjs +3 -3
  29. package/esm2020/lib/decorators/title.component.mjs +24 -0
  30. package/esm2020/lib/dialog/dialog.module.mjs +4 -4
  31. package/esm2020/lib/drawer/drawer-container.component.mjs +17 -57
  32. package/esm2020/lib/drawer/drawer.component.mjs +97 -127
  33. package/esm2020/lib/drawer/drawer.module.mjs +3 -4
  34. package/esm2020/lib/drawer/index.mjs +1 -2
  35. package/esm2020/lib/dropdown/dropdown-panel.component.mjs +4 -4
  36. package/esm2020/lib/dropdown/dropdown.module.mjs +5 -6
  37. package/esm2020/lib/menu/menu.component.mjs +20 -7
  38. package/esm2020/lib/menu/menu.module.mjs +4 -7
  39. package/esm2020/lib/number-box/number-box.component.mjs +2 -2
  40. package/esm2020/lib/number-box/number-box.module.mjs +4 -7
  41. package/esm2020/lib/page/base-page.class.mjs +3 -3
  42. package/esm2020/lib/page/index.mjs +1 -3
  43. package/esm2020/lib/page/page.module.mjs +4 -6
  44. package/esm2020/lib/password-box/password-box.component.mjs +2 -2
  45. package/esm2020/lib/password-box/password-box.module.mjs +4 -7
  46. package/esm2020/lib/picker/picker.component.mjs +260 -25
  47. package/esm2020/lib/picker/picker.model.class.mjs +2 -0
  48. package/esm2020/lib/popover/popover.component.mjs +6 -3
  49. package/esm2020/lib/popup/popup.component.mjs +13 -10
  50. package/esm2020/lib/popup/popup.module.mjs +4 -3
  51. package/esm2020/lib/radio/index.mjs +1 -1
  52. package/esm2020/lib/radio/radio.component.mjs +3 -3
  53. package/esm2020/lib/radio/radio.module.mjs +1 -1
  54. package/esm2020/lib/searchbox/index.mjs +3 -0
  55. package/esm2020/lib/searchbox/searchbox.component.mjs +47 -0
  56. package/esm2020/lib/searchbox/searchbox.module.mjs +24 -0
  57. package/esm2020/lib/selectbox/selectbox.component.mjs +33 -26
  58. package/esm2020/lib/selectbox/selectbox.module.mjs +5 -9
  59. package/esm2020/lib/tabs/tabs.module.mjs +4 -4
  60. package/esm2020/lib/textbox/textbox.module.mjs +5 -9
  61. package/esm2020/lib/toast/toast.class.mjs +1 -1
  62. package/esm2020/lib/toast/toast.component.mjs +14 -12
  63. package/esm2020/lib/toast/toast.module.mjs +5 -3
  64. package/esm2020/lib/toast/toast.service.mjs +37 -9
  65. package/esm2020/public-api.mjs +2 -2
  66. package/fesm2015/acorex-components.mjs +849 -662
  67. package/fesm2015/acorex-components.mjs.map +1 -1
  68. package/fesm2020/acorex-components.mjs +840 -662
  69. package/fesm2020/acorex-components.mjs.map +1 -1
  70. package/lib/alert/alert.component.d.ts +7 -6
  71. package/lib/alert/alert.module.d.ts +4 -8
  72. package/lib/alert/index.d.ts +0 -4
  73. package/lib/badge/badge.component.d.ts +3 -3
  74. package/lib/base/components.class.d.ts +11 -0
  75. package/lib/base/index.d.ts +1 -0
  76. package/lib/base/mixin/base-components.class.d.ts +2 -2
  77. package/lib/base/mixin/button-mixin.class.d.ts +0 -3
  78. package/lib/base/mixin/color-look-mixing.class.d.ts +4 -4
  79. package/lib/base/mixin/mixin.class.d.ts +6 -6
  80. package/lib/base/mixin/selection-component.class.d.ts +3 -0
  81. package/lib/base/mixin/textbox-mixin.class.d.ts +3 -3
  82. package/lib/base/styles.class.d.ts +1 -1
  83. package/lib/button/button-group.component.d.ts +4 -4
  84. package/lib/button/button-item.class.d.ts +2 -2
  85. package/lib/button/button.module.d.ts +2 -3
  86. package/lib/calendar/calendar.module.d.ts +4 -5
  87. package/lib/checkbox/checkbox.module.d.ts +1 -1
  88. package/lib/datepicker/datepicker.module.d.ts +3 -4
  89. package/lib/decorators/close-button.component.d.ts +13 -0
  90. package/lib/decorators/decorators.module.d.ts +10 -6
  91. package/lib/decorators/footer.component.d.ts +8 -0
  92. package/lib/decorators/header.component.d.ts +1 -1
  93. package/lib/decorators/icon.component.d.ts +10 -0
  94. package/lib/decorators/index.d.ts +4 -0
  95. package/lib/decorators/prefix.component.d.ts +1 -1
  96. package/lib/decorators/suffix.component.d.ts +1 -1
  97. package/lib/decorators/title.component.d.ts +9 -0
  98. package/lib/dialog/dialog.module.d.ts +1 -1
  99. package/lib/drawer/drawer-container.component.d.ts +5 -8
  100. package/lib/drawer/drawer.component.d.ts +23 -19
  101. package/lib/drawer/drawer.module.d.ts +2 -3
  102. package/lib/drawer/index.d.ts +0 -1
  103. package/lib/dropdown/dropdown.module.d.ts +3 -4
  104. package/lib/menu/menu.component.d.ts +1 -0
  105. package/lib/menu/menu.module.d.ts +2 -2
  106. package/lib/number-box/number-box.module.d.ts +2 -3
  107. package/lib/page/base-page.class.d.ts +2 -2
  108. package/lib/page/index.d.ts +0 -2
  109. package/lib/page/page.module.d.ts +1 -3
  110. package/lib/password-box/password-box.module.d.ts +1 -2
  111. package/lib/picker/picker.component.d.ts +54 -13
  112. package/lib/picker/picker.model.class.d.ts +10 -0
  113. package/lib/popover/popover.component.d.ts +2 -1
  114. package/lib/popup/popup.module.d.ts +2 -1
  115. package/lib/searchbox/index.d.ts +2 -0
  116. package/lib/searchbox/searchbox.component.d.ts +16 -0
  117. package/lib/searchbox/searchbox.module.d.ts +11 -0
  118. package/lib/selectbox/selectbox.component.d.ts +4 -14
  119. package/lib/selectbox/selectbox.module.d.ts +6 -7
  120. package/lib/tabs/tabs.module.d.ts +1 -1
  121. package/lib/textbox/textbox.module.d.ts +2 -3
  122. package/lib/toast/toast.class.d.ts +4 -3
  123. package/lib/toast/toast.component.d.ts +0 -2
  124. package/lib/toast/toast.module.d.ts +3 -1
  125. package/lib/toast/toast.service.d.ts +4 -0
  126. package/package.json +1 -1
  127. package/public-api.d.ts +1 -1
  128. package/esm2020/lib/alert/alert-content.component.mjs +0 -21
  129. package/esm2020/lib/alert/alert-footer.component.mjs +0 -27
  130. package/esm2020/lib/alert/alert-suffix.component.mjs +0 -27
  131. package/esm2020/lib/alert/alert-title.component.mjs +0 -23
  132. package/esm2020/lib/drawer/drawer-content.component.mjs +0 -27
  133. package/esm2020/lib/icon/icon.component.mjs +0 -28
  134. package/esm2020/lib/icon/icon.module.mjs +0 -21
  135. package/esm2020/lib/icon/index.mjs +0 -3
  136. package/esm2020/lib/page/page-footer.component.mjs +0 -28
  137. package/esm2020/lib/page/page-header.component.mjs +0 -28
  138. package/lib/alert/alert-content.component.d.ts +0 -5
  139. package/lib/alert/alert-footer.component.d.ts +0 -5
  140. package/lib/alert/alert-suffix.component.d.ts +0 -5
  141. package/lib/alert/alert-title.component.d.ts +0 -5
  142. package/lib/drawer/drawer-content.component.d.ts +0 -8
  143. package/lib/icon/icon.component.d.ts +0 -10
  144. package/lib/icon/icon.module.d.ts +0 -8
  145. package/lib/icon/index.d.ts +0 -2
  146. package/lib/page/page-footer.component.d.ts +0 -7
  147. package/lib/page/page-header.component.d.ts +0 -7
@@ -1,48 +1,283 @@
1
- import { Component, ContentChild, Input, TemplateRef, ViewChild } from '@angular/core';
1
+ import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewChildren } from '@angular/core';
2
2
  import { AXBaseValueComponentMixin } from '../base';
3
3
  import { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';
4
4
  import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
5
6
  export class AXPickerComponent extends AXBaseValueComponentMixin {
6
- /**
7
- * @ignore
8
- */
9
7
  constructor(elementRef, cdr) {
10
8
  super(elementRef, cdr);
11
- this.rows = 3;
9
+ this.cdr = cdr;
12
10
  this.items = [];
13
- // require.ensure(['path/to/your/module'], require => {
14
- // let yourModule = require('path/to/your/module');
15
- // yourModule.someFunction();
16
- // });
11
+ this.OnChange = new EventEmitter();
12
+ this.touchOrMouse = {
13
+ isTouchable: 'ontouchstart' in window,
14
+ isMouseDown: false
15
+ };
16
+ this.draggingInfo = {
17
+ isDragging: false,
18
+ groupIndex: null,
19
+ startPageY: null
20
+ };
21
+ this.itemPerDegree = 23;
22
+ this.safeDoTimeoutId = null;
23
+ }
24
+ ngOnInit() {
25
+ this.currentIndexList = this.getInitialCurrentIndexList();
26
+ this.lastCurrentIndexList = [].concat(this.currentIndexList);
27
+ this.groupsRectList = new Array(this.items.length);
28
+ this.eventsRegister();
29
+ window.addEventListener('resize', this.safeGetRectsBindEvents.bind(this));
17
30
  }
18
31
  ngAfterViewInit() {
32
+ this.getGroupsRectList();
33
+ }
34
+ ngOnDestroy() {
35
+ window.removeEventListener('resize', this.safeGetRectsBindEvents.bind(this));
36
+ }
37
+ setGroupData(gIndex, groupData) {
38
+ if (!this.currentIndexList) {
39
+ this.currentIndexList = this.getInitialCurrentIndexList();
40
+ }
41
+ this.items[gIndex] = groupData;
42
+ const iCI = groupData.currentIndex;
43
+ let movedIndex = 0;
44
+ if (typeof iCI === 'number' && iCI >= 0 && groupData.list && groupData.list.length && iCI <= groupData.list.length - 1) {
45
+ movedIndex = Math.round(iCI);
46
+ }
47
+ this.currentIndexList[gIndex] = movedIndex;
48
+ this.lastCurrentIndexList = [].concat(this.currentIndexList);
49
+ }
50
+ getInitialCurrentIndexList() {
51
+ return this.items.map((item, index) => {
52
+ const iCI = item.currentIndex;
53
+ if (typeof iCI === 'number' && iCI >= 0 && item.list && item.list.length && iCI <= item.list.length - 1) {
54
+ return Math.round(iCI);
55
+ }
56
+ return 0;
57
+ });
58
+ }
59
+ safeGetRectsBindEvents() {
60
+ if (this.safeDoTimeoutId) {
61
+ clearTimeout(this.safeDoTimeoutId);
62
+ }
63
+ this.safeDoTimeoutId = setTimeout(() => {
64
+ this.getGroupsRectList();
65
+ }, 200);
66
+ }
67
+ getGroupsRectList() {
68
+ if (this.pickerGroupLayer) {
69
+ this.pickerGroupLayer.toArray().forEach((item, index) => {
70
+ this.groupsRectList[index] = item.nativeElement.getBoundingClientRect();
71
+ });
72
+ }
73
+ }
74
+ eventsRegister() {
75
+ const handleEventLayer = this.pickerHandleLayer.nativeElement;
76
+ if (handleEventLayer) {
77
+ this.addEventsForElement(handleEventLayer);
78
+ }
79
+ }
80
+ addEventsForElement(el) {
81
+ const _ = this.touchOrMouse.isTouchable;
82
+ const eventHandlerList = [
83
+ { name: _ ? 'touchstart' : 'mousedown', handler: this.handleStart },
84
+ { name: _ ? 'touchmove' : 'mousemove', handler: this.handleMove },
85
+ { name: _ ? 'touchend' : 'mouseup', handler: this.handleEnd },
86
+ { name: _ ? 'touchcancel' : 'mouseleave', handler: this.handleCancel }
87
+ ];
88
+ eventHandlerList.forEach((item, index) => {
89
+ el.removeEventListener(item.name, item.handler, false);
90
+ el.addEventListener(item.name, item.handler.bind(this), false);
91
+ });
92
+ }
93
+ triggerMiddleLayerGroupClick(gIndex) {
94
+ const data = this.items;
95
+ if (typeof gIndex === 'number' && typeof data[gIndex].onClick === 'function') {
96
+ data[gIndex].onClick(gIndex, this.currentIndexList[gIndex]);
97
+ }
98
+ }
99
+ triggerAboveLayerClick(ev, gIndex) {
100
+ const movedIndex = this.currentIndexList[gIndex] + 1;
101
+ this.currentIndexList[gIndex] = movedIndex;
102
+ this.correctionCurrentIndex(ev, gIndex);
103
+ }
104
+ triggerMiddleLayerClick(ev, gIndex) {
105
+ this.triggerMiddleLayerGroupClick(gIndex);
106
+ }
107
+ triggerBelowLayerClick(ev, gIndex) {
108
+ const movedIndex = this.currentIndexList[gIndex] - 1;
109
+ this.currentIndexList[gIndex] = movedIndex;
110
+ this.correctionCurrentIndex(ev, gIndex);
111
+ }
112
+ getTouchInfo(ev) {
113
+ return this.touchOrMouse.isTouchable ? ev.changedTouches[0] || ev.touches[0] : ev;
114
+ }
115
+ getGroupIndexBelongsEvent(ev) {
116
+ const touchInfo = this.getTouchInfo(ev);
117
+ for (let i = 0; i < this.groupsRectList.length; i++) {
118
+ const item = this.groupsRectList[i];
119
+ if (item.left < touchInfo.pageX && touchInfo.pageX < item.right) {
120
+ return i;
121
+ }
122
+ }
123
+ return null;
124
+ }
125
+ handleEventClick(ev) {
126
+ const gIndex = this.getGroupIndexBelongsEvent(ev);
127
+ switch (ev.target.dataset.type) {
128
+ case 'top':
129
+ this.triggerAboveLayerClick(ev, gIndex);
130
+ break;
131
+ case 'middle':
132
+ this.triggerMiddleLayerClick(ev, gIndex);
133
+ break;
134
+ case 'bottom':
135
+ this.triggerBelowLayerClick(ev, gIndex);
136
+ break;
137
+ default:
138
+ }
19
139
  }
20
- _handleMoveChange(e) {
21
- this.value = this.items[e.value];
140
+ handleStart(ev) {
141
+ if (ev.cancelable) {
142
+ ev.preventDefault();
143
+ ev.stopPropagation();
144
+ }
145
+ const touchInfo = this.getTouchInfo(ev);
146
+ this.draggingInfo.startPageY = touchInfo.pageY;
147
+ if (!this.touchOrMouse.isTouchable) {
148
+ this.touchOrMouse.isMouseDown = true;
149
+ }
22
150
  }
23
- open() {
151
+ handleMove(ev) {
152
+ ev.preventDefault();
153
+ ev.stopPropagation();
154
+ if (this.touchOrMouse.isTouchable || this.touchOrMouse.isMouseDown) {
155
+ this.draggingInfo.isDragging = true;
156
+ this.setCurrentIndexOnMove(ev);
157
+ }
158
+ }
159
+ handleEnd(ev) {
160
+ ev.preventDefault();
161
+ ev.stopPropagation();
162
+ if (!this.draggingInfo.isDragging) {
163
+ this.handleEventClick(ev);
164
+ }
165
+ this.draggingInfo.isDragging = false;
166
+ this.touchOrMouse.isMouseDown = false;
167
+ this.correctionAfterDragging(ev);
168
+ }
169
+ handleCancel(ev) {
170
+ ev.preventDefault();
171
+ ev.stopPropagation();
172
+ if (this.touchOrMouse.isTouchable || this.touchOrMouse.isMouseDown) {
173
+ this.correctionAfterDragging(ev);
174
+ this.touchOrMouse.isMouseDown = false;
175
+ this.draggingInfo.isDragging = false;
176
+ }
177
+ }
178
+ setCurrentIndexOnMove(ev) {
179
+ const touchInfo = this.getTouchInfo(ev);
180
+ if (this.draggingInfo.groupIndex === null) {
181
+ this.draggingInfo.groupIndex = this.getGroupIndexBelongsEvent(ev);
182
+ }
183
+ const gIndex = this.draggingInfo.groupIndex;
184
+ if (typeof gIndex === 'number' && (this.items[gIndex].divider || !this.items[gIndex].list)) {
185
+ return;
186
+ }
187
+ const moveCount = (this.draggingInfo.startPageY - touchInfo.pageY) / 32;
188
+ const movedIndex = this.currentIndexList[gIndex] + moveCount;
189
+ this.currentIndexList[gIndex] = movedIndex;
190
+ this.draggingInfo.startPageY = touchInfo.pageY;
191
+ }
192
+ correctionAfterDragging(ev) {
193
+ const gIndex = this.draggingInfo.groupIndex;
194
+ this.correctionCurrentIndex(ev, gIndex);
195
+ this.draggingInfo.groupIndex = null;
196
+ this.draggingInfo.startPageY = null;
197
+ }
198
+ correctionCurrentIndex(ev, gIndex) {
199
+ setTimeout(() => {
200
+ if (typeof gIndex === 'number' && this.items[gIndex].divider !== true && this.items[gIndex].list.length > 0) {
201
+ const unsafeGroupIndex = this.currentIndexList[gIndex];
202
+ let movedIndex = unsafeGroupIndex;
203
+ if (unsafeGroupIndex > this.items[gIndex].list.length - 1) {
204
+ movedIndex = this.items[gIndex].list.length - 1;
205
+ }
206
+ else if (unsafeGroupIndex < 0) {
207
+ movedIndex = 0;
208
+ }
209
+ movedIndex = Math.round(movedIndex);
210
+ this.currentIndexList[gIndex] = movedIndex;
211
+ if (movedIndex !== this.lastCurrentIndexList[gIndex]) {
212
+ this.OnChange.emit({ gIndex, iIndex: movedIndex });
213
+ }
214
+ this.lastCurrentIndexList = [].concat(this.currentIndexList);
215
+ }
216
+ }, 100);
217
+ }
218
+ isCurrentItem(gIndex, iIndex) {
219
+ return this.currentIndexList[gIndex] === iIndex;
220
+ }
221
+ getCurrentIndexList() {
222
+ return this.currentIndexList;
223
+ }
224
+ getGroupClass(gIndex) {
225
+ const group = this.items[gIndex];
226
+ const defaultWeightClass = 'weight-' + (group.weight || 1);
227
+ const groupClass = [defaultWeightClass];
228
+ if (group.className) {
229
+ groupClass.push(group.className);
230
+ }
231
+ return groupClass;
232
+ }
233
+ getItemClass(gIndex, iIndex, isDivider = false) {
234
+ const group = this.items[gIndex];
235
+ const itemClass = [];
236
+ if (!isDivider && this.isCurrentItem(gIndex, iIndex)) {
237
+ itemClass.push('smooth-item-selected');
238
+ }
239
+ if (group.textAlign) {
240
+ itemClass.push('text-' + group.textAlign);
241
+ }
242
+ return itemClass;
243
+ }
244
+ getItemStyle(gIndex, iIndex) {
245
+ const gapCount = this.currentIndexList[gIndex] - iIndex;
246
+ if (Math.abs(gapCount) < (90 / this.itemPerDegree)) {
247
+ const rotateStyle = {
248
+ transform: 'rotateX(' + gapCount * this.itemPerDegree + 'deg) translate3d(0, 0, 5.625em)',
249
+ opacity: (1 - Math.abs(gapCount) / (90 / this.itemPerDegree)).toString()
250
+ };
251
+ if (!this.draggingInfo.isDragging) {
252
+ rotateStyle['transition'] = 'transform 150ms ease-out';
253
+ }
254
+ return rotateStyle;
255
+ }
256
+ if (gapCount > 0) {
257
+ return { transform: 'rotateX(90deg) translate3d(0, 0, 5.625em)' };
258
+ }
259
+ else {
260
+ return { transform: 'rotateX(-90deg) translate3d(0, 0, 5.625em)' };
261
+ }
24
262
  }
25
263
  }
26
264
  AXPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXPickerComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
27
- AXPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: AXPickerComponent, selector: "ax-picker", inputs: { readonly: "readonly", allowNull: "allowNull", value: "value", debounceTime: "debounceTime", name: "name", checked: "checked", rows: "rows", width: "width", height: "height", itemHeight: "itemHeight", items: "items" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged" }, host: { classAttribute: "ax-picker" }, queries: [{ propertyName: "itemTemplate", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "picker", first: true, predicate: ["picker"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!-- <ax-carousel [width]=\"width\" [height]=\"height\" [fixedWidth]=\"width\" [fixedHeight]=\"itemHeight\" [centered]=\"true\" [vertical]=\"true\" [loop]=\"false\" [wheel]=\"true\" (onSlideChanged)=\"_handleMoveChange($event)\">\r\n <ax-carousel-item class=\"ax-picker-item\" *ngFor=\"let item of items\">\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </ax-carousel-item>\r\n</ax-carousel> -->\r\n<!-- <ul class=\"scroller\">\r\n <li *ngFor=\"let item of items\">\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </li>\r\n\r\n</ul> -->\r\n\r\n<button id=\"picker\" #picker>open picker</button>" });
265
+ AXPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: AXPickerComponent, selector: "ax-picker", inputs: { readonly: "readonly", allowNull: "allowNull", value: "value", debounceTime: "debounceTime", name: "name", checked: "checked", items: "items" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", OnChange: "OnChange" }, host: { classAttribute: "ax-picker" }, queries: [{ propertyName: "itemTemplate", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "pickerHandleLayer", first: true, predicate: ["pickerHandleLayer"], descendants: true, static: true }, { propertyName: "pickerGroupLayer", predicate: ["pickerGroupLayer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!-- <ax-carousel [width]=\"width\" [height]=\"height\" [fixedWidth]=\"width\" [fixedHeight]=\"itemHeight\" [centered]=\"true\" [vertical]=\"true\" [loop]=\"false\" [wheel]=\"true\" (onSlideChanged)=\"_handleMoveChange($event)\">\r\n <ax-carousel-item class=\"ax-picker-item\" *ngFor=\"let item of items\">\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </ax-carousel-item>\r\n</ax-carousel> -->\r\n<div class=\"ng-data-picker flex-box\">\r\n\r\n <!-- picker-group-layer -->\r\n <div #pickerGroupLayer *ngFor=\"let group of items; let gI = index\" class=\"picker-group\" [ngClass]=\"getGroupClass(gI)\">\r\n\r\n <div class=\"picker-list\">\r\n <div *ngIf=\"group.divider else ngIfElse\" class=\"picker-item divider\" [ngClass]=\"getItemClass(gI, i, true)\">\r\n {{ group.text }}\r\n </div>\r\n\r\n <div #ngIfElse *ngFor=\"let item of group.list; let i = index\" class=\"picker-item\" [ngClass]=\"getItemClass(gI, i)\"\r\n [ngStyle]=\"getItemStyle(gI, i)\">\r\n {{ item.value || item }}\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <div #pickerHandleLayer class=\"picker-handle-layer flex-box dir-column\">\r\n <div data-type=\"top\" class=\"picker-top weight-1\"></div>\r\n <div data-type=\"middle\" class=\"picker-middle\"></div>\r\n <div data-type=\"bottom\" class=\"picker-bottom weight-1\"></div>\r\n </div>\r\n\r\n</div>", directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
28
266
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXPickerComponent, decorators: [{
29
267
  type: Component,
30
- args: [{ selector: 'ax-picker', host: { class: 'ax-picker' }, inputs: [...VALUE_INPUTS], outputs: [...VALUE_OUTPUT], template: "<!-- <ax-carousel [width]=\"width\" [height]=\"height\" [fixedWidth]=\"width\" [fixedHeight]=\"itemHeight\" [centered]=\"true\" [vertical]=\"true\" [loop]=\"false\" [wheel]=\"true\" (onSlideChanged)=\"_handleMoveChange($event)\">\r\n <ax-carousel-item class=\"ax-picker-item\" *ngFor=\"let item of items\">\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </ax-carousel-item>\r\n</ax-carousel> -->\r\n<!-- <ul class=\"scroller\">\r\n <li *ngFor=\"let item of items\">\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </li>\r\n\r\n</ul> -->\r\n\r\n<button id=\"picker\" #picker>open picker</button>" }]
31
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { picker: [{
268
+ args: [{ selector: 'ax-picker', host: { class: 'ax-picker' }, inputs: [...VALUE_INPUTS], outputs: [...VALUE_OUTPUT], template: "<!-- <ax-carousel [width]=\"width\" [height]=\"height\" [fixedWidth]=\"width\" [fixedHeight]=\"itemHeight\" [centered]=\"true\" [vertical]=\"true\" [loop]=\"false\" [wheel]=\"true\" (onSlideChanged)=\"_handleMoveChange($event)\">\r\n <ax-carousel-item class=\"ax-picker-item\" *ngFor=\"let item of items\">\r\n <ng-container [ngTemplateOutlet]=\"itemTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </ax-carousel-item>\r\n</ax-carousel> -->\r\n<div class=\"ng-data-picker flex-box\">\r\n\r\n <!-- picker-group-layer -->\r\n <div #pickerGroupLayer *ngFor=\"let group of items; let gI = index\" class=\"picker-group\" [ngClass]=\"getGroupClass(gI)\">\r\n\r\n <div class=\"picker-list\">\r\n <div *ngIf=\"group.divider else ngIfElse\" class=\"picker-item divider\" [ngClass]=\"getItemClass(gI, i, true)\">\r\n {{ group.text }}\r\n </div>\r\n\r\n <div #ngIfElse *ngFor=\"let item of group.list; let i = index\" class=\"picker-item\" [ngClass]=\"getItemClass(gI, i)\"\r\n [ngStyle]=\"getItemStyle(gI, i)\">\r\n {{ item.value || item }}\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <div #pickerHandleLayer class=\"picker-handle-layer flex-box dir-column\">\r\n <div data-type=\"top\" class=\"picker-top weight-1\"></div>\r\n <div data-type=\"middle\" class=\"picker-middle\"></div>\r\n <div data-type=\"bottom\" class=\"picker-bottom weight-1\"></div>\r\n </div>\r\n\r\n</div>" }]
269
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { pickerGroupLayer: [{
270
+ type: ViewChildren,
271
+ args: ['pickerGroupLayer']
272
+ }], pickerHandleLayer: [{
32
273
  type: ViewChild,
33
- args: ['picker']
274
+ args: ['pickerHandleLayer', { static: true }]
34
275
  }], itemTemplate: [{
35
276
  type: ContentChild,
36
277
  args: [TemplateRef]
37
- }], rows: [{
38
- type: Input
39
- }], width: [{
40
- type: Input
41
- }], height: [{
42
- type: Input
43
- }], itemHeight: [{
44
- type: Input
45
278
  }], items: [{
46
279
  type: Input
280
+ }], OnChange: [{
281
+ type: Output
47
282
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9jb21wb25lbnRzL3NyYy9saWIvcGlja2VyL3BpY2tlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL3BpY2tlci9waWNrZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixTQUFTLEVBQUUsWUFBWSxFQUFjLEtBQUssRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFnQixNQUFNLGVBQWUsQ0FBQztBQUNwSSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDcEQsT0FBTyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7QUFRN0UsTUFBTSxPQUFPLGlCQUFrQixTQUFRLHlCQUF5QjtJQXNCNUQ7O01BRUU7SUFDRixZQUFZLFVBQXNCLEVBQUUsR0FBc0I7UUFDdEQsS0FBSyxDQUFDLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQztRQWpCM0IsU0FBSSxHQUFXLENBQUMsQ0FBQztRQVdqQixVQUFLLEdBQVUsRUFBRSxDQUFDO1FBT2hCLHlEQUF5RDtRQUN6RCx1REFBdUQ7UUFDdkQsaUNBQWlDO1FBQ2pDLFFBQVE7SUFDVixDQUFDO0lBRUQsZUFBZTtJQUVmLENBQUM7SUFHRCxpQkFBaUIsQ0FBQyxDQUFNO1FBQ3BCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFckMsQ0FBQztJQUNELElBQUk7SUFFSixDQUFDOzs4R0E1Q1EsaUJBQWlCO2tHQUFqQixpQkFBaUIsaWJBSVosV0FBVyx5S0NkN0IsMnhCQWFnRDsyRkRIbkMsaUJBQWlCO2tCQVA3QixTQUFTOytCQUNJLFdBQVcsUUFFZixFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsVUFDcEIsQ0FBQyxHQUFHLFlBQVksQ0FBQyxXQUNoQixDQUFDLEdBQUcsWUFBWSxDQUFDO2lJQUlMLE1BQU07c0JBQTFCLFNBQVM7dUJBQUMsUUFBUTtnQkFHbkIsWUFBWTtzQkFEWCxZQUFZO3VCQUFDLFdBQVc7Z0JBS3pCLElBQUk7c0JBREgsS0FBSztnQkFJTixLQUFLO3NCQURKLEtBQUs7Z0JBSU4sTUFBTTtzQkFETCxLQUFLO2dCQUdOLFVBQVU7c0JBRFQsS0FBSztnQkFJTixLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIEVsZW1lbnRSZWYsIElucHV0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkLCBWaWV3Q2hpbGRyZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQVhCYXNlVmFsdWVDb21wb25lbnRNaXhpbiB9IGZyb20gJy4uL2Jhc2UnO1xyXG5pbXBvcnQgeyBWQUxVRV9JTlBVVFMsIFZBTFVFX09VVFBVVCB9IGZyb20gJy4uL2Jhc2UvbWl4aW4vdmFsdWUtbWl4aW4uY2xhc3MnO1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYXgtcGlja2VyJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9waWNrZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgaG9zdDogeyBjbGFzczogJ2F4LXBpY2tlcicgfSxcclxuICAgIGlucHV0czogWy4uLlZBTFVFX0lOUFVUU10sXHJcbiAgICBvdXRwdXRzOiBbLi4uVkFMVUVfT1VUUFVUXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhQaWNrZXJDb21wb25lbnQgZXh0ZW5kcyBBWEJhc2VWYWx1ZUNvbXBvbmVudE1peGluIHtcclxuXHJcbiAgICBAVmlld0NoaWxkKCdwaWNrZXInKSBwaWNrZXI6RWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD5cclxuXHJcbiAgICBAQ29udGVudENoaWxkKFRlbXBsYXRlUmVmKVxyXG4gICAgaXRlbVRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+XHJcblxyXG4gICAgXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcm93czogbnVtYmVyID0gMztcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgd2lkdGg6IHN0cmluZztcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgaGVpZ2h0OiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKVxyXG4gICAgaXRlbUhlaWdodDogc3RyaW5nO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBpdGVtczogYW55W10gPSBbXTtcclxuXHJcbiAgICAvKipcclxuICAgICogIEBpZ25vcmVcclxuICAgICovXHJcbiAgICBjb25zdHJ1Y3RvcihlbGVtZW50UmVmOiBFbGVtZW50UmVmLCBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgICAgICAgc3VwZXIoZWxlbWVudFJlZiwgY2RyKTtcclxuICAgICAgLy8gICByZXF1aXJlLmVuc3VyZShbJ3BhdGgvdG8veW91ci9tb2R1bGUnXSwgcmVxdWlyZSA9PiB7XHJcbiAgICAgIC8vICAgICBsZXQgeW91ck1vZHVsZSA9IHJlcXVpcmUoJ3BhdGgvdG8veW91ci9tb2R1bGUnKTtcclxuICAgICAgLy8gICAgIHlvdXJNb2R1bGUuc29tZUZ1bmN0aW9uKCk7XHJcbiAgICAgIC8vICB9KTsgXHJcbiAgICB9XHJcblxyXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gIFxyXG4gICAgfVxyXG5cclxuXHJcbiAgICBfaGFuZGxlTW92ZUNoYW5nZShlOiBhbnkpIHtcclxuICAgICAgICB0aGlzLnZhbHVlID0gdGhpcy5pdGVtc1tlLnZhbHVlXTtcclxuXHJcbiAgICB9XHJcbiAgICBvcGVuKCl7XHJcbiAgICAgXHJcbiAgICB9XHJcbn1cclxuIiwiPCEtLSA8YXgtY2Fyb3VzZWwgW3dpZHRoXT1cIndpZHRoXCIgW2hlaWdodF09XCJoZWlnaHRcIiBbZml4ZWRXaWR0aF09XCJ3aWR0aFwiIFtmaXhlZEhlaWdodF09XCJpdGVtSGVpZ2h0XCIgIFtjZW50ZXJlZF09XCJ0cnVlXCIgW3ZlcnRpY2FsXT1cInRydWVcIiBbbG9vcF09XCJmYWxzZVwiIFt3aGVlbF09XCJ0cnVlXCIgKG9uU2xpZGVDaGFuZ2VkKT1cIl9oYW5kbGVNb3ZlQ2hhbmdlKCRldmVudClcIj5cclxuICAgIDxheC1jYXJvdXNlbC1pdGVtIGNsYXNzPVwiYXgtcGlja2VyLWl0ZW1cIiAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtc1wiPlxyXG4gICAgICAgIDxuZy1jb250YWluZXIgW25nVGVtcGxhdGVPdXRsZXRdPVwiaXRlbVRlbXBsYXRlXCJcclxuICAgICAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7ICRpbXBsaWNpdDogaXRlbSB9XCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L2F4LWNhcm91c2VsLWl0ZW0+XHJcbjwvYXgtY2Fyb3VzZWw+IC0tPlxyXG48IS0tIDx1bCBjbGFzcz1cInNjcm9sbGVyXCI+XHJcbiAgICA8bGkgKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXNcIj5cclxuICAgICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIml0ZW1UZW1wbGF0ZVwiIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7ICRpbXBsaWNpdDogaXRlbSB9XCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L2xpPlxyXG5cclxuPC91bD4gLS0+XHJcblxyXG48YnV0dG9uIGlkPVwicGlja2VyXCIgI3BpY2tlcj5vcGVuIHBpY2tlcjwvYnV0dG9uPiJdfQ==
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/picker/picker.component.ts","../../../../../../projects/acorex/components/src/lib/picker/picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\r\nimport { AXBaseValueComponentMixin } from '../base';\r\nimport { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';\r\nimport { PickerItem } from './picker.model.class';\r\n@Component({\r\n    selector: 'ax-picker',\r\n    templateUrl: './picker.component.html',\r\n    host: { class: 'ax-picker' },\r\n    inputs: [...VALUE_INPUTS],\r\n    outputs: [...VALUE_OUTPUT]\r\n})\r\nexport class AXPickerComponent extends AXBaseValueComponentMixin {\r\n\r\n    @ViewChildren('pickerGroupLayer') pickerGroupLayer\r\n    @ViewChild('pickerHandleLayer', { static: true }) pickerHandleLayer: ElementRef<HTMLDivElement>\r\n\r\n    @ContentChild(TemplateRef)\r\n    itemTemplate: TemplateRef<any>\r\n\r\n    @Input() items: PickerItem[] = []\r\n    @Output() OnChange: EventEmitter<any> = new EventEmitter<any>()\r\n\r\n    currentIndexList: number[]\r\n    lastCurrentIndexList: number[]\r\n    groupsRectList: any[]\r\n    touchOrMouse = {\r\n        isTouchable: 'ontouchstart' in window,\r\n        isMouseDown: false\r\n    }\r\n    draggingInfo = {\r\n        isDragging: false,\r\n        groupIndex: null,\r\n        startPageY: null\r\n    }\r\n    itemPerDegree = 23\r\n    safeDoTimeoutId: any = null\r\n    constructor(elementRef: ElementRef, private cdr: ChangeDetectorRef) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n\r\n    ngOnInit() {\r\n        this.currentIndexList = this.getInitialCurrentIndexList()\r\n        this.lastCurrentIndexList = [].concat(this.currentIndexList)\r\n\r\n        this.groupsRectList = new Array(this.items.length)\r\n\r\n        this.eventsRegister()\r\n        window.addEventListener('resize', this.safeGetRectsBindEvents.bind(this))\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.getGroupsRectList()\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window.removeEventListener('resize', this.safeGetRectsBindEvents.bind(this))\r\n    }\r\n\r\n    setGroupData(gIndex, groupData) {\r\n        if (!this.currentIndexList) {\r\n            this.currentIndexList = this.getInitialCurrentIndexList()\r\n        }\r\n        this.items[gIndex] = groupData\r\n        const iCI = groupData.currentIndex\r\n        let movedIndex = 0\r\n        if (typeof iCI === 'number' && iCI >= 0 && groupData.list && groupData.list.length && iCI <= groupData.list.length - 1) {\r\n            movedIndex = Math.round(iCI)\r\n        }\r\n        this.currentIndexList[gIndex] = movedIndex\r\n        this.lastCurrentIndexList = [].concat(this.currentIndexList)\r\n    }\r\n\r\n    getInitialCurrentIndexList() {\r\n        return this.items.map((item, index) => {\r\n            const iCI = item.currentIndex\r\n            if (typeof iCI === 'number' && iCI >= 0 && item.list && item.list.length && iCI <= item.list.length - 1) {\r\n                return Math.round(iCI)\r\n            }\r\n            return 0\r\n        })\r\n    }\r\n\r\n    safeGetRectsBindEvents() {\r\n        if (this.safeDoTimeoutId) {\r\n            clearTimeout(this.safeDoTimeoutId)\r\n        }\r\n        this.safeDoTimeoutId = setTimeout(() => {\r\n            this.getGroupsRectList()\r\n        }, 200)\r\n    }\r\n\r\n    getGroupsRectList() {\r\n        if (this.pickerGroupLayer) {\r\n            this.pickerGroupLayer.toArray().forEach((item, index) => {\r\n                this.groupsRectList[index] = item.nativeElement.getBoundingClientRect()\r\n            })\r\n        }\r\n    }\r\n\r\n    eventsRegister() {\r\n        const handleEventLayer = this.pickerHandleLayer.nativeElement\r\n        if (handleEventLayer) {\r\n            this.addEventsForElement(handleEventLayer)\r\n        }\r\n    }\r\n\r\n    addEventsForElement(el) {\r\n        const _ = this.touchOrMouse.isTouchable\r\n        const eventHandlerList = [\r\n            { name: _ ? 'touchstart' : 'mousedown', handler: this.handleStart },\r\n            { name: _ ? 'touchmove' : 'mousemove', handler: this.handleMove },\r\n            { name: _ ? 'touchend' : 'mouseup', handler: this.handleEnd },\r\n            { name: _ ? 'touchcancel' : 'mouseleave', handler: this.handleCancel }\r\n        ]\r\n        eventHandlerList.forEach((item, index) => {\r\n            el.removeEventListener(item.name, item.handler, false)\r\n            el.addEventListener(item.name, item.handler.bind(this), false)\r\n        })\r\n    }\r\n\r\n    triggerMiddleLayerGroupClick(gIndex) {\r\n        const data = this.items\r\n        if (typeof gIndex === 'number' && typeof data[gIndex].onClick === 'function') {\r\n            data[gIndex].onClick(gIndex, this.currentIndexList[gIndex])\r\n        }\r\n    }\r\n\r\n    triggerAboveLayerClick(ev, gIndex) {\r\n        const movedIndex = this.currentIndexList[gIndex] + 1\r\n        this.currentIndexList[gIndex] = movedIndex\r\n        this.correctionCurrentIndex(ev, gIndex)\r\n    }\r\n\r\n    triggerMiddleLayerClick(ev, gIndex) {\r\n        this.triggerMiddleLayerGroupClick(gIndex)\r\n    }\r\n\r\n    triggerBelowLayerClick(ev, gIndex) {\r\n        const movedIndex = this.currentIndexList[gIndex] - 1\r\n        this.currentIndexList[gIndex] = movedIndex\r\n        this.correctionCurrentIndex(ev, gIndex)\r\n    }\r\n\r\n    getTouchInfo(ev) {\r\n        return this.touchOrMouse.isTouchable ? ev.changedTouches[0] || ev.touches[0] : ev\r\n    }\r\n\r\n    getGroupIndexBelongsEvent(ev) {\r\n        const touchInfo = this.getTouchInfo(ev)\r\n        for (let i = 0; i < this.groupsRectList.length; i++) {\r\n            const item = this.groupsRectList[i]\r\n            if (item.left < touchInfo.pageX && touchInfo.pageX < item.right) {\r\n                return i\r\n            }\r\n        }\r\n        return null\r\n    }\r\n\r\n    handleEventClick(ev) {\r\n        const gIndex = this.getGroupIndexBelongsEvent(ev)\r\n        switch (ev.target.dataset.type) {\r\n            case 'top':\r\n                this.triggerAboveLayerClick(ev, gIndex)\r\n                break\r\n            case 'middle':\r\n                this.triggerMiddleLayerClick(ev, gIndex)\r\n                break\r\n            case 'bottom':\r\n                this.triggerBelowLayerClick(ev, gIndex)\r\n                break\r\n            default:\r\n        }\r\n    }\r\n\r\n    handleStart(ev) {\r\n        if (ev.cancelable) {\r\n            ev.preventDefault()\r\n            ev.stopPropagation()\r\n        }\r\n        const touchInfo = this.getTouchInfo(ev)\r\n        this.draggingInfo.startPageY = touchInfo.pageY\r\n        if (!this.touchOrMouse.isTouchable) {\r\n            this.touchOrMouse.isMouseDown = true\r\n        }\r\n    }\r\n\r\n    handleMove(ev) {\r\n        ev.preventDefault()\r\n        ev.stopPropagation()\r\n        if (this.touchOrMouse.isTouchable || this.touchOrMouse.isMouseDown) {\r\n            this.draggingInfo.isDragging = true\r\n            this.setCurrentIndexOnMove(ev)\r\n        }\r\n    }\r\n\r\n    handleEnd(ev) {\r\n        ev.preventDefault()\r\n        ev.stopPropagation()\r\n        if (!this.draggingInfo.isDragging) {\r\n            this.handleEventClick(ev)\r\n        }\r\n        this.draggingInfo.isDragging = false\r\n        this.touchOrMouse.isMouseDown = false\r\n        this.correctionAfterDragging(ev)\r\n    }\r\n\r\n    handleCancel(ev) {\r\n        ev.preventDefault()\r\n        ev.stopPropagation()\r\n        if (this.touchOrMouse.isTouchable || this.touchOrMouse.isMouseDown) {\r\n            this.correctionAfterDragging(ev)\r\n            this.touchOrMouse.isMouseDown = false\r\n            this.draggingInfo.isDragging = false\r\n        }\r\n    }\r\n\r\n    setCurrentIndexOnMove(ev) {\r\n        const touchInfo = this.getTouchInfo(ev)\r\n        if (this.draggingInfo.groupIndex === null) {\r\n            this.draggingInfo.groupIndex = this.getGroupIndexBelongsEvent(ev)\r\n        }\r\n        const gIndex = this.draggingInfo.groupIndex\r\n        if (typeof gIndex === 'number' && (this.items[gIndex].divider || !this.items[gIndex].list)) {\r\n            return\r\n        }\r\n        const moveCount = (this.draggingInfo.startPageY - touchInfo.pageY) / 32\r\n        const movedIndex = this.currentIndexList[gIndex] + moveCount\r\n        this.currentIndexList[gIndex] = movedIndex\r\n        this.draggingInfo.startPageY = touchInfo.pageY\r\n    }\r\n\r\n    correctionAfterDragging(ev) {\r\n        const gIndex = this.draggingInfo.groupIndex\r\n        this.correctionCurrentIndex(ev, gIndex)\r\n        this.draggingInfo.groupIndex = null\r\n        this.draggingInfo.startPageY = null\r\n    }\r\n\r\n    correctionCurrentIndex(ev, gIndex) {\r\n        setTimeout(() => {\r\n            if (typeof gIndex === 'number' && this.items[gIndex].divider !== true && this.items[gIndex].list.length > 0) {\r\n                const unsafeGroupIndex = this.currentIndexList[gIndex]\r\n                let movedIndex = unsafeGroupIndex\r\n                if (unsafeGroupIndex > this.items[gIndex].list.length - 1) {\r\n                    movedIndex = this.items[gIndex].list.length - 1\r\n                } else if (unsafeGroupIndex < 0) {\r\n                    movedIndex = 0\r\n                }\r\n                movedIndex = Math.round(movedIndex)\r\n                this.currentIndexList[gIndex] = movedIndex\r\n                if (movedIndex !== this.lastCurrentIndexList[gIndex]) {\r\n                    this.OnChange.emit({ gIndex, iIndex: movedIndex })\r\n                }\r\n                this.lastCurrentIndexList = [].concat(this.currentIndexList)\r\n            }\r\n        }, 100)\r\n    }\r\n\r\n    isCurrentItem(gIndex, iIndex) {\r\n        return this.currentIndexList[gIndex] === iIndex\r\n    }\r\n\r\n    getCurrentIndexList() {\r\n        return this.currentIndexList\r\n    }\r\n\r\n    getGroupClass(gIndex) {\r\n        const group = this.items[gIndex]\r\n        const defaultWeightClass = 'weight-' + (group.weight || 1)\r\n        const groupClass = [defaultWeightClass]\r\n        if (group.className) {\r\n            groupClass.push(group.className)\r\n        }\r\n        return groupClass\r\n    }\r\n\r\n    getItemClass(gIndex, iIndex, isDivider = false) {\r\n        const group = this.items[gIndex]\r\n        const itemClass = []\r\n        if (!isDivider && this.isCurrentItem(gIndex, iIndex)) {\r\n            itemClass.push('smooth-item-selected')\r\n        }\r\n        if (group.textAlign) {\r\n            itemClass.push('text-' + group.textAlign)\r\n        }\r\n        return itemClass\r\n    }\r\n\r\n    getItemStyle(gIndex, iIndex) {\r\n        const gapCount = this.currentIndexList[gIndex] - iIndex\r\n        if (Math.abs(gapCount) < (90 / this.itemPerDegree)) {\r\n            const rotateStyle = {\r\n                transform: 'rotateX(' + gapCount * this.itemPerDegree + 'deg) translate3d(0, 0, 5.625em)',\r\n                opacity: (1 - Math.abs(gapCount) / (90 / this.itemPerDegree)).toString()\r\n            }\r\n            if (!this.draggingInfo.isDragging) {\r\n                rotateStyle['transition'] = 'transform 150ms ease-out'\r\n            }\r\n            return rotateStyle\r\n        }\r\n        if (gapCount > 0) {\r\n            return { transform: 'rotateX(90deg) translate3d(0, 0, 5.625em)' }\r\n        } else {\r\n            return { transform: 'rotateX(-90deg) translate3d(0, 0, 5.625em)' }\r\n        }\r\n    }\r\n}\r\n","<!-- <ax-carousel [width]=\"width\" [height]=\"height\" [fixedWidth]=\"width\" [fixedHeight]=\"itemHeight\"  [centered]=\"true\" [vertical]=\"true\" [loop]=\"false\" [wheel]=\"true\" (onSlideChanged)=\"_handleMoveChange($event)\">\r\n    <ax-carousel-item class=\"ax-picker-item\" *ngFor=\"let item of items\">\r\n        <ng-container [ngTemplateOutlet]=\"itemTemplate\"\r\n                [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n    </ax-carousel-item>\r\n</ax-carousel> -->\r\n<div class=\"ng-data-picker flex-box\">\r\n\r\n  <!-- picker-group-layer -->\r\n  <div #pickerGroupLayer *ngFor=\"let group of items; let gI = index\" class=\"picker-group\" [ngClass]=\"getGroupClass(gI)\">\r\n\r\n    <div class=\"picker-list\">\r\n      <div *ngIf=\"group.divider else ngIfElse\" class=\"picker-item divider\" [ngClass]=\"getItemClass(gI, i, true)\">\r\n        {{ group.text }}\r\n      </div>\r\n\r\n      <div #ngIfElse *ngFor=\"let item of group.list; let i = index\" class=\"picker-item\" [ngClass]=\"getItemClass(gI, i)\"\r\n        [ngStyle]=\"getItemStyle(gI, i)\">\r\n        {{ item.value || item }}\r\n      </div>\r\n    </div>\r\n\r\n  </div>\r\n\r\n  <div #pickerHandleLayer class=\"picker-handle-layer flex-box dir-column\">\r\n    <div data-type=\"top\" class=\"picker-top weight-1\"></div>\r\n    <div data-type=\"middle\" class=\"picker-middle\"></div>\r\n    <div data-type=\"bottom\" class=\"picker-bottom weight-1\"></div>\r\n  </div>\r\n\r\n</div>"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLm1vZGVsLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9waWNrZXIvcGlja2VyLm1vZGVsLmNsYXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFBpY2tlckl0ZW0ge1xyXG4gIHRleHRBbGlnbj86ICdzdGFydCcgfCAnY2VudGVyJyB8ICdlbmQnIHwgJ2p1c3RpZnknIHwgJ2xlZnQnIHwgJ3JpZ2h0JyB8ICdub3dyYXAnIHwgJ3dyYXAnXHJcbiAgd2VpZ2h0PzogMSB8IDIgfCAzIHwgNCB8IDUgfCA2IHwgNyB8IDggfCA5IHwgMTAgfCAxMSB8IDEyXHJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXHJcblxyXG4gIG9uQ2xpY2s/OiBGdW5jdGlvblxyXG4gIGN1cnJlbnRJbmRleD86IG51bWJlclxyXG4gIGxpc3Q/Olx0QXJyYXk8YW55PlxyXG5cclxuICBkaXZpZGVyPzogYm9vbGVhblxyXG4gIHRleHQ/OiBzdHJpbmdcclxufSJdfQ==
@@ -38,6 +38,7 @@ export class AXPopoverComponent extends AXInteractiveComponenetMixin {
38
38
  this.closeTrigger = 'clickout';
39
39
  //
40
40
  this.hasBackdrop = false;
41
+ this.adaptivityEnabled = false;
41
42
  //
42
43
  this._mousePos = { x: 0, y: 0 };
43
44
  this._isScrollAttached = false;
@@ -150,7 +151,7 @@ export class AXPopoverComponent extends AXInteractiveComponenetMixin {
150
151
  if (!targetRef)
151
152
  return;
152
153
  if (!this._overlayRef) {
153
- if (this._platform.is('Mobile')) {
154
+ if (this._platform.is('Mobile') && this.adaptivityEnabled) {
154
155
  this._openAsActionsheet();
155
156
  }
156
157
  else {
@@ -220,7 +221,7 @@ export class AXPopoverComponent extends AXInteractiveComponenetMixin {
220
221
  }
221
222
  }
222
223
  AXPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXPopoverComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1.Overlay }, { token: i2.AXPlatform }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
223
- AXPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: AXPopoverComponent, selector: "ax-popover", inputs: { target: "target", position: "position", openTrigger: "openTrigger", closeTrigger: "closeTrigger", hasBackdrop: "hasBackdrop", backdropClass: "backdropClass" }, outputs: { onOpened: "onOpened", onClosed: "onClosed" }, host: { listeners: { "keydown": "_handleKeydownHandler($event)" } }, viewQueries: [{ propertyName: "_baseTemplate", first: true, predicate: ["baseTemplate"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #baseTemplate>\r\n <ng-content></ng-content>\r\n</ng-template>", changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
224
+ AXPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: AXPopoverComponent, selector: "ax-popover", inputs: { target: "target", position: "position", openTrigger: "openTrigger", closeTrigger: "closeTrigger", hasBackdrop: "hasBackdrop", backdropClass: "backdropClass", adaptivityEnabled: "adaptivityEnabled" }, outputs: { onOpened: "onOpened", onClosed: "onClosed" }, host: { listeners: { "keydown": "_handleKeydownHandler($event)" } }, viewQueries: [{ propertyName: "_baseTemplate", first: true, predicate: ["baseTemplate"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #baseTemplate>\r\n <ng-content></ng-content>\r\n</ng-template>", changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
224
225
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXPopoverComponent, decorators: [{
225
226
  type: Component,
226
227
  args: [{ selector: 'ax-popover', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template #baseTemplate>\r\n <ng-content></ng-content>\r\n</ng-template>" }]
@@ -239,6 +240,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
239
240
  type: Input
240
241
  }], backdropClass: [{
241
242
  type: Input
243
+ }], adaptivityEnabled: [{
244
+ type: Input
242
245
  }], onOpened: [{
243
246
  type: Output
244
247
  }], onClosed: [{
@@ -247,4 +250,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
247
250
  type: HostListener,
248
251
  args: ['keydown', ['$event']]
249
252
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/popover/popover.component.ts","../../../../../../projects/acorex/components/src/lib/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgZone, ChangeDetectorRef, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, TemplateRef, ElementRef, ViewContainerRef, HostListener, EventEmitter, Output } from '@angular/core';\r\nimport { AXBaseComponent, AXConnectedPosition, AXEvent, AXInteractiveComponenetMixin } from '../base';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { AXDrawingUtil, AXPlatform, AXPoint } from '@acorex/core';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport _ from 'lodash';\r\nimport { throttleTime } from 'rxjs/operators';\r\n\r\n\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'ax-popover',\r\n  templateUrl: './popover.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXPopoverComponent extends AXInteractiveComponenetMixin {\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    public _cdr: ChangeDetectorRef,\r\n    private _zone: NgZone,\r\n    private _overlay: Overlay,\r\n    private _platform: AXPlatform,\r\n    private _viewContainerRef: ViewContainerRef,\r\n\r\n  ) {\r\n    super(_elementRef, _cdr);\r\n  }\r\n  //\r\n  private _target: HTMLElement;\r\n  @Input()\r\n  public get target(): HTMLElement | ElementRef | AXBaseComponent {\r\n    return this._target;\r\n  }\r\n  public set target(v: HTMLElement | ElementRef | AXBaseComponent) {\r\n    if (v instanceof HTMLElement)\r\n      this._target = v;\r\n    else if (v instanceof ElementRef)\r\n      this._target = v.nativeElement;\r\n    else if (v instanceof AXBaseComponent)\r\n      this._target = v._getInnerElement();\r\n  }\r\n\r\n\r\n  @Input()\r\n  position: AXConnectedPosition | AXConnectedPosition[] = [\r\n    {\r\n      originX: 'start',\r\n      originY: 'bottom',\r\n      overlayX: 'start',\r\n      overlayY: 'top',\r\n    },\r\n    {\r\n      originX: 'start',\r\n      originY: 'top',\r\n      overlayX: 'start',\r\n      overlayY: 'bottom'\r\n    }\r\n  ];\r\n  //\r\n  @ViewChild('baseTemplate')\r\n  _baseTemplate: TemplateRef<any>;\r\n  _overlayRef: OverlayRef;\r\n  _templatePortal: TemplatePortal;\r\n\r\n  _subs: Subscription[] = [];\r\n  //\r\n  @Input()\r\n  openTrigger: 'manual' | 'click' | 'mouseover' | 'toggle' = 'toggle';\r\n  //\r\n  @Input()\r\n  closeTrigger: 'manual' | 'clickout' | 'mouseout' = 'clickout';\r\n  //\r\n  @Input()\r\n  hasBackdrop: boolean = false;\r\n\r\n  @Input()\r\n  backdropClass: string;\r\n  //\r\n  private _mousePos: AXPoint = { x: 0, y: 0 };\r\n  private _isScrollAttached: boolean = false;\r\n  //\r\n  @Output()\r\n  onOpened: EventEmitter<AXEvent> = new EventEmitter<AXEvent>();\r\n  @Output()\r\n  onClosed: EventEmitter<AXEvent> = new EventEmitter<AXEvent>();\r\n\r\n  _emitOnOpenedEvent() {\r\n    this.onOpened.emit({\r\n      component: this,\r\n      htmlElement: this._getHostElement()\r\n    });\r\n  }\r\n\r\n  _emitOnClosedEvent() {\r\n    this.onClosed.emit({\r\n      component: this,\r\n      htmlElement: this._getHostElement()\r\n    });\r\n  }\r\n  //\r\n  onViewInit() {\r\n    if (this._target) {\r\n      if (this.openTrigger === 'mouseover') {\r\n        const mouseEnter$ = fromEvent<MouseEvent>(this._target, 'mouseover');\r\n        this._addSub(mouseEnter$.subscribe(e => {\r\n          const point = { x: e.clientX, y: e.clientY };\r\n          if (AXDrawingUtil.isInElementBound(point, this._target))\r\n            this.open();\r\n        }));\r\n      }\r\n      if (this.closeTrigger === 'mouseout') {\r\n        const mouseMove$ = fromEvent<MouseEvent>(document, 'mousemove');\r\n        this._addSub(mouseMove$.pipe(throttleTime(50)).subscribe(e => {\r\n          this._mousePos.x = e.clientX;\r\n          this._mousePos.y = e.clientY;\r\n          if (this.isOpen) {\r\n            setTimeout(() => {\r\n              if (!_.some([this._target, this._overlayRef.overlayElement], el => _.includes(document.elementsFromPoint(this._mousePos.x, this._mousePos.y), el)))\r\n                this.close();\r\n            }, 100)\r\n          }\r\n        }));\r\n\r\n      }\r\n      //\r\n      if (this.openTrigger === 'click' || this.openTrigger === 'toggle') {\r\n        const click$ = fromEvent<MouseEvent>(this._target, 'click');\r\n        this._addSub(click$.subscribe(e => {\r\n          this.openTrigger == 'toggle' ? this.toggle() : this.open();\r\n        }));\r\n      }\r\n    }\r\n  }\r\n  //\r\n  onDestroy(): void {\r\n    this._overlayRef?.detach();\r\n    this._overlayRef?.dispose();\r\n    this._subs.forEach(s => {\r\n      s?.unsubscribe();\r\n    });\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  _handleKeydownHandler(e: KeyboardEvent) {\r\n    // if (e.key === 'Enter' && e.type === 'keydown') {\r\n    //   this.toggle();\r\n    // }\r\n    if (e.key === 'Escape') {\r\n      if (this.isOpen) {\r\n        this.close();\r\n        e.stopPropagation();\r\n      }\r\n    }\r\n  }\r\n\r\n  toggle() {\r\n    this.isOpen ? this.close() : this.open();\r\n  }\r\n  //\r\n  close() {\r\n    if (!this.isOpen) {\r\n      return;\r\n    }\r\n    this._overlayRef?.detach();\r\n    this._emitOnClosedEvent();\r\n  }\r\n\r\n  dispose() {\r\n    this.close();\r\n    this._overlayRef?.dispose();\r\n    this._overlayRef = null;\r\n  }\r\n  //\r\n  open() {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n    this._ensureOverlayCreated();\r\n    this._overlayRef.attach(this._templatePortal);\r\n    this._emitOnOpenedEvent();\r\n  }\r\n\r\n  private _ensureOverlayCreated() {\r\n    const targetRef = this._target;\r\n    if (!targetRef)\r\n      return;\r\n\r\n    if (!this._overlayRef) {\r\n      if (this._platform.is('Mobile')) {\r\n        this._openAsActionsheet();\r\n      }\r\n      else {\r\n        this._openAsPopover(targetRef);\r\n      }\r\n\r\n      if (this.closeTrigger == 'clickout') {\r\n        this._addSub(this._overlayRef._outsidePointerEvents.subscribe(c => {\r\n          const target = c.target as HTMLElement;\r\n          const comElem = targetRef;\r\n          if (!(comElem.contains(target))) {\r\n            this.close();\r\n          }\r\n        }));\r\n      }\r\n      this._addSub(this._overlayRef.attachments().subscribe(() => {\r\n        if (!this._isScrollAttached) {\r\n          this._addSub(this._platform.scroll.subscribe(c => {\r\n            if (!(c.nativeEvent.target as HTMLElement).closest('.ax-overlay-pane'))\r\n              this.updatePosition();\r\n          }));\r\n          this._isScrollAttached = true;\r\n        }\r\n      }));\r\n    }\r\n    if (!this._templatePortal) {\r\n      this._templatePortal = new TemplatePortal(this._baseTemplate, this._viewContainerRef);\r\n    }\r\n  }\r\n\r\n  private _openAsPopover(targetRef: HTMLElement) {\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy: this._overlay.position()\r\n        .flexibleConnectedTo(targetRef)\r\n        .withPositions(Array.isArray(this.position) ? this.position : [this.position])\r\n        .withPush(false),\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-fadeIn', 'ax-animate-faster'],\r\n      maxHeight: 'unset',\r\n      hasBackdrop: this.hasBackdrop,\r\n      backdropClass: [this.backdropClass || 'cdk-overlay-transparent-backdrop']\r\n    });\r\n  }\r\n\r\n  private _openAsActionsheet() {\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy: this._overlay.position().flexibleConnectedTo(document.body).withPositions([\r\n        {\r\n          originX: 'center',\r\n          originY: 'bottom',\r\n          overlayX: 'center',\r\n          overlayY: 'bottom'\r\n        }\r\n      ]),\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-slideInUp', 'ax-animate-faster'],\r\n      hasBackdrop: true,\r\n      width: '100%'\r\n    });\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return this._overlayRef ? this._overlayRef.hasAttached() : false;\r\n  }\r\n\r\n  private _addSub(sub: Subscription) {\r\n    this._subs.push(sub);\r\n  }\r\n\r\n\r\n  updatePosition(): void {\r\n    this._overlayRef?.updatePosition();\r\n    this.focus();\r\n  }\r\n\r\n}\r\n","<ng-template #baseTemplate>\r\n  <ng-content></ng-content>\r\n</ng-template>"]}
253
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/popover/popover.component.ts","../../../../../../projects/acorex/components/src/lib/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgZone, ChangeDetectorRef, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, TemplateRef, ElementRef, ViewContainerRef, HostListener, EventEmitter, Output } from '@angular/core';\r\nimport { AXBaseComponent, AXConnectedPosition, AXEvent, AXInteractiveComponenetMixin } from '../base';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { AXDrawingUtil, AXPlatform, AXPoint } from '@acorex/core';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport _ from 'lodash';\r\nimport { throttleTime } from 'rxjs/operators';\r\n\r\n\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'ax-popover',\r\n  templateUrl: './popover.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXPopoverComponent extends AXInteractiveComponenetMixin {\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    public _cdr: ChangeDetectorRef,\r\n    private _zone: NgZone,\r\n    private _overlay: Overlay,\r\n    private _platform: AXPlatform,\r\n    private _viewContainerRef: ViewContainerRef,\r\n\r\n  ) {\r\n    super(_elementRef, _cdr);\r\n  }\r\n  //\r\n  private _target: HTMLElement;\r\n  @Input()\r\n  public get target(): HTMLElement | ElementRef | AXBaseComponent {\r\n    return this._target;\r\n  }\r\n  public set target(v: HTMLElement | ElementRef | AXBaseComponent) {\r\n    if (v instanceof HTMLElement)\r\n      this._target = v;\r\n    else if (v instanceof ElementRef)\r\n      this._target = v.nativeElement;\r\n    else if (v instanceof AXBaseComponent)\r\n      this._target = v._getInnerElement();\r\n  }\r\n\r\n\r\n  @Input()\r\n  position: AXConnectedPosition | AXConnectedPosition[] = [\r\n    {\r\n      originX: 'start',\r\n      originY: 'bottom',\r\n      overlayX: 'start',\r\n      overlayY: 'top',\r\n    },\r\n    {\r\n      originX: 'start',\r\n      originY: 'top',\r\n      overlayX: 'start',\r\n      overlayY: 'bottom'\r\n    }\r\n  ];\r\n  //\r\n  @ViewChild('baseTemplate')\r\n  _baseTemplate: TemplateRef<any>;\r\n  _overlayRef: OverlayRef;\r\n  _templatePortal: TemplatePortal;\r\n\r\n  _subs: Subscription[] = [];\r\n  //\r\n  @Input()\r\n  openTrigger: 'manual' | 'click' | 'mouseover' | 'toggle' = 'toggle';\r\n  //\r\n  @Input()\r\n  closeTrigger: 'manual' | 'clickout' | 'mouseout' = 'clickout';\r\n  //\r\n  @Input()\r\n  hasBackdrop: boolean = false;\r\n\r\n  @Input()\r\n  backdropClass: string;\r\n\r\n  @Input()\r\n  adaptivityEnabled: boolean=false;\r\n  //\r\n  private _mousePos: AXPoint = { x: 0, y: 0 };\r\n  private _isScrollAttached: boolean = false;\r\n  //\r\n  @Output()\r\n  onOpened: EventEmitter<AXEvent> = new EventEmitter<AXEvent>();\r\n  @Output()\r\n  onClosed: EventEmitter<AXEvent> = new EventEmitter<AXEvent>();\r\n\r\n  _emitOnOpenedEvent() {\r\n    this.onOpened.emit({\r\n      component: this,\r\n      htmlElement: this._getHostElement()\r\n    });\r\n  }\r\n\r\n  _emitOnClosedEvent() {\r\n    this.onClosed.emit({\r\n      component: this,\r\n      htmlElement: this._getHostElement()\r\n    });\r\n  }\r\n  //\r\n  onViewInit() {\r\n    if (this._target) {\r\n      if (this.openTrigger === 'mouseover') {\r\n        const mouseEnter$ = fromEvent<MouseEvent>(this._target, 'mouseover');\r\n        this._addSub(mouseEnter$.subscribe(e => {\r\n          const point = { x: e.clientX, y: e.clientY };\r\n          if (AXDrawingUtil.isInElementBound(point, this._target))\r\n            this.open();\r\n        }));\r\n      }\r\n      if (this.closeTrigger === 'mouseout') {\r\n        const mouseMove$ = fromEvent<MouseEvent>(document, 'mousemove');\r\n        this._addSub(mouseMove$.pipe(throttleTime(50)).subscribe(e => {\r\n          this._mousePos.x = e.clientX;\r\n          this._mousePos.y = e.clientY;\r\n          if (this.isOpen) {\r\n            setTimeout(() => {\r\n              if (!_.some([this._target, this._overlayRef.overlayElement], el => _.includes(document.elementsFromPoint(this._mousePos.x, this._mousePos.y), el)))\r\n                this.close();\r\n            }, 100)\r\n          }\r\n        }));\r\n\r\n      }\r\n      //\r\n      if (this.openTrigger === 'click' || this.openTrigger === 'toggle') {\r\n        const click$ = fromEvent<MouseEvent>(this._target, 'click');\r\n        this._addSub(click$.subscribe(e => {\r\n          this.openTrigger == 'toggle' ? this.toggle() : this.open();\r\n        }));\r\n      }\r\n    }\r\n  }\r\n  //\r\n  onDestroy(): void {\r\n    this._overlayRef?.detach();\r\n    this._overlayRef?.dispose();\r\n    this._subs.forEach(s => {\r\n      s?.unsubscribe();\r\n    });\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  _handleKeydownHandler(e: KeyboardEvent) {\r\n    // if (e.key === 'Enter' && e.type === 'keydown') {\r\n    //   this.toggle();\r\n    // }\r\n    if (e.key === 'Escape') {\r\n      if (this.isOpen) {\r\n        this.close();\r\n        e.stopPropagation();\r\n      }\r\n    }\r\n  }\r\n\r\n  toggle() {\r\n    this.isOpen ? this.close() : this.open();\r\n  }\r\n  //\r\n  close() {\r\n    if (!this.isOpen) {\r\n      return;\r\n    }\r\n    this._overlayRef?.detach();\r\n    this._emitOnClosedEvent();\r\n  }\r\n\r\n  dispose() {\r\n    this.close();\r\n    this._overlayRef?.dispose();\r\n    this._overlayRef = null;\r\n  }\r\n  //\r\n  open() {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n    this._ensureOverlayCreated();\r\n    this._overlayRef.attach(this._templatePortal);\r\n    this._emitOnOpenedEvent();\r\n  }\r\n\r\n  private _ensureOverlayCreated() {\r\n    const targetRef = this._target;\r\n    if (!targetRef)\r\n      return;\r\n\r\n    if (!this._overlayRef) {\r\n      if (this._platform.is('Mobile') && this.adaptivityEnabled) {\r\n        this._openAsActionsheet();\r\n      }\r\n      else {\r\n        this._openAsPopover(targetRef);\r\n      }\r\n\r\n      if (this.closeTrigger == 'clickout') {\r\n        this._addSub(this._overlayRef._outsidePointerEvents.subscribe(c => {\r\n          const target = c.target as HTMLElement;\r\n          const comElem = targetRef;\r\n          if (!(comElem.contains(target))) {\r\n            this.close();\r\n          }\r\n        }));\r\n      }\r\n      this._addSub(this._overlayRef.attachments().subscribe(() => {\r\n        if (!this._isScrollAttached) {\r\n          this._addSub(this._platform.scroll.subscribe(c => {\r\n            if (!(c.nativeEvent.target as HTMLElement).closest('.ax-overlay-pane'))\r\n              this.updatePosition();\r\n          }));\r\n          this._isScrollAttached = true;\r\n        }\r\n      }));\r\n    }\r\n    if (!this._templatePortal) {\r\n      this._templatePortal = new TemplatePortal(this._baseTemplate, this._viewContainerRef);\r\n    }\r\n  }\r\n\r\n  private _openAsPopover(targetRef: HTMLElement) {\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy: this._overlay.position()\r\n        .flexibleConnectedTo(targetRef)\r\n        .withPositions(Array.isArray(this.position) ? this.position : [this.position])\r\n        .withPush(false),\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-fadeIn', 'ax-animate-faster'],\r\n      maxHeight: 'unset',\r\n      hasBackdrop: this.hasBackdrop,\r\n      backdropClass: [this.backdropClass || 'cdk-overlay-transparent-backdrop']\r\n    });\r\n  }\r\n\r\n  private _openAsActionsheet() {\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy: this._overlay.position().flexibleConnectedTo(document.body).withPositions([\r\n        {\r\n          originX: 'center',\r\n          originY: 'bottom',\r\n          overlayX: 'center',\r\n          overlayY: 'bottom'\r\n        }\r\n      ]),\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-slideInUp', 'ax-animate-faster'],\r\n      hasBackdrop: true,\r\n      width: '100%'\r\n    });\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return this._overlayRef ? this._overlayRef.hasAttached() : false;\r\n  }\r\n\r\n  private _addSub(sub: Subscription) {\r\n    this._subs.push(sub);\r\n  }\r\n\r\n\r\n  updatePosition(): void {\r\n    this._overlayRef?.updatePosition();\r\n    this.focus();\r\n  }\r\n\r\n}\r\n","<ng-template #baseTemplate>\r\n  <ng-content></ng-content>\r\n</ng-template>"]}