primeng 16.0.2 → 16.1.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/accordion/accordion.d.ts +35 -11
- package/api/translation.d.ts +23 -0
- package/api/treenode.d.ts +1 -1
- package/avatar/avatar.d.ts +11 -1
- package/breadcrumb/breadcrumb.d.ts +5 -1
- package/button/button.d.ts +3 -0
- package/chip/chip.d.ts +1 -0
- package/contextmenu/contextmenu.d.ts +157 -67
- package/dock/dock.d.ts +47 -2
- package/dom/domhandler.d.ts +1 -0
- package/esm2022/accordion/accordion.mjs +177 -43
- package/esm2022/api/primengconfig.mjs +75 -2
- package/esm2022/api/translation.mjs +1 -1
- package/esm2022/api/treenode.mjs +1 -1
- package/esm2022/autocomplete/autocomplete.mjs +3 -3
- package/esm2022/avatar/avatar.mjs +18 -4
- package/esm2022/blockui/blockui.mjs +19 -3
- package/esm2022/breadcrumb/breadcrumb.mjs +50 -33
- package/esm2022/button/button.mjs +4 -1
- package/esm2022/card/card.mjs +3 -3
- package/esm2022/chip/chip.mjs +18 -13
- package/esm2022/contextmenu/contextmenu.mjs +993 -547
- package/esm2022/divider/divider.mjs +3 -3
- package/esm2022/dock/dock.mjs +284 -86
- package/esm2022/dom/domhandler.mjs +19 -7
- package/esm2022/dynamicdialog/dynamicdialog-ref.mjs +4 -1
- package/esm2022/fieldset/fieldset.mjs +59 -32
- package/esm2022/image/image.mjs +11 -3
- package/esm2022/inplace/inplace.mjs +18 -11
- package/esm2022/megamenu/megamenu.mjs +997 -348
- package/esm2022/menu/menu.mjs +397 -166
- package/esm2022/menubar/menubar.mjs +895 -282
- package/esm2022/orderlist/orderlist.mjs +9 -15
- package/esm2022/panel/panel.mjs +44 -33
- package/esm2022/panelmenu/panelmenu.mjs +982 -344
- package/esm2022/progressbar/progressbar.mjs +19 -15
- package/esm2022/progressspinner/progressspinner.mjs +5 -5
- package/esm2022/ripple/ripple.mjs +3 -1
- package/esm2022/scrollpanel/scrollpanel.mjs +195 -23
- package/esm2022/scrolltop/scrolltop.mjs +11 -2
- package/esm2022/skeleton/skeleton.mjs +3 -3
- package/esm2022/slidemenu/slidemenu.mjs +1059 -372
- package/esm2022/splitbutton/splitbutton.mjs +2 -2
- package/esm2022/splitter/splitter.mjs +160 -29
- package/esm2022/steps/steps.mjs +112 -22
- package/esm2022/table/table.mjs +13 -7
- package/esm2022/tabmenu/tabmenu.mjs +191 -63
- package/esm2022/tabview/tabview.mjs +173 -39
- package/esm2022/terminal/terminal.mjs +3 -3
- package/esm2022/tieredmenu/tieredmenu.mjs +868 -392
- package/esm2022/toolbar/toolbar.mjs +17 -10
- package/esm2022/tooltip/tooltip.mjs +1 -1
- package/esm2022/tree/tree.mjs +3 -3
- package/esm2022/treetable/treetable.mjs +17 -17
- package/esm2022/utils/objectutils.mjs +31 -1
- package/esm2022/utils/uniquecomponentid.mjs +2 -3
- package/fesm2022/primeng-accordion.mjs +176 -42
- package/fesm2022/primeng-accordion.mjs.map +1 -1
- package/fesm2022/primeng-api.mjs +74 -1
- package/fesm2022/primeng-api.mjs.map +1 -1
- package/fesm2022/primeng-autocomplete.mjs +2 -2
- package/fesm2022/primeng-autocomplete.mjs.map +1 -1
- package/fesm2022/primeng-avatar.mjs +17 -3
- package/fesm2022/primeng-avatar.mjs.map +1 -1
- package/fesm2022/primeng-blockui.mjs +18 -2
- package/fesm2022/primeng-blockui.mjs.map +1 -1
- package/fesm2022/primeng-breadcrumb.mjs +49 -32
- package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
- package/fesm2022/primeng-button.mjs +3 -0
- package/fesm2022/primeng-button.mjs.map +1 -1
- package/fesm2022/primeng-card.mjs +2 -2
- package/fesm2022/primeng-card.mjs.map +1 -1
- package/fesm2022/primeng-chip.mjs +17 -12
- package/fesm2022/primeng-chip.mjs.map +1 -1
- package/fesm2022/primeng-contextmenu.mjs +992 -546
- package/fesm2022/primeng-contextmenu.mjs.map +1 -1
- package/fesm2022/primeng-divider.mjs +2 -2
- package/fesm2022/primeng-divider.mjs.map +1 -1
- package/fesm2022/primeng-dock.mjs +283 -85
- package/fesm2022/primeng-dock.mjs.map +1 -1
- package/fesm2022/primeng-dom.mjs +18 -6
- package/fesm2022/primeng-dom.mjs.map +1 -1
- package/fesm2022/primeng-dynamicdialog.mjs +3 -0
- package/fesm2022/primeng-dynamicdialog.mjs.map +1 -1
- package/fesm2022/primeng-fieldset.mjs +57 -30
- package/fesm2022/primeng-fieldset.mjs.map +1 -1
- package/fesm2022/primeng-image.mjs +10 -2
- package/fesm2022/primeng-image.mjs.map +1 -1
- package/fesm2022/primeng-inplace.mjs +17 -10
- package/fesm2022/primeng-inplace.mjs.map +1 -1
- package/fesm2022/primeng-megamenu.mjs +996 -348
- package/fesm2022/primeng-megamenu.mjs.map +1 -1
- package/fesm2022/primeng-menu.mjs +396 -165
- package/fesm2022/primeng-menu.mjs.map +1 -1
- package/fesm2022/primeng-menubar.mjs +894 -281
- package/fesm2022/primeng-menubar.mjs.map +1 -1
- package/fesm2022/primeng-orderlist.mjs +8 -14
- package/fesm2022/primeng-orderlist.mjs.map +1 -1
- package/fesm2022/primeng-panel.mjs +44 -33
- package/fesm2022/primeng-panel.mjs.map +1 -1
- package/fesm2022/primeng-panelmenu.mjs +981 -344
- package/fesm2022/primeng-panelmenu.mjs.map +1 -1
- package/fesm2022/primeng-progressbar.mjs +18 -14
- package/fesm2022/primeng-progressbar.mjs.map +1 -1
- package/fesm2022/primeng-progressspinner.mjs +4 -4
- package/fesm2022/primeng-progressspinner.mjs.map +1 -1
- package/fesm2022/primeng-ripple.mjs +2 -0
- package/fesm2022/primeng-ripple.mjs.map +1 -1
- package/fesm2022/primeng-scrollpanel.mjs +194 -22
- package/fesm2022/primeng-scrollpanel.mjs.map +1 -1
- package/fesm2022/primeng-scrolltop.mjs +10 -1
- package/fesm2022/primeng-scrolltop.mjs.map +1 -1
- package/fesm2022/primeng-skeleton.mjs +2 -2
- package/fesm2022/primeng-skeleton.mjs.map +1 -1
- package/fesm2022/primeng-slidemenu.mjs +1058 -371
- package/fesm2022/primeng-slidemenu.mjs.map +1 -1
- package/fesm2022/primeng-splitbutton.mjs +1 -1
- package/fesm2022/primeng-splitbutton.mjs.map +1 -1
- package/fesm2022/primeng-splitter.mjs +160 -29
- package/fesm2022/primeng-splitter.mjs.map +1 -1
- package/fesm2022/primeng-steps.mjs +111 -21
- package/fesm2022/primeng-steps.mjs.map +1 -1
- package/fesm2022/primeng-table.mjs +12 -6
- package/fesm2022/primeng-table.mjs.map +1 -1
- package/fesm2022/primeng-tabmenu.mjs +190 -62
- package/fesm2022/primeng-tabmenu.mjs.map +1 -1
- package/fesm2022/primeng-tabview.mjs +172 -38
- package/fesm2022/primeng-tabview.mjs.map +1 -1
- package/fesm2022/primeng-terminal.mjs +2 -2
- package/fesm2022/primeng-terminal.mjs.map +1 -1
- package/fesm2022/primeng-tieredmenu.mjs +867 -391
- package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
- package/fesm2022/primeng-toolbar.mjs +16 -9
- package/fesm2022/primeng-toolbar.mjs.map +1 -1
- package/fesm2022/primeng-tooltip.mjs.map +1 -1
- package/fesm2022/primeng-tree.mjs +2 -2
- package/fesm2022/primeng-tree.mjs.map +1 -1
- package/fesm2022/primeng-treetable.mjs +16 -16
- package/fesm2022/primeng-treetable.mjs.map +1 -1
- package/fesm2022/primeng-utils.mjs +31 -2
- package/fesm2022/primeng-utils.mjs.map +1 -1
- package/fieldset/fieldset.d.ts +6 -5
- package/image/image.d.ts +1 -0
- package/inplace/inplace.d.ts +6 -1
- package/megamenu/megamenu.d.ts +137 -15
- package/menu/menu.d.ts +64 -7
- package/menubar/menubar.d.ts +116 -22
- package/orderlist/orderlist.d.ts +2 -1
- package/package.json +124 -124
- package/panel/panel.d.ts +6 -5
- package/panelmenu/panelmenu.d.ts +134 -22
- package/resources/components/autocomplete/autocomplete.css +9 -8
- package/resources/components/breadcrumb/breadcrumb.css +9 -3
- package/resources/components/common/common.css +1 -1
- package/resources/components/contextmenu/contextmenu.css +1 -7
- package/resources/components/dock/dock.css +1 -1
- package/resources/components/megamenu/megamenu.css +9 -10
- package/resources/components/panelmenu/panelmenu.css +4 -2
- package/resources/components/slidemenu/slidemenu.css +40 -41
- package/resources/primeng.css +1 -1
- package/resources/primeng.min.css +1 -1
- package/resources/themes/arya-blue/theme.css +342 -390
- package/resources/themes/arya-green/theme.css +342 -390
- package/resources/themes/arya-orange/theme.css +342 -390
- package/resources/themes/arya-purple/theme.css +342 -390
- package/resources/themes/bootstrap4-dark-blue/theme.css +357 -416
- package/resources/themes/bootstrap4-dark-purple/theme.css +357 -416
- package/resources/themes/bootstrap4-light-blue/theme.css +369 -428
- package/resources/themes/bootstrap4-light-purple/theme.css +369 -428
- package/resources/themes/fluent-light/theme.css +352 -400
- package/resources/themes/lara-dark-blue/theme.css +344 -392
- package/resources/themes/lara-dark-indigo/theme.css +344 -392
- package/resources/themes/lara-dark-purple/theme.css +344 -392
- package/resources/themes/lara-dark-teal/theme.css +344 -392
- package/resources/themes/lara-light-blue/theme.css +370 -418
- package/resources/themes/lara-light-indigo/theme.css +370 -418
- package/resources/themes/lara-light-purple/theme.css +370 -418
- package/resources/themes/lara-light-teal/theme.css +370 -418
- package/resources/themes/luna-amber/theme.css +360 -408
- package/resources/themes/luna-blue/theme.css +360 -408
- package/resources/themes/luna-green/theme.css +360 -408
- package/resources/themes/luna-pink/theme.css +360 -408
- package/resources/themes/md-dark-deeppurple/theme.css +373 -403
- package/resources/themes/md-dark-indigo/theme.css +373 -403
- package/resources/themes/md-light-deeppurple/theme.css +373 -403
- package/resources/themes/md-light-indigo/theme.css +373 -403
- package/resources/themes/mdc-dark-deeppurple/theme.css +373 -403
- package/resources/themes/mdc-dark-indigo/theme.css +373 -403
- package/resources/themes/mdc-light-deeppurple/theme.css +373 -403
- package/resources/themes/mdc-light-indigo/theme.css +373 -403
- package/resources/themes/mira/theme.css +347 -395
- package/resources/themes/nano/theme.css +348 -396
- package/resources/themes/nova/theme.css +336 -384
- package/resources/themes/nova-accent/theme.css +336 -384
- package/resources/themes/nova-alt/theme.css +336 -384
- package/resources/themes/rhea/theme.css +336 -384
- package/resources/themes/saga-blue/theme.css +348 -396
- package/resources/themes/saga-green/theme.css +348 -396
- package/resources/themes/saga-orange/theme.css +348 -396
- package/resources/themes/saga-purple/theme.css +348 -396
- package/resources/themes/soho-dark/theme.css +362 -410
- package/resources/themes/soho-light/theme.css +370 -418
- package/resources/themes/tailwind-light/theme.css +361 -409
- package/resources/themes/vela-blue/theme.css +348 -396
- package/resources/themes/vela-green/theme.css +348 -396
- package/resources/themes/vela-orange/theme.css +348 -396
- package/resources/themes/vela-purple/theme.css +348 -396
- package/resources/themes/viva-dark/theme.css +342 -390
- package/resources/themes/viva-light/theme.css +348 -396
- package/scrollpanel/scrollpanel.d.ts +22 -4
- package/scrolltop/scrolltop.d.ts +6 -1
- package/slidemenu/slidemenu.d.ts +192 -88
- package/splitter/splitter.d.ts +18 -5
- package/steps/steps.d.ts +20 -3
- package/table/table.d.ts +3 -1
- package/tabmenu/tabmenu.d.ts +24 -1
- package/tabview/tabview.d.ts +26 -3
- package/tieredmenu/tieredmenu.d.ts +134 -50
- package/toolbar/toolbar.d.ts +6 -1
- package/tooltip/tooltip.d.ts +1 -1
- package/utils/objectutils.d.ts +4 -0
- package/utils/uniquecomponentid.d.ts +1 -1
@@ -25,6 +25,11 @@ class ScrollPanel {
|
|
25
25
|
* @group Props
|
26
26
|
*/
|
27
27
|
styleClass;
|
28
|
+
/**
|
29
|
+
* Step factor to scroll the content while pressing the arrow keys.
|
30
|
+
* @group Props
|
31
|
+
*/
|
32
|
+
step = 5;
|
28
33
|
containerViewChild;
|
29
34
|
contentViewChild;
|
30
35
|
xBarViewChild;
|
@@ -39,6 +44,10 @@ class ScrollPanel {
|
|
39
44
|
isXBarClicked = false;
|
40
45
|
isYBarClicked = false;
|
41
46
|
contentTemplate;
|
47
|
+
lastScrollLeft = 0;
|
48
|
+
lastScrollTop = 0;
|
49
|
+
orientation = 'vertical';
|
50
|
+
timer;
|
42
51
|
windowResizeListener;
|
43
52
|
contentScrollListener;
|
44
53
|
mouseEnterListener;
|
@@ -117,18 +126,22 @@ class ScrollPanel {
|
|
117
126
|
this.scrollYRatio = ownHeight / totalHeight;
|
118
127
|
this.requestAnimationFrame(() => {
|
119
128
|
if (this.scrollXRatio >= 1) {
|
129
|
+
xBar.setAttribute('data-p-scrollpanel-hidden', 'true');
|
120
130
|
DomHandler.addClass(xBar, 'p-scrollpanel-hidden');
|
121
131
|
}
|
122
132
|
else {
|
133
|
+
xBar.setAttribute('data-p-scrollpanel-hidden', 'false');
|
123
134
|
DomHandler.removeClass(xBar, 'p-scrollpanel-hidden');
|
124
135
|
const xBarWidth = Math.max(this.scrollXRatio * 100, 10);
|
125
136
|
const xBarLeft = (content.scrollLeft * (100 - xBarWidth)) / (totalWidth - ownWidth);
|
126
137
|
xBar.style.cssText = 'width:' + xBarWidth + '%; left:' + xBarLeft + '%;bottom:' + bottom + 'px;';
|
127
138
|
}
|
128
139
|
if (this.scrollYRatio >= 1) {
|
140
|
+
yBar.setAttribute('data-p-scrollpanel-hidden', 'true');
|
129
141
|
DomHandler.addClass(yBar, 'p-scrollpanel-hidden');
|
130
142
|
}
|
131
143
|
else {
|
144
|
+
yBar.setAttribute('data-p-scrollpanel-hidden', 'false');
|
132
145
|
DomHandler.removeClass(yBar, 'p-scrollpanel-hidden');
|
133
146
|
const yBarHeight = Math.max(this.scrollYRatio * 100, 10);
|
134
147
|
const yBarTop = (content.scrollTop * (100 - yBarHeight)) / (totalHeight - ownHeight);
|
@@ -137,32 +150,123 @@ class ScrollPanel {
|
|
137
150
|
});
|
138
151
|
this.cd.markForCheck();
|
139
152
|
}
|
140
|
-
|
141
|
-
this.
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
this.
|
146
|
-
|
153
|
+
onScroll(event) {
|
154
|
+
if (this.lastScrollLeft !== event.target.scrollLeft) {
|
155
|
+
this.lastScrollLeft = event.target.scrollLeft;
|
156
|
+
this.orientation = 'horizontal';
|
157
|
+
}
|
158
|
+
else if (this.lastScrollTop !== event.target.scrollTop) {
|
159
|
+
this.lastScrollTop = event.target.scrollTop;
|
160
|
+
this.orientation = 'vertical';
|
161
|
+
}
|
162
|
+
this.moveBar();
|
163
|
+
}
|
164
|
+
onKeyDown(event) {
|
165
|
+
if (this.orientation === 'vertical') {
|
166
|
+
switch (event.code) {
|
167
|
+
case 'ArrowDown': {
|
168
|
+
this.setTimer('scrollTop', this.step);
|
169
|
+
event.preventDefault();
|
170
|
+
break;
|
171
|
+
}
|
172
|
+
case 'ArrowUp': {
|
173
|
+
this.setTimer('scrollTop', this.step * -1);
|
174
|
+
event.preventDefault();
|
175
|
+
break;
|
176
|
+
}
|
177
|
+
case 'ArrowLeft':
|
178
|
+
case 'ArrowRight': {
|
179
|
+
event.preventDefault();
|
180
|
+
break;
|
181
|
+
}
|
182
|
+
default:
|
183
|
+
//no op
|
184
|
+
break;
|
185
|
+
}
|
186
|
+
}
|
187
|
+
else if (this.orientation === 'horizontal') {
|
188
|
+
switch (event.code) {
|
189
|
+
case 'ArrowRight': {
|
190
|
+
this.setTimer('scrollLeft', this.step);
|
191
|
+
event.preventDefault();
|
192
|
+
break;
|
193
|
+
}
|
194
|
+
case 'ArrowLeft': {
|
195
|
+
this.setTimer('scrollLeft', this.step * -1);
|
196
|
+
event.preventDefault();
|
197
|
+
break;
|
198
|
+
}
|
199
|
+
case 'ArrowDown':
|
200
|
+
case 'ArrowUp': {
|
201
|
+
event.preventDefault();
|
202
|
+
break;
|
203
|
+
}
|
204
|
+
default:
|
205
|
+
//no op
|
206
|
+
break;
|
207
|
+
}
|
208
|
+
}
|
209
|
+
}
|
210
|
+
onKeyUp() {
|
211
|
+
this.clearTimer();
|
212
|
+
}
|
213
|
+
repeat(bar, step) {
|
214
|
+
this.contentViewChild.nativeElement[bar] += step;
|
215
|
+
this.moveBar();
|
216
|
+
}
|
217
|
+
setTimer(bar, step) {
|
218
|
+
this.clearTimer();
|
219
|
+
this.timer = setTimeout(() => {
|
220
|
+
this.repeat(bar, step);
|
221
|
+
}, 40);
|
222
|
+
}
|
223
|
+
clearTimer() {
|
224
|
+
if (this.timer) {
|
225
|
+
clearTimeout(this.timer);
|
226
|
+
}
|
147
227
|
}
|
148
228
|
bindDocumentMouseListeners() {
|
149
|
-
|
150
|
-
|
229
|
+
if (!this.documentMouseMoveListener) {
|
230
|
+
this.documentMouseMoveListener = (e) => {
|
231
|
+
this.onDocumentMouseMove(e);
|
232
|
+
};
|
233
|
+
this.document.addEventListener('mousemove', this.documentMouseMoveListener);
|
234
|
+
}
|
235
|
+
if (!this.documentMouseUpListener) {
|
236
|
+
this.documentMouseUpListener = (e) => {
|
237
|
+
this.onDocumentMouseUp(e);
|
238
|
+
};
|
239
|
+
this.document.addEventListener('mouseup', this.documentMouseUpListener);
|
240
|
+
}
|
151
241
|
}
|
152
242
|
unbindDocumentMouseListeners() {
|
153
243
|
if (this.documentMouseMoveListener) {
|
154
|
-
this.documentMouseMoveListener
|
244
|
+
this.document.removeEventListener('mousemove', this.documentMouseMoveListener);
|
155
245
|
this.documentMouseMoveListener = null;
|
156
246
|
}
|
157
247
|
if (this.documentMouseUpListener) {
|
158
|
-
this.documentMouseUpListener
|
248
|
+
document.removeEventListener('mouseup', this.documentMouseUpListener);
|
159
249
|
this.documentMouseUpListener = null;
|
160
250
|
}
|
161
251
|
}
|
252
|
+
onYBarMouseDown(e) {
|
253
|
+
this.isYBarClicked = true;
|
254
|
+
this.yBarViewChild.nativeElement.focus();
|
255
|
+
this.lastPageY = e.pageY;
|
256
|
+
this.yBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'true');
|
257
|
+
DomHandler.addClass(this.yBarViewChild.nativeElement, 'p-scrollpanel-grabbed');
|
258
|
+
this.document.body.setAttribute('data-p-scrollpanel-grabbed', 'true');
|
259
|
+
DomHandler.addClass(this.document.body, 'p-scrollpanel-grabbed');
|
260
|
+
this.bindDocumentMouseListeners();
|
261
|
+
e.preventDefault();
|
262
|
+
}
|
162
263
|
onXBarMouseDown(e) {
|
163
264
|
this.isXBarClicked = true;
|
265
|
+
this.xBarViewChild.nativeElement.focus();
|
164
266
|
this.lastPageX = e.pageX;
|
267
|
+
this.xBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'false');
|
165
268
|
DomHandler.addClass(this.xBarViewChild.nativeElement, 'p-scrollpanel-grabbed');
|
269
|
+
this.document.body.setAttribute('data-p-scrollpanel-grabbed', 'false');
|
166
270
|
DomHandler.addClass(this.document.body, 'p-scrollpanel-grabbed');
|
167
271
|
this.bindDocumentMouseListeners();
|
168
272
|
e.preventDefault();
|
@@ -203,9 +307,25 @@ class ScrollPanel {
|
|
203
307
|
scrollTop = scrollTop > scrollableHeight ? scrollableHeight : scrollTop > 0 ? scrollTop : 0;
|
204
308
|
this.contentViewChild.nativeElement.scrollTop = scrollTop;
|
205
309
|
}
|
310
|
+
onFocus(event) {
|
311
|
+
if (this.xBarViewChild.nativeElement.isSameNode(event.target)) {
|
312
|
+
this.orientation = 'horizontal';
|
313
|
+
}
|
314
|
+
else if (this.yBarViewChild.nativeElement.isSameNode(event.target)) {
|
315
|
+
this.orientation = 'vertical';
|
316
|
+
}
|
317
|
+
}
|
318
|
+
onBlur() {
|
319
|
+
if (this.orientation === 'horizontal') {
|
320
|
+
this.orientation = 'vertical';
|
321
|
+
}
|
322
|
+
}
|
206
323
|
onDocumentMouseUp(e) {
|
324
|
+
this.yBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'false');
|
207
325
|
DomHandler.removeClass(this.yBarViewChild.nativeElement, 'p-scrollpanel-grabbed');
|
326
|
+
this.xBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'false');
|
208
327
|
DomHandler.removeClass(this.xBarViewChild.nativeElement, 'p-scrollpanel-grabbed');
|
328
|
+
this.document.body.setAttribute('data-p-scrollpanel-grabbed', 'false');
|
209
329
|
DomHandler.removeClass(this.document.body, 'p-scrollpanel-grabbed');
|
210
330
|
this.unbindDocumentMouseListeners();
|
211
331
|
this.isXBarClicked = false;
|
@@ -250,16 +370,41 @@ class ScrollPanel {
|
|
250
370
|
this.moveBar();
|
251
371
|
}
|
252
372
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ScrollPanel, deps: [{ token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: DOCUMENT }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
253
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: ScrollPanel, selector: "p-scrollPanel", inputs: { style: "style", styleClass: "styleClass" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "containerViewChild", first: true, predicate: ["container"], descendants: true }, { propertyName: "contentViewChild", first: true, predicate: ["content"], descendants: true }, { propertyName: "xBarViewChild", first: true, predicate: ["xBar"], descendants: true }, { propertyName: "yBarViewChild", first: true, predicate: ["yBar"], descendants: true }], ngImport: i0, template: `
|
254
|
-
<div #container [ngClass]="'p-scrollpanel p-component'" [ngStyle]="style" [class]="styleClass">
|
255
|
-
<div class="p-scrollpanel-wrapper">
|
256
|
-
<div #content class="p-scrollpanel-content">
|
373
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: ScrollPanel, selector: "p-scrollPanel", inputs: { style: "style", styleClass: "styleClass", step: "step" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "containerViewChild", first: true, predicate: ["container"], descendants: true }, { propertyName: "contentViewChild", first: true, predicate: ["content"], descendants: true }, { propertyName: "xBarViewChild", first: true, predicate: ["xBar"], descendants: true }, { propertyName: "yBarViewChild", first: true, predicate: ["yBar"], descendants: true }], ngImport: i0, template: `
|
374
|
+
<div #container [ngClass]="'p-scrollpanel p-component'" [ngStyle]="style" [class]="styleClass" [attr.data-pc-name]="'scrollpanel'">
|
375
|
+
<div class="p-scrollpanel-wrapper" [attr.data-pc-section]="'wrapper'">
|
376
|
+
<div #content class="p-scrollpanel-content" [attr.data-pc-section]="'content'" (mouseenter)="moveBar()" (scroll)="onScroll($event)">
|
257
377
|
<ng-content></ng-content>
|
258
378
|
<ng-container *ngTemplateOutlet="contentTemplate"></ng-container>
|
259
379
|
</div>
|
260
380
|
</div>
|
261
|
-
<div
|
262
|
-
|
381
|
+
<div
|
382
|
+
#xBar
|
383
|
+
class="p-scrollpanel-bar p-scrollpanel-bar-x"
|
384
|
+
tabindex="0"
|
385
|
+
role="scrollbar"
|
386
|
+
[attr.aria-orientation]="'horizontal'"
|
387
|
+
[attr.aria-valuenow]="lastScrollLeft"
|
388
|
+
[attr.data-pc-section]="'barx'"
|
389
|
+
(mousedown)="onXBarMouseDown($event)"
|
390
|
+
(keydown)="onKeyDown($event)"
|
391
|
+
(keyup)="onKeyUp()"
|
392
|
+
(focus)="onFocus($event)"
|
393
|
+
(blur)="onBlur()"
|
394
|
+
></div>
|
395
|
+
<div
|
396
|
+
#yBar
|
397
|
+
class="p-scrollpanel-bar p-scrollpanel-bar-y"
|
398
|
+
tabindex="0"
|
399
|
+
role="scrollbar"
|
400
|
+
[attr.aria-orientation]="'vertical'"
|
401
|
+
[attr.aria-valuenow]="lastScrollTop"
|
402
|
+
[attr.data-pc-section]="'bary'"
|
403
|
+
(mousedown)="onYBarMouseDown($event)"
|
404
|
+
(keydown)="onKeyDown($event)"
|
405
|
+
(keyup)="onKeyUp()"
|
406
|
+
(focus)="onFocus($event)"
|
407
|
+
></div>
|
263
408
|
</div>
|
264
409
|
`, isInline: true, styles: [".p-scrollpanel-wrapper{overflow:hidden;width:100%;height:100%;position:relative;float:left}.p-scrollpanel-content{height:calc(100% + 18px);width:calc(100% + 18px);padding:0 18px 18px 0;position:relative;overflow:auto;box-sizing:border-box}.p-scrollpanel-bar{position:relative;background:#c1c1c1;border-radius:3px;cursor:pointer;opacity:0;transition:opacity .25s linear}.p-scrollpanel-bar-y{width:9px;top:0}.p-scrollpanel-bar-x{height:9px;bottom:0}.p-scrollpanel-hidden{visibility:hidden}.p-scrollpanel:hover .p-scrollpanel-bar,.p-scrollpanel:active .p-scrollpanel-bar{opacity:1}.p-scrollpanel-grabbed{-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
265
410
|
}
|
@@ -267,15 +412,40 @@ export { ScrollPanel };
|
|
267
412
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ScrollPanel, decorators: [{
|
268
413
|
type: Component,
|
269
414
|
args: [{ selector: 'p-scrollPanel', template: `
|
270
|
-
<div #container [ngClass]="'p-scrollpanel p-component'" [ngStyle]="style" [class]="styleClass">
|
271
|
-
<div class="p-scrollpanel-wrapper">
|
272
|
-
<div #content class="p-scrollpanel-content">
|
415
|
+
<div #container [ngClass]="'p-scrollpanel p-component'" [ngStyle]="style" [class]="styleClass" [attr.data-pc-name]="'scrollpanel'">
|
416
|
+
<div class="p-scrollpanel-wrapper" [attr.data-pc-section]="'wrapper'">
|
417
|
+
<div #content class="p-scrollpanel-content" [attr.data-pc-section]="'content'" (mouseenter)="moveBar()" (scroll)="onScroll($event)">
|
273
418
|
<ng-content></ng-content>
|
274
419
|
<ng-container *ngTemplateOutlet="contentTemplate"></ng-container>
|
275
420
|
</div>
|
276
421
|
</div>
|
277
|
-
<div
|
278
|
-
|
422
|
+
<div
|
423
|
+
#xBar
|
424
|
+
class="p-scrollpanel-bar p-scrollpanel-bar-x"
|
425
|
+
tabindex="0"
|
426
|
+
role="scrollbar"
|
427
|
+
[attr.aria-orientation]="'horizontal'"
|
428
|
+
[attr.aria-valuenow]="lastScrollLeft"
|
429
|
+
[attr.data-pc-section]="'barx'"
|
430
|
+
(mousedown)="onXBarMouseDown($event)"
|
431
|
+
(keydown)="onKeyDown($event)"
|
432
|
+
(keyup)="onKeyUp()"
|
433
|
+
(focus)="onFocus($event)"
|
434
|
+
(blur)="onBlur()"
|
435
|
+
></div>
|
436
|
+
<div
|
437
|
+
#yBar
|
438
|
+
class="p-scrollpanel-bar p-scrollpanel-bar-y"
|
439
|
+
tabindex="0"
|
440
|
+
role="scrollbar"
|
441
|
+
[attr.aria-orientation]="'vertical'"
|
442
|
+
[attr.aria-valuenow]="lastScrollTop"
|
443
|
+
[attr.data-pc-section]="'bary'"
|
444
|
+
(mousedown)="onYBarMouseDown($event)"
|
445
|
+
(keydown)="onKeyDown($event)"
|
446
|
+
(keyup)="onKeyUp()"
|
447
|
+
(focus)="onFocus($event)"
|
448
|
+
></div>
|
279
449
|
</div>
|
280
450
|
`, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
281
451
|
class: 'p-element'
|
@@ -290,6 +460,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
290
460
|
type: Input
|
291
461
|
}], styleClass: [{
|
292
462
|
type: Input
|
463
|
+
}], step: [{
|
464
|
+
type: Input
|
293
465
|
}], containerViewChild: [{
|
294
466
|
type: ViewChild,
|
295
467
|
args: ['container']
|
@@ -320,4 +492,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
320
492
|
declarations: [ScrollPanel]
|
321
493
|
}]
|
322
494
|
}] });
|
323
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollpanel.js","sourceRoot":"","sources":["../../../src/app/components/scrollpanel/scrollpanel.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    Inject,\n    Input,\n    NgModule,\n    NgZone,\n    OnDestroy,\n    PLATFORM_ID,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { PrimeTemplate } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\n/**\n * ScrollPanel is a cross browser, lightweight and themable alternative to native browser scrollbar.\n * @group Components\n */\n@Component({\n    selector: 'p-scrollPanel',\n    template: `\n        <div #container [ngClass]=\"'p-scrollpanel p-component'\" [ngStyle]=\"style\" [class]=\"styleClass\">\n            <div class=\"p-scrollpanel-wrapper\">\n                <div #content class=\"p-scrollpanel-content\">\n                    <ng-content></ng-content>\n                    <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n                </div>\n            </div>\n            <div #xBar class=\"p-scrollpanel-bar p-scrollpanel-bar-x\"></div>\n            <div #yBar class=\"p-scrollpanel-bar p-scrollpanel-bar-y\"></div>\n        </div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./scrollpanel.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class ScrollPanel implements AfterViewInit, AfterContentInit, OnDestroy {\n    /**\n     * Inline style of the component.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the component.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n\n    @ViewChild('container') containerViewChild: ElementRef | undefined;\n\n    @ViewChild('content') contentViewChild: ElementRef | undefined;\n\n    @ViewChild('xBar') xBarViewChild: ElementRef | undefined;\n\n    @ViewChild('yBar') yBarViewChild: ElementRef | undefined;\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    scrollYRatio: number | undefined;\n\n    scrollXRatio: number | undefined;\n\n    timeoutFrame: any = (fn: VoidFunction) => setTimeout(fn, 0);\n\n    initialized: boolean = false;\n\n    lastPageY: number | undefined;\n\n    lastPageX: number | undefined;\n\n    isXBarClicked: boolean = false;\n\n    isYBarClicked: boolean = false;\n\n    contentTemplate: TemplateRef<any> | undefined;\n\n    windowResizeListener: VoidFunction | null | undefined;\n\n    contentScrollListener: VoidFunction | null | undefined;\n\n    mouseEnterListener: VoidFunction | null | undefined;\n\n    xBarMouseDownListener: VoidFunction | null | undefined;\n\n    yBarMouseDownListener: VoidFunction | null | undefined;\n\n    documentMouseMoveListener: VoidFunction | null | undefined;\n\n    documentMouseUpListener: VoidFunction | null | undefined;\n\n    constructor(@Inject(PLATFORM_ID) private platformId: any, public el: ElementRef, public zone: NgZone, public cd: ChangeDetectorRef, @Inject(DOCUMENT) private document: Document, private renderer: Renderer2) {}\n\n    ngAfterViewInit() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.zone.runOutsideAngular(() => {\n                this.moveBar();\n                this.moveBar = this.moveBar.bind(this);\n                this.onXBarMouseDown = this.onXBarMouseDown.bind(this);\n                this.onYBarMouseDown = this.onYBarMouseDown.bind(this);\n                this.onDocumentMouseMove = this.onDocumentMouseMove.bind(this);\n                this.onDocumentMouseUp = this.onDocumentMouseUp.bind(this);\n\n                this.windowResizeListener = this.renderer.listen(window, 'resize', this.moveBar);\n                this.contentScrollListener = this.renderer.listen((this.contentViewChild as ElementRef).nativeElement, 'scroll', this.moveBar);\n                this.mouseEnterListener = this.renderer.listen((this.contentViewChild as ElementRef).nativeElement, 'mouseenter', this.moveBar);\n                this.xBarMouseDownListener = this.renderer.listen((this.xBarViewChild as ElementRef).nativeElement, 'mousedown', this.onXBarMouseDown);\n                this.yBarMouseDownListener = this.renderer.listen((this.yBarViewChild as ElementRef).nativeElement, 'mousedown', this.onYBarMouseDown);\n                this.calculateContainerHeight();\n\n                this.initialized = true;\n            });\n        }\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'content':\n                    this.contentTemplate = item.template;\n                    break;\n\n                default:\n                    this.contentTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    calculateContainerHeight() {\n        let container = (this.containerViewChild as ElementRef).nativeElement;\n        let content = (this.contentViewChild as ElementRef).nativeElement;\n        let xBar = (this.xBarViewChild as ElementRef).nativeElement;\n        const window = this.document.defaultView as Window;\n\n        let containerStyles: { [klass: string]: any } = window.getComputedStyle(container),\n            xBarStyles = window.getComputedStyle(xBar),\n            pureContainerHeight = DomHandler.getHeight(container) - parseInt(xBarStyles['height'], 10);\n\n        if (containerStyles['max-height'] != 'none' && pureContainerHeight == 0) {\n            if (content.offsetHeight + parseInt(xBarStyles['height'], 10) > parseInt(containerStyles['max-height'], 10)) {\n                container.style.height = containerStyles['max-height'];\n            } else {\n                container.style.height = content.offsetHeight + parseFloat(containerStyles.paddingTop) + parseFloat(containerStyles.paddingBottom) + parseFloat(containerStyles.borderTopWidth) + parseFloat(containerStyles.borderBottomWidth) + 'px';\n            }\n        }\n    }\n\n    moveBar() {\n        let container = (this.containerViewChild as ElementRef).nativeElement;\n        let content = (this.contentViewChild as ElementRef).nativeElement;\n\n        /* horizontal scroll */\n        let xBar = (this.xBarViewChild as ElementRef).nativeElement;\n        let totalWidth = content.scrollWidth;\n        let ownWidth = content.clientWidth;\n        let bottom = (container.clientHeight - xBar.clientHeight) * -1;\n\n        this.scrollXRatio = ownWidth / totalWidth;\n\n        /* vertical scroll */\n        let yBar = (this.yBarViewChild as ElementRef).nativeElement;\n        let totalHeight = content.scrollHeight;\n        let ownHeight = content.clientHeight;\n        let right = (container.clientWidth - yBar.clientWidth) * -1;\n\n        this.scrollYRatio = ownHeight / totalHeight;\n\n        this.requestAnimationFrame(() => {\n            if ((this.scrollXRatio as number) >= 1) {\n                DomHandler.addClass(xBar, 'p-scrollpanel-hidden');\n            } else {\n                DomHandler.removeClass(xBar, 'p-scrollpanel-hidden');\n                const xBarWidth = Math.max((this.scrollXRatio as number) * 100, 10);\n                const xBarLeft = (content.scrollLeft * (100 - xBarWidth)) / (totalWidth - ownWidth);\n                xBar.style.cssText = 'width:' + xBarWidth + '%; left:' + xBarLeft + '%;bottom:' + bottom + 'px;';\n            }\n\n            if ((this.scrollYRatio as number) >= 1) {\n                DomHandler.addClass(yBar, 'p-scrollpanel-hidden');\n            } else {\n                DomHandler.removeClass(yBar, 'p-scrollpanel-hidden');\n                const yBarHeight = Math.max((this.scrollYRatio as number) * 100, 10);\n                const yBarTop = (content.scrollTop * (100 - yBarHeight)) / (totalHeight - ownHeight);\n                yBar.style.cssText = 'height:' + yBarHeight + '%; top: calc(' + yBarTop + '% - ' + xBar.clientHeight + 'px);right:' + right + 'px;';\n            }\n        });\n        this.cd.markForCheck();\n    }\n\n    onYBarMouseDown(e: MouseEvent) {\n        this.isYBarClicked = true;\n        this.lastPageY = e.pageY;\n        DomHandler.addClass((this.yBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n\n        DomHandler.addClass(this.document.body, 'p-scrollpanel-grabbed');\n        this.bindDocumentMouseListeners();\n        e.preventDefault();\n    }\n\n    bindDocumentMouseListeners(): void {\n        this.documentMouseMoveListener = this.renderer.listen(this.document, 'mousemove', this.onDocumentMouseMove.bind(this));\n        this.documentMouseUpListener = this.renderer.listen(this.document, 'mouseup', this.onDocumentMouseUp.bind(this));\n    }\n\n    unbindDocumentMouseListeners(): void {\n        if (this.documentMouseMoveListener) {\n            this.documentMouseMoveListener();\n            this.documentMouseMoveListener = null;\n        }\n\n        if (this.documentMouseUpListener) {\n            this.documentMouseUpListener();\n            this.documentMouseUpListener = null;\n        }\n    }\n\n    onXBarMouseDown(e: MouseEvent) {\n        this.isXBarClicked = true;\n        this.lastPageX = e.pageX;\n        DomHandler.addClass((this.xBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n\n        DomHandler.addClass(this.document.body, 'p-scrollpanel-grabbed');\n\n        this.bindDocumentMouseListeners();\n        e.preventDefault();\n    }\n\n    onDocumentMouseMove(e: MouseEvent) {\n        if (this.isXBarClicked) {\n            this.onMouseMoveForXBar(e);\n        } else if (this.isYBarClicked) {\n            this.onMouseMoveForYBar(e);\n        } else {\n            this.onMouseMoveForXBar(e);\n            this.onMouseMoveForYBar(e);\n        }\n    }\n\n    onMouseMoveForXBar(e: MouseEvent) {\n        let deltaX = e.pageX - (this.lastPageX as number);\n        this.lastPageX = e.pageX;\n\n        this.requestAnimationFrame(() => {\n            (this.contentViewChild as ElementRef).nativeElement.scrollLeft += deltaX / (this.scrollXRatio as number);\n        });\n    }\n\n    onMouseMoveForYBar(e: MouseEvent) {\n        let deltaY = e.pageY - (this.lastPageY as number);\n        this.lastPageY = e.pageY;\n\n        this.requestAnimationFrame(() => {\n            (this.contentViewChild as ElementRef).nativeElement.scrollTop += deltaY / (this.scrollYRatio as number);\n        });\n    }\n    /**\n     * Scrolls the top location to the given value.\n     * @param scrollTop\n     * @group Method\n     */\n    scrollTop(scrollTop: number) {\n        let scrollableHeight = (this.contentViewChild as ElementRef).nativeElement.scrollHeight - (this.contentViewChild as ElementRef).nativeElement.clientHeight;\n        scrollTop = scrollTop > scrollableHeight ? scrollableHeight : scrollTop > 0 ? scrollTop : 0;\n        (this.contentViewChild as ElementRef).nativeElement.scrollTop = scrollTop;\n    }\n\n    onDocumentMouseUp(e: Event) {\n        DomHandler.removeClass((this.yBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n        DomHandler.removeClass((this.xBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n        DomHandler.removeClass(this.document.body, 'p-scrollpanel-grabbed');\n\n        this.unbindDocumentMouseListeners();\n        this.isXBarClicked = false;\n        this.isYBarClicked = false;\n    }\n\n    requestAnimationFrame(f: VoidFunction) {\n        let frame = window.requestAnimationFrame || this.timeoutFrame;\n        frame(f);\n    }\n\n    unbindListeners() {\n        if (this.windowResizeListener) {\n            this.windowResizeListener();\n            this.windowResizeListener = null;\n        }\n\n        if (this.contentScrollListener) {\n            this.contentScrollListener();\n            this.contentScrollListener = null;\n        }\n\n        if (this.mouseEnterListener) {\n            this.mouseEnterListener();\n            this.mouseEnterListener = null;\n        }\n\n        if (this.xBarMouseDownListener) {\n            this.xBarMouseDownListener();\n            this.xBarMouseDownListener = null;\n        }\n\n        if (this.yBarMouseDownListener) {\n            this.yBarMouseDownListener();\n            this.yBarMouseDownListener = null;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.initialized) {\n            this.unbindListeners();\n        }\n    }\n    /**\n     * Refreshes the position and size of the scrollbar.\n     * @group Method\n     */\n    refresh() {\n        this.moveBar();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [ScrollPanel],\n    declarations: [ScrollPanel]\n})\nexport class ScrollPanelModule {}\n"]}
|
495
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollpanel.js","sourceRoot":"","sources":["../../../src/app/components/scrollpanel/scrollpanel.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    Inject,\n    Input,\n    NgModule,\n    NgZone,\n    OnDestroy,\n    PLATFORM_ID,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { PrimeTemplate } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { Nullable } from 'primeng/ts-helpers';\n/**\n * ScrollPanel is a cross browser, lightweight and themable alternative to native browser scrollbar.\n * @group Components\n */\n@Component({\n    selector: 'p-scrollPanel',\n    template: `\n        <div #container [ngClass]=\"'p-scrollpanel p-component'\" [ngStyle]=\"style\" [class]=\"styleClass\" [attr.data-pc-name]=\"'scrollpanel'\">\n            <div class=\"p-scrollpanel-wrapper\" [attr.data-pc-section]=\"'wrapper'\">\n                <div #content class=\"p-scrollpanel-content\" [attr.data-pc-section]=\"'content'\" (mouseenter)=\"moveBar()\" (scroll)=\"onScroll($event)\">\n                    <ng-content></ng-content>\n                    <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n                </div>\n            </div>\n            <div\n                #xBar\n                class=\"p-scrollpanel-bar p-scrollpanel-bar-x\"\n                tabindex=\"0\"\n                role=\"scrollbar\"\n                [attr.aria-orientation]=\"'horizontal'\"\n                [attr.aria-valuenow]=\"lastScrollLeft\"\n                [attr.data-pc-section]=\"'barx'\"\n                (mousedown)=\"onXBarMouseDown($event)\"\n                (keydown)=\"onKeyDown($event)\"\n                (keyup)=\"onKeyUp()\"\n                (focus)=\"onFocus($event)\"\n                (blur)=\"onBlur()\"\n            ></div>\n            <div\n                #yBar\n                class=\"p-scrollpanel-bar p-scrollpanel-bar-y\"\n                tabindex=\"0\"\n                role=\"scrollbar\"\n                [attr.aria-orientation]=\"'vertical'\"\n                [attr.aria-valuenow]=\"lastScrollTop\"\n                [attr.data-pc-section]=\"'bary'\"\n                (mousedown)=\"onYBarMouseDown($event)\"\n                (keydown)=\"onKeyDown($event)\"\n                (keyup)=\"onKeyUp()\"\n                (focus)=\"onFocus($event)\"\n            ></div>\n        </div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./scrollpanel.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class ScrollPanel implements AfterViewInit, AfterContentInit, OnDestroy {\n    /**\n     * Inline style of the component.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the component.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Step factor to scroll the content while pressing the arrow keys.\n     * @group Props\n     */\n    @Input() step: number = 5;\n\n    @ViewChild('container') containerViewChild: ElementRef | undefined;\n\n    @ViewChild('content') contentViewChild: ElementRef | undefined;\n\n    @ViewChild('xBar') xBarViewChild: ElementRef | undefined;\n\n    @ViewChild('yBar') yBarViewChild: ElementRef | undefined;\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    scrollYRatio: number | undefined;\n\n    scrollXRatio: number | undefined;\n\n    timeoutFrame: any = (fn: VoidFunction) => setTimeout(fn, 0);\n\n    initialized: boolean = false;\n\n    lastPageY: number | undefined;\n\n    lastPageX: number | undefined;\n\n    isXBarClicked: boolean = false;\n\n    isYBarClicked: boolean = false;\n\n    contentTemplate: TemplateRef<any> | undefined;\n\n    lastScrollLeft: number = 0;\n\n    lastScrollTop: number = 0;\n\n    orientation: string = 'vertical';\n\n    timer: any;\n\n    windowResizeListener: VoidFunction | null | undefined;\n\n    contentScrollListener: VoidFunction | null | undefined;\n\n    mouseEnterListener: VoidFunction | null | undefined;\n\n    xBarMouseDownListener: VoidFunction | null | undefined;\n\n    yBarMouseDownListener: VoidFunction | null | undefined;\n\n    documentMouseMoveListener: Nullable<(event?: any) => void>;\n\n    documentMouseUpListener: Nullable<(event?: any) => void>;\n\n    constructor(@Inject(PLATFORM_ID) private platformId: any, public el: ElementRef, public zone: NgZone, public cd: ChangeDetectorRef, @Inject(DOCUMENT) private document: Document, private renderer: Renderer2) {}\n\n    ngAfterViewInit() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.zone.runOutsideAngular(() => {\n                this.moveBar();\n                this.moveBar = this.moveBar.bind(this);\n                this.onXBarMouseDown = this.onXBarMouseDown.bind(this);\n                this.onYBarMouseDown = this.onYBarMouseDown.bind(this);\n                this.onDocumentMouseMove = this.onDocumentMouseMove.bind(this);\n                this.onDocumentMouseUp = this.onDocumentMouseUp.bind(this);\n\n                this.windowResizeListener = this.renderer.listen(window, 'resize', this.moveBar);\n                this.contentScrollListener = this.renderer.listen((this.contentViewChild as ElementRef).nativeElement, 'scroll', this.moveBar);\n                this.mouseEnterListener = this.renderer.listen((this.contentViewChild as ElementRef).nativeElement, 'mouseenter', this.moveBar);\n                this.xBarMouseDownListener = this.renderer.listen((this.xBarViewChild as ElementRef).nativeElement, 'mousedown', this.onXBarMouseDown);\n                this.yBarMouseDownListener = this.renderer.listen((this.yBarViewChild as ElementRef).nativeElement, 'mousedown', this.onYBarMouseDown);\n                this.calculateContainerHeight();\n\n                this.initialized = true;\n            });\n        }\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'content':\n                    this.contentTemplate = item.template;\n                    break;\n\n                default:\n                    this.contentTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    calculateContainerHeight() {\n        let container = (this.containerViewChild as ElementRef).nativeElement;\n        let content = (this.contentViewChild as ElementRef).nativeElement;\n        let xBar = (this.xBarViewChild as ElementRef).nativeElement;\n        const window = this.document.defaultView as Window;\n\n        let containerStyles: { [klass: string]: any } = window.getComputedStyle(container),\n            xBarStyles = window.getComputedStyle(xBar),\n            pureContainerHeight = DomHandler.getHeight(container) - parseInt(xBarStyles['height'], 10);\n\n        if (containerStyles['max-height'] != 'none' && pureContainerHeight == 0) {\n            if (content.offsetHeight + parseInt(xBarStyles['height'], 10) > parseInt(containerStyles['max-height'], 10)) {\n                container.style.height = containerStyles['max-height'];\n            } else {\n                container.style.height = content.offsetHeight + parseFloat(containerStyles.paddingTop) + parseFloat(containerStyles.paddingBottom) + parseFloat(containerStyles.borderTopWidth) + parseFloat(containerStyles.borderBottomWidth) + 'px';\n            }\n        }\n    }\n\n    moveBar() {\n        let container = (this.containerViewChild as ElementRef).nativeElement;\n        let content = (this.contentViewChild as ElementRef).nativeElement;\n\n        /* horizontal scroll */\n        let xBar = (this.xBarViewChild as ElementRef).nativeElement;\n        let totalWidth = content.scrollWidth;\n        let ownWidth = content.clientWidth;\n        let bottom = (container.clientHeight - xBar.clientHeight) * -1;\n\n        this.scrollXRatio = ownWidth / totalWidth;\n\n        /* vertical scroll */\n        let yBar = (this.yBarViewChild as ElementRef).nativeElement;\n        let totalHeight = content.scrollHeight;\n        let ownHeight = content.clientHeight;\n        let right = (container.clientWidth - yBar.clientWidth) * -1;\n\n        this.scrollYRatio = ownHeight / totalHeight;\n\n        this.requestAnimationFrame(() => {\n            if ((this.scrollXRatio as number) >= 1) {\n                xBar.setAttribute('data-p-scrollpanel-hidden', 'true');\n                DomHandler.addClass(xBar, 'p-scrollpanel-hidden');\n            } else {\n                xBar.setAttribute('data-p-scrollpanel-hidden', 'false');\n                DomHandler.removeClass(xBar, 'p-scrollpanel-hidden');\n                const xBarWidth = Math.max((this.scrollXRatio as number) * 100, 10);\n                const xBarLeft = (content.scrollLeft * (100 - xBarWidth)) / (totalWidth - ownWidth);\n                xBar.style.cssText = 'width:' + xBarWidth + '%; left:' + xBarLeft + '%;bottom:' + bottom + 'px;';\n            }\n\n            if ((this.scrollYRatio as number) >= 1) {\n                yBar.setAttribute('data-p-scrollpanel-hidden', 'true');\n                DomHandler.addClass(yBar, 'p-scrollpanel-hidden');\n            } else {\n                yBar.setAttribute('data-p-scrollpanel-hidden', 'false');\n                DomHandler.removeClass(yBar, 'p-scrollpanel-hidden');\n                const yBarHeight = Math.max((this.scrollYRatio as number) * 100, 10);\n                const yBarTop = (content.scrollTop * (100 - yBarHeight)) / (totalHeight - ownHeight);\n                yBar.style.cssText = 'height:' + yBarHeight + '%; top: calc(' + yBarTop + '% - ' + xBar.clientHeight + 'px);right:' + right + 'px;';\n            }\n        });\n        this.cd.markForCheck();\n    }\n\n    onScroll(event) {\n        if (this.lastScrollLeft !== event.target.scrollLeft) {\n            this.lastScrollLeft = event.target.scrollLeft;\n            this.orientation = 'horizontal';\n        } else if (this.lastScrollTop !== event.target.scrollTop) {\n            this.lastScrollTop = event.target.scrollTop;\n            this.orientation = 'vertical';\n        }\n\n        this.moveBar();\n    }\n\n    onKeyDown(event) {\n        if (this.orientation === 'vertical') {\n            switch (event.code) {\n                case 'ArrowDown': {\n                    this.setTimer('scrollTop', this.step);\n                    event.preventDefault();\n                    break;\n                }\n\n                case 'ArrowUp': {\n                    this.setTimer('scrollTop', this.step * -1);\n                    event.preventDefault();\n                    break;\n                }\n\n                case 'ArrowLeft':\n\n                case 'ArrowRight': {\n                    event.preventDefault();\n                    break;\n                }\n\n                default:\n                    //no op\n                    break;\n            }\n        } else if (this.orientation === 'horizontal') {\n            switch (event.code) {\n                case 'ArrowRight': {\n                    this.setTimer('scrollLeft', this.step);\n                    event.preventDefault();\n                    break;\n                }\n\n                case 'ArrowLeft': {\n                    this.setTimer('scrollLeft', this.step * -1);\n                    event.preventDefault();\n                    break;\n                }\n\n                case 'ArrowDown':\n\n                case 'ArrowUp': {\n                    event.preventDefault();\n                    break;\n                }\n\n                default:\n                    //no op\n                    break;\n            }\n        }\n    }\n\n    onKeyUp() {\n        this.clearTimer();\n    }\n\n    repeat(bar, step) {\n        this.contentViewChild.nativeElement[bar] += step;\n        this.moveBar();\n    }\n\n    setTimer(bar, step) {\n        this.clearTimer();\n        this.timer = setTimeout(() => {\n            this.repeat(bar, step);\n        }, 40);\n    }\n\n    clearTimer() {\n        if (this.timer) {\n            clearTimeout(this.timer);\n        }\n    }\n\n    bindDocumentMouseListeners(): void {\n        if (!this.documentMouseMoveListener) {\n            this.documentMouseMoveListener = (e) => {\n                this.onDocumentMouseMove(e);\n            };\n            this.document.addEventListener('mousemove', this.documentMouseMoveListener);\n        }\n\n        if (!this.documentMouseUpListener) {\n            this.documentMouseUpListener = (e) => {\n                this.onDocumentMouseUp(e);\n            };\n            this.document.addEventListener('mouseup', this.documentMouseUpListener);\n        }\n    }\n\n    unbindDocumentMouseListeners(): void {\n        if (this.documentMouseMoveListener) {\n            this.document.removeEventListener('mousemove', this.documentMouseMoveListener);\n            this.documentMouseMoveListener = null;\n        }\n\n        if (this.documentMouseUpListener) {\n            document.removeEventListener('mouseup', this.documentMouseUpListener);\n            this.documentMouseUpListener = null;\n        }\n    }\n\n    onYBarMouseDown(e: MouseEvent) {\n        this.isYBarClicked = true;\n        this.yBarViewChild.nativeElement.focus();\n        this.lastPageY = e.pageY;\n\n        this.yBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'true');\n        DomHandler.addClass((this.yBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n\n        this.document.body.setAttribute('data-p-scrollpanel-grabbed', 'true');\n        DomHandler.addClass(this.document.body, 'p-scrollpanel-grabbed');\n        this.bindDocumentMouseListeners();\n        e.preventDefault();\n    }\n\n    onXBarMouseDown(e: MouseEvent) {\n        this.isXBarClicked = true;\n        this.xBarViewChild.nativeElement.focus();\n        this.lastPageX = e.pageX;\n\n        this.xBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'false');\n        DomHandler.addClass((this.xBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n\n        this.document.body.setAttribute('data-p-scrollpanel-grabbed', 'false');\n        DomHandler.addClass(this.document.body, 'p-scrollpanel-grabbed');\n\n        this.bindDocumentMouseListeners();\n        e.preventDefault();\n    }\n\n    onDocumentMouseMove(e: MouseEvent) {\n        if (this.isXBarClicked) {\n            this.onMouseMoveForXBar(e);\n        } else if (this.isYBarClicked) {\n            this.onMouseMoveForYBar(e);\n        } else {\n            this.onMouseMoveForXBar(e);\n            this.onMouseMoveForYBar(e);\n        }\n    }\n\n    onMouseMoveForXBar(e: MouseEvent) {\n        let deltaX = e.pageX - (this.lastPageX as number);\n        this.lastPageX = e.pageX;\n\n        this.requestAnimationFrame(() => {\n            (this.contentViewChild as ElementRef).nativeElement.scrollLeft += deltaX / (this.scrollXRatio as number);\n        });\n    }\n\n    onMouseMoveForYBar(e: MouseEvent) {\n        let deltaY = e.pageY - (this.lastPageY as number);\n        this.lastPageY = e.pageY;\n\n        this.requestAnimationFrame(() => {\n            (this.contentViewChild as ElementRef).nativeElement.scrollTop += deltaY / (this.scrollYRatio as number);\n        });\n    }\n    /**\n     * Scrolls the top location to the given value.\n     * @param scrollTop\n     * @group Method\n     */\n    scrollTop(scrollTop: number) {\n        let scrollableHeight = (this.contentViewChild as ElementRef).nativeElement.scrollHeight - (this.contentViewChild as ElementRef).nativeElement.clientHeight;\n        scrollTop = scrollTop > scrollableHeight ? scrollableHeight : scrollTop > 0 ? scrollTop : 0;\n        (this.contentViewChild as ElementRef).nativeElement.scrollTop = scrollTop;\n    }\n\n    onFocus(event) {\n        if (this.xBarViewChild.nativeElement.isSameNode(event.target)) {\n            this.orientation = 'horizontal';\n        } else if (this.yBarViewChild.nativeElement.isSameNode(event.target)) {\n            this.orientation = 'vertical';\n        }\n    }\n\n    onBlur() {\n        if (this.orientation === 'horizontal') {\n            this.orientation = 'vertical';\n        }\n    }\n\n    onDocumentMouseUp(e: Event) {\n        this.yBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'false');\n        DomHandler.removeClass((this.yBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n        this.xBarViewChild.nativeElement.setAttribute('data-p-scrollpanel-grabbed', 'false');\n        DomHandler.removeClass((this.xBarViewChild as ElementRef).nativeElement, 'p-scrollpanel-grabbed');\n        this.document.body.setAttribute('data-p-scrollpanel-grabbed', 'false');\n        DomHandler.removeClass(this.document.body, 'p-scrollpanel-grabbed');\n\n        this.unbindDocumentMouseListeners();\n        this.isXBarClicked = false;\n        this.isYBarClicked = false;\n    }\n\n    requestAnimationFrame(f: VoidFunction) {\n        let frame = window.requestAnimationFrame || this.timeoutFrame;\n        frame(f);\n    }\n\n    unbindListeners() {\n        if (this.windowResizeListener) {\n            this.windowResizeListener();\n            this.windowResizeListener = null;\n        }\n\n        if (this.contentScrollListener) {\n            this.contentScrollListener();\n            this.contentScrollListener = null;\n        }\n\n        if (this.mouseEnterListener) {\n            this.mouseEnterListener();\n            this.mouseEnterListener = null;\n        }\n\n        if (this.xBarMouseDownListener) {\n            this.xBarMouseDownListener();\n            this.xBarMouseDownListener = null;\n        }\n\n        if (this.yBarMouseDownListener) {\n            this.yBarMouseDownListener();\n            this.yBarMouseDownListener = null;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.initialized) {\n            this.unbindListeners();\n        }\n    }\n    /**\n     * Refreshes the position and size of the scrollbar.\n     * @group Method\n     */\n    refresh() {\n        this.moveBar();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [ScrollPanel],\n    declarations: [ScrollPanel]\n})\nexport class ScrollPanelModule {}\n"]}
|
@@ -59,6 +59,11 @@ class ScrollTop {
|
|
59
59
|
* @group Props
|
60
60
|
*/
|
61
61
|
hideTransitionOptions = '.15s';
|
62
|
+
/**
|
63
|
+
* Establishes a string value that labels the scroll-top button.
|
64
|
+
* @group Props
|
65
|
+
*/
|
66
|
+
buttonAriaLabel;
|
62
67
|
templates;
|
63
68
|
iconTemplate;
|
64
69
|
documentScrollListener;
|
@@ -165,12 +170,13 @@ class ScrollTop {
|
|
165
170
|
}
|
166
171
|
}
|
167
172
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ScrollTop, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Component });
|
168
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: ScrollTop, selector: "p-scrollTop", inputs: { styleClass: "styleClass", style: "style", target: "target", threshold: "threshold", icon: "icon", behavior: "behavior", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], ngImport: i0, template: `
|
173
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: ScrollTop, selector: "p-scrollTop", inputs: { styleClass: "styleClass", style: "style", target: "target", threshold: "threshold", icon: "icon", behavior: "behavior", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions", buttonAriaLabel: "buttonAriaLabel" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], ngImport: i0, template: `
|
169
174
|
<button
|
170
175
|
*ngIf="visible"
|
171
176
|
[@animation]="{ value: 'open', params: { showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions } }"
|
172
177
|
(@animation.start)="onEnter($event)"
|
173
178
|
(@animation.done)="onLeave($event)"
|
179
|
+
[attr.aria-label]="scrollTopAriaLabel"
|
174
180
|
[ngClass]="containerClass()"
|
175
181
|
(click)="onClick()"
|
176
182
|
[class]="styleClass"
|
@@ -205,6 +211,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
205
211
|
[@animation]="{ value: 'open', params: { showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions } }"
|
206
212
|
(@animation.start)="onEnter($event)"
|
207
213
|
(@animation.done)="onLeave($event)"
|
214
|
+
[attr.aria-label]="scrollTopAriaLabel"
|
208
215
|
[ngClass]="containerClass()"
|
209
216
|
(click)="onClick()"
|
210
217
|
[class]="styleClass"
|
@@ -253,6 +260,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
253
260
|
type: Input
|
254
261
|
}], hideTransitionOptions: [{
|
255
262
|
type: Input
|
263
|
+
}], buttonAriaLabel: [{
|
264
|
+
type: Input
|
256
265
|
}], templates: [{
|
257
266
|
type: ContentChildren,
|
258
267
|
args: [PrimeTemplate]
|
@@ -271,4 +280,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
271
280
|
declarations: [ScrollTop]
|
272
281
|
}]
|
273
282
|
}] });
|
274
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrolltop.js","sourceRoot":"","sources":["../../../src/app/components/scrolltop/scrolltop.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent, animate, state, style, transition, trigger } from '@angular/animations';\nimport { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, Inject, Input, NgModule, OnDestroy, OnInit, PLATFORM_ID, QueryList, Renderer2, TemplateRef, ViewEncapsulation } from '@angular/core';\nimport { PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { ChevronUpIcon } from 'primeng/icons/chevronup';\nimport { ZIndexUtils } from 'primeng/utils';\n/**\n * ScrollTop gets displayed after a certain scroll position and used to navigates to the top of the page quickly.\n * @group Components\n */\n@Component({\n    selector: 'p-scrollTop',\n    template: `\n        <button\n            *ngIf=\"visible\"\n            [@animation]=\"{ value: 'open', params: { showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions } }\"\n            (@animation.start)=\"onEnter($event)\"\n            (@animation.done)=\"onLeave($event)\"\n            [ngClass]=\"containerClass()\"\n            (click)=\"onClick()\"\n            [class]=\"styleClass\"\n            [ngStyle]=\"style\"\n            type=\"button\"\n        >\n            <ng-container *ngIf=\"!iconTemplate\">\n                <span *ngIf=\"icon\" [class]=\"icon\" [ngClass]=\"'p-scrolltop-icon'\"></span>\n                <ChevronUpIcon *ngIf=\"!icon\" [styleClass]=\"'p-scrolltop-icon'\" [ngStyle]=\"{ 'font-size': '1rem', scale: '1.5' }\" />\n            </ng-container>\n            <ng-template [ngIf]=\"!icon\" *ngTemplateOutlet=\"iconTemplate; context: { styleClass: 'p-scrolltop-icon' }\"></ng-template>\n        </button>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./scrolltop.css'],\n    animations: [\n        trigger('animation', [\n            state(\n                'void',\n                style({\n                    opacity: 0\n                })\n            ),\n            state(\n                'open',\n                style({\n                    opacity: 1\n                })\n            ),\n            transition('void => open', animate('{{showTransitionParams}}')),\n            transition('open => void', animate('{{hideTransitionParams}}'))\n        ])\n    ],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class ScrollTop implements OnInit, OnDestroy {\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Target of the ScrollTop.\n     * @group Props\n     */\n    @Input() target: 'window' | 'parent' | undefined = 'window';\n    /**\n     * Defines the threshold value of the vertical scroll position of the target to toggle the visibility.\n     * @group Props\n     */\n    @Input() threshold: number = 400;\n    /**\n     * Name of the icon or JSX.Element for icon.\n     * @group Props\n     */\n    @Input() icon: string | undefined;\n    /**\n     * Defines the scrolling behavior, \"smooth\" adds an animation and \"auto\" scrolls with a jump.\n     * @group Props\n     */\n    @Input() behavior: 'auto' | 'smooth' | undefined = 'smooth';\n    /**\n     * A string value used to determine the display transition options.\n     * @group Props\n     */\n    @Input() showTransitionOptions: string = '.15s';\n    /**\n     * A string value used to determine the hiding transition options.\n     * @group Props\n     */\n    @Input() hideTransitionOptions: string = '.15s';\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    iconTemplate: TemplateRef<any> | undefined;\n\n    documentScrollListener: VoidFunction | null | undefined;\n\n    parentScrollListener: VoidFunction | null | undefined;\n\n    visible: boolean = false;\n\n    overlay: any;\n\n    private window: Window | null;\n\n    constructor(@Inject(DOCUMENT) private document: Document, @Inject(PLATFORM_ID) private platformId: any, private renderer: Renderer2, public el: ElementRef, private cd: ChangeDetectorRef, public config: PrimeNGConfig) {\n        this.window = this.document.defaultView;\n    }\n\n    ngOnInit() {\n        if (this.target === 'window') this.bindDocumentScrollListener();\n        else if (this.target === 'parent') this.bindParentScrollListener();\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'icon':\n                    this.iconTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    onClick() {\n        let scrollElement = this.target === 'window' ? this.window : this.el.nativeElement.parentElement;\n        scrollElement.scroll({\n            top: 0,\n            behavior: this.behavior\n        });\n    }\n\n    onEnter(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'open':\n                this.overlay = event.element;\n                ZIndexUtils.set('overlay', this.overlay, this.config.zIndex.overlay);\n                break;\n            case 'void':\n                this.overlay = null;\n                break;\n        }\n    }\n\n    onLeave(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'void':\n                ZIndexUtils.clear(event.element);\n                break;\n        }\n    }\n\n    checkVisibility(scrollY: number) {\n        if (scrollY > this.threshold) this.visible = true;\n        else this.visible = false;\n\n        this.cd.markForCheck();\n    }\n\n    bindParentScrollListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.parentScrollListener = this.renderer.listen(this.el.nativeElement.parentElement, 'scroll', () => {\n                this.checkVisibility(this.el.nativeElement.parentElement.scrollTop);\n            });\n        }\n    }\n\n    bindDocumentScrollListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.documentScrollListener = this.renderer.listen(this.window, 'scroll', () => {\n                this.checkVisibility(DomHandler.getWindowScrollTop());\n            });\n        }\n    }\n\n    unbindParentScrollListener() {\n        if (this.parentScrollListener) {\n            this.parentScrollListener();\n            this.parentScrollListener = null;\n        }\n    }\n\n    unbindDocumentScrollListener() {\n        if (this.documentScrollListener) {\n            this.documentScrollListener();\n            this.documentScrollListener = null;\n        }\n    }\n\n    containerClass() {\n        return {\n            'p-scrolltop p-link p-component': true,\n            'p-scrolltop-sticky': this.target !== 'window'\n        };\n    }\n\n    ngOnDestroy() {\n        if (this.target === 'window') this.unbindDocumentScrollListener();\n        else if (this.target === 'parent') this.unbindParentScrollListener();\n\n        if (this.overlay) {\n            ZIndexUtils.clear(this.overlay);\n            this.overlay = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, ChevronUpIcon, SharedModule],\n    exports: [ScrollTop, SharedModule],\n    declarations: [ScrollTop]\n})\nexport class ScrollTopModule {}\n"]}
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrolltop.js","sourceRoot":"","sources":["../../../src/app/components/scrolltop/scrolltop.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent, animate, state, style, transition, trigger } from '@angular/animations';\nimport { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, Inject, Input, NgModule, OnDestroy, OnInit, PLATFORM_ID, QueryList, Renderer2, TemplateRef, ViewEncapsulation } from '@angular/core';\nimport { PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { ChevronUpIcon } from 'primeng/icons/chevronup';\nimport { ZIndexUtils } from 'primeng/utils';\n/**\n * ScrollTop gets displayed after a certain scroll position and used to navigates to the top of the page quickly.\n * @group Components\n */\n@Component({\n    selector: 'p-scrollTop',\n    template: `\n        <button\n            *ngIf=\"visible\"\n            [@animation]=\"{ value: 'open', params: { showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions } }\"\n            (@animation.start)=\"onEnter($event)\"\n            (@animation.done)=\"onLeave($event)\"\n            [attr.aria-label]=\"scrollTopAriaLabel\"\n            [ngClass]=\"containerClass()\"\n            (click)=\"onClick()\"\n            [class]=\"styleClass\"\n            [ngStyle]=\"style\"\n            type=\"button\"\n        >\n            <ng-container *ngIf=\"!iconTemplate\">\n                <span *ngIf=\"icon\" [class]=\"icon\" [ngClass]=\"'p-scrolltop-icon'\"></span>\n                <ChevronUpIcon *ngIf=\"!icon\" [styleClass]=\"'p-scrolltop-icon'\" [ngStyle]=\"{ 'font-size': '1rem', scale: '1.5' }\" />\n            </ng-container>\n            <ng-template [ngIf]=\"!icon\" *ngTemplateOutlet=\"iconTemplate; context: { styleClass: 'p-scrolltop-icon' }\"></ng-template>\n        </button>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./scrolltop.css'],\n    animations: [\n        trigger('animation', [\n            state(\n                'void',\n                style({\n                    opacity: 0\n                })\n            ),\n            state(\n                'open',\n                style({\n                    opacity: 1\n                })\n            ),\n            transition('void => open', animate('{{showTransitionParams}}')),\n            transition('open => void', animate('{{hideTransitionParams}}'))\n        ])\n    ],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class ScrollTop implements OnInit, OnDestroy {\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Target of the ScrollTop.\n     * @group Props\n     */\n    @Input() target: 'window' | 'parent' | undefined = 'window';\n    /**\n     * Defines the threshold value of the vertical scroll position of the target to toggle the visibility.\n     * @group Props\n     */\n    @Input() threshold: number = 400;\n    /**\n     * Name of the icon or JSX.Element for icon.\n     * @group Props\n     */\n    @Input() icon: string | undefined;\n    /**\n     * Defines the scrolling behavior, \"smooth\" adds an animation and \"auto\" scrolls with a jump.\n     * @group Props\n     */\n    @Input() behavior: 'auto' | 'smooth' | undefined = 'smooth';\n    /**\n     * A string value used to determine the display transition options.\n     * @group Props\n     */\n    @Input() showTransitionOptions: string = '.15s';\n    /**\n     * A string value used to determine the hiding transition options.\n     * @group Props\n     */\n    @Input() hideTransitionOptions: string = '.15s';\n    /**\n     * Establishes a string value that labels the scroll-top button.\n     * @group Props\n     */\n    @Input() buttonAriaLabel: string | undefined;\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    iconTemplate: TemplateRef<any> | undefined;\n\n    documentScrollListener: VoidFunction | null | undefined;\n\n    parentScrollListener: VoidFunction | null | undefined;\n\n    visible: boolean = false;\n\n    overlay: any;\n\n    private window: Window | null;\n\n    constructor(@Inject(DOCUMENT) private document: Document, @Inject(PLATFORM_ID) private platformId: any, private renderer: Renderer2, public el: ElementRef, private cd: ChangeDetectorRef, public config: PrimeNGConfig) {\n        this.window = this.document.defaultView;\n    }\n\n    ngOnInit() {\n        if (this.target === 'window') this.bindDocumentScrollListener();\n        else if (this.target === 'parent') this.bindParentScrollListener();\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'icon':\n                    this.iconTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    onClick() {\n        let scrollElement = this.target === 'window' ? this.window : this.el.nativeElement.parentElement;\n        scrollElement.scroll({\n            top: 0,\n            behavior: this.behavior\n        });\n    }\n\n    onEnter(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'open':\n                this.overlay = event.element;\n                ZIndexUtils.set('overlay', this.overlay, this.config.zIndex.overlay);\n                break;\n            case 'void':\n                this.overlay = null;\n                break;\n        }\n    }\n\n    onLeave(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'void':\n                ZIndexUtils.clear(event.element);\n                break;\n        }\n    }\n\n    checkVisibility(scrollY: number) {\n        if (scrollY > this.threshold) this.visible = true;\n        else this.visible = false;\n\n        this.cd.markForCheck();\n    }\n\n    bindParentScrollListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.parentScrollListener = this.renderer.listen(this.el.nativeElement.parentElement, 'scroll', () => {\n                this.checkVisibility(this.el.nativeElement.parentElement.scrollTop);\n            });\n        }\n    }\n\n    bindDocumentScrollListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            this.documentScrollListener = this.renderer.listen(this.window, 'scroll', () => {\n                this.checkVisibility(DomHandler.getWindowScrollTop());\n            });\n        }\n    }\n\n    unbindParentScrollListener() {\n        if (this.parentScrollListener) {\n            this.parentScrollListener();\n            this.parentScrollListener = null;\n        }\n    }\n\n    unbindDocumentScrollListener() {\n        if (this.documentScrollListener) {\n            this.documentScrollListener();\n            this.documentScrollListener = null;\n        }\n    }\n\n    containerClass() {\n        return {\n            'p-scrolltop p-link p-component': true,\n            'p-scrolltop-sticky': this.target !== 'window'\n        };\n    }\n\n    ngOnDestroy() {\n        if (this.target === 'window') this.unbindDocumentScrollListener();\n        else if (this.target === 'parent') this.unbindParentScrollListener();\n\n        if (this.overlay) {\n            ZIndexUtils.clear(this.overlay);\n            this.overlay = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, ChevronUpIcon, SharedModule],\n    exports: [ScrollTop, SharedModule],\n    declarations: [ScrollTop]\n})\nexport class ScrollTopModule {}\n"]}
|