UNPKG

igniteui-react-grids

Version:

Ignite UI React grid components.

54 lines (53 loc) 1.92 kB
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; } }