@egjs/ngx-infinitegrid 3.2.5 → 4.1.2-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/README.md +111 -178
  2. package/bundles/egjs-ngx-infinitegrid.umd.js +587 -751
  3. package/bundles/egjs-ngx-infinitegrid.umd.js.map +1 -1
  4. package/bundles/egjs-ngx-infinitegrid.umd.min.js +12 -12
  5. package/bundles/egjs-ngx-infinitegrid.umd.min.js.map +1 -1
  6. package/egjs-ngx-infinitegrid.d.ts +5 -1
  7. package/egjs-ngx-infinitegrid.metadata.json +1 -1
  8. package/esm2015/egjs-ngx-infinitegrid.js +7 -7
  9. package/esm2015/lib/consts.js +20 -23
  10. package/esm2015/lib/grids/ngx-frame-infinitegrid.component.js +19 -0
  11. package/esm2015/lib/grids/ngx-justified-infinitegrid.component.js +21 -0
  12. package/esm2015/lib/grids/ngx-masonry-infinitegrid.component.js +20 -0
  13. package/esm2015/lib/grids/ngx-packing-infinitegrid.component.js +20 -0
  14. package/esm2015/lib/ngx-infinitegrid.component.js +135 -312
  15. package/esm2015/lib/ngx-infinitegrid.interface.js +10 -18
  16. package/esm2015/lib/ngx-infinitegrid.module.js +14 -21
  17. package/esm2015/lib/ngx-infinitegrid.service.js +5 -10
  18. package/esm2015/lib/types.js +2 -5
  19. package/esm2015/public-api.js +5 -13
  20. package/fesm2015/egjs-ngx-infinitegrid.js +215 -476
  21. package/fesm2015/egjs-ngx-infinitegrid.js.map +1 -1
  22. package/lib/consts.d.ts +1 -1
  23. package/lib/grids/ngx-frame-infinitegrid.component.d.ts +8 -0
  24. package/lib/grids/ngx-justified-infinitegrid.component.d.ts +10 -0
  25. package/lib/grids/ngx-masonry-infinitegrid.component.d.ts +9 -0
  26. package/lib/grids/ngx-packing-infinitegrid.component.d.ts +9 -0
  27. package/lib/ngx-infinitegrid.component.d.ts +58 -37
  28. package/lib/ngx-infinitegrid.interface.d.ts +9 -5
  29. package/lib/ngx-infinitegrid.service.d.ts +1 -1
  30. package/lib/types.d.ts +18 -4
  31. package/package.json +19 -16
  32. package/public-api.d.ts +1 -5
  33. package/esm2015/lib/ngx-framelayout.component.js +0 -28
  34. package/esm2015/lib/ngx-gridlayout.component.js +0 -28
  35. package/esm2015/lib/ngx-justifiedlayout.component.js +0 -28
  36. package/esm2015/lib/ngx-packinglayout.component.js +0 -28
  37. package/esm2015/lib/ngx-squarelayout.component.js +0 -28
  38. package/esm5/egjs-ngx-infinitegrid.js +0 -10
  39. package/esm5/lib/consts.js +0 -8
  40. package/esm5/lib/ngx-framelayout.component.js +0 -33
  41. package/esm5/lib/ngx-gridlayout.component.js +0 -33
  42. package/esm5/lib/ngx-infinitegrid.component.js +0 -385
  43. package/esm5/lib/ngx-infinitegrid.interface.js +0 -25
  44. package/esm5/lib/ngx-infinitegrid.module.js +0 -42
  45. package/esm5/lib/ngx-infinitegrid.service.js +0 -21
  46. package/esm5/lib/ngx-justifiedlayout.component.js +0 -33
  47. package/esm5/lib/ngx-packinglayout.component.js +0 -33
  48. package/esm5/lib/ngx-squarelayout.component.js +0 -33
  49. package/esm5/lib/types.js +0 -5
  50. package/esm5/public-api.js +0 -16
  51. package/fesm5/egjs-ngx-infinitegrid.js +0 -611
  52. package/fesm5/egjs-ngx-infinitegrid.js.map +0 -1
  53. package/lib/ngx-framelayout.component.d.ts +0 -5
  54. package/lib/ngx-gridlayout.component.d.ts +0 -5
  55. package/lib/ngx-justifiedlayout.component.d.ts +0 -5
  56. package/lib/ngx-packinglayout.component.d.ts +0 -5
  57. package/lib/ngx-squarelayout.component.d.ts +0 -5
@@ -1,347 +1,170 @@
1
1
  /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
2
+ * egjs-infinitegrid
3
+ * Copyright (c) 2021-present NAVER Corp.
4
+ * MIT license
4
5
  */
