UNPKG

igniteui-webcomponents-grids

Version:

Ignite UI Web Components grid components.

54 lines (53 loc) 2.36 kB
import { IgCollection } from "igniteui-webcomponents-core"; import { markType } from "igniteui-webcomponents-core"; import { SyncableObservableCollection$2 } from "igniteui-webcomponents-core"; import { PropertyEditorPropertyDescription as PropertyEditorPropertyDescription_internal } from "igniteui-webcomponents-layouts"; import { IgcPropertyEditorPropertyDescriptionComponent as IgcPropertyEditorPropertyDescriptionComponent } from "igniteui-webcomponents-layouts"; export class IgcHorizontalPropertyEditorDataSource extends IgCollection { constructor(list) { super(); if (!IgcPropertyEditorPropertyDescriptionComponent.$type) { IgcPropertyEditorPropertyDescriptionComponent.$type = markType(IgcPropertyEditorPropertyDescriptionComponent, "IgcPropertyEditorPropertyDescriptionComponent"); } if (list) { for (let i = 0; i < list.length; i++) { this.add(list[i]); } } } _createInnerColl() { if (!IgcPropertyEditorPropertyDescriptionComponent.$type) { IgcPropertyEditorPropertyDescriptionComponent.$type = markType(IgcPropertyEditorPropertyDescriptionComponent, "IgcPropertyEditorPropertyDescriptionComponent"); } let coll = new SyncableObservableCollection$2(IgcPropertyEditorPropertyDescriptionComponent.$type, PropertyEditorPropertyDescription_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 IgcPropertyEditorPropertyDescriptionComponent(); if (ext) { if (!int.$type && ext._implementation.setNativeElement) { ext._implementation.setNativeElement(int); } else { ext._implementation = int; } } } return ext; }; return coll; } }