@egjs/ngx-infinitegrid 4.10.0-beta.1 → 4.10.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 (40) hide show
  1. package/esm2020/egjs-ngx-infinitegrid.mjs +5 -0
  2. package/esm2020/lib/grids/ngx-frame-infinitegrid.component.mjs +25 -0
  3. package/esm2020/lib/grids/ngx-justified-infinitegrid.component.mjs +29 -0
  4. package/esm2020/lib/grids/ngx-masonry-infinitegrid.component.mjs +31 -0
  5. package/esm2020/lib/grids/ngx-packing-infinitegrid.component.mjs +27 -0
  6. package/esm2020/lib/ngx-infinitegrid.component.mjs +232 -0
  7. package/esm2020/lib/ngx-infinitegrid.module.mjs +44 -0
  8. package/{esm2015/lib/types.js → esm2020/lib/types.mjs} +1 -1
  9. package/fesm2015/egjs-ngx-infinitegrid.mjs +388 -0
  10. package/fesm2015/egjs-ngx-infinitegrid.mjs.map +1 -0
  11. package/fesm2020/egjs-ngx-infinitegrid.mjs +398 -0
  12. package/fesm2020/egjs-ngx-infinitegrid.mjs.map +1 -0
  13. package/index.d.ts +5 -0
  14. package/lib/grids/ngx-frame-infinitegrid.component.d.ts +3 -0
  15. package/lib/grids/ngx-justified-infinitegrid.component.d.ts +3 -0
  16. package/lib/grids/ngx-masonry-infinitegrid.component.d.ts +3 -0
  17. package/lib/grids/ngx-packing-infinitegrid.component.d.ts +3 -0
  18. package/lib/ngx-infinitegrid.component.d.ts +4 -0
  19. package/lib/ngx-infinitegrid.module.d.ts +10 -0
  20. package/lib/types.d.ts +1 -0
  21. package/package.json +22 -10
  22. package/bundles/egjs-ngx-infinitegrid.umd.js +0 -664
  23. package/bundles/egjs-ngx-infinitegrid.umd.js.map +0 -1
  24. package/bundles/egjs-ngx-infinitegrid.umd.min.js +0 -2
  25. package/bundles/egjs-ngx-infinitegrid.umd.min.js.map +0 -1
  26. package/egjs-ngx-infinitegrid.d.ts +0 -6
  27. package/egjs-ngx-infinitegrid.metadata.json +0 -1
  28. package/esm2015/egjs-ngx-infinitegrid.js +0 -7
  29. package/esm2015/lib/grids/ngx-frame-infinitegrid.component.js +0 -19
  30. package/esm2015/lib/grids/ngx-justified-infinitegrid.component.js +0 -21
  31. package/esm2015/lib/grids/ngx-masonry-infinitegrid.component.js +0 -22
  32. package/esm2015/lib/grids/ngx-packing-infinitegrid.component.js +0 -20
  33. package/esm2015/lib/ngx-infinitegrid.component.js +0 -187
  34. package/esm2015/lib/ngx-infinitegrid.module.js +0 -31
  35. package/fesm2015/egjs-ngx-infinitegrid.js +0 -318
  36. package/fesm2015/egjs-ngx-infinitegrid.js.map +0 -1
  37. /package/{esm2015/lib/consts.js → esm2020/lib/consts.mjs} +0 -0
  38. /package/{esm2015/lib/ngx-infinitegrid.interface.js → esm2020/lib/ngx-infinitegrid.interface.mjs} +0 -0
  39. /package/{esm2015/private_export.js → esm2020/private_export.mjs} +0 -0
  40. /package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
