@egjs/ngx-infinitegrid 4.10.0-beta.0 → 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.
- package/esm2020/egjs-ngx-infinitegrid.mjs +5 -0
- package/esm2020/lib/consts.mjs +22 -0
- package/esm2020/lib/grids/ngx-frame-infinitegrid.component.mjs +25 -0
- package/esm2020/lib/grids/ngx-justified-infinitegrid.component.mjs +29 -0
- package/esm2020/lib/grids/ngx-masonry-infinitegrid.component.mjs +31 -0
- package/esm2020/lib/grids/ngx-packing-infinitegrid.component.mjs +27 -0
- package/esm2020/lib/ngx-infinitegrid.component.mjs +232 -0
- package/esm2020/lib/ngx-infinitegrid.module.mjs +44 -0
- package/{esm2015/lib/types.js → esm2020/lib/types.mjs} +1 -1
- package/esm2020/private_export.mjs +5 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +2 -1
- package/fesm2015/egjs-ngx-infinitegrid.mjs +388 -0
- package/fesm2015/egjs-ngx-infinitegrid.mjs.map +1 -0
- package/fesm2020/egjs-ngx-infinitegrid.mjs +398 -0
- package/fesm2020/egjs-ngx-infinitegrid.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/consts.d.ts +1 -1
- package/lib/grids/ngx-frame-infinitegrid.component.d.ts +3 -0
- package/lib/grids/ngx-justified-infinitegrid.component.d.ts +3 -0
- package/lib/grids/ngx-masonry-infinitegrid.component.d.ts +3 -0
- package/lib/grids/ngx-packing-infinitegrid.component.d.ts +3 -0
- package/lib/ngx-infinitegrid.component.d.ts +5 -1
- package/lib/ngx-infinitegrid.module.d.ts +10 -0
- package/lib/types.d.ts +1 -0
- package/package.json +22 -14
- package/private_export.d.ts +4 -0
- package/public-api.d.ts +1 -0
- package/bundles/egjs-ngx-infinitegrid.umd.js +0 -662
- package/bundles/egjs-ngx-infinitegrid.umd.js.map +0 -1
- package/bundles/egjs-ngx-infinitegrid.umd.min.js +0 -2
- package/bundles/egjs-ngx-infinitegrid.umd.min.js.map +0 -1
- package/egjs-ngx-infinitegrid.d.ts +0 -9
- package/egjs-ngx-infinitegrid.metadata.json +0 -1
- package/esm2015/egjs-ngx-infinitegrid.js +0 -10
- package/esm2015/lib/consts.js +0 -25
- package/esm2015/lib/grids/ngx-frame-infinitegrid.component.js +0 -19
- package/esm2015/lib/grids/ngx-justified-infinitegrid.component.js +0 -21
- package/esm2015/lib/grids/ngx-masonry-infinitegrid.component.js +0 -22
- package/esm2015/lib/grids/ngx-packing-infinitegrid.component.js +0 -20
- package/esm2015/lib/ngx-infinitegrid.component.js +0 -187
- package/esm2015/lib/ngx-infinitegrid.module.js +0 -31
- package/fesm2015/egjs-ngx-infinitegrid.js +0 -319
- package/fesm2015/egjs-ngx-infinitegrid.js.map +0 -1
- /package/{esm2015/lib/ngx-infinitegrid.interface.js → esm2020/lib/ngx-infinitegrid.interface.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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWluZmluaXRlZ3JpZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaW5maW5pdGVncmlkL3NyYy9saWIvbmd4LWluZmluaXRlZ3JpZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNGLE9BQU8sRUFHTixTQUFTLEVBQ1QsVUFBVSxFQUNWLFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxFQUNOLFdBQVcsRUFDWCxNQUFNLEVBQ04sTUFBTSxFQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQ0wsaUJBQWlCLEVBS2pCLG1CQUFtQixFQUNuQixtQkFBbUIsRUFNbkIsUUFBUSxHQUNULE1BQU0sb0JBQW9CLENBQUM7QUFDNUIsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFVeEUsTUFBTSxPQUFPLHdCQUNYLFNBQVEsd0JBQXdCO0lBc0RoQyxZQUNZLFVBQW1DLEVBQ2hCLFdBQW1CLEVBQ3hDLE9BQWU7UUFFdkIsS0FBSyxFQUFFLENBQUM7UUFKRSxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQUNoQixnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUN4QyxZQUFPLEdBQVAsT0FBTyxDQUFRO1FBbEJoQixVQUFLLEdBQWtDLEVBQUUsQ0FBQztRQUMxQyxZQUFPLEdBQW9DLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkUsWUFBTyxHQUFvQyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksRUFB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WUF4RnJCLE1BQU07Ozs4QkFxQ0wsS0FBSzt1QkFDTCxLQUFLO3dCQUNMLEtBQUs7MkJBQ0wsS0FBSzt3QkFDTCxLQUFLO3lCQUNMLEtBQUs7eUJBQ0wsS0FBSzt5QkFDTCxLQUFLOzBCQUNMLEtBQUs7NkJBQ0wsS0FBSztrQkFDTCxLQUFLOzhCQUNMLEtBQUs7NkJBQ0wsS0FBSztnQ0FDTCxLQUFLO3lCQUNMLEtBQUs7cUJBQ0wsS0FBSzsyQkFDTCxLQUFLO3FDQUNMLEtBQUs7a0NBQ0wsS0FBSzsrQkFDTCxLQUFLO21DQUNMLEtBQUs7dUNBQ0wsS0FBSzs0QkFDTCxLQUFLOzBCQUNMLEtBQUs7NkJBQ0wsS0FBSztnQ0FDTCxLQUFLOzhCQUNMLEtBQUs7OEJBQ0wsS0FBSztpQ0FDTCxLQUFLOzZCQUVMLEtBQUs7eUJBQ0wsS0FBSztxQkFDTCxLQUFLOzZCQUNMLEtBQUs7b0JBQ0wsS0FBSztzQkFDTCxLQUFLO3NCQUNMLEtBQUs7NkJBQ0wsTUFBTTsyQkFDTixNQUFNOzJCQUNOLE1BQU07NEJBQ04sTUFBTTs2QkFDTixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBlZ2pzLWluZmluaXRlZ3JpZFxuICogQ29weXJpZ2h0IChjKSAyMDIxLXByZXNlbnQgTkFWRVIgQ29ycC5cbiAqIE1JVCBsaWNlbnNlXG4gKi9cbiBpbXBvcnQge1xuICBBZnRlclZpZXdDaGVja2VkLFxuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT25EZXN0cm95LFxuICBPdXRwdXQsXG4gIFBMQVRGT1JNX0lELFxuICBJbmplY3QsXG4gIE5nWm9uZVxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGlzUGxhdGZvcm1TZXJ2ZXIgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgZnJvbUV2ZW50LCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7XG4gIGdldFJlbmRlcmluZ0l0ZW1zLFxuICBJbmZpbml0ZUdyaWRGdW5jdGlvbixcbiAgSW5maW5pdGVHcmlkSXRlbSxcbiAgSW5maW5pdGVHcmlkSXRlbUluZm8sXG4gIEluZmluaXRlR3JpZE9wdGlvbnMsXG4gIElORklOSVRFR1JJRF9FVkVOVFMsXG4gIG1vdW50UmVuZGVyaW5nSXRlbXMsXG4gIE9uQ29udGVudEVycm9yLFxuICBPblJlbmRlckNvbXBsZXRlLFxuICBPblJlcXVlc3RBcHBlbmQsXG4gIE9uUmVxdWVzdFByZXBlbmQsXG4gIE9uQ2hhbmdlU2Nyb2xsLFxuICBSZW5kZXJlcixcbn0gZnJvbSAnQGVnanMvaW5maW5pdGVncmlkJztcbmltcG9ydCB7IE5neEluZmluaXRlR3JpZEludGVyZmFjZSB9IGZyb20gJy4vbmd4LWluZmluaXRlZ3JpZC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgTmd4SW5maW5pdGVHcmlkUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWluZmluaXRlLWdyaWQsIFtOZ3hJbmZpbml0ZUdyaWRdJyxcbiAgdGVtcGxhdGU6ICc8c2xvdD48L3Nsb3Q+JyxcbiAgc3R5bGVzOiBbXG4gICAgJzpob3N0IHsgZGlzcGxheTogYmxvY2sgfScsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIE5neEluZmluaXRlR3JpZENvbXBvbmVudFxuICBleHRlbmRzIE5neEluZmluaXRlR3JpZEludGVyZmFjZVxuICBpbXBsZW1lbnRzIFJlcXVpcmVkPEluZmluaXRlR3JpZE9wdGlvbnM+LFxuICBOZ3hJbmZpbml0ZUdyaWRQcm9wcyxcbiAgQWZ0ZXJWaWV3SW5pdCwgQWZ0ZXJWaWV3Q2hlY2tlZCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICBwdWJsaWMgc3RhdGljIEdyaWRDbGFzczogSW5maW5pdGVHcmlkRnVuY3Rpb24gfCBudWxsID0gbnVsbDtcbiAgQElucHV0KCkgZ3JpZENvbnN0cnVjdG9yITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2dyaWRDb25zdHJ1Y3RvciddO1xuICBASW5wdXQoKSByZW5kZXJlciE6IE5neEluZmluaXRlR3JpZFByb3BzWydyZW5kZXJlciddO1xuICBASW5wdXQoKSBjb250YWluZXIhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snY29udGFpbmVyJ107XG4gIEBJbnB1dCgpIGNvbnRhaW5lclRhZyE6IE5neEluZmluaXRlR3JpZFByb3BzWydjb250YWluZXJUYWcnXTtcbiAgQElucHV0KCkgdGhyZXNob2xkITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3RocmVzaG9sZCddO1xuICBASW5wdXQoKSB1c2VSZWN5Y2xlITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3VzZVJlY3ljbGUnXTtcbiAgQElucHV0KCkgaG9yaXpvbnRhbCE6IE5neEluZmluaXRlR3JpZFByb3BzWydob3Jpem9udGFsJ107XG4gIEBJbnB1dCgpIHBlcmNlbnRhZ2UhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sncGVyY2VudGFnZSddO1xuICBASW5wdXQoKSBpc0VxdWFsU2l6ZSE6IE5neEluZmluaXRlR3JpZFByb3BzWydpc0VxdWFsU2l6ZSddO1xuICBASW5wdXQoKSBpc0NvbnN0YW50U2l6ZSE6IE5neEluZmluaXRlR3JpZFByb3BzWydpc0NvbnN0YW50U2l6ZSddO1xuICBASW5wdXQoKSBnYXAhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snZ2FwJ107XG4gIEBJbnB1dCgpIGF0dHJpYnV0ZVByZWZpeCE6IE5neEluZmluaXRlR3JpZFByb3BzWydhdHRyaWJ1dGVQcmVmaXgnXTtcbiAgQElucHV0KCkgcmVzaXplRGVib3VuY2UhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sncmVzaXplRGVib3VuY2UnXTtcbiAgQElucHV0KCkgbWF4UmVzaXplRGVib3VuY2UhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snbWF4UmVzaXplRGVib3VuY2UnXTtcbiAgQElucHV0KCkgYXV0b1Jlc2l6ZSE6IE5neEluZmluaXRlR3JpZFByb3BzWydhdXRvUmVzaXplJ107XG4gIEBJbnB1dCgpIHVzZUZpdCE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VGaXQnXTtcbiAgQElucHV0KCkgdXNlVHJhbnNmb3JtITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3VzZVRyYW5zZm9ybSddO1xuICBASW5wdXQoKSByZW5kZXJPblByb3BlcnR5Q2hhbmdlITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3JlbmRlck9uUHJvcGVydHlDaGFuZ2UnXTtcbiAgQElucHV0KCkgcHJlc2VydmVVSU9uRGVzdHJveSE6IE5neEluZmluaXRlR3JpZFByb3BzWydwcmVzZXJ2ZVVJT25EZXN0cm95J107XG4gIEBJbnB1dCgpIGRlZmF1bHREaXJlY3Rpb24hOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snZGVmYXVsdERpcmVjdGlvbiddO1xuICBASW5wdXQoKSBleHRlcm5hbEl0ZW1SZW5kZXJlciE6IE5neEluZmluaXRlR3JpZFByb3BzWydleHRlcm5hbEl0ZW1SZW5kZXJlciddO1xuICBASW5wdXQoKSBleHRlcm5hbENvbnRhaW5lck1hbmFnZXIhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snZXh0ZXJuYWxDb250YWluZXJNYW5hZ2VyJ107XG4gIEBJbnB1dCgpIG91dGxpbmVMZW5ndGghOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snb3V0bGluZUxlbmd0aCddO1xuICBASW5wdXQoKSBvdXRsaW5lU2l6ZSE6IE5neEluZmluaXRlR3JpZFByb3BzWydvdXRsaW5lU2l6ZSddO1xuICBASW5wdXQoKSB1c2VSb3VuZGVkU2l6ZSE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VSb3VuZGVkU2l6ZSddO1xuICBASW5wdXQoKSB1c2VSZXNpemVPYnNlcnZlciE6IE5neEluZmluaXRlR3JpZFByb3BzWyd1c2VSZXNpemVPYnNlcnZlciddO1xuICBASW5wdXQoKSBvYnNlcnZlQ2hpbGRyZW4hOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snb2JzZXJ2ZUNoaWxkcmVuJ107XG4gIEBJbnB1dCgpIHNjcm9sbENvbnRhaW5lciE6IE5neEluZmluaXRlR3JpZFByb3BzWydzY3JvbGxDb250YWluZXInXTtcbiAgQElucHV0KCkgYXBwbGllZEl0ZW1DaGVja2VyITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ2FwcGxpZWRJdGVtQ2hlY2tlciddO1xuXG4gIEBJbnB1dCgpIHVzZVBsYWNlaG9sZGVyITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3VzZUZpcnN0UmVuZGVyJ107XG4gIEBJbnB1dCgpIHVzZUxvYWRpbmchOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sndXNlTG9hZGluZyddO1xuICBASW5wdXQoKSBzdGF0dXMhOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snc3RhdHVzJ107XG4gIEBJbnB1dCgpIHVzZUZpcnN0UmVuZGVyITogTmd4SW5maW5pdGVHcmlkUHJvcHNbJ3VzZUZpcnN0UmVuZGVyJ107XG4gIEBJbnB1dCgpIGl0ZW1zOiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1snaXRlbXMnXSA9IFtdO1xuICBASW5wdXQoKSB0cmFja0J5OiBOZ3hJbmZpbml0ZUdyaWRQcm9wc1sndHJhY2tCeSddID0gKChfLCBpdGVtKSA9PiBpdGVtLmtleSk7XG4gIEBJbnB1dCgpIGdyb3VwQnk6IE5neEluZmluaXRlR3JpZFByb3BzWydncm91cEJ5J10gPSAoKF8sIGl0ZW0pID0+IGl0ZW0uZ3JvdXBLZXkpO1xuICBAT3V0cHV0KCkgcmVuZGVyQ29tcGxldGUhOiBFdmVudEVtaXR0ZXI8T25SZW5kZXJDb21wbGV0ZT47XG4gIEBPdXRwdXQoKSBjb250ZW50RXJyb3IhOiBFdmVudEVtaXR0ZXI8T25Db250ZW50RXJyb3I+O1xuICBAT3V0cHV0KCkgY2hhbmdlU2Nyb2xsITogRXZlbnRFbWl0dGVyPE9uQ2hhbmdlU2Nyb2xsPjtcbiAgQE91dHB1dCgpIHJlcXVlc3RBcHBlbmQhOiBFdmVudEVtaXR0ZXI8T25SZXF1ZXN0QXBwZW5kPjtcbiAgQE91dHB1dCgpIHJlcXVlc3RQcmVwZW5kITogRXZlbnRFbWl0dGVyPE9uUmVxdWVzdFByZXBlbmQ+O1xuICBwdWJsaWMgdmlzaWJsZUl0ZW1zOiBJbmZpbml0ZUdyaWRJdGVtW10gPSBbXTtcblxuICBwcml2YXRlIF9yZW5kZXJlciA9IG5ldyBSZW5kZXJlcigpO1xuICBwcml2YXRlIF9pc0NoYW5nZSA9IGZhbHNlO1xuXG4gIHByaXZhdGUgX2Rlc3Ryb3kkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgQEluamVjdChQTEFURk9STV9JRCkgcHJpdmF0ZSBfcGxhdGZvcm1JZDogc3RyaW5nLFxuICAgIHByaXZhdGUgX25nWm9uZTogTmdab25lXG4gICkge1xuICAgIHN1cGVyKCk7XG5cbiAgICBmb3IgKGNvbnN0IG5hbWUgaW4gSU5GSU5JVEVHUklEX0VWRU5UUykge1xuICAgICAgY29uc3QgZXZlbnROYW1lID0gKElORklOSVRFR1JJRF9FVkVOVFMgYXMgYW55KVtuYW1lXTtcbiAgICAgICh0aGlzIGFzIGFueSlbZXZlbnROYW1lXSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICB9XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLl91cGRhdGVWaXNpYmxlQ2hpbGRyZW4oKTtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKCkge1xuICAgIHRoaXMuX2lzQ2hhbmdlID0gdHJ1ZTtcbiAgICB0aGlzLl91cGRhdGVWaXNpYmxlQ2hpbGRyZW4oKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICBpZiAoaXNQbGF0Zm9ybVNlcnZlcih0aGlzLl9wbGF0Zm9ybUlkKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IEdyaWRDbGFzcyA9ICh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQpLkdyaWRDbGFzcztcbiAgICBjb25zdCBkZWZhdWx0T3B0aW9ucyA9IEdyaWRDbGFzcyEuZGVmYXVsdE9wdGlvbnM7XG4gICAgY29uc3Qgb3B0aW9uczogUGFydGlhbDxJbmZpbml0ZUdyaWRPcHRpb25zPiA9IHt9O1xuXG4gICAgZm9yIChjb25zdCBuYW1lIGluIGRlZmF1bHRPcHRpb25zKSB7XG4gICAgICBpZiAobmFtZSBpbiB0aGlzICYmIHR5cGVvZiAodGhpcyBhcyBhbnkpW25hbWVdICE9PSBcInVuZGVmaW5lZFwiKSB7XG4gICAgICAgIChvcHRpb25zIGFzIGFueSlbbmFtZV0gPSAodGhpcyBhcyBhbnkpW25hbWVdO1xuICAgICAgfVxuICAgIH1cblxuICAgIG9wdGlvbnMucmVuZGVyZXIgPSB0aGlzLl9yZW5kZXJlcjtcblxuICAgIC8vIFRoZSBgSW5maW5pdGVHcmlkYCBzZXQgdXBzIGBzY3JvbGxgIGFuZCBgcmVzaXplYCBldmVudHMgdGhyb3VnaCBgU2Nyb2xsTWFuYWdlcmBcbiAgICAvLyBhbmQgYFJlc2l6ZVdhdGNoZXJgLiBUaGVzZSBldmVudHMgZm9yY2UgQW5ndWxhciB0byBydW4gY2hhbmdlIGRldGVjdGlvbiB3aGVuZXZlclxuICAgIC8vIGRpc3BhdGNoZWQ7IHRoaXMgaGFwcGVucyB0b28gb2Z0ZW4uXG4gICAgY29uc3QgZ3JpZCA9IHRoaXMuX25nWm9uZS5ydW5PdXRzaWRlQW5ndWxhcihcbiAgICAgICgpID0+IG5ldyBHcmlkQ2xhc3MhKHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCBvcHRpb25zKVxuICAgICk7XG5cbiAgICBmb3IgKGNvbnN0IG5hbWUgaW4gSU5GSU5JVEVHUklEX0VWRU5UUykge1xuICAgICAgY29uc3QgZXZlbnROYW1lID0gKElORklOSVRFR1JJRF9FVkVOVFMgYXMgYW55KVtuYW1lXTtcblxuICAgICAgZnJvbUV2ZW50KGdyaWQsIGV2ZW50TmFtZSlcbiAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuX2Rlc3Ryb3kkKSlcbiAgICAgICAgLnN1YnNjcmliZSgoZXZlbnQpID0+IHtcbiAgICAgICAgICBjb25zdCBlbWl0dGVyID0gKHRoaXMgYXMgYW55KVtldmVudE5hbWVdO1xuICAgICAgICAgIGlmIChlbWl0dGVyICYmIGVtaXR0ZXIub2JzZXJ2ZXJzLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgIHRoaXMuX25nWm9uZS5ydW4oKCkgPT4gZW1pdHRlci5lbWl0KGV2ZW50KSk7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICB0aGlzLnZhbmlsbGFHcmlkID0gZ3JpZDtcblxuICAgIGZyb21FdmVudCh0aGlzLl9yZW5kZXJlciwgJ3JlcXVlc3RVcGRhdGUnKVxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuX2Rlc3Ryb3kkKSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLl9uZ1pvbmUucnVuKCgpID0+IHtcbiAgICAgICAgICB0aGlzLl9pc0NoYW5nZSA9IHRydWU7XG4gICAgICAgICAgdGhpcy5fdXBkYXRlVmlzaWJsZUNoaWxkcmVuKCk7XG4gICAgICAgIH0pO1xuICAgICAgfSk7XG5cbiAgICBtb3VudFJlbmRlcmluZ0l0ZW1zKHRoaXMuX2dldEl0ZW1JbmZvcygpLCB7XG4gICAgICBncmlkLFxuICAgICAgdXNlRmlyc3RSZW5kZXI6IHRoaXMudXNlRmlyc3RSZW5kZXIsXG4gICAgICB1c2VMb2FkaW5nOiB0aGlzLnVzZUxvYWRpbmcsXG4gICAgICB1c2VQbGFjZWhvbGRlcjogdGhpcy51c2VQbGFjZWhvbGRlcixcbiAgICAgIGhvcml6b250YWw6IHRoaXMuaG9yaXpvbnRhbCxcbiAgICAgIHN0YXR1czogdGhpcy5zdGF0dXMsXG4gICAgfSk7XG4gICAgdGhpcy5fcmVuZGVyZXIudXBkYXRlZCgpO1xuICB9XG5cbiAgbmdBZnRlclZpZXdDaGVja2VkKCkge1xuICAgIGlmICghdGhpcy5faXNDaGFuZ2UgfHwgIXRoaXMudmFuaWxsYUdyaWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgY29uc3QgY2hpbGRyZW4gPSBbXS5zbGljZS5jYWxsKHRoaXMuZ2V0Q29udGFpbmVyRWxlbWVudCgpLmNoaWxkcmVuKTtcblxuICAgIGlmICh0aGlzLnZpc2libGVJdGVtcy5sZW5ndGggIT09IGNoaWxkcmVuLmxlbmd0aCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aGlzLl9pc0NoYW5nZSA9IGZhbHNlO1xuICAgIGNvbnN0IEdyaWRDbGFzcyA9ICh0aGlzLmNvbnN0cnVjdG9yIGFzIHR5cGVvZiBOZ3hJbmZpbml0ZUdyaWRDb21wb25lbnQpLkdyaWRDbGFzcztcbiAgICBjb25zdCBwcm9wZXJ0eVR5cGVzID0gR3JpZENsYXNzIS5wcm9wZXJ0eVR5cGVzO1xuICAgIGNvbnN0IGdyaWQgPSB0aGlzLnZhbmlsbGFHcmlkO1xuXG4gICAgZm9yIChjb25zdCBuYW1lIGluIHByb3BlcnR5VHlwZXMpIHtcbiAgICAgIGlmIChuYW1lIGluIHRoaXMpIHtcbiAgICAgICAgKGdyaWQgYXMgYW55KVtuYW1lXSA9ICh0aGlzIGFzIGFueSlbbmFtZV07XG4gICAgICB9XG4gICAgfVxuXG4gICAgdGhpcy5fcmVuZGVyZXIudXBkYXRlZChjaGlsZHJlbik7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLl9kZXN0cm95JC5uZXh0KCk7XG4gICAgdGhpcy52YW5pbGxhR3JpZD8uZGVzdHJveSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfZ2V0SXRlbUluZm9zKCk6IEluZmluaXRlR3JpZEl0ZW1JbmZvW10ge1xuICAgIGNvbnN0IGl0ZW1zID0gdGhpcy5pdGVtcztcbiAgICBjb25zdCB0cmFja0J5ID0gdGhpcy50cmFja0J5O1xuICAgIGNvbnN0IGdyb3VwQnkgPSB0aGlzLmdyb3VwQnk7XG5cbiAgICByZXR1cm4gaXRlbXMubWFwKChpdGVtLCBpKSA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBncm91cEtleTogZ3JvdXBCeShpLCBpdGVtKSxcbiAgICAgICAga2V5OiB0cmFja0J5KGksIGl0ZW0pLFxuICAgICAgICBkYXRhOiBpdGVtLFxuICAgICAgfTtcbiAgICB9KTtcbiAgfVxuXG4gIHByaXZhdGUgX3VwZGF0ZVZpc2libGVDaGlsZHJlbigpIHtcbiAgICB0aGlzLnZpc2libGVJdGVtcyA9IGdldFJlbmRlcmluZ0l0ZW1zKHRoaXMuX2dldEl0ZW1JbmZvcygpLCB7XG4gICAgICBncmlkOiB0aGlzLnZhbmlsbGFHcmlkLFxuICAgICAgdXNlRmlyc3RSZW5kZXI6IHRoaXMudXNlRmlyc3RSZW5kZXIsXG4gICAgICB1c2VMb2FkaW5nOiB0aGlzLnVzZUxvYWRpbmcsXG4gICAgICB1c2VQbGFjZWhvbGRlcjogdGhpcy51c2VQbGFjZWhvbGRlcixcbiAgICAgIGhvcml6b250YWw6IHRoaXMuaG9yaXpvbnRhbCxcbiAgICAgIHN0YXR1czogdGhpcy5zdGF0dXMsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -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,319 +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
|
-
<ng-template [ngIf]="container === true" [ngIfElse]="noContainer">
|
|
200
|
-
<div #containerRef>
|
|
201
|
-
<ng-container *ngTemplateOutlet="content"></ng-container>
|
|
202
|
-
</div>
|
|
203
|
-
</ng-template>
|
|
204
|
-
<ng-template #noContainer>
|
|
205
|
-
<ng-container *ngTemplateOutlet="content"></ng-container>
|
|
206
|
-
</ng-template>
|
|
207
|
-
</ng-template>
|
|
208
|
-
|
|
209
|
-
<ng-template [ngIf]="elementRef.nativeElement.tagName.indexOf('NGX-') === 0" [ngIfElse]="noWrapper">
|
|
210
|
-
<div #wrapperRef>
|
|
211
|
-
<ng-container *ngTemplateOutlet="viewer"></ng-container>
|
|
212
|
-
</div>
|
|
213
|
-
</ng-template>
|
|
214
|
-
|
|
215
|
-
<ng-template #noWrapper>
|
|
216
|
-
<ng-container *ngTemplateOutlet="viewer"></ng-container>
|
|
217
|
-
</ng-template>
|
|
218
|
-
`;
|
|
219
|
-
|
|
220
|
-
class NgxMasonryInfiniteGridComponent extends NgxInfiniteGridComponent {
|
|
221
|
-
}
|
|
222
|
-
NgxMasonryInfiniteGridComponent.GridClass = MasonryInfiniteGrid;
|
|
223
|
-
NgxMasonryInfiniteGridComponent.decorators = [
|
|
224
|
-
{ type: Component, args: [{
|
|
225
|
-
selector: 'ngx-masonry-infinite-grid, [NgxMasonryInfiniteGrid]',
|
|
226
|
-
template: TEMPLATE
|
|
227
|
-
},] }
|
|
228
|
-
];
|
|
229
|
-
NgxMasonryInfiniteGridComponent.propDecorators = {
|
|
230
|
-
column: [{ type: Input }],
|
|
231
|
-
columnSize: [{ type: Input }],
|
|
232
|
-
columnSizeRatio: [{ type: Input }],
|
|
233
|
-
align: [{ type: Input }],
|
|
234
|
-
columnCalculationThreshold: [{ type: Input }],
|
|
235
|
-
maxStretchColumnSize: [{ type: Input }]
|
|
236
|
-
};
|
|
237
|
-
|
|
238
|
-
class NgxJustifiedInfiniteGridComponent extends NgxInfiniteGridComponent {
|
|
239
|
-
}
|
|
240
|
-
NgxJustifiedInfiniteGridComponent.GridClass = JustifiedInfiniteGrid;
|
|
241
|
-
NgxJustifiedInfiniteGridComponent.decorators = [
|
|
242
|
-
{ type: Component, args: [{
|
|
243
|
-
selector: 'ngx-justified-infinite-grid, [NgxJustifiedInfiniteGrid]',
|
|
244
|
-
template: TEMPLATE
|
|
245
|
-
},] }
|
|
246
|
-
];
|
|
247
|
-
NgxJustifiedInfiniteGridComponent.propDecorators = {
|
|
248
|
-
columnRange: [{ type: Input }],
|
|
249
|
-
rowRange: [{ type: Input }],
|
|
250
|
-
sizeRange: [{ type: Input }],
|
|
251
|
-
displayedRow: [{ type: Input }],
|
|
252
|
-
isCroppedSize: [{ type: Input }]
|
|
253
|
-
};
|
|
254
|
-
|
|
255
|
-
class NgxFrameInfiniteGridComponent extends NgxInfiniteGridComponent {
|
|
256
|
-
}
|
|
257
|
-
NgxFrameInfiniteGridComponent.GridClass = FrameInfiniteGrid;
|
|
258
|
-
NgxFrameInfiniteGridComponent.decorators = [
|
|
259
|
-
{ type: Component, args: [{
|
|
260
|
-
selector: 'ngx-frame-infinite-grid, [NgxFrameInfiniteGrid]',
|
|
261
|
-
template: TEMPLATE
|
|
262
|
-
},] }
|
|
263
|
-
];
|
|
264
|
-
NgxFrameInfiniteGridComponent.propDecorators = {
|
|
265
|
-
frame: [{ type: Input }],
|
|
266
|
-
useFrameFill: [{ type: Input }],
|
|
267
|
-
rectSize: [{ type: Input }]
|
|
268
|
-
};
|
|
269
|
-
|
|
270
|
-
class NgxPackingInfiniteGridComponent extends NgxInfiniteGridComponent {
|
|
271
|
-
}
|
|
272
|
-
NgxPackingInfiniteGridComponent.GridClass = PackingInfiniteGrid;
|
|
273
|
-
NgxPackingInfiniteGridComponent.decorators = [
|
|
274
|
-
{ type: Component, args: [{
|
|
275
|
-
selector: 'ngx-packing-infinite-grid, [NgxPackingInfiniteGrid]',
|
|
276
|
-
template: TEMPLATE
|
|
277
|
-
},] }
|
|
278
|
-
];
|
|
279
|
-
NgxPackingInfiniteGridComponent.propDecorators = {
|
|
280
|
-
aspectRatio: [{ type: Input }],
|
|
281
|
-
sizeWeight: [{ type: Input }],
|
|
282
|
-
ratioWeight: [{ type: Input }],
|
|
283
|
-
weightPriority: [{ type: Input }]
|
|
284
|
-
};
|
|
285
|
-
|
|
286
|
-
class NgxInfiniteGridModule {
|
|
287
|
-
}
|
|
288
|
-
NgxInfiniteGridModule.decorators = [
|
|
289
|
-
{ type: NgModule, args: [{
|
|
290
|
-
declarations: [
|
|
291
|
-
NgxInfiniteGridComponent,
|
|
292
|
-
NgxMasonryInfiniteGridComponent,
|
|
293
|
-
NgxJustifiedInfiniteGridComponent,
|
|
294
|
-
NgxFrameInfiniteGridComponent,
|
|
295
|
-
NgxPackingInfiniteGridComponent,
|
|
296
|
-
],
|
|
297
|
-
imports: [
|
|
298
|
-
CommonModule,
|
|
299
|
-
],
|
|
300
|
-
exports: [
|
|
301
|
-
NgxInfiniteGridComponent,
|
|
302
|
-
NgxMasonryInfiniteGridComponent,
|
|
303
|
-
NgxJustifiedInfiniteGridComponent,
|
|
304
|
-
NgxFrameInfiniteGridComponent,
|
|
305
|
-
NgxPackingInfiniteGridComponent,
|
|
306
|
-
],
|
|
307
|
-
},] }
|
|
308
|
-
];
|
|
309
|
-
|
|
310
|
-
/*
|
|
311
|
-
* Public API Surface of ngx-infinitegrid
|
|
312
|
-
*/
|
|
313
|
-
|
|
314
|
-
/**
|
|
315
|
-
* Generated bundle index. Do not edit.
|
|
316
|
-
*/
|
|
317
|
-
|
|
318
|
-
export { NgxInfiniteGridComponent, NgxInfiniteGridModule, NgxMasonryInfiniteGridComponent, NgxInfiniteGridInterface as ɵa, TEMPLATE as ɵb, NgxJustifiedInfiniteGridComponent as ɵc, NgxFrameInfiniteGridComponent as ɵd, NgxPackingInfiniteGridComponent as ɵe };
|
|
319
|
-
//# 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/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 protected 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 <ng-template [ngIf]=\"container === true\" [ngIfElse]=\"noContainer\">\n <div #containerRef>\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n </ng-template>\n <ng-template #noContainer>\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-template>\n</ng-template>\n\n<ng-template [ngIf]=\"elementRef.nativeElement.tagName.indexOf('NGX-') === 0\" [ngIfElse]=\"noWrapper\">\n <div #wrapperRef>\n <ng-container *ngTemplateOutlet=\"viewer\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #noWrapper>\n <ng-container *ngTemplateOutlet=\"viewer\"></ng-container>\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 styles: [],\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 styles: [],\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\n@Component({\n selector: 'ngx-frame-infinite-grid, [NgxFrameInfiniteGrid]',\n template: TEMPLATE,\n styles: [],\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 styles: [],\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","/*\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","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n\nexport {TEMPLATE as ɵb} from './lib/consts';\nexport {NgxFrameInfiniteGridComponent as ɵd} from './lib/grids/ngx-frame-infinitegrid.component';\nexport {NgxJustifiedInfiniteGridComponent as ɵc} from './lib/grids/ngx-justified-infinitegrid.component';\nexport {NgxPackingInfiniteGridComponent as ɵe} from './lib/grids/ngx-packing-infinitegrid.component';\nexport {NgxInfiniteGridInterface as ɵa} from './lib/ngx-infinitegrid.interface';"],"names":["VanillaMasonryInfiniteGrid","VanillaJustifiedInfiniteGrid","VanillaFrameInfiniteGrid","VanillaPackingInfiniteGrid"],"mappings":"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"}
|
/package/{esm2015/lib/ngx-infinitegrid.interface.js → esm2020/lib/ngx-infinitegrid.interface.mjs}
RENAMED
|
File without changes
|