UNPKG

igniteui-react-grids

Version:

Ignite UI React grid components.

54 lines (53 loc) 2.34 kB
import { IgCollection } from "igniteui-react-core"; import { markType } from "igniteui-react-core"; import { SyncableObservableCollection$2 } from "igniteui-react-core"; import { GridFilterDialogViewModelGroupingLevel as GridFilterDialogViewModelGroupingLevel_internal } from './GridFilterDialogViewModelGroupingLevel'; import { IgrGridFilterDialogViewModelGroupingLevel as IgrGridFilterDialogViewModelGroupingLevel } from './igr-grid-filter-dialog-view-model-grouping-level'; export class IgrGridFilterDialogViewModelGroupingLevelCollection extends IgCollection { constructor(list) { super(); if (!IgrGridFilterDialogViewModelGroupingLevel.$type) { IgrGridFilterDialogViewModelGroupingLevel.$type = markType(IgrGridFilterDialogViewModelGroupingLevel, "IgrGridFilterDialogViewModelGroupingLevel"); } if (list) { for (let i = 0; i < list.length; i++) { this.add(list[i]); } } } _createInnerColl() { if (!IgrGridFilterDialogViewModelGroupingLevel.$type) { IgrGridFilterDialogViewModelGroupingLevel.$type = markType(IgrGridFilterDialogViewModelGroupingLevel, "IgrGridFilterDialogViewModelGroupingLevel"); } let coll = new SyncableObservableCollection$2(IgrGridFilterDialogViewModelGroupingLevel.$type, GridFilterDialogViewModelGroupingLevel_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 = new IgrGridFilterDialogViewModelGroupingLevel(); if (ext) { if (!int.$type && ext._implementation.setNativeElement) { ext._implementation.setNativeElement(int); } else { ext._implementation = int; } } } return ext; }; return coll; } }