@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.
- package/esm2020/lib/alert/alert-button.component.mjs +2 -3
- package/esm2020/lib/alert/alert.component.mjs +33 -23
- package/esm2020/lib/alert/alert.module.mjs +6 -22
- package/esm2020/lib/alert/index.mjs +1 -5
- package/esm2020/lib/base/components.class.mjs +17 -0
- package/esm2020/lib/base/events.class.mjs +1 -1
- package/esm2020/lib/base/index.mjs +2 -1
- package/esm2020/lib/base/mixin/base-components.class.mjs +5 -5
- package/esm2020/lib/base/mixin/base-menu-mixin.class.mjs +4 -3
- package/esm2020/lib/base/mixin/color-look-mixing.class.mjs +1 -1
- package/esm2020/lib/base/mixin/datalist-component.class.mjs +2 -1
- package/esm2020/lib/base/styles.class.mjs +1 -1
- package/esm2020/lib/button/button-group.component.mjs +1 -1
- package/esm2020/lib/button/button-item.class.mjs +1 -1
- package/esm2020/lib/button/button.module.mjs +4 -5
- package/esm2020/lib/calendar/calendar.component.mjs +4 -4
- package/esm2020/lib/calendar/calendar.module.mjs +4 -5
- package/esm2020/lib/checkbox/checkbox.module.mjs +5 -5
- package/esm2020/lib/datepicker/datepicker.component.mjs +11 -7
- package/esm2020/lib/datepicker/datepicker.module.mjs +4 -7
- package/esm2020/lib/decorators/close-button.component.mjs +40 -0
- package/esm2020/lib/decorators/decorators.module.mjs +37 -7
- package/esm2020/lib/decorators/footer.component.mjs +24 -0
- package/esm2020/lib/decorators/header.component.mjs +3 -5
- package/esm2020/lib/decorators/icon.component.mjs +28 -0
- package/esm2020/lib/decorators/index.mjs +5 -1
- package/esm2020/lib/decorators/prefix.component.mjs +3 -3
- package/esm2020/lib/decorators/suffix.component.mjs +3 -3
- package/esm2020/lib/decorators/title.component.mjs +24 -0
- package/esm2020/lib/dialog/dialog.module.mjs +4 -4
- package/esm2020/lib/drawer/drawer-container.component.mjs +17 -57
- package/esm2020/lib/drawer/drawer.component.mjs +97 -127
- package/esm2020/lib/drawer/drawer.module.mjs +3 -4
- package/esm2020/lib/drawer/index.mjs +1 -2
- package/esm2020/lib/dropdown/dropdown-panel.component.mjs +4 -4
- package/esm2020/lib/dropdown/dropdown.module.mjs +5 -6
- package/esm2020/lib/menu/menu.component.mjs +20 -7
- package/esm2020/lib/menu/menu.module.mjs +4 -7
- package/esm2020/lib/number-box/number-box.component.mjs +2 -2
- package/esm2020/lib/number-box/number-box.module.mjs +4 -7
- package/esm2020/lib/page/base-page.class.mjs +3 -3
- package/esm2020/lib/page/index.mjs +1 -3
- package/esm2020/lib/page/page.module.mjs +4 -6
- package/esm2020/lib/password-box/password-box.component.mjs +2 -2
- package/esm2020/lib/password-box/password-box.module.mjs +4 -7
- package/esm2020/lib/picker/picker.component.mjs +260 -25
- package/esm2020/lib/picker/picker.model.class.mjs +2 -0
- package/esm2020/lib/popover/popover.component.mjs +6 -3
- package/esm2020/lib/popup/popup.component.mjs +13 -10
- package/esm2020/lib/popup/popup.module.mjs +4 -3
- package/esm2020/lib/radio/index.mjs +1 -1
- package/esm2020/lib/radio/radio.component.mjs +3 -3
- package/esm2020/lib/radio/radio.module.mjs +1 -1
- package/esm2020/lib/searchbox/index.mjs +3 -0
- package/esm2020/lib/searchbox/searchbox.component.mjs +47 -0
- package/esm2020/lib/searchbox/searchbox.module.mjs +24 -0
- package/esm2020/lib/selectbox/selectbox.component.mjs +33 -26
- package/esm2020/lib/selectbox/selectbox.module.mjs +5 -9
- package/esm2020/lib/tabs/tabs.module.mjs +4 -4
- package/esm2020/lib/textbox/textbox.module.mjs +5 -9
- package/esm2020/lib/toast/toast.class.mjs +1 -1
- package/esm2020/lib/toast/toast.component.mjs +14 -12
- package/esm2020/lib/toast/toast.module.mjs +5 -3
- package/esm2020/lib/toast/toast.service.mjs +37 -9
- package/esm2020/public-api.mjs +2 -2
- package/fesm2015/acorex-components.mjs +849 -662
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +840 -662
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/lib/alert/alert.component.d.ts +7 -6
- package/lib/alert/alert.module.d.ts +4 -8
- package/lib/alert/index.d.ts +0 -4
- package/lib/badge/badge.component.d.ts +3 -3
- package/lib/base/components.class.d.ts +11 -0
- package/lib/base/index.d.ts +1 -0
- package/lib/base/mixin/base-components.class.d.ts +2 -2
- package/lib/base/mixin/button-mixin.class.d.ts +0 -3
- package/lib/base/mixin/color-look-mixing.class.d.ts +4 -4
- package/lib/base/mixin/mixin.class.d.ts +6 -6
- package/lib/base/mixin/selection-component.class.d.ts +3 -0
- package/lib/base/mixin/textbox-mixin.class.d.ts +3 -3
- package/lib/base/styles.class.d.ts +1 -1
- package/lib/button/button-group.component.d.ts +4 -4
- package/lib/button/button-item.class.d.ts +2 -2
- package/lib/button/button.module.d.ts +2 -3
- package/lib/calendar/calendar.module.d.ts +4 -5
- package/lib/checkbox/checkbox.module.d.ts +1 -1
- package/lib/datepicker/datepicker.module.d.ts +3 -4
- package/lib/decorators/close-button.component.d.ts +13 -0
- package/lib/decorators/decorators.module.d.ts +10 -6
- package/lib/decorators/footer.component.d.ts +8 -0
- package/lib/decorators/header.component.d.ts +1 -1
- package/lib/decorators/icon.component.d.ts +10 -0
- package/lib/decorators/index.d.ts +4 -0
- package/lib/decorators/prefix.component.d.ts +1 -1
- package/lib/decorators/suffix.component.d.ts +1 -1
- package/lib/decorators/title.component.d.ts +9 -0
- package/lib/dialog/dialog.module.d.ts +1 -1
- package/lib/drawer/drawer-container.component.d.ts +5 -8
- package/lib/drawer/drawer.component.d.ts +23 -19
- package/lib/drawer/drawer.module.d.ts +2 -3
- package/lib/drawer/index.d.ts +0 -1
- package/lib/dropdown/dropdown.module.d.ts +3 -4
- package/lib/menu/menu.component.d.ts +1 -0
- package/lib/menu/menu.module.d.ts +2 -2
- package/lib/number-box/number-box.module.d.ts +2 -3
- package/lib/page/base-page.class.d.ts +2 -2
- package/lib/page/index.d.ts +0 -2
- package/lib/page/page.module.d.ts +1 -3
- package/lib/password-box/password-box.module.d.ts +1 -2
- package/lib/picker/picker.component.d.ts +54 -13
- package/lib/picker/picker.model.class.d.ts +10 -0
- package/lib/popover/popover.component.d.ts +2 -1
- package/lib/popup/popup.module.d.ts +2 -1
- package/lib/searchbox/index.d.ts +2 -0
- package/lib/searchbox/searchbox.component.d.ts +16 -0
- package/lib/searchbox/searchbox.module.d.ts +11 -0
- package/lib/selectbox/selectbox.component.d.ts +4 -14
- package/lib/selectbox/selectbox.module.d.ts +6 -7
- package/lib/tabs/tabs.module.d.ts +1 -1
- package/lib/textbox/textbox.module.d.ts +2 -3
- package/lib/toast/toast.class.d.ts +4 -3
- package/lib/toast/toast.component.d.ts +0 -2
- package/lib/toast/toast.module.d.ts +3 -1
- package/lib/toast/toast.service.d.ts +4 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/esm2020/lib/alert/alert-content.component.mjs +0 -21
- package/esm2020/lib/alert/alert-footer.component.mjs +0 -27
- package/esm2020/lib/alert/alert-suffix.component.mjs +0 -27
- package/esm2020/lib/alert/alert-title.component.mjs +0 -23
- package/esm2020/lib/drawer/drawer-content.component.mjs +0 -27
- package/esm2020/lib/icon/icon.component.mjs +0 -28
- package/esm2020/lib/icon/icon.module.mjs +0 -21
- package/esm2020/lib/icon/index.mjs +0 -3
- package/esm2020/lib/page/page-footer.component.mjs +0 -28
- package/esm2020/lib/page/page-header.component.mjs +0 -28
- package/lib/alert/alert-content.component.d.ts +0 -5
- package/lib/alert/alert-footer.component.d.ts +0 -5
- package/lib/alert/alert-suffix.component.d.ts +0 -5
- package/lib/alert/alert-title.component.d.ts +0 -5
- package/lib/drawer/drawer-content.component.d.ts +0 -8
- package/lib/icon/icon.component.d.ts +0 -10
- package/lib/icon/icon.module.d.ts +0 -8
- package/lib/icon/index.d.ts +0 -2
- package/lib/page/page-footer.component.d.ts +0 -7
- 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.
|
|
9
|
+
this.cdr = cdr;
|
|
12
10
|
this.items = [];
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
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
|
-
|
|
21
|
-
|
|
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
|
-
|
|
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",
|
|
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
|
|
31
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: {
|
|
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: ['
|
|
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":"AAAA,OAAO,EAAqB,SAAS,EAAE,YAAY,EAAc,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC1J,OAAO,EAAE,yBAAyB,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;;;AAS7E,MAAM,OAAO,iBAAkB,SAAQ,yBAAyB;IAyB5D,YAAY,UAAsB,EAAU,GAAsB;QAC9D,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QADiB,QAAG,GAAH,GAAG,CAAmB;QAjBzD,UAAK,GAAiB,EAAE,CAAA;QACvB,aAAQ,GAAsB,IAAI,YAAY,EAAO,CAAA;QAK/D,iBAAY,GAAG;YACX,WAAW,EAAE,cAAc,IAAI,MAAM;YACrC,WAAW,EAAE,KAAK;SACrB,CAAA;QACD,iBAAY,GAAG;YACX,UAAU,EAAE,KAAK;YACjB,UAAU,EAAE,IAAI;YAChB,UAAU,EAAE,IAAI;SACnB,CAAA;QACD,kBAAa,GAAG,EAAE,CAAA;QAClB,oBAAe,GAAQ,IAAI,CAAA;IAG3B,CAAC;IAGD,QAAQ;QACJ,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,0BAA0B,EAAE,CAAA;QACzD,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;QAE5D,IAAI,CAAC,cAAc,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAElD,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;IAC7E,CAAC;IAED,eAAe;QACX,IAAI,CAAC,iBAAiB,EAAE,CAAA;IAC5B,CAAC;IAED,WAAW;QACP,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;IAChF,CAAC;IAED,YAAY,CAAC,MAAM,EAAE,SAAS;QAC1B,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,0BAA0B,EAAE,CAAA;SAC5D;QACD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,SAAS,CAAA;QAC9B,MAAM,GAAG,GAAG,SAAS,CAAC,YAAY,CAAA;QAClC,IAAI,UAAU,GAAG,CAAC,CAAA;QAClB,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACpH,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;SAC/B;QACD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,UAAU,CAAA;QAC1C,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;IAChE,CAAC;IAED,0BAA0B;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAA;YAC7B,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrG,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;aACzB;YACD,OAAO,CAAC,CAAA;QACZ,CAAC,CAAC,CAAA;IACN,CAAC;IAED,sBAAsB;QAClB,IAAI,IAAI,CAAC,eAAe,EAAE;YACtB,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;SACrC;QACD,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC,GAAG,EAAE;YACnC,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAC5B,CAAC,EAAE,GAAG,CAAC,CAAA;IACX,CAAC;IAED,iBAAiB;QACb,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACpD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAA;YAC3E,CAAC,CAAC,CAAA;SACL;IACL,CAAC;IAED,cAAc;QACV,MAAM,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAA;QAC7D,IAAI,gBAAgB,EAAE;YAClB,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;SAC7C;IACL,CAAC;IAED,mBAAmB,CAAC,EAAE;QAClB,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAA;QACvC,MAAM,gBAAgB,GAAG;YACrB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE;YACnE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE;YACjE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE;YAC7D,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE;SACzE,CAAA;QACD,gBAAgB,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACrC,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAA;YACtD,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAA;QAClE,CAAC,CAAC,CAAA;IACN,CAAC;IAED,4BAA4B,CAAC,MAAM;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAA;QACvB,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,KAAK,UAAU,EAAE;YAC1E,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAA;SAC9D;IACL,CAAC;IAED,sBAAsB,CAAC,EAAE,EAAE,MAAM;QAC7B,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QACpD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,UAAU,CAAA;QAC1C,IAAI,CAAC,sBAAsB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;IAC3C,CAAC;IAED,uBAAuB,CAAC,EAAE,EAAE,MAAM;QAC9B,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,CAAA;IAC7C,CAAC;IAED,sBAAsB,CAAC,EAAE,EAAE,MAAM;QAC7B,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QACpD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,UAAU,CAAA;QAC1C,IAAI,CAAC,sBAAsB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;IAC3C,CAAC;IAED,YAAY,CAAC,EAAE;QACX,OAAO,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IACrF,CAAC;IAED,yBAAyB,CAAC,EAAE;QACxB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAA;QACvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACjD,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAA;YACnC,IAAI,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE;gBAC7D,OAAO,CAAC,CAAA;aACX;SACJ;QACD,OAAO,IAAI,CAAA;IACf,CAAC;IAED,gBAAgB,CAAC,EAAE;QACf,MAAM,MAAM,GAAG,IAAI,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAA;QACjD,QAAQ,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE;YAC5B,KAAK,KAAK;gBACN,IAAI,CAAC,sBAAsB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;gBACvC,MAAK;YACT,KAAK,QAAQ;gBACT,IAAI,CAAC,uBAAuB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;gBACxC,MAAK;YACT,KAAK,QAAQ;gBACT,IAAI,CAAC,sBAAsB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;gBACvC,MAAK;YACT,QAAQ;SACX;IACL,CAAC;IAED,WAAW,CAAC,EAAE;QACV,IAAI,EAAE,CAAC,UAAU,EAAE;YACf,EAAE,CAAC,cAAc,EAAE,CAAA;YACnB,EAAE,CAAC,eAAe,EAAE,CAAA;SACvB;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAA;QACvC,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,SAAS,CAAC,KAAK,CAAA;QAC9C,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;YAChC,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,IAAI,CAAA;SACvC;IACL,CAAC;IAED,UAAU,CAAC,EAAE;QACT,EAAE,CAAC,cAAc,EAAE,CAAA;QACnB,EAAE,CAAC,eAAe,EAAE,CAAA;QACpB,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;YAChE,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAA;YACnC,IAAI,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAA;SACjC;IACL,CAAC;IAED,SAAS,CAAC,EAAE;QACR,EAAE,CAAC,cAAc,EAAE,CAAA;QACnB,EAAE,CAAC,eAAe,EAAE,CAAA;QACpB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE;YAC/B,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAA;SAC5B;QACD,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,KAAK,CAAA;QACpC,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,KAAK,CAAA;QACrC,IAAI,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAAA;IACpC,CAAC;IAED,YAAY,CAAC,EAAE;QACX,EAAE,CAAC,cAAc,EAAE,CAAA;QACnB,EAAE,CAAC,eAAe,EAAE,CAAA;QACpB,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;YAChE,IAAI,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAAA;YAChC,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,KAAK,CAAA;YACrC,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,KAAK,CAAA;SACvC;IACL,CAAC;IAED,qBAAqB,CAAC,EAAE;QACpB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAA;QACvC,IAAI,IAAI,CAAC,YAAY,CAAC,UAAU,KAAK,IAAI,EAAE;YACvC,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAA;SACpE;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAA;QAC3C,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE;YACxF,OAAM;SACT;QACD,MAAM,SAAS,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,EAAE,CAAA;QACvE,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,SAAS,CAAA;QAC5D,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,UAAU,CAAA;QAC1C,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,SAAS,CAAC,KAAK,CAAA;IAClD,CAAC;IAED,uBAAuB,CAAC,EAAE;QACtB,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAA;QAC3C,IAAI,CAAC,sBAAsB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;QACvC,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAA;QACnC,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,CAAA;IACvC,CAAC;IAED,sBAAsB,CAAC,EAAE,EAAE,MAAM;QAC7B,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;gBACzG,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAA;gBACtD,IAAI,UAAU,GAAG,gBAAgB,CAAA;gBACjC,IAAI,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;oBACvD,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAA;iBAClD;qBAAM,IAAI,gBAAgB,GAAG,CAAC,EAAE;oBAC7B,UAAU,GAAG,CAAC,CAAA;iBACjB;gBACD,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;gBACnC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,UAAU,CAAA;gBAC1C,IAAI,UAAU,KAAK,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,EAAE;oBAClD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAA;iBACrD;gBACD,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;aAC/D;QACL,CAAC,EAAE,GAAG,CAAC,CAAA;IACX,CAAC;IAED,aAAa,CAAC,MAAM,EAAE,MAAM;QACxB,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,MAAM,CAAA;IACnD,CAAC;IAED,mBAAmB;QACf,OAAO,IAAI,CAAC,gBAAgB,CAAA;IAChC,CAAC;IAED,aAAa,CAAC,MAAM;QAChB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAChC,MAAM,kBAAkB,GAAG,SAAS,GAAG,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC,CAAA;QAC1D,MAAM,UAAU,GAAG,CAAC,kBAAkB,CAAC,CAAA;QACvC,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;SACnC;QACD,OAAO,UAAU,CAAA;IACrB,CAAC;IAED,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,KAAK;QAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAChC,MAAM,SAAS,GAAG,EAAE,CAAA;QACpB,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE;YAClD,SAAS,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAA;SACzC;QACD,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,SAAS,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,SAAS,CAAC,CAAA;SAC5C;QACD,OAAO,SAAS,CAAA;IACpB,CAAC;IAED,YAAY,CAAC,MAAM,EAAE,MAAM;QACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,MAAM,CAAA;QACvD,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE;YAChD,MAAM,WAAW,GAAG;gBAChB,SAAS,EAAE,UAAU,GAAG,QAAQ,GAAG,IAAI,CAAC,aAAa,GAAG,iCAAiC;gBACzF,OAAO,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,EAAE;aAC3E,CAAA;YACD,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE;gBAC/B,WAAW,CAAC,YAAY,CAAC,GAAG,0BAA0B,CAAA;aACzD;YACD,OAAO,WAAW,CAAA;SACrB;QACD,IAAI,QAAQ,GAAG,CAAC,EAAE;YACd,OAAO,EAAE,SAAS,EAAE,2CAA2C,EAAE,CAAA;SACpE;aAAM;YACH,OAAO,EAAE,SAAS,EAAE,4CAA4C,EAAE,CAAA;SACrE;IACL,CAAC;;8GAvSQ,iBAAiB;kGAAjB,iBAAiB,6XAKZ,WAAW,uSChB7B,09CA8BM;2FDnBO,iBAAiB;kBAP7B,SAAS;+BACI,WAAW,QAEf,EAAE,KAAK,EAAE,WAAW,EAAE,UACpB,CAAC,GAAG,YAAY,CAAC,WAChB,CAAC,GAAG,YAAY,CAAC;iIAIQ,gBAAgB;sBAAjD,YAAY;uBAAC,kBAAkB;gBACkB,iBAAiB;sBAAlE,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGhD,YAAY;sBADX,YAAY;uBAAC,WAAW;gBAGhB,KAAK;sBAAb,KAAK;gBACI,QAAQ;sBAAjB,MAAM","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>"]}
|