igniteui-react-grids
Version:
Ignite UI React grid components.
54 lines (53 loc) • 1.92 kB
JavaScript
import { IgCollection } from "igniteui-react-core";
import { markType } from "igniteui-react-core";
import { SyncableObservableCollection$2 } from "igniteui-react-core";
import { DataGridColumn as DataGridColumn_internal } from './DataGridColumn';
import { IgrDataGridColumn as IgrDataGridColumn } from './igr-data-grid-column';
export class IgrGridColumnCollection extends IgCollection {
constructor(list) {
super();
if (!IgrDataGridColumn.$type) {
IgrDataGridColumn.$type = markType(IgrDataGridColumn, "IgrDataGridColumn");
}
if (list) {
for (let i = 0; i < list.length; i++) {
this.add(list[i]);
}
}
}
_createInnerColl() {
if (!IgrDataGridColumn.$type) {
IgrDataGridColumn.$type = markType(IgrDataGridColumn, "IgrDataGridColumn");
}
let coll = new SyncableObservableCollection$2(IgrDataGridColumn.$type, DataGridColumn_internal.$type, 0);
coll.compare = (ext, int) => {
let comp = ext;
if (comp._implementation) {
comp = comp._implementation;
}
if (comp.equals) {
return comp.equals(int);
}
return comp === int;
};
coll.createTo = (ext) => {
return ext._implementation;
};
coll.createFrom = (int) => {
let ext = int.externalObject;
if (!ext) {
ext = IgrDataGridColumn._createFromInternal(int);
if (ext) {
if (!int.$type && ext._implementation.setNativeElement) {
ext._implementation.setNativeElement(int);
}
else {
ext._implementation = int;
}
}
}
return ext;
};
return coll;
}
}