From 3a1cf859c5c74159eae3d1a84d7668a3c7fbe1f9 Mon Sep 17 00:00:00 2001 From: ghiscoding Date: Tue, 10 Dec 2024 22:43:32 -0500 Subject: [PATCH] feat: allow using AureliaSlickgrid component w/o grid options --- .../src/custom-elements/aurelia-slickgrid.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/packages/aurelia-slickgrid/src/custom-elements/aurelia-slickgrid.ts b/packages/aurelia-slickgrid/src/custom-elements/aurelia-slickgrid.ts index 9a76189bf..c3caedc5e 100644 --- a/packages/aurelia-slickgrid/src/custom-elements/aurelia-slickgrid.ts +++ b/packages/aurelia-slickgrid/src/custom-elements/aurelia-slickgrid.ts @@ -149,7 +149,7 @@ export class AureliaSlickgridCustomElement { @bindable() dataset: any[] = []; @bindable() datasetHierarchical?: any[] | null; @bindable() gridId = ''; - @bindable() gridOptions!: GridOption; + @bindable() gridOptions: GridOption = {}; constructor( protected readonly aureliaUtilService: AureliaUtilService = resolve(AureliaUtilService), @@ -248,8 +248,8 @@ export class AureliaSlickgridCustomElement { } attached() { - if (!this.gridOptions || !this.columnDefinitions) { - throw new Error('Using `` requires `grid-options.bind` and `column-definitions.bind`, it seems that you might have forgot to provide them since at least of them is undefined.'); + if (!this.columnDefinitions) { + throw new Error('Using `` requires `column-definitions.bind`, it seems that you might have forgot to provide the missing bindable model.'); } this._eventHandler = new SlickEventHandler(); @@ -291,7 +291,7 @@ export class AureliaSlickgridCustomElement { this._eventPubSubService.publish('onBeforeGridCreate', true); // make sure the dataset is initialized (if not it will throw an error that it cannot getLength of null) - this._dataset = this._dataset || this.dataset || []; + this._dataset ||= []; this._currentDatasetLength = this._dataset.length; this.gridOptions = this.mergeGridOptions(this.gridOptions); this._paginationOptions = this.gridOptions?.pagination; @@ -556,7 +556,7 @@ export class AureliaSlickgridCustomElement { } emptyGridContainerElm() { - const gridContainerId = this.gridOptions?.gridContainerId ?? 'grid1'; + const gridContainerId = this.gridOptions?.gridContainerId || 'grid1'; const gridContainerElm = document.querySelector(`#${gridContainerId}`) as HTMLDivElement; emptyElement(gridContainerElm); }