5
- import { Component, ViewChild, ElementRef, Input, Output, EventEmitter, } from '@angular/core';
6
- import NativeInfiniteGrid, { GridLayout, categorize, ItemManager, IGNORE_CLASSNAME, INFINITEGRID_EVENTS, } from '@egjs/infinitegrid';
7
- import ListDiffer from '@egjs/list-differ';
8
- import { TEMPLATE } from './consts';
9
- import NgxinfiniteGridInterface from './ngx-infinitegrid.interface';
10
- export class NgxInfiniteGridComponent extends NgxinfiniteGridInterface {
11
- /**
12
- * @param {?} elRef
13
- */
14
- constructor(elRef) {
6
+ import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, PLATFORM_ID, Inject, ChangeDetectionStrategy, ChangeDetectorRef, } from '@angular/core';
7
+ import { isPlatformBrowser } from '@angular/common';
8
+ import { getRenderingItems, INFINITEGRID_EVENTS, mountRenderingItems, Renderer, } from '@egjs/infinitegrid';
9
+ import { NgxInfiniteGridInterface } from './ngx-infinitegrid.interface';
10
+ // @dynamic
11
+ export class NgxInfiniteGridComponent extends NgxInfiniteGridInterface {
12
+ constructor(elementRef, _detectorRef, _platform) {
15
13
  super();
16
- this.elRef = elRef;
17
- this.trackBy = ((/**
18
- * @param {?} _
19
- * @param {?} item
20
- * @return {?}
21
- */
22
- (_, item) => item.key));
23
- this.groupBy = ((/**
24
- * @param {?} _
25
- * @param {?} item
26
- * @return {?}
27
- */
28
- (_, item) => item.groupKey));
14
+ this.elementRef = elementRef;
15
+ this._detectorRef = _detectorRef;
16
+ this._platform = _platform;
29
17
  this.items = [];
30
- this.useFirstRender = false;
31
- this.layoutType = GridLayout;
32
- this.options = {};
33
- this.layoutOptions = {};
34
- this.append = new EventEmitter();
35
- this.prepend = new EventEmitter();
36
- this.imageError = new EventEmitter();
37
- this.contentError = new EventEmitter();
38
- // tslint:disable-next-line: no-output-native
39
- this.change = new EventEmitter();
40
- this.layoutComplete = new EventEmitter();
41
- this.visibleChange = new EventEmitter();
42
- this.render = new EventEmitter();
18
+ this.trackBy = ((_, item) => item.key);
19
+ this.groupBy = ((_, item) => item.groupKey);
43
20
  this.visibleItems = [];
44
- this.layoutState = '';
45
- this.isChange = false;
46
- this.visibleDiffer = new ListDiffer([], (/**
47
- * @param {?} item
48
- * @return {?}
49
- */
50
- item => item.itemKey));
51
- this.nextFunction = (/**
52
- * @return {?}
53
- */
54
- () => { });
55
- this.setStatus = (/**
56
- * @param {?} status
57
- * @param {?=} applyScrollPos
58
- * @param {?=} syncElements
59
- * @return {?}
60
- */
61
- (status, applyScrollPos, syncElements = this.getElements()) => {
62
- this.ig.setStatus(status, applyScrollPos, syncElements);
63
- return this;
64
- });
21
+ this._renderer = new Renderer();
22
+ this._isChange = false;
23
+ for (const name in INFINITEGRID_EVENTS) {
24
+ const eventName = INFINITEGRID_EVENTS[name];
25
+ this[eventName] = new EventEmitter();
26
+ }
65
27
  }
66
- /**
67
- * @return {?}
68
- */
69
28
  ngOnInit() {
70
- /** @type {?} */
71
- const groups = categorize(this.items);
72
- if (this.status) {
73
- const { startCursor, endCursor } = this.status._infinite;
74
- this.updateVisibleItems(ItemManager.pluck(groups.slice(startCursor, endCursor + 1), 'items').map((/**
75
- * @param {?} item
76
- * @return {?}
77
- */
78
- item => item.data)));
79
- }
80
- else if (this.useFirstRender) {
81
- this.updateVisibleItems(this.items);
82
- }
29
+ this._updateVisibleChildren();
83
30
  }
84
- /**
85
- * @param {?} changes
86
- * @return {?}
87
- */
88
- ngOnChanges(changes) {
89
- /** @type {?} */
90
- const ig = this.ig;
91
- if (!ig) {
31
+ ngOnChanges() {
32
+ this._isChange = true;
33
+ this._updateVisibleChildren();
34
+ }
35
+ ngAfterViewInit() {
36
+ var _a;
37
+ if (!isPlatformBrowser(this._platform)) {
92
38
  return;
93
39
  }
94
- /** @type {?} */
95
- const result = ig.beforeSync(this.toItems());
96
- this.layoutState = result === 'relayout' ? result : this.layoutState || result;
97
- this.updateVisibleItems(this.getVisibleItems());
98
- this.isChange = true;
99
- if (changes.loading) {
100
- ig.setLoadingBar({
101
- append: this.loading,
102
- prepend: this.loading,
40
+ const GridClass = this.constructor.GridClass;
41
+ const defaultOptions = GridClass.defaultOptions;
42
+ const options = {};
43
+ const containerElement = (_a = this._containerRef) === null || _a === void 0 ? void 0 : _a.nativeElement;
44
+ for (const name in defaultOptions) {
45
+ if (name in this && typeof this[name] !== "undefined") {
46
+ options[name] = this[name];
47
+ }
48
+ }
49
+ if (containerElement) {
50
+ options.container = containerElement;
51
+ }
52
+ options.renderer = this._renderer;
53
+ const wrapper = this._wrapperRef || this.elementRef;
54
+ const grid = new GridClass(wrapper.nativeElement, options);
55
+ for (const name in INFINITEGRID_EVENTS) {
56
+ const eventName = INFINITEGRID_EVENTS[name];
57
+ grid.on(eventName, (e) => {
58
+ this[eventName].emit(e);
103
59
  });
104
60
  }
61
+ this.vanillaGrid = grid;
62
+ this._renderer.on("requestUpdate", () => {
63
+ this._isChange = true;
64
+ this._updateVisibleChildren();
65
+ });
66
+ mountRenderingItems(this._getItemInfos(), {
67
+ grid,
68
+ useFirstRender: this.useFirstRender,
69
+ useLoading: this.useLoading,
70
+ usePlaceholder: this.usePlaceholder,
71
+ horizontal: this.horizontal,
72
+ status: this.status,
73
+ });
74
+ this._renderer.updated();
105
75
  }
106
- /**
107
- * @return {?}
108
- */
109
76
  ngAfterViewChecked() {
110
- if (!this.isChange) {
77
+ if (!this._isChange || !this.vanillaGrid) {
111
78
  return;
112
79
  }
113
- this.isChange = false;
114
- this.ig.sync(this.getElements());
115
- /** @type {?} */
116
- const layoutState = this.layoutState;
117
- if (layoutState) {
118
- this.layoutState = '';
119
- this.ig.layout(layoutState === 'relayout');
120
- }
121
- this.nextFunction();
122
- this.nextFunction = (/**
123
- * @return {?}
124
- */
125
- () => { });
126
- }
127
- /**
128
- * @return {?}
129
- */
130
- ngAfterViewInit() {
131
- /** @type {?} */
132
- const ref = this.wrapperRef || this.elRef;
133
- this.ig = new NativeInfiniteGrid(ref.nativeElement, Object.assign({}, this.options, { renderExternal: true })).on('render', (/**
134
- * @param {?} __0
135
- * @return {?}
136
- */
137
- ({ next }) => {
138
- setTimeout((/**
139
- * @return {?}
140
- */
141
- () => {
142
- this.nextFunction = next;
143
- this.updateVisibleItems(this.getVisibleItems());
144
- this.isChange = true;
145
- }));
146
- }));
147
- /** @type {?} */
148
- const ig = this.ig;
149
- INFINITEGRID_EVENTS.forEach((/**
150
- * @param {?} name
151
- * @return {?}
152
- */
153
- name => {
154
- if (!this[name]) {
155
- return;
80
+ this._isChange = false;
81
+ const GridClass = this.constructor.GridClass;
82
+ const propertyTypes = GridClass.propertyTypes;
83
+ const grid = this.vanillaGrid;
84
+ for (const name in propertyTypes) {
85
+ if (name in this) {
86
+ grid[name] = this[name];
156
87
  }
157
- ig.on((/** @type {?} */ (name)), (/**
158
- * @param {?} e
159
- * @return {?}
160
- */
161
- e => {
162
- ((/** @type {?} */ (this)))[name].emit(Object.assign({}, e, { currentTarget: this }));
163
- }));
164
- }));
165
- ig.setLayout(this.layoutType, Object.assign({}, this.layoutOptions));
166
- if (this.loading) {
167
- ig.setLoadingBar({
168
- prepend: this.loading,
169
- append: this.loading,
170
- });
171
- }
172
- if (this.status) {
173
- this.setStatus(this.status, true);
174
- }
175
- else {
176
- ig.beforeSync(this.toItems());
177
- ig.layout(true);
178
88
  }
89
+ this._renderer.updated();
179
90
  }
180
- /**
181
- * @return {?}
182
- */
183
91
  ngOnDestroy() {
184
- this.ig.destroy();
185
- }
186
- /**
187
- * @private
188
- * @return {?}
189
- */
190
- getElements() {
191
- /** @type {?} */
192
- const ref = this.containerRef || this.wrapperRef || this.elRef;
193
- /** @type {?} */
194
- const elements = [].slice.call(ref.nativeElement.children);
195
- if (this.loading) {
196
- return elements.filter((/**
197
- * @param {?} el
198
- * @return {?}
199
- */
200
- el => {
201
- return el.className.indexOf(IGNORE_CLASSNAME) < 0;
202
- }));
203
- }
204
- return elements;
205
- }
206
- /**
207
- * @private
208
- * @return {?}
209
- */
210
- getVisibleItems() {
211
- return this.ig.getRenderingItems().map((/**
212
- * @param {?} item
213
- * @return {?}
214
- */
215
- item => item.data));
92
+ var _a;
93
+ (_a = this.vanillaGrid) === null || _a === void 0 ? void 0 : _a.destroy();
216
94
  }
217
- /**
218
- * @private
219
- * @return {?}
220
- */
221
- toItems() {
222
- /** @type {?} */
223
- const groupBy = this.groupBy;
224
- /** @type {?} */
95
+ _getItemInfos() {
96
+ const items = this.items;
225
97
  const trackBy = this.trackBy;
226
- return this.items.map((/**
227
- * @param {?} item
228
- * @param {?} i
229
- * @return {?}
230
- */
231
- (item, i) => ({
232
- groupKey: groupBy(i, item),
233
- itemKey: trackBy(i, item),
234
- data: item,
235
- })));
98
+ const groupBy = this.groupBy;
99
+ return items.map((item, i) => {
100
+ return {
101
+ groupKey: groupBy(i, item),
102
+ key: trackBy(i, item),
103
+ data: item,
104
+ };
105
+ });
236
106
  }
237
- /**
238
- * @private
239
- * @param {?} items
240
- * @return {?}
241
- */
242
- updateVisibleItems(items) {
243
- const { added, changed, removed } = this.visibleDiffer.update(items);
244
- this.visibleItems = items;
245
- if (added.length || changed.length || removed.length) {
246
- this.visibleChange.emit(items);
247
- }
107
+ _updateVisibleChildren() {
108
+ this.visibleItems = getRenderingItems(this._getItemInfos(), {
109
+ grid: this.vanillaGrid,
110
+ useFirstRender: this.useFirstRender,
111
+ useLoading: this.useLoading,
112
+ usePlaceholder: this.usePlaceholder,
113
+ horizontal: this.horizontal,
114
+ status: this.status,
115
+ });
116
+ this._detectorRef.markForCheck();
248
117
  }
249
118
  }
250
119
  NgxInfiniteGridComponent.decorators = [
251
120
  { type: Component, args: [{
252
- selector: 'ngx-infinitegrid, [NgxInfiniteGrid]',
253
- template: TEMPLATE
254
- }] }
121
+ selector: 'ngx-infinite-grid, [NgxInfiniteGrid]',
122
+ template: '<slot></slot>',
123
+ changeDetection: ChangeDetectionStrategy.OnPush,
124
+ styles: [':host { display: block }']
125
+ },] }
255
126
  ];
256
- /** @nocollapse */
257
127
  NgxInfiniteGridComponent.ctorParameters = () => [
258
- { type: ElementRef }
128
+ { type: ElementRef },
129
+ { type: ChangeDetectorRef },
130
+ { type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
259
131
  ];
260
132
  NgxInfiniteGridComponent.propDecorators = {
261
- trackBy: [{ type: Input }],
262
- groupBy: [{ type: Input }],
263
- items: [{ type: Input }],
133
+ gridConstructor: [{ type: Input }],
134
+ renderer: [{ type: Input }],
135
+ container: [{ type: Input }],
136
+ containerTag: [{ type: Input }],
137
+ threshold: [{ type: Input }],
138
+ useRecycle: [{ type: Input }],
139
+ horizontal: [{ type: Input }],
140
+ percentage: [{ type: Input }],
141
+ isEqualSize: [{ type: Input }],
142
+ isConstantSize: [{ type: Input }],
143
+ gap: [{ type: Input }],
144
+ attributePrefix: [{ type: Input }],
145
+ resizeDebounce: [{ type: Input }],
146
+ maxResizeDebounce: [{ type: Input }],
147
+ autoResize: [{ type: Input }],
148
+ useFit: [{ type: Input }],
149
+ useTransform: [{ type: Input }],
150
+ renderOnPropertyChange: [{ type: Input }],
151
+ preserveUIOnDestroy: [{ type: Input }],
152
+ defaultDirection: [{ type: Input }],
153
+ externalItemRenderer: [{ type: Input }],
154
+ externalContainerManager: [{ type: Input }],
155
+ usePlaceholder: [{ type: Input }],
156
+ useLoading: [{ type: Input }],
264
157
  status: [{ type: Input }],
265
- loading: [{ type: Input }],
266
158
  useFirstRender: [{ type: Input }],
267
- layoutType: [{ type: Input }],
268
- options: [{ type: Input }],
269
- layoutOptions: [{ type: Input }],
270
- append: [{ type: Output }],
271
- prepend: [{ type: Output }],
272
- imageError: [{ type: Output }],
159
+ items: [{ type: Input }],
160
+ trackBy: [{ type: Input }],
161
+ groupBy: [{ type: Input }],
162
+ renderComplete: [{ type: Output }],
273
163
  contentError: [{ type: Output }],
274
- change: [{ type: Output }],
275
- layoutComplete: [{ type: Output }],
276
- visibleChange: [{ type: Output }],
277
- render: [{ type: Output }],
278
- wrapperRef: [{ type: ViewChild, args: ['wrapper', { static: false },] }],
279
- containerRef: [{ type: ViewChild, args: ['container', { static: false },] }]
164
+ changeScroll: [{ type: Output }],
165
+ requestAppend: [{ type: Output }],
166
+ requestPrepend: [{ type: Output }],
167
+ _wrapperRef: [{ type: ViewChild, args: ['wrapperRef', { static: false },] }],
168
+ _containerRef: [{ type: ViewChild, args: ['containerRef', { static: false },] }]
280
169
  };
281
- if (false) {
282
- /** @type {?} */
283
- NgxInfiniteGridComponent.prototype.trackBy;
284
- /** @type {?} */
285
- NgxInfiniteGridComponent.prototype.groupBy;
286
- /** @type {?} */
287
- NgxInfiniteGridComponent.prototype.items;
288
- /** @type {?} */
289
- NgxInfiniteGridComponent.prototype.status;
290
- /** @type {?} */
291
- NgxInfiniteGridComponent.prototype.loading;
292
- /** @type {?} */
293
- NgxInfiniteGridComponent.prototype.useFirstRender;
294
- /** @type {?} */
295
- NgxInfiniteGridComponent.prototype.layoutType;
296
- /** @type {?} */
297
- NgxInfiniteGridComponent.prototype.options;
298
- /** @type {?} */
299
- NgxInfiniteGridComponent.prototype.layoutOptions;
300
- /** @type {?} */
301
- NgxInfiniteGridComponent.prototype.append;
302
- /** @type {?} */
303
- NgxInfiniteGridComponent.prototype.prepend;
304
- /** @type {?} */
305
- NgxInfiniteGridComponent.prototype.imageError;
306
- /** @type {?} */
307
- NgxInfiniteGridComponent.prototype.contentError;
308
- /** @type {?} */
309
- NgxInfiniteGridComponent.prototype.change;
310
- /** @type {?} */
311
- NgxInfiniteGridComponent.prototype.layoutComplete;
312
- /** @type {?} */
313
- NgxInfiniteGridComponent.prototype.visibleChange;
314
- /** @type {?} */
315
- NgxInfiniteGridComponent.prototype.render;
316
- /** @type {?} */
317
- NgxInfiniteGridComponent.prototype.wrapperRef;
318
- /** @type {?} */
319
- NgxInfiniteGridComponent.prototype.containerRef;
320
- /** @type {?} */
321
- NgxInfiniteGridComponent.prototype.visibleItems;
322
- /**
323
- * @type {?}
324
- * @private
325
- */
326
- NgxInfiniteGridComponent.prototype.layoutState;
327
- /**
328
- * @type {?}
329
- * @private
330
- */
331
- NgxInfiniteGridComponent.prototype.isChange;
332
- /**
333
- * @type {?}
334
- * @private
335
- */
336
- NgxInfiniteGridComponent.prototype.visibleDiffer;
337
- /**
338
- * @type {?}
339
- * @private
340
- */
341
- NgxInfiniteGridComponent.prototype.nextFunction;
342
- /** @type {?} */
343
- NgxInfiniteGridComponent.prototype.setStatus;
344
- /** @type {?} */
345
- NgxInfiniteGridComponent.prototype.elRef;
346
- }
347
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-infinitegrid.component.js","sourceRoot":"ng://@egjs/ngx-infinitegrid/","sources":["lib/ngx-infinitegrid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, OnInit, ViewChild, ElementRef,\n  Input, Output, EventEmitter, OnDestroy, OnChanges,\n  AfterViewInit, AfterViewChecked,\n} from '@angular/core';\n\nimport NativeInfiniteGrid, {\n  GridLayout,\n  ILayout,\n  categorize,\n  ItemManager,\n  IItem,\n  IInfiniteGridStatus,\n  IInfiniteGridItem,\n  StyleType,\n  IGNORE_CLASSNAME,\n  IInfiniteGridOptions,\n  INFINITEGRID_EVENTS,\n} from '@egjs/infinitegrid';\nimport ListDiffer from '@egjs/list-differ';\nimport { TEMPLATE } from './consts';\nimport NgxinfiniteGridInterface from './ngx-infinitegrid.interface';\nimport { InfiniteGridType } from './types';\n\n@Component({\n  selector: 'ngx-infinitegrid, [NgxInfiniteGrid]',\n  template: TEMPLATE,\n  styles: []\n})\nexport class NgxInfiniteGridComponent\n  extends NgxinfiniteGridInterface\n  implements OnInit, AfterViewInit, AfterViewChecked,\n  OnDestroy, OnChanges {\n\n  @Input() public trackBy: ((index: number, item: any) => any) = ((_, item) => item.key);\n  @Input() public groupBy: ((index: number, item: any) => any) = ((_, item) => item.groupKey);\n  @Input() public items: IItem[] = [];\n  @Input() public status!: IInfiniteGridStatus;\n  @Input() public loading!: HTMLElement;\n  @Input() public useFirstRender = false;\n  @Input() public layoutType: new () => ILayout = GridLayout;\n  @Input() public options: Partial<IInfiniteGridOptions> = {};\n  @Input() public layoutOptions: Partial<ILayout['options']> = {};\n\n  @Output() public append: EventEmitter<any> = new EventEmitter();\n  @Output() public prepend: EventEmitter<any> = new EventEmitter();\n  @Output() public imageError: EventEmitter<any> = new EventEmitter();\n  @Output() public contentError: EventEmitter<any> = new EventEmitter();\n  // tslint:disable-next-line: no-output-native\n  @Output() public change: EventEmitter<any> = new EventEmitter();\n  @Output() public layoutComplete: EventEmitter<any> = new EventEmitter();\n  @Output() public visibleChange: EventEmitter<any> = new EventEmitter();\n  @Output() public render: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild('wrapper', { static: false }) wrapperRef: ElementRef;\n  @ViewChild('container', { static: false }) containerRef: ElementRef;\n\n  public visibleItems: IItem[] = [];\n\n  private layoutState = '';\n  private isChange = false;\n  private visibleDiffer: ListDiffer<IItem> = new ListDiffer<IItem>([], item => item.itemKey);\n  private nextFunction = () => { };\n\n  constructor(public elRef: ElementRef) {\n    super();\n  }\n  ngOnInit() {\n    const groups = categorize(this.items);\n\n    if (this.status) {\n      const { startCursor, endCursor } = this.status._infinite;\n\n      this.updateVisibleItems(ItemManager.pluck(groups.slice(startCursor, endCursor + 1), 'items').map(item => item.data));\n    } else if (this.useFirstRender) {\n      this.updateVisibleItems(this.items);\n    }\n  }\n  ngOnChanges(changes) {\n    const ig = this.ig;\n    if (!ig) {\n      return;\n    }\n    const result = ig.beforeSync(this.toItems());\n\n    this.layoutState = result === 'relayout' ? result : this.layoutState || result;\n    this.updateVisibleItems(this.getVisibleItems());\n    this.isChange = true;\n\n    if (changes.loading) {\n      ig.setLoadingBar({\n        append: this.loading,\n        prepend: this.loading,\n      });\n    }\n  }\n  ngAfterViewChecked() {\n    if (!this.isChange) {\n      return;\n    }\n    this.isChange = false;\n    this.ig.sync(this.getElements());\n\n    const layoutState = this.layoutState;\n    if (layoutState) {\n      this.layoutState = '';\n      this.ig.layout(layoutState === 'relayout');\n    }\n    this.nextFunction();\n    this.nextFunction = () => { };\n  }\n  ngAfterViewInit() {\n    const ref = this.wrapperRef || this.elRef;\n\n    this.ig = new NativeInfiniteGrid(ref.nativeElement, {\n      ...this.options,\n      renderExternal: true,\n    }).on('render', ({ next }) => {\n      setTimeout(() => {\n        this.nextFunction = next;\n        this.updateVisibleItems(this.getVisibleItems());\n        this.isChange = true;\n      });\n    });\n    const ig = this.ig;\n\n    INFINITEGRID_EVENTS.forEach(name => {\n      if (!this[name]) {\n        return;\n      }\n      ig.on(name as any, e => {\n        (this as any)[name].emit({ ...e, currentTarget: this });\n      });\n    });\n    ig.setLayout(this.layoutType, { ...this.layoutOptions });\n\n\n    if (this.loading) {\n      ig.setLoadingBar({\n        prepend: this.loading,\n        append: this.loading,\n      });\n    }\n    if (this.status) {\n      this.setStatus(this.status, true);\n    } else {\n      ig.beforeSync(this.toItems());\n      ig.layout(true);\n    }\n  }\n  public setStatus = (status: IInfiniteGridStatus, applyScrollPos?: boolean, syncElements: HTMLElement[] = this.getElements()): NgxInfiniteGridComponent => {\n    this.ig.setStatus(status, applyScrollPos, syncElements);\n    return this;\n  }\n  public ngOnDestroy() {\n    this.ig.destroy();\n  }\n  private getElements() {\n    const ref = this.containerRef || this.wrapperRef || this.elRef;\n\n    const elements = [].slice.call(ref.nativeElement.children);\n\n    if (this.loading) {\n      return elements.filter(el => {\n        return el.className.indexOf(IGNORE_CLASSNAME) < 0;\n      });\n    }\n    return elements;\n  }\n  private getVisibleItems() {\n    return this.ig.getRenderingItems().map(item => item.data);\n  }\n  private toItems() {\n    const groupBy = this.groupBy;\n    const trackBy = this.trackBy;\n    return this.items.map((item, i) => ({\n      groupKey: groupBy(i, item),\n      itemKey: trackBy(i, item),\n      data: item,\n    }));\n  }\n  private updateVisibleItems(items: IItem[]) {\n    const { added, changed, removed } = this.visibleDiffer.update(items);\n\n    this.visibleItems = items;\n    if (added.length || changed.length || removed.length) {\n      this.visibleChange.emit(items);\n    }\n  }\n}\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-infinitegrid.component.js","sourceRoot":"","sources":["../../../../projects/ngx-infinitegrid/src/lib/ngx-infinitegrid.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * egjs-infinitegrid\n * Copyright (c) 2021-present NAVER Corp.\n * MIT license\n */\nimport {\n  AfterViewChecked, AfterViewInit, Component, ElementRef,\n  EventEmitter, Input, OnChanges, OnDestroy, Output, ViewChild,\n  PLATFORM_ID, Inject, ChangeDetectionStrategy, ChangeDetectorRef,\n} from '@angular/core';\nimport { isPlatformBrowser } from '@angular/common';\n\nimport {\n  getRenderingItems,\n  InfiniteGridFunction,\n  InfiniteGridItem,\n  InfiniteGridItemInfo,\n  InfiniteGridOptions,\n  INFINITEGRID_EVENTS,\n  mountRenderingItems,\n  OnContentError,\n  OnRenderComplete,\n  OnRequestAppend,\n  OnRequestPrepend,\n  OnChangeScroll,\n  Renderer,\n} from '@egjs/infinitegrid';\nimport { NgxInfiniteGridInterface } from './ngx-infinitegrid.interface';\nimport { NgxInfiniteGridProps } from './types';\n\n// @dynamic\n@Component({\n  selector: 'ngx-infinite-grid, [NgxInfiniteGrid]',\n  template: '<slot></slot>',\n  styles: [\n    ':host { display: block }',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgxInfiniteGridComponent\n  extends NgxInfiniteGridInterface\n  implements Required<InfiniteGridOptions>,\n  NgxInfiniteGridProps,\n  AfterViewInit, AfterViewChecked, OnChanges, OnDestroy {\n  public static GridClass: InfiniteGridFunction;\n  @Input() gridConstructor!: NgxInfiniteGridProps['gridConstructor'];\n  @Input() renderer!: NgxInfiniteGridProps['renderer'];\n  @Input() container!: NgxInfiniteGridProps['container'];\n  @Input() containerTag!: NgxInfiniteGridProps['containerTag'];\n  @Input() threshold!: NgxInfiniteGridProps['threshold'];\n  @Input() useRecycle!: NgxInfiniteGridProps['useRecycle'];\n  @Input() horizontal!: NgxInfiniteGridProps['horizontal'];\n  @Input() percentage!: NgxInfiniteGridProps['percentage'];\n  @Input() isEqualSize!: NgxInfiniteGridProps['isEqualSize'];\n  @Input() isConstantSize!: NgxInfiniteGridProps['isConstantSize'];\n  @Input() gap!: NgxInfiniteGridProps['gap'];\n  @Input() attributePrefix!: NgxInfiniteGridProps['attributePrefix'];\n  @Input() resizeDebounce!: NgxInfiniteGridProps['resizeDebounce'];\n  @Input() maxResizeDebounce!: NgxInfiniteGridProps['maxResizeDebounce'];\n  @Input() autoResize!: NgxInfiniteGridProps['autoResize'];\n  @Input() useFit!: NgxInfiniteGridProps['useFit'];\n  @Input() useTransform!: NgxInfiniteGridProps['useTransform'];\n  @Input() renderOnPropertyChange!: NgxInfiniteGridProps['renderOnPropertyChange'];\n  @Input() preserveUIOnDestroy!: NgxInfiniteGridProps['preserveUIOnDestroy'];\n  @Input() defaultDirection!: NgxInfiniteGridProps['defaultDirection'];\n  @Input() externalItemRenderer!: NgxInfiniteGridProps['externalItemRenderer'];\n  @Input() externalContainerManager!: NgxInfiniteGridProps['externalContainerManager'];\n  @Input() usePlaceholder!: NgxInfiniteGridProps['useFirstRender'];\n  @Input() useLoading!: NgxInfiniteGridProps['useLoading'];\n  @Input() status!: NgxInfiniteGridProps['status'];\n  @Input() useFirstRender!: NgxInfiniteGridProps['useFirstRender'];\n  @Input() items: NgxInfiniteGridProps['items'] = [];\n  @Input() trackBy: NgxInfiniteGridProps['trackBy'] = ((_, item) => item.key);\n  @Input() groupBy: NgxInfiniteGridProps['groupBy'] = ((_, item) => item.groupKey);\n  @Output() renderComplete!: EventEmitter<OnRenderComplete>;\n  @Output() contentError!: EventEmitter<OnContentError>;\n  @Output() changeScroll!: EventEmitter<OnChangeScroll>;\n  @Output() requestAppend!: EventEmitter<OnRequestAppend>;\n  @Output() requestPrepend!: EventEmitter<OnRequestPrepend>;\n  public visibleItems: InfiniteGridItem[] = [];\n  @ViewChild('wrapperRef', { static: false }) _wrapperRef!: ElementRef;\n  @ViewChild('containerRef', { static: false }) _containerRef!: ElementRef;\n  private _renderer = new Renderer();\n  private _isChange = false;\n\n  constructor(\n    protected elementRef: ElementRef,\n    private _detectorRef: ChangeDetectorRef,\n    @Inject(PLATFORM_ID) private _platform: Object,\n  ) {\n    super();\n    for (const name in INFINITEGRID_EVENTS) {\n      const eventName = (INFINITEGRID_EVENTS as any)[name];\n      (this as any)[eventName] = new EventEmitter();\n    }\n  }\n\n  ngOnInit() {\n    this._updateVisibleChildren();\n  }\n  ngOnChanges() {\n    this._isChange = true;\n    this._updateVisibleChildren();\n  }\n  ngAfterViewInit(): void {\n    if (!isPlatformBrowser(this._platform)) {\n      return;\n    }\n    const GridClass = (this.constructor as typeof NgxInfiniteGridComponent).GridClass;\n    const defaultOptions = GridClass.defaultOptions;\n    const options: Partial<InfiniteGridOptions> = {};\n    const containerElement = this._containerRef?.nativeElement;\n\n    for (const name in defaultOptions) {\n      if (name in this && typeof (this as any)[name] !== \"undefined\") {\n        (options as any)[name] = (this as any)[name];\n      }\n    }\n    if (containerElement) {\n      options.container = containerElement;\n    }\n    options.renderer = this._renderer;\n    const wrapper = this._wrapperRef! || this.elementRef;\n\n    const grid = new GridClass(wrapper.nativeElement, options);\n\n    for (const name in INFINITEGRID_EVENTS) {\n      const eventName = (INFINITEGRID_EVENTS as any)[name];\n\n      grid.on(eventName, (e: any) => {\n        (this as any)[eventName].emit(e as any);\n      });\n    }\n\n    this.vanillaGrid = grid;\n    this._renderer.on(\"requestUpdate\", () => {\n      this._isChange = true;\n      this._updateVisibleChildren();\n    });\n\n    mountRenderingItems(this._getItemInfos(), {\n      grid,\n      useFirstRender: this.useFirstRender,\n      useLoading: this.useLoading,\n      usePlaceholder: this.usePlaceholder,\n      horizontal: this.horizontal,\n      status: this.status,\n    });\n    this._renderer.updated();\n  }\n  ngAfterViewChecked() {\n    if (!this._isChange || !this.vanillaGrid) {\n      return;\n    }\n    this._isChange = false;\n    const GridClass = (this.constructor as typeof NgxInfiniteGridComponent).GridClass;\n    const propertyTypes = GridClass.propertyTypes;\n    const grid = this.vanillaGrid;\n\n    for (const name in propertyTypes) {\n      if (name in this) {\n        (grid as any)[name] = (this as any)[name];\n      }\n    }\n\n    this._renderer.updated();\n  }\n  ngOnDestroy() {\n    this.vanillaGrid?.destroy();\n  }\n\n  private _getItemInfos(): InfiniteGridItemInfo[] {\n    const items = this.items;\n    const trackBy = this.trackBy;\n    const groupBy = this.groupBy;\n\n    return items.map((item, i) => {\n      return {\n        groupKey: groupBy(i, item),\n        key: trackBy(i, item),\n        data: item,\n      };\n    });\n  }\n  private _updateVisibleChildren() {\n    this.visibleItems = getRenderingItems(this._getItemInfos(), {\n      grid: this.vanillaGrid,\n      useFirstRender: this.useFirstRender,\n      useLoading: this.useLoading,\n      usePlaceholder: this.usePlaceholder,\n      horizontal: this.horizontal,\n      status: this.status,\n    });\n    this._detectorRef.markForCheck();\n  }\n}\n"]}
@@ -1,21 +1,13 @@
1
+ import { __decorate } from "tslib";
1
2
  /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
3
+ * egjs-infinitegrid
4
+ * Copyright (c) 2021-present NAVER Corp.
5
+ * MIT license
4
6
  */
5
- import * as tslib_1 from "tslib";
6
- import NativeInfiniteGrid, { withInfiniteGridMethods } from '@egjs/infinitegrid';
7
- export default class NgxInfiniteGridInterface {
7
+ import { withInfiniteGridMethods } from '@egjs/infinitegrid';
8
+ export class NgxInfiniteGridInterface {
8
9
  }
9
- tslib_1.__decorate([
10
- withInfiniteGridMethods,
11
- tslib_1.__metadata("design:type", NativeInfiniteGrid)
12
- ], NgxInfiniteGridInterface.prototype, "ig", void 0);
13
- if (false) {
14
- /**
15
- * @type {?}
16
- * @protected
17
- */
18
- NgxInfiniteGridInterface.prototype.ig;
19
- }
20
- // WARNING: interface has both a type and a value, skipping emit
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AZWdqcy9uZ3gtaW5maW5pdGVncmlkLyIsInNvdXJjZXMiOlsibGliL25neC1pbmZpbml0ZWdyaWQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxrQkFBa0IsRUFBRSxFQUF1Qix1QkFBdUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBSXRHLE1BQU0sQ0FBQyxPQUFPLE9BQU8sd0JBQXdCO0NBSTVDO0FBRkM7SUFEQyx1QkFBdUI7c0NBQ1Qsa0JBQWtCO29EQUFDOzs7Ozs7SUFEbEMsc0NBQ2tDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE5hdGl2ZUluZmluaXRlR3JpZCwgeyBJSW5maW5pdGVHcmlkU3RhdHVzLCB3aXRoSW5maW5pdGVHcmlkTWV0aG9kcyB9IGZyb20gJ0BlZ2pzL2luZmluaXRlZ3JpZCc7XG5pbXBvcnQgeyBJbmZpbml0ZUdyaWRUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL25neC1pbmZpbml0ZWdyaWQuY29tcG9uZW50JztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTmd4SW5maW5pdGVHcmlkSW50ZXJmYWNlIHtcbiAgQHdpdGhJbmZpbml0ZUdyaWRNZXRob2RzXG4gIHByb3RlY3RlZCBpZyE6IE5hdGl2ZUluZmluaXRlR3JpZDtcblxufVxuZXhwb3J0IGRlZmF1bHQgaW50ZXJmYWNlIE5neEluZmluaXRlR3JpZEludGVyZmFjZSBleHRlbmRzIEluZmluaXRlR3JpZFR5cGU8Tmd4SW5maW5pdGVHcmlkQ29tcG9uZW50PiB7IH1cbiJdfQ==
10
+ __decorate([
11
+ withInfiniteGridMethods
12
+ ], NgxInfiniteGridInterface.prototype, "vanillaGrid", void 0);
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaW5maW5pdGVncmlkL3NyYy9saWIvbmd4LWluZmluaXRlZ3JpZC5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7QUFDSCxPQUE0QixFQUF1Qix1QkFBdUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBR3ZHLE1BQU0sT0FBTyx3QkFBd0I7Q0FHcEM7QUFEQztJQURDLHVCQUF1Qjs2REFDb0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGVnanMtaW5maW5pdGVncmlkXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjEtcHJlc2VudCBOQVZFUiBDb3JwLlxuICogTUlUIGxpY2Vuc2VcbiAqL1xuaW1wb3J0IFZhbmlsbGFJbmZpbml0ZUdyaWQsIHsgSW5maW5pdGVHcmlkTWV0aG9kcywgd2l0aEluZmluaXRlR3JpZE1ldGhvZHMgfSBmcm9tICdAZWdqcy9pbmZpbml0ZWdyaWQnO1xuaW1wb3J0IHsgTmd4SW5maW5pdGVHcmlkQ29tcG9uZW50IH0gZnJvbSAnLi9uZ3gtaW5maW5pdGVncmlkLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjbGFzcyBOZ3hJbmZpbml0ZUdyaWRJbnRlcmZhY2Uge1xuICBAd2l0aEluZmluaXRlR3JpZE1ldGhvZHNcbiAgcHJvdGVjdGVkIHZhbmlsbGFHcmlkITogVmFuaWxsYUluZmluaXRlR3JpZDtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgTmd4SW5maW5pdGVHcmlkSW50ZXJmYWNlIGV4dGVuZHMgSW5maW5pdGVHcmlkTWV0aG9kczxOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQ+IHsgfVxuIl19
@@ -1,38 +1,31 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
1
+ import { CommonModule } from '@angular/common';
5
2
  import { NgModule } from '@angular/core';
6
3
  import { NgxInfiniteGridComponent } from './ngx-infinitegrid.component';
7
- import { NgxGridLayoutComponent } from './ngx-gridlayout.component';
8
- import { NgxJustifiedLayoutComponent } from './ngx-justifiedlayout.component';
9
- import { NgxSquareLayoutComponent } from './ngx-squarelayout.component';
10
- import { NgxFrameLayoutComponent } from './ngx-framelayout.component';
11
- import { NgxPackingLayoutComponent } from './ngx-packinglayout.component';
12
- import { CommonModule } from '@angular/common';
4
+ import { NgxMasonryInfiniteGridComponent } from './grids/ngx-masonry-infinitegrid.component';
5
+ import { NgxJustifiedInfiniteGridComponent } from './grids/ngx-justified-infinitegrid.component';
6
+ import { NgxFrameInfiniteGridComponent } from './grids/ngx-frame-infinitegrid.component';
7
+ import { NgxPackingInfiniteGridComponent } from './grids/ngx-packing-infinitegrid.component';
13
8
  export class NgxInfiniteGridModule {
14
9
  }
15
10
  NgxInfiniteGridModule.decorators = [
16
11
  { type: NgModule, args: [{
17
12
  declarations: [
18
13
  NgxInfiniteGridComponent,
19
- NgxGridLayoutComponent,
20
- NgxJustifiedLayoutComponent,
21
- NgxSquareLayoutComponent,
22
- NgxFrameLayoutComponent,
23
- NgxPackingLayoutComponent,
14
+ NgxMasonryInfiniteGridComponent,
15
+ NgxJustifiedInfiniteGridComponent,
16
+ NgxFrameInfiniteGridComponent,
17
+ NgxPackingInfiniteGridComponent,
24
18
  ],
25
19
  imports: [
26
20
  CommonModule,
27
21
  ],
28
22
  exports: [
29
23
  NgxInfiniteGridComponent,
30
- NgxGridLayoutComponent,
31
- NgxJustifiedLayoutComponent,
32
- NgxSquareLayoutComponent,
33
- NgxFrameLayoutComponent,
34
- NgxPackingLayoutComponent,
24
+ NgxMasonryInfiniteGridComponent,
25
+ NgxJustifiedInfiniteGridComponent,
26
+ NgxFrameInfiniteGridComponent,
27
+ NgxPackingInfiniteGridComponent,
35
28
  ],
36
29
  },] }
37
30
  ];
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AZWdqcy9uZ3gtaW5maW5pdGVncmlkLyIsInNvdXJjZXMiOlsibGliL25neC1pbmZpbml0ZWdyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQXVCL0MsTUFBTSxPQUFPLHFCQUFxQjs7O1lBckJqQyxRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLHdCQUF3QjtvQkFDeEIsc0JBQXNCO29CQUN0QiwyQkFBMkI7b0JBQzNCLHdCQUF3QjtvQkFDeEIsdUJBQXVCO29CQUN2Qix5QkFBeUI7aUJBQzFCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxZQUFZO2lCQUNiO2dCQUNELE9BQU8sRUFBRTtvQkFDUCx3QkFBd0I7b0JBQ3hCLHNCQUFzQjtvQkFDdEIsMkJBQTJCO29CQUMzQix3QkFBd0I7b0JBQ3hCLHVCQUF1QjtvQkFDdkIseUJBQXlCO2lCQUMxQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5neEluZmluaXRlR3JpZENvbXBvbmVudCB9IGZyb20gJy4vbmd4LWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4R3JpZExheW91dENvbXBvbmVudCB9IGZyb20gJy4vbmd4LWdyaWRsYXlvdXQuY29tcG9uZW50JztcbmltcG9ydCB7IE5neEp1c3RpZmllZExheW91dENvbXBvbmVudCB9IGZyb20gJy4vbmd4LWp1c3RpZmllZGxheW91dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4U3F1YXJlTGF5b3V0Q29tcG9uZW50IH0gZnJvbSAnLi9uZ3gtc3F1YXJlbGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOZ3hGcmFtZUxheW91dENvbXBvbmVudCB9IGZyb20gJy4vbmd4LWZyYW1lbGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOZ3hQYWNraW5nTGF5b3V0Q29tcG9uZW50IH0gZnJvbSAnLi9uZ3gtcGFja2luZ2xheW91dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgTmd4SW5maW5pdGVHcmlkQ29tcG9uZW50LFxuICAgIE5neEdyaWRMYXlvdXRDb21wb25lbnQsXG4gICAgTmd4SnVzdGlmaWVkTGF5b3V0Q29tcG9uZW50LFxuICAgIE5neFNxdWFyZUxheW91dENvbXBvbmVudCxcbiAgICBOZ3hGcmFtZUxheW91dENvbXBvbmVudCxcbiAgICBOZ3hQYWNraW5nTGF5b3V0Q29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgTmd4SW5maW5pdGVHcmlkQ29tcG9uZW50LFxuICAgIE5neEdyaWRMYXlvdXRDb21wb25lbnQsXG4gICAgTmd4SnVzdGlmaWVkTGF5b3V0Q29tcG9uZW50LFxuICAgIE5neFNxdWFyZUxheW91dENvbXBvbmVudCxcbiAgICBOZ3hGcmFtZUxheW91dENvbXBvbmVudCxcbiAgICBOZ3hQYWNraW5nTGF5b3V0Q29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3hJbmZpbml0ZUdyaWRNb2R1bGUgeyB9XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaW5maW5pdGVncmlkL3NyYy9saWIvbmd4LWluZmluaXRlZ3JpZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDeEUsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDN0YsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDakcsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDekYsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUF3QjdGLE1BQU0sT0FBTyxxQkFBcUI7OztZQW5CakMsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRTtvQkFDWix3QkFBd0I7b0JBQ3hCLCtCQUErQjtvQkFDL0IsaUNBQWlDO29CQUNqQyw2QkFBNkI7b0JBQzdCLCtCQUErQjtpQkFDaEM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLFlBQVk7aUJBQ2I7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLHdCQUF3QjtvQkFDeEIsK0JBQStCO29CQUMvQixpQ0FBaUM7b0JBQ2pDLDZCQUE2QjtvQkFDN0IsK0JBQStCO2lCQUNoQzthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL25neC1pbmZpbml0ZWdyaWQuY29tcG9uZW50JztcbmltcG9ydCB7IE5neE1hc29ucnlJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL2dyaWRzL25neC1tYXNvbnJ5LWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4SnVzdGlmaWVkSW5maW5pdGVHcmlkQ29tcG9uZW50IH0gZnJvbSAnLi9ncmlkcy9uZ3gtanVzdGlmaWVkLWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4RnJhbWVJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL2dyaWRzL25neC1mcmFtZS1pbmZpbml0ZWdyaWQuY29tcG9uZW50JztcbmltcG9ydCB7IE5neFBhY2tpbmdJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL2dyaWRzL25neC1wYWNraW5nLWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuXG5cblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQsXG4gICAgTmd4TWFzb25yeUluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hKdXN0aWZpZWRJbmZpbml0ZUdyaWRDb21wb25lbnQsXG4gICAgTmd4RnJhbWVJbmZpbml0ZUdyaWRDb21wb25lbnQsXG4gICAgTmd4UGFja2luZ0luZmluaXRlR3JpZENvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIE5neEluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hNYXNvbnJ5SW5maW5pdGVHcmlkQ29tcG9uZW50LFxuICAgIE5neEp1c3RpZmllZEluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hGcmFtZUluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hQYWNraW5nSW5maW5pdGVHcmlkQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3hJbmZpbml0ZUdyaWRNb2R1bGUgeyB9XG4iXX0=