@@ -1,187 +0,0 @@
1
- /**
2
- * egjs-infinitegrid
3
- * Copyright (c) 2021-present NAVER Corp.
4
- * MIT license
5
- */
6
- import { Component, ElementRef, EventEmitter, Input, Output, PLATFORM_ID, Inject, NgZone } from '@angular/core';
7
- import { isPlatformServer } from '@angular/common';
8
- import { fromEvent, Subject } from 'rxjs';
9
- import { takeUntil } from 'rxjs/operators';
10
- import { getRenderingItems, INFINITEGRID_EVENTS, mountRenderingItems, Renderer, } from '@egjs/infinitegrid';
11
- import { NgxInfiniteGridInterface } from './ngx-infinitegrid.interface';
12
- export class NgxInfiniteGridComponent extends NgxInfiniteGridInterface {
13
- constructor(elementRef, _platformId, _ngZone) {
14
- super();
15
- this.elementRef = elementRef;
16
- this._platformId = _platformId;
17
- this._ngZone = _ngZone;
18
- this.items = [];
19
- this.trackBy = ((_, item) => item.key);
20
- this.groupBy = ((_, item) => item.groupKey);
21
- this.visibleItems = [];
22
- this._renderer = new Renderer();
23
- this._isChange = false;
24
- this._destroy$ = new Subject();
25
- for (const name in INFINITEGRID_EVENTS) {
26
- const eventName = INFINITEGRID_EVENTS[name];
27
- this[eventName] = new EventEmitter();
28
- }
29
- }
30
- ngOnInit() {
31
- this._updateVisibleChildren();
32
- }
33
- ngOnChanges() {
34
- this._isChange = true;
35
- this._updateVisibleChildren();
36
- }
37
- ngAfterViewInit() {
38
- if (isPlatformServer(this._platformId)) {
39
- return;
40
- }
41
- const GridClass = this.constructor.GridClass;
42
- const defaultOptions = GridClass.defaultOptions;
43
- const options = {};
44
- for (const name in defaultOptions) {
45
- if (name in this && typeof this[name] !== "undefined") {
46
- options[name] = this[name];
47
- }
48
- }
49
- options.renderer = this._renderer;
50
- // The `InfiniteGrid` set ups `scroll` and `resize` events through `ScrollManager`
51
- // and `ResizeWatcher`. These events force Angular to run change detection whenever
52
- // dispatched; this happens too often.
53
- const grid = this._ngZone.runOutsideAngular(() => new GridClass(this.elementRef.nativeElement, options));
54
- for (const name in INFINITEGRID_EVENTS) {
55
- const eventName = INFINITEGRID_EVENTS[name];
56
- fromEvent(grid, eventName)
57
- .pipe(takeUntil(this._destroy$))
58
- .subscribe((event) => {
59
- const emitter = this[eventName];
60
- if (emitter && emitter.observers.length > 0) {
61
- this._ngZone.run(() => emitter.emit(event));
62
- }
63
- });
64
- }
65
- this.vanillaGrid = grid;
66
- fromEvent(this._renderer, 'requestUpdate')
67
- .pipe(takeUntil(this._destroy$))
68
- .subscribe(() => {
69
- this._ngZone.run(() => {
70
- this._isChange = true;
71
- this._updateVisibleChildren();
72
- });
73
- });
74
- mountRenderingItems(this._getItemInfos(), {
75
- grid,
76
- useFirstRender: this.useFirstRender,
77
- useLoading: this.useLoading,
78
- usePlaceholder: this.usePlaceholder,
79
- horizontal: this.horizontal,
80
- status: this.status,
81
- });
82
- this._renderer.updated();
83
- }
84
- ngAfterViewChecked() {
85
- if (!this._isChange || !this.vanillaGrid) {
86
- return;
87
- }
88
- const children = [].slice.call(this.getContainerElement().children);
89
- if (this.visibleItems.length !== children.length) {
90
- return;
91
- }
92
- this._isChange = false;
93
- const GridClass = this.constructor.GridClass;
94
- const propertyTypes = GridClass.propertyTypes;
95
- const grid = this.vanillaGrid;
96
- for (const name in propertyTypes) {
97
- if (name in this) {
98
- grid[name] = this[name];
99
- }
100
- }
101
- this._renderer.updated(children);
102
- }
103
- ngOnDestroy() {
104
- var _a;
105
- this._destroy$.next();
106
- (_a = this.vanillaGrid) === null || _a === void 0 ? void 0 : _a.destroy();
107
- }
108
- _getItemInfos() {
109
- const items = this.items;
110
- const trackBy = this.trackBy;
111
- const groupBy = this.groupBy;
112
- return items.map((item, i) => {
113
- return {
114
- groupKey: groupBy(i, item),
115
- key: trackBy(i, item),
116
- data: item,
117
- };
118
- });
119
- }
120
- _updateVisibleChildren() {
121
- this.visibleItems = getRenderingItems(this._getItemInfos(), {
122
- grid: this.vanillaGrid,
123
- useFirstRender: this.useFirstRender,
124
- useLoading: this.useLoading,
125
- usePlaceholder: this.usePlaceholder,
126
- horizontal: this.horizontal,
127
- status: this.status,
128
- });
129
- }
130
- }
131
- NgxInfiniteGridComponent.GridClass = null;
132
- NgxInfiniteGridComponent.decorators = [
133
- { type: Component, args: [{
134
- selector: 'ngx-infinite-grid, [NgxInfiniteGrid]',
135
- template: '<slot></slot>',
136
- styles: [':host { display: block }']
137
- },] }
138
- ];
139
- NgxInfiniteGridComponent.ctorParameters = () => [
140
- { type: ElementRef },
141
- { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] },
142
- { type: NgZone }
143
- ];
144
- NgxInfiniteGridComponent.propDecorators = {
145
- gridConstructor: [{ type: Input }],
146
- renderer: [{ type: Input }],
147
- container: [{ type: Input }],
148
- containerTag: [{ type: Input }],
149
- threshold: [{ type: Input }],
150
- useRecycle: [{ type: Input }],
151
- horizontal: [{ type: Input }],
152
- percentage: [{ type: Input }],
153
- isEqualSize: [{ type: Input }],
154
- isConstantSize: [{ type: Input }],
155
- gap: [{ type: Input }],
156
- attributePrefix: [{ type: Input }],
157
- resizeDebounce: [{ type: Input }],
158
- maxResizeDebounce: [{ type: Input }],
159
- autoResize: [{ type: Input }],
160
- useFit: [{ type: Input }],
161
- useTransform: [{ type: Input }],
162
- renderOnPropertyChange: [{ type: Input }],
163
- preserveUIOnDestroy: [{ type: Input }],
164
- defaultDirection: [{ type: Input }],
165
- externalItemRenderer: [{ type: Input }],
166
- externalContainerManager: [{ type: Input }],
167
- outlineLength: [{ type: Input }],
168
- outlineSize: [{ type: Input }],
169
- useRoundedSize: [{ type: Input }],
170
- useResizeObserver: [{ type: Input }],
171
- observeChildren: [{ type: Input }],
172
- scrollContainer: [{ type: Input }],
173
- appliedItemChecker: [{ type: Input }],
174
- usePlaceholder: [{ type: Input }],
175
- useLoading: [{ type: Input }],
176
- status: [{ type: Input }],
177
- useFirstRender: [{ type: Input }],
178
- items: [{ type: Input }],
179
- trackBy: [{ type: Input }],
180
- groupBy: [{ type: Input }],
181
- renderComplete: [{ type: Output }],
182
- contentError: [{ type: Output }],
183
- changeScroll: [{ type: Output }],
184
- requestAppend: [{ type: Output }],
185
- requestPrepend: [{ type: Output }]
186
- };
187
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaW5maW5pdGVncmlkL3NyYy9saWIvbmd4LWluZmluaXRlZ3JpZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNGLE9BQU8sRUFHTixTQUFTLEVBQ1QsVUFBVSxFQUNWLFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxFQUNOLFdBQVcsRUFDWCxNQUFNLEVBQ04sTUFBTSxFQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQ0wsaUJBQWlCLEVBS2pCLG1CQUFtQixFQUNuQixtQkFBbUIsRUFNbkIsUUFBUSxHQUNULE1BQU0sb0JBQW9CLENBQUM7QUFDNUIsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFVeEUsTUFBTSxPQUFPLHdCQUNYLFNBQVEsd0JBQXdCO0lBc0RoQyxZQUNTLFVBQW1DLEVBQ2IsV0FBbUIsRUFDeEMsT0FBZTtRQUV2QixLQUFLLEVBQUUsQ0FBQztRQUpELGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQ2IsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFDeEMsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQWxCaEIsVUFBSyxHQUFrQyxFQUFFLENBQUM7UUFDMUMsWUFBTyxHQUFvQyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ25FLFlBQU8sR0FBb0MsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUs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eEZyQixNQUFNOzs7OEJBcUNMLEtBQUs7dUJBQ0wsS0FBSzt3QkFDTCxLQUFLOzJCQUNMLEtBQUs7d0JBQ0wsS0FBSzt5QkFDTCxLQUFLO3lCQUNMLEtBQUs7eUJBQ0wsS0FBSzswQkFDTCxLQUFLOzZCQUNMLEtBQUs7a0JBQ0wsS0FBSzs4QkFDTCxLQUFLOzZCQUNMLEtBQUs7Z0NBQ0wsS0FBSzt5QkFDTCxLQUFLO3FCQUNMLEtBQUs7MkJBQ0wsS0FBSztxQ0FDTCxLQUFLO2tDQUNMLEtBQUs7K0JBQ0wsS0FBSzttQ0FDTCxLQUFLO3VDQUNMLEtBQUs7NEJBQ0wsS0FBSzswQkFDTCxLQUFLOzZCQUNMLEtBQUs7Z0NBQ0wsS0FBSzs4QkFDTCxLQUFLOzhCQUNMLEtBQUs7aUNBQ0wsS0FBSzs2QkFFTCxLQUFLO3lCQUNMLEtBQUs7cUJBQ0wsS0FBSzs2QkFDTCxLQUFLO29CQUNMLEtBQUs7c0JBQ0wsS0FBSztzQkFDTCxLQUFLOzZCQUNMLE1BQU07MkJBQ04sTUFBTTsyQkFDTixNQUFNOzRCQUNOLE1BQU07NkJBQ04sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogZWdqcy1pbmZpbml0ZWdyaWRcbiAqIENvcHlyaWdodCAoYykgMjAyMS1wcmVzZW50IE5BVkVSIENvcnAuXG4gKiBNSVQgbGljZW5zZVxuICovXG4gaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3Q2hlY2tlZCxcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIE9uRGVzdHJveSxcbiAgT3V0cHV0LFxuICBQTEFURk9STV9JRCxcbiAgSW5qZWN0LFxuICBOZ1pvbmVcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IGZyb21FdmVudCwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge1xuICBnZXRSZW5kZXJpbmdJdGVtcyxcbiAgSW5maW5pdGVHcmlkRnVuY3Rpb24sXG4gIEluZmluaXRlR3JpZEl0ZW0sXG4gIEluZmluaXRlR3JpZEl0ZW1JbmZvLFxuICBJbmZpbml0ZUdyaWRPcHRpb25zLFxuICBJTkZJTklURUdSSURfRVZFTlRTLFxuICBtb3VudFJlbmRlcmluZ0l0ZW1zLFxuICBPbkNvbnRlbnRFcnJvcixcbiAgT25SZW5kZXJDb21wbGV0ZSxcbiAgT25SZXF1ZXN0QXBwZW5kLFxuICBPblJlcXVlc3RQcmVwZW5kLFxuICBPbkNoYW5nZVNjcm9sbCxcbiAgUmVuZGVyZXIsXG59IGZyb20gJ0BlZ2pzL2luZmluaXRlZ3JpZCc7XG5pbXBvcnQgeyBOZ3hJbmZpbml0ZUdyaWRJbnRlcmZhY2UgfSBmcm9tICcuL25neC1pbmZpbml0ZWdyaWQuaW50ZXJmYWNlJztcbmltcG9ydCB7IE5neEluZmluaXRlR3JpZFByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25neC1pbmZpbml0ZS1ncmlkLCBbTmd4SW5maW5pdGVHcmlkXScsXG4gIHRlbXBsYXRlOiAnPHNsb3Q+PC9zbG90PicsXG4gIHN0eWxlczogW1xuICAgICc6aG9zdCB7IGRpc3BsYXk6IGJsb2NrIH0nLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnRcbiAgZXh0ZW5kcyBOZ3hJbmZpbml0ZUdyaWRJbnRlcmZhY2VcbiAgaW1wbGVtZW50cyBSZXF1aXJlZDxJbmZpbml0ZUdyaWRPcHRpb25zPixcbiAgTmd4SW5maW5pdGVHcmlkUHJvcHMsXG4gIEFmdGVyVmlld0luaXQsIEFmdGVyVmlld0NoZWNrZWQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgcHVibGljIHN0YXRpYyBHcmlkQ2xhc3M6IEluZmluaXRlR3JpZEZ1bmN0aW9uIHwgbnVsbCA9IG51bGw7XG4gIEBJbnB1dCgpIGdyaWRDb25zdHJ1Y3RvciE6IE5neEluZmluaXRlR3JpZFByb3BzWydncmlkQ29uc3RydWN0b3InXTtcbiAgQElucHV0KCkgcmVuZGVyZXIhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sncmVuZGVyZXInXTtcbiAgQElucHV0KCkgY29udGFpbmVyITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2NvbnRhaW5lciddO1xuICBASW5wdXQoKSBjb250YWluZXJUYWchOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snY29udGFpbmVyVGFnJ107XG4gIEBJbnB1dCgpIHRocmVzaG9sZCE6IE5neEluZmluaXRlR3JpZFByb3BzWyd0aHJlc2hvbGQnXTtcbiAgQElucHV0KCkgdXNlUmVjeWNsZSE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VSZWN5Y2xlJ107XG4gIEBJbnB1dCgpIGhvcml6b250YWwhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snaG9yaXpvbnRhbCddO1xuICBASW5wdXQoKSBwZXJjZW50YWdlITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3BlcmNlbnRhZ2UnXTtcbiAgQElucHV0KCkgaXNFcXVhbFNpemUhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snaXNFcXVhbFNpemUnXTtcbiAgQElucHV0KCkgaXNDb25zdGFudFNpemUhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snaXNDb25zdGFudFNpemUnXTtcbiAgQElucHV0KCkgZ2FwITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2dhcCddO1xuICBASW5wdXQoKSBhdHRyaWJ1dGVQcmVmaXghOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snYXR0cmlidXRlUHJlZml4J107XG4gIEBJbnB1dCgpIHJlc2l6ZURlYm91bmNlITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3Jlc2l6ZURlYm91bmNlJ107XG4gIEBJbnB1dCgpIG1heFJlc2l6ZURlYm91bmNlITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ21heFJlc2l6ZURlYm91bmNlJ107XG4gIEBJbnB1dCgpIGF1dG9SZXNpemUhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snYXV0b1Jlc2l6ZSddO1xuICBASW5wdXQoKSB1c2VGaXQhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sndXNlRml0J107XG4gIEBJbnB1dCgpIHVzZVRyYW5zZm9ybSE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VUcmFuc2Zvcm0nXTtcbiAgQElucHV0KCkgcmVuZGVyT25Qcm9wZXJ0eUNoYW5nZSE6IE5neEluZmluaXRlR3JpZFByb3BzWydyZW5kZXJPblByb3BlcnR5Q2hhbmdlJ107XG4gIEBJbnB1dCgpIHByZXNlcnZlVUlPbkRlc3Ryb3khOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sncHJlc2VydmVVSU9uRGVzdHJveSddO1xuICBASW5wdXQoKSBkZWZhdWx0RGlyZWN0aW9uITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2RlZmF1bHREaXJlY3Rpb24nXTtcbiAgQElucHV0KCkgZXh0ZXJuYWxJdGVtUmVuZGVyZXIhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snZXh0ZXJuYWxJdGVtUmVuZGVyZXInXTtcbiAgQElucHV0KCkgZXh0ZXJuYWxDb250YWluZXJNYW5hZ2VyITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2V4dGVybmFsQ29udGFpbmVyTWFuYWdlciddO1xuICBASW5wdXQoKSBvdXRsaW5lTGVuZ3RoITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ291dGxpbmVMZW5ndGgnXTtcbiAgQElucHV0KCkgb3V0bGluZVNpemUhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snb3V0bGluZVNpemUnXTtcbiAgQElucHV0KCkgdXNlUm91bmRlZFNpemUhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sndXNlUm91bmRlZFNpemUnXTtcbiAgQElucHV0KCkgdXNlUmVzaXplT2JzZXJ2ZXIhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sndXNlUmVzaXplT2JzZXJ2ZXInXTtcbiAgQElucHV0KCkgb2JzZXJ2ZUNoaWxkcmVuITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ29ic2VydmVDaGlsZHJlbiddO1xuICBASW5wdXQoKSBzY3JvbGxDb250YWluZXIhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snc2Nyb2xsQ29udGFpbmVyJ107XG4gIEBJbnB1dCgpIGFwcGxpZWRJdGVtQ2hlY2tlciE6IE5neEluZmluaXRlR3JpZFByb3BzWydhcHBsaWVkSXRlbUNoZWNrZXInXTtcblxuICBASW5wdXQoKSB1c2VQbGFjZWhvbGRlciE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VGaXJzdFJlbmRlciddO1xuICBASW5wdXQoKSB1c2VMb2FkaW5nITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3VzZUxvYWRpbmcnXTtcbiAgQElucHV0KCkgc3RhdHVzITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3N0YXR1cyddO1xuICBASW5wdXQoKSB1c2VGaXJzdFJlbmRlciE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VGaXJzdFJlbmRlciddO1xuICBASW5wdXQoKSBpdGVtczogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2l0ZW1zJ10gPSBbXTtcbiAgQElucHV0KCkgdHJhY2tCeTogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3RyYWNrQnknXSA9ICgoXywgaXRlbSkgPT4gaXRlbS5rZXkpO1xuICBASW5wdXQoKSBncm91cEJ5OiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snZ3JvdXBCeSddID0gKChfLCBpdGVtKSA9PiBpdGVtLmdyb3VwS2V5KTtcbiAgQE91dHB1dCgpIHJlbmRlckNvbXBsZXRlITogRXZlbnRFbWl0dGVyPE9uUmVuZGVyQ29tcGxldGU+O1xuICBAT3V0cHV0KCkgY29udGVudEVycm9yITogRXZlbnRFbWl0dGVyPE9uQ29udGVudEVycm9yPjtcbiAgQE91dHB1dCgpIGNoYW5nZVNjcm9sbCE6IEV2ZW50RW1pdHRlcjxPbkNoYW5nZVNjcm9sbD47XG4gIEBPdXRwdXQoKSByZXF1ZXN0QXBwZW5kITogRXZlbnRFbWl0dGVyPE9uUmVxdWVzdEFwcGVuZD47XG4gIEBPdXRwdXQoKSByZXF1ZXN0UHJlcGVuZCE6IEV2ZW50RW1pdHRlcjxPblJlcXVlc3RQcmVwZW5kPjtcbiAgcHVibGljIHZpc2libGVJdGVtczogSW5maW5pdGVHcmlkSXRlbVtdID0gW107XG5cbiAgcHJpdmF0ZSBfcmVuZGVyZXIgPSBuZXcgUmVuZGVyZXIoKTtcbiAgcHJpdmF0ZSBfaXNDaGFuZ2UgPSBmYWxzZTtcblxuICBwcml2YXRlIF9kZXN0cm95JCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxuICAgIEBJbmplY3QoUExBVEZPUk1fSUQpIHByaXZhdGUgX3BsYXRmb3JtSWQ6IHN0cmluZyxcbiAgICBwcml2YXRlIF9uZ1pvbmU6IE5nWm9uZVxuICApIHtcbiAgICBzdXBlcigpO1xuXG4gICAgZm9yIChjb25zdCBuYW1lIGluIElORklOSVRFR1JJRF9FVkVOVFMpIHtcbiAgICAgIGNvbnN0IGV2ZW50TmFtZSA9IChJTkZJTklURUdSSURfRVZFTlRTIGFzIGFueSlbbmFtZV07XG4gICAgICAodGhpcyBhcyBhbnkpW2V2ZW50TmFtZV0gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gICAgfVxuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5fdXBkYXRlVmlzaWJsZUNoaWxkcmVuKCk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcygpIHtcbiAgICB0aGlzLl9pc0NoYW5nZSA9IHRydWU7XG4gICAgdGhpcy5fdXBkYXRlVmlzaWJsZUNoaWxkcmVuKCk7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgaWYgKGlzUGxhdGZvcm1TZXJ2ZXIodGhpcy5fcGxhdGZvcm1JZCkpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBHcmlkQ2xhc3MgPSAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgTmd4SW5maW5pdGVHcmlkQ29tcG9uZW50KS5HcmlkQ2xhc3M7XG4gICAgY29uc3QgZGVmYXVsdE9wdGlvbnMgPSBHcmlkQ2xhc3MhLmRlZmF1bHRPcHRpb25zO1xuICAgIGNvbnN0IG9wdGlvbnM6IFBhcnRpYWw8SW5maW5pdGVHcmlkT3B0aW9ucz4gPSB7fTtcblxuICAgIGZvciAoY29uc3QgbmFtZSBpbiBkZWZhdWx0T3B0aW9ucykge1xuICAgICAgaWYgKG5hbWUgaW4gdGhpcyAmJiB0eXBlb2YgKHRoaXMgYXMgYW55KVtuYW1lXSAhPT0gXCJ1bmRlZmluZWRcIikge1xuICAgICAgICAob3B0aW9ucyBhcyBhbnkpW25hbWVdID0gKHRoaXMgYXMgYW55KVtuYW1lXTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBvcHRpb25zLnJlbmRlcmVyID0gdGhpcy5fcmVuZGVyZXI7XG5cbiAgICAvLyBUaGUgYEluZmluaXRlR3JpZGAgc2V0IHVwcyBgc2Nyb2xsYCBhbmQgYHJlc2l6ZWAgZXZlbnRzIHRocm91Z2ggYFNjcm9sbE1hbmFnZXJgXG4gICAgLy8gYW5kIGBSZXNpemVXYXRjaGVyYC4gVGhlc2UgZXZlbnRzIGZvcmNlIEFuZ3VsYXIgdG8gcnVuIGNoYW5nZSBkZXRlY3Rpb24gd2hlbmV2ZXJcbiAgICAvLyBkaXNwYXRjaGVkOyB0aGlzIGhhcHBlbnMgdG9vIG9mdGVuLlxuICAgIGNvbnN0IGdyaWQgPSB0aGlzLl9uZ1pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoXG4gICAgICAoKSA9PiBuZXcgR3JpZENsYXNzISh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgb3B0aW9ucylcbiAgICApO1xuXG4gICAgZm9yIChjb25zdCBuYW1lIGluIElORklOSVRFR1JJRF9FVkVOVFMpIHtcbiAgICAgIGNvbnN0IGV2ZW50TmFtZSA9IChJTkZJTklURUdSSURfRVZFTlRTIGFzIGFueSlbbmFtZV07XG5cbiAgICAgIGZyb21FdmVudChncmlkLCBldmVudE5hbWUpXG4gICAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JCkpXG4gICAgICAgIC5zdWJzY3JpYmUoKGV2ZW50KSA9PiB7XG4gICAgICAgICAgY29uc3QgZW1pdHRlciA9ICh0aGlzIGFzIGFueSlbZXZlbnROYW1lXTtcbiAgICAgICAgICBpZiAoZW1pdHRlciAmJiBlbWl0dGVyLm9ic2VydmVycy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICB0aGlzLl9uZ1pvbmUucnVuKCgpID0+IGVtaXR0ZXIuZW1pdChldmVudCkpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgdGhpcy52YW5pbGxhR3JpZCA9IGdyaWQ7XG5cbiAgICBmcm9tRXZlbnQodGhpcy5fcmVuZGVyZXIsICdyZXF1ZXN0VXBkYXRlJylcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JCkpXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgdGhpcy5fbmdab25lLnJ1bigoKSA9PiB7XG4gICAgICAgICAgdGhpcy5faXNDaGFuZ2UgPSB0cnVlO1xuICAgICAgICAgIHRoaXMuX3VwZGF0ZVZpc2libGVDaGlsZHJlbigpO1xuICAgICAgICB9KTtcbiAgICAgIH0pO1xuXG4gICAgbW91bnRSZW5kZXJpbmdJdGVtcyh0aGlzLl9nZXRJdGVtSW5mb3MoKSwge1xuICAgICAgZ3JpZCxcbiAgICAgIHVzZUZpcnN0UmVuZGVyOiB0aGlzLnVzZUZpcnN0UmVuZGVyLFxuICAgICAgdXNlTG9hZGluZzogdGhpcy51c2VMb2FkaW5nLFxuICAgICAgdXNlUGxhY2Vob2xkZXI6IHRoaXMudXNlUGxhY2Vob2xkZXIsXG4gICAgICBob3Jpem9udGFsOiB0aGlzLmhvcml6b250YWwsXG4gICAgICBzdGF0dXM6IHRoaXMuc3RhdHVzLFxuICAgIH0pO1xuICAgIHRoaXMuX3JlbmRlcmVyLnVwZGF0ZWQoKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3Q2hlY2tlZCgpIHtcbiAgICBpZiAoIXRoaXMuX2lzQ2hhbmdlIHx8ICF0aGlzLnZhbmlsbGFHcmlkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGNvbnN0IGNoaWxkcmVuID0gW10uc2xpY2UuY2FsbCh0aGlzLmdldENvbnRhaW5lckVsZW1lbnQoKS5jaGlsZHJlbik7XG5cbiAgICBpZiAodGhpcy52aXNpYmxlSXRlbXMubGVuZ3RoICE9PSBjaGlsZHJlbi5sZW5ndGgpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy5faXNDaGFuZ2UgPSBmYWxzZTtcbiAgICBjb25zdCBHcmlkQ2xhc3MgPSAodGhpcy5jb25zdHJ1Y3RvciBhcyB0eXBlb2YgTmd4SW5maW5pdGVHcmlkQ29tcG9uZW50KS5HcmlkQ2xhc3M7XG4gICAgY29uc3QgcHJvcGVydHlUeXBlcyA9IEdyaWRDbGFzcyEucHJvcGVydHlUeXBlcztcbiAgICBjb25zdCBncmlkID0gdGhpcy52YW5pbGxhR3JpZDtcblxuICAgIGZvciAoY29uc3QgbmFtZSBpbiBwcm9wZXJ0eVR5cGVzKSB7XG4gICAgICBpZiAobmFtZSBpbiB0aGlzKSB7XG4gICAgICAgIChncmlkIGFzIGFueSlbbmFtZV0gPSAodGhpcyBhcyBhbnkpW25hbWVdO1xuICAgICAgfVxuICAgIH1cblxuICAgIHRoaXMuX3JlbmRlcmVyLnVwZGF0ZWQoY2hpbGRyZW4pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5fZGVzdHJveSQubmV4dCgpO1xuICAgIHRoaXMudmFuaWxsYUdyaWQ/LmRlc3Ryb3koKTtcbiAgfVxuXG4gIHByaXZhdGUgX2dldEl0ZW1JbmZvcygpOiBJbmZpbml0ZUdyaWRJdGVtSW5mb1tdIHtcbiAgICBjb25zdCBpdGVtcyA9IHRoaXMuaXRlbXM7XG4gICAgY29uc3QgdHJhY2tCeSA9IHRoaXMudHJhY2tCeTtcbiAgICBjb25zdCBncm91cEJ5ID0gdGhpcy5ncm91cEJ5O1xuXG4gICAgcmV0dXJuIGl0ZW1zLm1hcCgoaXRlbSwgaSkgPT4ge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgZ3JvdXBLZXk6IGdyb3VwQnkoaSwgaXRlbSksXG4gICAgICAgIGtleTogdHJhY2tCeShpLCBpdGVtKSxcbiAgICAgICAgZGF0YTogaXRlbSxcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIF91cGRhdGVWaXNpYmxlQ2hpbGRyZW4oKSB7XG4gICAgdGhpcy52aXNpYmxlSXRlbXMgPSBnZXRSZW5kZXJpbmdJdGVtcyh0aGlzLl9nZXRJdGVtSW5mb3MoKSwge1xuICAgICAgZ3JpZDogdGhpcy52YW5pbGxhR3JpZCxcbiAgICAgIHVzZUZpcnN0UmVuZGVyOiB0aGlzLnVzZUZpcnN0UmVuZGVyLFxuICAgICAgdXNlTG9hZGluZzogdGhpcy51c2VMb2FkaW5nLFxuICAgICAgdXNlUGxhY2Vob2xkZXI6IHRoaXMudXNlUGxhY2Vob2xkZXIsXG4gICAgICBob3Jpem9udGFsOiB0aGlzLmhvcml6b250YWwsXG4gICAgICBzdGF0dXM6IHRoaXMuc3RhdHVzLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -1,31 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { NgModule } from '@angular/core';
3
- import { NgxInfiniteGridComponent } from './ngx-infinitegrid.component';
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';
8
- export class NgxInfiniteGridModule {
9
- }
10
- NgxInfiniteGridModule.decorators = [
11
- { type: NgModule, args: [{
12
- declarations: [
13
- NgxInfiniteGridComponent,
14
- NgxMasonryInfiniteGridComponent,
15
- NgxJustifiedInfiniteGridComponent,
16
- NgxFrameInfiniteGridComponent,
17
- NgxPackingInfiniteGridComponent,
18
- ],
19
- imports: [
20
- CommonModule,
21
- ],
22
- exports: [
23
- NgxInfiniteGridComponent,
24
- NgxMasonryInfiniteGridComponent,
25
- NgxJustifiedInfiniteGridComponent,
26
- NgxFrameInfiniteGridComponent,
27
- NgxPackingInfiniteGridComponent,
28
- ],
29
- },] }
30
- ];
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaW5maW5pdGVncmlkL3NyYy9saWIvbmd4LWluZmluaXRlZ3JpZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDeEUsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDN0YsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDakcsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDekYsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUF3QjdGLE1BQU0sT0FBTyxxQkFBcUI7OztZQW5CakMsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRTtvQkFDWix3QkFBd0I7b0JBQ3hCLCtCQUErQjtvQkFDL0IsaUNBQWlDO29CQUNqQyw2QkFBNkI7b0JBQzdCLCtCQUErQjtpQkFDaEM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLFlBQVk7aUJBQ2I7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLHdCQUF3QjtvQkFDeEIsK0JBQStCO29CQUMvQixpQ0FBaUM7b0JBQ2pDLDZCQUE2QjtvQkFDN0IsK0JBQStCO2lCQUNoQzthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL25neC1pbmZpbml0ZWdyaWQuY29tcG9uZW50JztcbmltcG9ydCB7IE5neE1hc29ucnlJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL2dyaWRzL25neC1tYXNvbnJ5LWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4SnVzdGlmaWVkSW5maW5pdGVHcmlkQ29tcG9uZW50IH0gZnJvbSAnLi9ncmlkcy9uZ3gtanVzdGlmaWVkLWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd4RnJhbWVJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL2dyaWRzL25neC1mcmFtZS1pbmZpbml0ZWdyaWQuY29tcG9uZW50JztcbmltcG9ydCB7IE5neFBhY2tpbmdJbmZpbml0ZUdyaWRDb21wb25lbnQgfSBmcm9tICcuL2dyaWRzL25neC1wYWNraW5nLWluZmluaXRlZ3JpZC5jb21wb25lbnQnO1xuXG5cblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQsXG4gICAgTmd4TWFzb25yeUluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hKdXN0aWZpZWRJbmZpbml0ZUdyaWRDb21wb25lbnQsXG4gICAgTmd4RnJhbWVJbmZpbml0ZUdyaWRDb21wb25lbnQsXG4gICAgTmd4UGFja2luZ0luZmluaXRlR3JpZENvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIE5neEluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hNYXNvbnJ5SW5maW5pdGVHcmlkQ29tcG9uZW50LFxuICAgIE5neEp1c3RpZmllZEluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hGcmFtZUluZmluaXRlR3JpZENvbXBvbmVudCxcbiAgICBOZ3hQYWNraW5nSW5maW5pdGVHcmlkQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3hJbmZpbml0ZUdyaWRNb2R1bGUgeyB9XG4iXX0=
@@ -1,318 +0,0 @@
1
- import { EventEmitter, Component, ElementRef, Inject, PLATFORM_ID, NgZone, Input, Output, NgModule } from '@angular/core';
2
- import { isPlatformServer, CommonModule } from '@angular/common';
3
- import { Subject, fromEvent } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
5
- import { withInfiniteGridMethods, Renderer, INFINITEGRID_EVENTS, mountRenderingItems, getRenderingItems, MasonryInfiniteGrid, JustifiedInfiniteGrid, FrameInfiniteGrid, PackingInfiniteGrid } from '@egjs/infinitegrid';
6
- import { __decorate } from 'tslib';
7
-
8
- class NgxInfiniteGridInterface {
9
- }
10
- __decorate([
11
- withInfiniteGridMethods
12
- ], NgxInfiniteGridInterface.prototype, "vanillaGrid", void 0);
13
-
14
- /**
15
- * egjs-infinitegrid
16
- * Copyright (c) 2021-present NAVER Corp.
17
- * MIT license
18
- */
19
- class NgxInfiniteGridComponent extends NgxInfiniteGridInterface {
20
- constructor(elementRef, _platformId, _ngZone) {
21
- super();
22
- this.elementRef = elementRef;
23
- this._platformId = _platformId;
24
- this._ngZone = _ngZone;
25
- this.items = [];
26
- this.trackBy = ((_, item) => item.key);
27
- this.groupBy = ((_, item) => item.groupKey);
28
- this.visibleItems = [];
29
- this._renderer = new Renderer();
30
- this._isChange = false;
31
- this._destroy$ = new Subject();
32
- for (const name in INFINITEGRID_EVENTS) {
33
- const eventName = INFINITEGRID_EVENTS[name];
34
- this[eventName] = new EventEmitter();
35
- }
36
- }
37
- ngOnInit() {
38
- this._updateVisibleChildren();
39
- }
40
- ngOnChanges() {
41
- this._isChange = true;
42
- this._updateVisibleChildren();
43
- }
44
- ngAfterViewInit() {
45
- if (isPlatformServer(this._platformId)) {
46
- return;
47
- }
48
- const GridClass = this.constructor.GridClass;
49
- const defaultOptions = GridClass.defaultOptions;
50
- const options = {};
51
- for (const name in defaultOptions) {
52
- if (name in this && typeof this[name] !== "undefined") {
53
- options[name] = this[name];
54
- }
55
- }
56
- options.renderer = this._renderer;
57
- // The `InfiniteGrid` set ups `scroll` and `resize` events through `ScrollManager`
58
- // and `ResizeWatcher`. These events force Angular to run change detection whenever
59
- // dispatched; this happens too often.
60
- const grid = this._ngZone.runOutsideAngular(() => new GridClass(this.elementRef.nativeElement, options));
61
- for (const name in INFINITEGRID_EVENTS) {
62
- const eventName = INFINITEGRID_EVENTS[name];
63
- fromEvent(grid, eventName)
64
- .pipe(takeUntil(this._destroy$))
65
- .subscribe((event) => {
66
- const emitter = this[eventName];
67
- if (emitter && emitter.observers.length > 0) {
68
- this._ngZone.run(() => emitter.emit(event));
69
- }
70
- });
71
- }
72
- this.vanillaGrid = grid;
73
- fromEvent(this._renderer, 'requestUpdate')
74
- .pipe(takeUntil(this._destroy$))
75
- .subscribe(() => {
76
- this._ngZone.run(() => {
77
- this._isChange = true;
78
- this._updateVisibleChildren();
79
- });
80
- });
81
- mountRenderingItems(this._getItemInfos(), {
82
- grid,
83
- useFirstRender: this.useFirstRender,
84
- useLoading: this.useLoading,
85
- usePlaceholder: this.usePlaceholder,
86
- horizontal: this.horizontal,
87
- status: this.status,
88
- });
89
- this._renderer.updated();
90
- }
91
- ngAfterViewChecked() {
92
- if (!this._isChange || !this.vanillaGrid) {
93
- return;
94
- }
95
- const children = [].slice.call(this.getContainerElement().children);
96
- if (this.visibleItems.length !== children.length) {
97
- return;
98
- }
99
- this._isChange = false;
100
- const GridClass = this.constructor.GridClass;
101
- const propertyTypes = GridClass.propertyTypes;
102
- const grid = this.vanillaGrid;
103
- for (const name in propertyTypes) {
104
- if (name in this) {
105
- grid[name] = this[name];
106
- }
107
- }
108
- this._renderer.updated(children);
109
- }
110
- ngOnDestroy() {
111
- var _a;
112
- this._destroy$.next();
113
- (_a = this.vanillaGrid) === null || _a === void 0 ? void 0 : _a.destroy();
114
- }
115
- _getItemInfos() {
116
- const items = this.items;
117
- const trackBy = this.trackBy;
118
- const groupBy = this.groupBy;
119
- return items.map((item, i) => {
120
- return {
121
- groupKey: groupBy(i, item),
122
- key: trackBy(i, item),
123
- data: item,
124
- };
125
- });
126
- }
127
- _updateVisibleChildren() {
128
- this.visibleItems = getRenderingItems(this._getItemInfos(), {
129
- grid: this.vanillaGrid,
130
- useFirstRender: this.useFirstRender,
131
- useLoading: this.useLoading,
132
- usePlaceholder: this.usePlaceholder,
133
- horizontal: this.horizontal,
134
- status: this.status,
135
- });
136
- }
137
- }
138
- NgxInfiniteGridComponent.GridClass = null;
139
- NgxInfiniteGridComponent.decorators = [
140
- { type: Component, args: [{
141
- selector: 'ngx-infinite-grid, [NgxInfiniteGrid]',
142
- template: '<slot></slot>',
143
- styles: [':host { display: block }']
144
- },] }
145
- ];
146
- NgxInfiniteGridComponent.ctorParameters = () => [
147
- { type: ElementRef },
148
- { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] },
149
- { type: NgZone }
150
- ];
151
- NgxInfiniteGridComponent.propDecorators = {
152
- gridConstructor: [{ type: Input }],
153
- renderer: [{ type: Input }],
154
- container: [{ type: Input }],
155
- containerTag: [{ type: Input }],
156
- threshold: [{ type: Input }],
157
- useRecycle: [{ type: Input }],
158
- horizontal: [{ type: Input }],
159
- percentage: [{ type: Input }],
160
- isEqualSize: [{ type: Input }],
161
- isConstantSize: [{ type: Input }],
162
- gap: [{ type: Input }],
163
- attributePrefix: [{ type: Input }],
164
- resizeDebounce: [{ type: Input }],
165
- maxResizeDebounce: [{ type: Input }],
166
- autoResize: [{ type: Input }],
167
- useFit: [{ type: Input }],
168
- useTransform: [{ type: Input }],
169
- renderOnPropertyChange: [{ type: Input }],
170
- preserveUIOnDestroy: [{ type: Input }],
171
- defaultDirection: [{ type: Input }],
172
- externalItemRenderer: [{ type: Input }],
173
- externalContainerManager: [{ type: Input }],
174
- outlineLength: [{ type: Input }],
175
- outlineSize: [{ type: Input }],
176
- useRoundedSize: [{ type: Input }],
177
- useResizeObserver: [{ type: Input }],
178
- observeChildren: [{ type: Input }],
179
- scrollContainer: [{ type: Input }],
180
- appliedItemChecker: [{ type: Input }],
181
- usePlaceholder: [{ type: Input }],
182
- useLoading: [{ type: Input }],
183
- status: [{ type: Input }],
184
- useFirstRender: [{ type: Input }],
185
- items: [{ type: Input }],
186
- trackBy: [{ type: Input }],
187
- groupBy: [{ type: Input }],
188
- renderComplete: [{ type: Output }],
189
- contentError: [{ type: Output }],
190
- changeScroll: [{ type: Output }],
191
- requestAppend: [{ type: Output }],
192
- requestPrepend: [{ type: Output }]
193
- };
194
-
195
- const TEMPLATE = `
196
- <ng-template #content><ng-content></ng-content></ng-template>
197
-
198
- <ng-template #viewer>
199
- <div *ngIf="container === true; else noContainer" #containerRef>
200
- <ng-template [ngTemplateOutlet]="content"></ng-template>
201
- </div>
202
-
203
- <ng-template #noContainer>
204
- <ng-template [ngTemplateOutlet]="content"></ng-template>
205
- </ng-template>
206
- </ng-template>
207
-
208
- <div *ngIf="elementRef.nativeElement.tagName.indexOf('NGX-') === 0; else noWrapper" #wrapperRef>
209
- <ng-template [ngTemplateOutlet]="viewer"></ng-template>
210
- </div>
211
-
212
- <ng-template #noWrapper>
213
- <ng-template [ngTemplateOutlet]="viewer"></ng-template>
214
- </ng-template>
215
- `;
216
-
217
- class NgxMasonryInfiniteGridComponent extends NgxInfiniteGridComponent {
218
- }
219
- NgxMasonryInfiniteGridComponent.GridClass = MasonryInfiniteGrid;
220
- NgxMasonryInfiniteGridComponent.decorators = [
221
- { type: Component, args: [{
222
- selector: 'ngx-masonry-infinite-grid, [NgxMasonryInfiniteGrid]',
223
- template: TEMPLATE
224
- },] }
225
- ];
226
- NgxMasonryInfiniteGridComponent.propDecorators = {
227
- column: [{ type: Input }],
228
- columnSize: [{ type: Input }],
229
- columnSizeRatio: [{ type: Input }],
230
- align: [{ type: Input }],
231
- columnCalculationThreshold: [{ type: Input }],
232
- maxStretchColumnSize: [{ type: Input }]
233
- };
234
-
235
- class NgxJustifiedInfiniteGridComponent extends NgxInfiniteGridComponent {
236
- }
237
- NgxJustifiedInfiniteGridComponent.GridClass = JustifiedInfiniteGrid;
238
- NgxJustifiedInfiniteGridComponent.decorators = [
239
- { type: Component, args: [{
240
- selector: 'ngx-justified-infinite-grid, [NgxJustifiedInfiniteGrid]',
241
- template: TEMPLATE
242
- },] }
243
- ];
244
- NgxJustifiedInfiniteGridComponent.propDecorators = {
245
- columnRange: [{ type: Input }],
246
- rowRange: [{ type: Input }],
247
- sizeRange: [{ type: Input }],
248
- displayedRow: [{ type: Input }],
249
- isCroppedSize: [{ type: Input }]
250
- };
251
-
252
- class NgxFrameInfiniteGridComponent extends NgxInfiniteGridComponent {
253
- }
254
- NgxFrameInfiniteGridComponent.GridClass = FrameInfiniteGrid;
255
- NgxFrameInfiniteGridComponent.decorators = [
256
- { type: Component, args: [{
257
- selector: 'ngx-frame-infinite-grid, [NgxFrameInfiniteGrid]',
258
- template: TEMPLATE
259
- },] }
260
- ];
261
- NgxFrameInfiniteGridComponent.propDecorators = {
262
- frame: [{ type: Input }],
263
- useFrameFill: [{ type: Input }],
264
- rectSize: [{ type: Input }]
265
- };
266
-
267
- class NgxPackingInfiniteGridComponent extends NgxInfiniteGridComponent {
268
- }
269
- NgxPackingInfiniteGridComponent.GridClass = PackingInfiniteGrid;
270
- NgxPackingInfiniteGridComponent.decorators = [
271
- { type: Component, args: [{
272
- selector: 'ngx-packing-infinite-grid, [NgxPackingInfiniteGrid]',
273
- template: TEMPLATE
274
- },] }
275
- ];
276
- NgxPackingInfiniteGridComponent.propDecorators = {
277
- aspectRatio: [{ type: Input }],
278
- sizeWeight: [{ type: Input }],
279
- ratioWeight: [{ type: Input }],
280
- weightPriority: [{ type: Input }]
281
- };
282
-
283
- class NgxInfiniteGridModule {
284
- }
285
- NgxInfiniteGridModule.decorators = [
286
- { type: NgModule, args: [{
287
- declarations: [
288
- NgxInfiniteGridComponent,
289
- NgxMasonryInfiniteGridComponent,
290
- NgxJustifiedInfiniteGridComponent,
291
- NgxFrameInfiniteGridComponent,
292
- NgxPackingInfiniteGridComponent,
293
- ],
294
- imports: [
295
- CommonModule,
296
- ],
297
- exports: [
298
- NgxInfiniteGridComponent,
299
- NgxMasonryInfiniteGridComponent,
300
- NgxJustifiedInfiniteGridComponent,
301
- NgxFrameInfiniteGridComponent,
302
- NgxPackingInfiniteGridComponent,
303
- ],
304
- },] }
305
- ];
306
-
307
- /** This shouldn't be used outside of the library, required for the Ivy compilation. */
308
-
309
- /*
310
- * Public API Surface of ngx-infinitegrid
311
- */
312
-
313
- /**
314
- * Generated bundle index. Do not edit.
315
- */
316
-
317
- export { NgxInfiniteGridComponent, NgxInfiniteGridModule, NgxMasonryInfiniteGridComponent, NgxFrameInfiniteGridComponent as ɵNgxFrameInfiniteGridComponent, NgxJustifiedInfiniteGridComponent as ɵNgxJustifiedInfiniteGridComponent, NgxPackingInfiniteGridComponent as ɵNgxPackingInfiniteGridComponent, NgxInfiniteGridInterface as ɵa, TEMPLATE as ɵb };
318
- //# sourceMappingURL=egjs-ngx-infinitegrid.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"egjs-ngx-infinitegrid.js","sources":["../../../projects/ngx-infinitegrid/src/lib/ngx-infinitegrid.interface.ts","../../../projects/ngx-infinitegrid/src/lib/ngx-infinitegrid.component.ts","../../../projects/ngx-infinitegrid/src/lib/consts.ts","../../../projects/ngx-infinitegrid/src/lib/grids/ngx-masonry-infinitegrid.component.ts","../../../projects/ngx-infinitegrid/src/lib/grids/ngx-justified-infinitegrid.component.ts","../../../projects/ngx-infinitegrid/src/lib/grids/ngx-frame-infinitegrid.component.ts","../../../projects/ngx-infinitegrid/src/lib/grids/ngx-packing-infinitegrid.component.ts","../../../projects/ngx-infinitegrid/src/lib/ngx-infinitegrid.module.ts","../../../projects/ngx-infinitegrid/src/private_export.ts","../../../projects/ngx-infinitegrid/src/public-api.ts","../../../projects/ngx-infinitegrid/src/egjs-ngx-infinitegrid.ts"],"sourcesContent":["/**\n * egjs-infinitegrid\n * Copyright (c) 2021-present NAVER Corp.\n * MIT license\n */\nimport VanillaInfiniteGrid, { InfiniteGridMethods, withInfiniteGridMethods } from '@egjs/infinitegrid';\nimport { NgxInfiniteGridComponent } from './ngx-infinitegrid.component';\n\nexport class NgxInfiniteGridInterface {\n @withInfiniteGridMethods\n protected vanillaGrid!: VanillaInfiniteGrid;\n}\nexport interface NgxInfiniteGridInterface extends InfiniteGridMethods<NgxInfiniteGridComponent> { }\n","/**\n * egjs-infinitegrid\n * Copyright (c) 2021-present NAVER Corp.\n * MIT license\n */\n import {\n AfterViewChecked,\n AfterViewInit,\n Component,\n ElementRef,\n EventEmitter,\n Input,\n OnChanges,\n OnDestroy,\n Output,\n PLATFORM_ID,\n Inject,\n NgZone\n} from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\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@Component({\n selector: 'ngx-infinite-grid, [NgxInfiniteGrid]',\n template: '<slot></slot>',\n styles: [\n ':host { display: block }',\n ],\n})\nexport class NgxInfiniteGridComponent\n extends NgxInfiniteGridInterface\n implements Required<InfiniteGridOptions>,\n NgxInfiniteGridProps,\n AfterViewInit, AfterViewChecked, OnChanges, OnDestroy {\n public static GridClass: InfiniteGridFunction | null = null;\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() outlineLength!: NgxInfiniteGridProps['outlineLength'];\n @Input() outlineSize!: NgxInfiniteGridProps['outlineSize'];\n @Input() useRoundedSize!: NgxInfiniteGridProps['useRoundedSize'];\n @Input() useResizeObserver!: NgxInfiniteGridProps['useResizeObserver'];\n @Input() observeChildren!: NgxInfiniteGridProps['observeChildren'];\n @Input() scrollContainer!: NgxInfiniteGridProps['scrollContainer'];\n @Input() appliedItemChecker!: NgxInfiniteGridProps['appliedItemChecker'];\n\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\n private _renderer = new Renderer();\n private _isChange = false;\n\n private _destroy$ = new Subject<void>();\n\n constructor(\n public elementRef: ElementRef<HTMLElement>,\n @Inject(PLATFORM_ID) private _platformId: string,\n private _ngZone: NgZone\n ) {\n super();\n\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\n ngOnChanges() {\n this._isChange = true;\n this._updateVisibleChildren();\n }\n\n ngAfterViewInit(): void {\n if (isPlatformServer(this._platformId)) {\n return;\n }\n\n const GridClass = (this.constructor as typeof NgxInfiniteGridComponent).GridClass;\n const defaultOptions = GridClass!.defaultOptions;\n const options: Partial<InfiniteGridOptions> = {};\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\n options.renderer = this._renderer;\n\n // The `InfiniteGrid` set ups `scroll` and `resize` events through `ScrollManager`\n // and `ResizeWatcher`. These events force Angular to run change detection whenever\n // dispatched; this happens too often.\n const grid = this._ngZone.runOutsideAngular(\n () => new GridClass!(this.elementRef.nativeElement, options)\n );\n\n for (const name in INFINITEGRID_EVENTS) {\n const eventName = (INFINITEGRID_EVENTS as any)[name];\n\n fromEvent(grid, eventName)\n .pipe(takeUntil(this._destroy$))\n .subscribe((event) => {\n const emitter = (this as any)[eventName];\n if (emitter && emitter.observers.length > 0) {\n this._ngZone.run(() => emitter.emit(event));\n }\n });\n }\n\n this.vanillaGrid = grid;\n\n fromEvent(this._renderer, 'requestUpdate')\n .pipe(takeUntil(this._destroy$))\n .subscribe(() => {\n this._ngZone.run(() => {\n this._isChange = true;\n this._updateVisibleChildren();\n });\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\n ngAfterViewChecked() {\n if (!this._isChange || !this.vanillaGrid) {\n return;\n }\n const children = [].slice.call(this.getContainerElement().children);\n\n if (this.visibleItems.length !== children.length) {\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(children);\n }\n\n ngOnDestroy() {\n this._destroy$.next();\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\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 }\n}\n","export const TEMPLATE = `\n<ng-template #content><ng-content></ng-content></ng-template>\n\n<ng-template #viewer>\n <div *ngIf=\"container === true; else noContainer\" #containerRef>\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n </div>\n\n <ng-template #noContainer>\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n </ng-template>\n</ng-template>\n\n<div *ngIf=\"elementRef.nativeElement.tagName.indexOf('NGX-') === 0; else noWrapper\" #wrapperRef>\n <ng-template [ngTemplateOutlet]=\"viewer\"></ng-template>\n</div>\n\n<ng-template #noWrapper>\n <ng-template [ngTemplateOutlet]=\"viewer\"></ng-template>\n</ng-template>\n`;\n","import {\n NgxInfiniteGridComponent,\n} from '../ngx-infinitegrid.component';\nimport { Component, Input } from '@angular/core';\nimport {\n MasonryInfiniteGrid as VanillaMasonryInfiniteGrid,\n MasonryInfiniteGridOptions,\n} from \"@egjs/infinitegrid\";\nimport { TEMPLATE } from '../consts';\n\n\n@Component({\n selector: 'ngx-masonry-infinite-grid, [NgxMasonryInfiniteGrid]',\n template: TEMPLATE,\n})\nexport class NgxMasonryInfiniteGridComponent extends NgxInfiniteGridComponent\n implements Required<MasonryInfiniteGridOptions> {\n public static GridClass = VanillaMasonryInfiniteGrid;\n @Input() column!: Required<MasonryInfiniteGridOptions>['column'];\n @Input() columnSize!: Required<MasonryInfiniteGridOptions>['columnSize'];\n @Input() columnSizeRatio!: Required<MasonryInfiniteGridOptions>['columnSizeRatio'];\n @Input() align!: Required<MasonryInfiniteGridOptions>['align'];\n @Input() columnCalculationThreshold!: Required<MasonryInfiniteGridOptions>['columnCalculationThreshold'];\n @Input() maxStretchColumnSize!: Required<MasonryInfiniteGridOptions>['maxStretchColumnSize'];\n}\n","import {\n NgxInfiniteGridComponent,\n} from '../ngx-infinitegrid.component';\nimport { Component, Input } from '@angular/core';\nimport {\n JustifiedInfiniteGrid as VanillaJustifiedInfiniteGrid,\n JustifiedInfiniteGridOptions,\n} from \"@egjs/infinitegrid\";\nimport { TEMPLATE } from '../consts';\n\n\n@Component({\n selector: 'ngx-justified-infinite-grid, [NgxJustifiedInfiniteGrid]',\n template: TEMPLATE,\n})\nexport class NgxJustifiedInfiniteGridComponent extends NgxInfiniteGridComponent\n implements Required<JustifiedInfiniteGridOptions> {\n @Input() columnRange!: Required<JustifiedInfiniteGridOptions>['columnRange'];\n @Input() rowRange!: Required<JustifiedInfiniteGridOptions>['rowRange'];\n @Input() sizeRange!: Required<JustifiedInfiniteGridOptions>['sizeRange'];\n @Input() displayedRow!: Required<JustifiedInfiniteGridOptions>['displayedRow'];\n @Input() isCroppedSize!: Required<JustifiedInfiniteGridOptions>['isCroppedSize'];\n public static GridClass = VanillaJustifiedInfiniteGrid;\n}\n","import {\n NgxInfiniteGridComponent,\n} from '../ngx-infinitegrid.component';\nimport { Component, Input } from '@angular/core';\nimport {\n FrameInfiniteGrid as VanillaFrameInfiniteGrid,\n FrameInfiniteGridOptions,\n} from \"@egjs/infinitegrid\";\nimport { TEMPLATE } from '../consts';\n\n@Component({\n selector: 'ngx-frame-infinite-grid, [NgxFrameInfiniteGrid]',\n template: TEMPLATE,\n})\nexport class NgxFrameInfiniteGridComponent extends NgxInfiniteGridComponent\n implements Required<FrameInfiniteGridOptions> {\n @Input() frame!: Required<FrameInfiniteGridOptions>['frame'];\n @Input() useFrameFill!: Required<FrameInfiniteGridOptions>['useFrameFill'];\n @Input() rectSize!: Required<FrameInfiniteGridOptions>['rectSize'];\n public static GridClass = VanillaFrameInfiniteGrid;\n}\n","import {\n NgxInfiniteGridComponent,\n} from '../ngx-infinitegrid.component';\nimport { Component, Input } from '@angular/core';\nimport {\n PackingInfiniteGrid as VanillaPackingInfiniteGrid,\n PackingInfiniteGridOptions,\n} from \"@egjs/infinitegrid\";\nimport { TEMPLATE } from '../consts';\n\n\n@Component({\n selector: 'ngx-packing-infinite-grid, [NgxPackingInfiniteGrid]',\n template: TEMPLATE,\n})\nexport class NgxPackingInfiniteGridComponent extends NgxInfiniteGridComponent\n implements Required<PackingInfiniteGridOptions> {\n @Input() aspectRatio!: Required<PackingInfiniteGridOptions>['aspectRatio'];\n @Input() sizeWeight!: Required<PackingInfiniteGridOptions>['sizeWeight'];\n @Input() ratioWeight!: Required<PackingInfiniteGridOptions>['ratioWeight'];\n @Input() weightPriority!: Required<PackingInfiniteGridOptions>['weightPriority'];\n public static GridClass = VanillaPackingInfiniteGrid;\n}\n","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { NgxInfiniteGridComponent } from './ngx-infinitegrid.component';\nimport { NgxMasonryInfiniteGridComponent } from './grids/ngx-masonry-infinitegrid.component';\nimport { NgxJustifiedInfiniteGridComponent } from './grids/ngx-justified-infinitegrid.component';\nimport { NgxFrameInfiniteGridComponent } from './grids/ngx-frame-infinitegrid.component';\nimport { NgxPackingInfiniteGridComponent } from './grids/ngx-packing-infinitegrid.component';\n\n\n\n\n@NgModule({\n declarations: [\n NgxInfiniteGridComponent,\n NgxMasonryInfiniteGridComponent,\n NgxJustifiedInfiniteGridComponent,\n NgxFrameInfiniteGridComponent,\n NgxPackingInfiniteGridComponent,\n ],\n imports: [\n CommonModule,\n ],\n exports: [\n NgxInfiniteGridComponent,\n NgxMasonryInfiniteGridComponent,\n NgxJustifiedInfiniteGridComponent,\n NgxFrameInfiniteGridComponent,\n NgxPackingInfiniteGridComponent,\n ],\n})\nexport class NgxInfiniteGridModule { }\n","/** This shouldn't be used outside of the library, required for the Ivy compilation. */\nexport { NgxJustifiedInfiniteGridComponent as ɵNgxJustifiedInfiniteGridComponent } from './lib/grids/ngx-justified-infinitegrid.component';\nexport { NgxFrameInfiniteGridComponent as ɵNgxFrameInfiniteGridComponent } from './lib/grids/ngx-frame-infinitegrid.component';\nexport { NgxPackingInfiniteGridComponent as ɵNgxPackingInfiniteGridComponent } from './lib/grids/ngx-packing-infinitegrid.component';\n","/*\n * Public API Surface of ngx-infinitegrid\n */\n\nexport * from './lib/grids/ngx-masonry-infinitegrid.component';\nexport * from './lib/ngx-infinitegrid.component';\nexport * from './lib/ngx-infinitegrid.module';\n\nexport * from './private_export';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n\nexport {TEMPLATE as ɵb} from './lib/consts';\nexport {NgxInfiniteGridInterface as ɵa} from './lib/ngx-infinitegrid.interface';"],"names":["VanillaMasonryInfiniteGrid","VanillaJustifiedInfiniteGrid","VanillaFrameInfiniteGrid","VanillaPackingInfiniteGrid"],"mappings":"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"}