verben-ng-ui 0.3.0 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/card-data-view/card-data-view.component.mjs +3 -3
- package/esm2022/lib/components/data-table/data-table.component.mjs +8 -4
- package/esm2022/lib/components/data-view/data-view.component.mjs +6 -6
- package/fesm2022/verben-ng-ui.mjs +12 -7
- package/fesm2022/verben-ng-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -98,11 +98,11 @@ export class CardDataViewComponent {
|
|
|
98
98
|
this.loadMoreClick.emit();
|
|
99
99
|
}
|
|
100
100
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: CardDataViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: CardDataViewComponent, selector: "verben-card-data-view", inputs: { pd: "pd", mg: "mg", lHeight: "lHeight", rHeight: "rHeight", rWidth: "rWidth", lWidth: "lWidth", textColor: "textColor", lbgColor: "lbgColor", rbgColor: "rbgColor", border: "border", display: "display", borderRadius: "borderRadius", activeCss: "activeCss", inActiveCss: "inActiveCss", displayAsRow: "displayAsRow", cardDataList: "cardDataList", dataId: "dataId", totalRecords: "totalRecords", footer: "footer", noOfVisibleChildren: "noOfVisibleChildren", onItemClick: "onItemClick", onCardChildClick: "onCardChildClick" }, outputs: { loadMoreClick: "loadMoreClick" }, queries: [{ propertyName: "rightContent", first: true, predicate: RightCardDataViewComponent, descendants: true }, { propertyName: "card", first: true, predicate: ["card"], descendants: true }], ngImport: i0, template: "<div #main class=\"
|
|
101
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: CardDataViewComponent, selector: "verben-card-data-view", inputs: { pd: "pd", mg: "mg", lHeight: "lHeight", rHeight: "rHeight", rWidth: "rWidth", lWidth: "lWidth", textColor: "textColor", lbgColor: "lbgColor", rbgColor: "rbgColor", border: "border", display: "display", borderRadius: "borderRadius", activeCss: "activeCss", inActiveCss: "inActiveCss", displayAsRow: "displayAsRow", cardDataList: "cardDataList", dataId: "dataId", totalRecords: "totalRecords", footer: "footer", noOfVisibleChildren: "noOfVisibleChildren", onItemClick: "onItemClick", onCardChildClick: "onCardChildClick" }, outputs: { loadMoreClick: "loadMoreClick" }, queries: [{ propertyName: "rightContent", first: true, predicate: RightCardDataViewComponent, descendants: true }, { propertyName: "card", first: true, predicate: ["card"], descendants: true }], ngImport: i0, template: "<div #main class=\"flex-col\" [style.display]=\"'flex'\">\n <!-- Header -->\n <ng-container ngProjectAs=\"verben-card-data-view-header\">\n <ng-content select='verben-card-data-view-header'></ng-content>\n </ng-container>\n\n <div [ngClass]=\"!hasCurrentItem()?'master-only-container':'master-detail-container'\">\n <!-- Card and Footer -->\n <div [style.borderRadius]=\"borderRadius\" [style.backgroundColor]=\"lbgColor\" class=\"flex-col \">\n <!-- Card section -->\n <ng-container ngProjectAs=\"verben-left-card-data-view\">\n <ng-content select='verben-left-card-data-view'></ng-content>\n </ng-container>\n\n <!-- Footer-->\n <ng-container ngProjectAs=\"verben-card-data-view-footer\">\n <ng-content select='verben-card-data-view-footer'></ng-content>\n </ng-container>\n </div>\n <!-- Detail Section-->\n <div class=\"card-detail-section\" [style.backgroundColor]=\"rbgColor\" *ngIf=\"hasCurrentItem()\"\n [style.borderRadius]=\"borderRadius\">\n <verben-svg (click)=\"clearData()\" class=\"cursor-pointer toRight\" icon=\"close\" [width]=\"20\" [height]=\"20\"\n color=\"black\"></verben-svg>\n <ng-container #right ngProjectAs=\"verben-right-card-data-view\">\n <ng-content #rightContent select='verben-right-card-data-view'></ng-content>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: [".container{gap:10px}:host{border-radius:12px}.master-detail-container{display:grid;grid-template-columns:30% 70%;gap:15px;justify-content:center}.master-only-container{display:grid;grid-template-columns:100%;justify-content:center}.paginator-text{margin-left:auto;margin-right:auto}.cursor-pointer{cursor:pointer}.toRight{align-self:flex-end}.card-detail-section{display:flex;flex-direction:column;gap:15px;padding:15px 20px 20px}::ng-deep .master-detail-container>div>verben-left-card-data-view>verben-left-card-data{display:flex!important;flex-direction:column}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "size"] }] });
|
|
102
102
|
}
|
|
103
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: CardDataViewComponent, decorators: [{
|
|
104
104
|
type: Component,
|
|
105
|
-
args: [{ selector: 'verben-card-data-view', template: "<div #main class=\"
|
|
105
|
+
args: [{ selector: 'verben-card-data-view', template: "<div #main class=\"flex-col\" [style.display]=\"'flex'\">\n <!-- Header -->\n <ng-container ngProjectAs=\"verben-card-data-view-header\">\n <ng-content select='verben-card-data-view-header'></ng-content>\n </ng-container>\n\n <div [ngClass]=\"!hasCurrentItem()?'master-only-container':'master-detail-container'\">\n <!-- Card and Footer -->\n <div [style.borderRadius]=\"borderRadius\" [style.backgroundColor]=\"lbgColor\" class=\"flex-col \">\n <!-- Card section -->\n <ng-container ngProjectAs=\"verben-left-card-data-view\">\n <ng-content select='verben-left-card-data-view'></ng-content>\n </ng-container>\n\n <!-- Footer-->\n <ng-container ngProjectAs=\"verben-card-data-view-footer\">\n <ng-content select='verben-card-data-view-footer'></ng-content>\n </ng-container>\n </div>\n <!-- Detail Section-->\n <div class=\"card-detail-section\" [style.backgroundColor]=\"rbgColor\" *ngIf=\"hasCurrentItem()\"\n [style.borderRadius]=\"borderRadius\">\n <verben-svg (click)=\"clearData()\" class=\"cursor-pointer toRight\" icon=\"close\" [width]=\"20\" [height]=\"20\"\n color=\"black\"></verben-svg>\n <ng-container #right ngProjectAs=\"verben-right-card-data-view\">\n <ng-content #rightContent select='verben-right-card-data-view'></ng-content>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: [".container{gap:10px}:host{border-radius:12px}.master-detail-container{display:grid;grid-template-columns:30% 70%;gap:15px;justify-content:center}.master-only-container{display:grid;grid-template-columns:100%;justify-content:center}.paginator-text{margin-left:auto;margin-right:auto}.cursor-pointer{cursor:pointer}.toRight{align-self:flex-end}.card-detail-section{display:flex;flex-direction:column;gap:15px;padding:15px 20px 20px}::ng-deep .master-detail-container>div>verben-left-card-data-view>verben-left-card-data{display:flex!important;flex-direction:column}\n"] }]
|
|
106
106
|
}], propDecorators: { pd: [{
|
|
107
107
|
type: Input
|
|
108
108
|
}], mg: [{
|
|
@@ -156,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
|
|
|
156
156
|
}], loadMoreClick: [{
|
|
157
157
|
type: Output
|
|
158
158
|
}] } });
|
|
159
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card-data-view.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/card-data-view/card-data-view.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/card-data-view/card-data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, contentChild, ContentChild, effect, ElementRef, EventEmitter, Input, Output, TemplateRef, viewChild, ViewChild } from '@angular/core';\nimport { CardData } from './card-data';\nimport { Title } from '@angular/platform-browser';\nimport { RightCardDataViewComponent } from './right-card-data-view/right-card-data-view.component';\nimport { LeftCardDataComponent } from './left-card-data/left-card-data.component';\n\n@Component({\n  selector: 'verben-card-data-view',\n  templateUrl: './card-data-view.component.html',\n  styleUrl: './card-data-view.component.css'\n})\n\nexport class CardDataViewComponent  {\n  @Input() pd = '10px';\n  @Input() mg = '0px';\n  @Input() lHeight?:string=\"100%\";\n  @Input() rHeight?:string=\"100%\";\n  @Input() rWidth?:string=\"70%\";\n  @Input() lWidth?:string=\"30%\";\n  @Input() textColor?:string ;\n  @Input() lbgColor?:string ;\n  @Input() rbgColor?:string ;\n  @Input() border?:string ;\n  @Input() display?:string ;\n  @Input() borderRadius?:string=\"12px\";\n  @Input() activeCss?:string ;\n  @Input() inActiveCss?:string ;\n  @Input() displayAsRow?:boolean =true;\n  @Input() cardDataList:CardData[]=[];\n  @Input() dataId!:string; //what to use to identify each data\n  @Input() totalRecords:number=0;\n  @Input() footer:boolean=false;\n  @Input() noOfVisibleChildren:number=3;\n  @ContentChild(RightCardDataViewComponent) rightContent!:RightCardDataViewComponent; \n  // @ContentChild(LeftCardDataComponent) left!:LeftCardDataComponent; \n  @ContentChild('card') card!: TemplateRef<any>;\n  // @ContentChild('content') content!: TemplateRef<any>;\n  currentItem:any={};\n  currentChildItem:any={};\n\n  hasCurrentItem()\n  {\n    return !!Object.keys(this.currentItem).length || !!Object.keys(this.currentChildItem).length\n  }\n  clearData()\n   {\n    this.currentItem={} as CardData\n    this.currentChildItem={} as CardData\n    this.cardDataList.forEach(_=>{\n      _.selected=false;\n      _.children.forEach(c=>{c.selected=false;c.isChildrenExpanded=false})\n      _.isChildrenExpanded=false\n    });\n   }\n   setDetailData()\n   {\n     this.rightContent.parentData= this.currentItem;\n      this.rightContent.chilData= this.currentChildItem;\n   }\n  @Input() onItemClick(item:CardData){\n    this.resetChildren(item);\n    item.selected= true;\n    this.cardDataList.forEach(element => {\n      if(element.data[this.dataId]==item.data[this.dataId])\n      {\n        this.currentItem= item;\n      }\n      else\n      {\n        element.selected=false;\n      }\n    });\n    this.setDetailData()\n    return this.currentItem\n  }\n resetChildren(newSelect:CardData)\n  {\n    if(this.currentItem && this.currentItem.children?.length){\n   (this.currentItem.children as any[]).forEach(c=>{\n    c.selected=false;\n  })\n  if(newSelect.data[this.dataId]!=this.currentItem.data[this.dataId])\n    this.currentItem.isChildrenExpanded=false;\n}\n  this.currentChildItem= null;\n  }\n  @Input() onCardChildClick(childIndex:number){\n    var item = this.currentItem.children[childIndex];\n    (this.currentItem.children as any[]).forEach(element => {\n      if(element.data[this.dataId]==item.data[this.dataId])\n      {\n        this.currentChildItem= item;\n      }\n      else\n      {\n        element.selected=false;\n      }\n    });\n    this.currentChildItem.selected=true;\n    this.setDetailData()\n    return this.currentChildItem\n  }\n  showChildren(item:CardData)\n  {\n    var currToggleState= item.isChildrenExpanded;\n    this.cardDataList.forEach(_=>{\n      _.isChildrenExpanded=false\n      _.selected=false;\n    });\n    item.selected=true;\n    item.isChildrenExpanded=!currToggleState\n  }\n\n  @Output() loadMoreClick = new EventEmitter();\n  onLoadMoreClick()\n  {\n    this.loadMoreClick.emit();\n  }\n}\n","<div #main class=\"container flex-col\" [style.display]=\"'flex'\">\n  <!-- Header -->\n  <ng-container ngProjectAs=\"verben-card-data-view-header\">\n    <ng-content select='verben-card-data-view-header'></ng-content>\n  </ng-container>\n\n  <div [ngClass]=\"!hasCurrentItem()?'master-only-container':'master-detail-container'\">\n    <!-- Card and Footer -->\n    <div [style.borderRadius]=\"borderRadius\" [style.backgroundColor]=\"lbgColor\" class=\"flex-col \">\n      <!-- Card section -->\n      <ng-container ngProjectAs=\"verben-left-card-data-view\">\n        <ng-content select='verben-left-card-data-view'></ng-content>\n      </ng-container>\n\n      <!-- Footer-->\n      <ng-container ngProjectAs=\"verben-card-data-view-footer\">\n        <ng-content select='verben-card-data-view-footer'></ng-content>\n      </ng-container>\n    </div>\n    <!-- Detail Section-->\n    <div class=\"card-detail-section\" [style.backgroundColor]=\"rbgColor\" *ngIf=\"hasCurrentItem()\"\n      [style.borderRadius]=\"borderRadius\">\n      <verben-svg (click)=\"clearData()\" class=\"cursor-pointer toRight\" icon=\"close\" [width]=\"20\" [height]=\"20\"\n        color=\"black\"></verben-svg>\n      <ng-container #right ngProjectAs=\"verben-right-card-data-view\">\n        <ng-content #rightContent select='verben-right-card-data-view'></ng-content>\n      </ng-container>\n    </div>\n  </div>\n</div>\n"]}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card-data-view.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/card-data-view/card-data-view.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/card-data-view/card-data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, contentChild, ContentChild, effect, ElementRef, EventEmitter, Input, Output, TemplateRef, viewChild, ViewChild } from '@angular/core';\nimport { CardData } from './card-data';\nimport { Title } from '@angular/platform-browser';\nimport { RightCardDataViewComponent } from './right-card-data-view/right-card-data-view.component';\nimport { LeftCardDataComponent } from './left-card-data/left-card-data.component';\n\n@Component({\n  selector: 'verben-card-data-view',\n  templateUrl: './card-data-view.component.html',\n  styleUrl: './card-data-view.component.css'\n})\n\nexport class CardDataViewComponent  {\n  @Input() pd = '10px';\n  @Input() mg = '0px';\n  @Input() lHeight?:string=\"100%\";\n  @Input() rHeight?:string=\"100%\";\n  @Input() rWidth?:string=\"70%\";\n  @Input() lWidth?:string=\"30%\";\n  @Input() textColor?:string ;\n  @Input() lbgColor?:string ;\n  @Input() rbgColor?:string ;\n  @Input() border?:string ;\n  @Input() display?:string ;\n  @Input() borderRadius?:string=\"12px\";\n  @Input() activeCss?:string ;\n  @Input() inActiveCss?:string ;\n  @Input() displayAsRow?:boolean =true;\n  @Input() cardDataList:CardData[]=[];\n  @Input() dataId!:string; //what to use to identify each data\n  @Input() totalRecords:number=0;\n  @Input() footer:boolean=false;\n  @Input() noOfVisibleChildren:number=3;\n  @ContentChild(RightCardDataViewComponent) rightContent!:RightCardDataViewComponent; \n  // @ContentChild(LeftCardDataComponent) left!:LeftCardDataComponent; \n  @ContentChild('card') card!: TemplateRef<any>;\n  // @ContentChild('content') content!: TemplateRef<any>;\n  currentItem:any={};\n  currentChildItem:any={};\n\n  hasCurrentItem()\n  {\n    return !!Object.keys(this.currentItem).length || !!Object.keys(this.currentChildItem).length\n  }\n  clearData()\n   {\n    this.currentItem={} as CardData\n    this.currentChildItem={} as CardData\n    this.cardDataList.forEach(_=>{\n      _.selected=false;\n      _.children.forEach(c=>{c.selected=false;c.isChildrenExpanded=false})\n      _.isChildrenExpanded=false\n    });\n   }\n   setDetailData()\n   {\n     this.rightContent.parentData= this.currentItem;\n      this.rightContent.chilData= this.currentChildItem;\n   }\n  @Input() onItemClick(item:CardData){\n    this.resetChildren(item);\n    item.selected= true;\n    this.cardDataList.forEach(element => {\n      if(element.data[this.dataId]==item.data[this.dataId])\n      {\n        this.currentItem= item;\n      }\n      else\n      {\n        element.selected=false;\n      }\n    });\n    this.setDetailData()\n    return this.currentItem\n  }\n resetChildren(newSelect:CardData)\n  {\n    if(this.currentItem && this.currentItem.children?.length){\n   (this.currentItem.children as any[]).forEach(c=>{\n    c.selected=false;\n  })\n  if(newSelect.data[this.dataId]!=this.currentItem.data[this.dataId])\n    this.currentItem.isChildrenExpanded=false;\n}\n  this.currentChildItem= null;\n  }\n  @Input() onCardChildClick(childIndex:number){\n    var item = this.currentItem.children[childIndex];\n    (this.currentItem.children as any[]).forEach(element => {\n      if(element.data[this.dataId]==item.data[this.dataId])\n      {\n        this.currentChildItem= item;\n      }\n      else\n      {\n        element.selected=false;\n      }\n    });\n    this.currentChildItem.selected=true;\n    this.setDetailData()\n    return this.currentChildItem\n  }\n  showChildren(item:CardData)\n  {\n    var currToggleState= item.isChildrenExpanded;\n    this.cardDataList.forEach(_=>{\n      _.isChildrenExpanded=false\n      _.selected=false;\n    });\n    item.selected=true;\n    item.isChildrenExpanded=!currToggleState\n  }\n\n  @Output() loadMoreClick = new EventEmitter();\n  onLoadMoreClick()\n  {\n    this.loadMoreClick.emit();\n  }\n}\n","<div #main class=\"flex-col\" [style.display]=\"'flex'\">\n  <!-- Header -->\n  <ng-container ngProjectAs=\"verben-card-data-view-header\">\n    <ng-content select='verben-card-data-view-header'></ng-content>\n  </ng-container>\n\n  <div [ngClass]=\"!hasCurrentItem()?'master-only-container':'master-detail-container'\">\n    <!-- Card and Footer -->\n    <div [style.borderRadius]=\"borderRadius\" [style.backgroundColor]=\"lbgColor\" class=\"flex-col \">\n      <!-- Card section -->\n      <ng-container ngProjectAs=\"verben-left-card-data-view\">\n        <ng-content select='verben-left-card-data-view'></ng-content>\n      </ng-container>\n\n      <!-- Footer-->\n      <ng-container ngProjectAs=\"verben-card-data-view-footer\">\n        <ng-content select='verben-card-data-view-footer'></ng-content>\n      </ng-container>\n    </div>\n    <!-- Detail Section-->\n    <div class=\"card-detail-section\" [style.backgroundColor]=\"rbgColor\" *ngIf=\"hasCurrentItem()\"\n      [style.borderRadius]=\"borderRadius\">\n      <verben-svg (click)=\"clearData()\" class=\"cursor-pointer toRight\" icon=\"close\" [width]=\"20\" [height]=\"20\"\n        color=\"black\"></verben-svg>\n      <ng-container #right ngProjectAs=\"verben-right-card-data-view\">\n        <ng-content #rightContent select='verben-right-card-data-view'></ng-content>\n      </ng-container>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -169,18 +169,22 @@ export class DataTableComponent {
|
|
|
169
169
|
});
|
|
170
170
|
};
|
|
171
171
|
allRowsSelected = () => {
|
|
172
|
-
|
|
172
|
+
const nonGroupRows = this.data().filter((row) => !this.isGroupRow(row));
|
|
173
|
+
return (nonGroupRows.length > 0 &&
|
|
174
|
+
this.selectedRowsSignal().size === nonGroupRows.length);
|
|
173
175
|
};
|
|
174
176
|
someRowsSelected = () => {
|
|
177
|
+
const nonGroupRows = this.data().filter((row) => !this.isGroupRow(row));
|
|
175
178
|
return (this.selectedRowsSignal().size > 0 &&
|
|
176
|
-
this.selectedRowsSignal().size <
|
|
179
|
+
this.selectedRowsSignal().size < nonGroupRows.length);
|
|
177
180
|
};
|
|
178
181
|
toggleAllRows = () => {
|
|
179
182
|
if (this.allRowsSelected()) {
|
|
180
183
|
this.selectedRowsSignal.set(new Set());
|
|
181
184
|
}
|
|
182
185
|
else {
|
|
183
|
-
|
|
186
|
+
const nonGroupRows = this.data().filter((row) => !this.isGroupRow(row));
|
|
187
|
+
this.selectedRowsSignal.set(new Set(nonGroupRows.map((row) => row.id)));
|
|
184
188
|
}
|
|
185
189
|
this.emitSelectionChange();
|
|
186
190
|
};
|
|
@@ -399,4 +403,4 @@ const defaultTableStyles = {
|
|
|
399
403
|
borderTop: '2px solid #e0e0e0',
|
|
400
404
|
},
|
|
401
405
|
};
|
|
402
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,eAAe,EACf,YAAY,EACZ,KAAK,EACL,KAAK,EAEL,MAAM,EAGN,MAAM,GAEP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;;;AASrD,MAAM,OAAO,kBAAkB;IAG7B,wCAAwC;IACxC,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAO,CAAC;IAC7B,OAAO,GAAG,KAAK,CAAC,QAAQ,EAAyB,CAAC;IAClD,6BAA6B;IAC7B,yBAAyB;IACzB,wBAAwB;IACxB,IAAI;IACJ,oBAAoB;IACpB,+BAA+B;IAC/B,IAAI;IACJ,2BAA2B;IAC3B,uCAAuC;IACvC,6BAA6B;IAC7B,8CAA8C;IAC9C,mCAAmC;IACnC,IAAI;IACJ,0BAA0B;IAC1B,OAAO,GAAG,KAAK,EAA+B,CAAC;IAEtC,WAAW,GAAgB,kBAAkB,CAAC;IAGvD,eAAe,CAA8B;IAEnC,OAAO,GAAG,IAAI,YAAY,EAAK,CAAC;IAChC,OAAO,GAAG,IAAI,YAAY,EAAK,CAAC;IAChC,SAAS,GAAG,IAAI,YAAY,EAAK,CAAC;IAClC,eAAe,GAAG,IAAI,YAAY,EAAO,CAAC;IAE5C,iBAAiB,GAAG,MAAM,CAAuB,IAAI,GAAG,EAAE,CAAC,CAAC;IAC5D,kBAAkB,GAAG,MAAM,CAAuB,IAAI,GAAG,EAAE,CAAC,CAAC;IAC7D,gBAAgB,GAAG,MAAM,CAC/B,IAAI,GAAG,EAAE,CACV,CAAC;IAEF,aAAa,GAA0C,MAAM,CAAC,EAAE,CAAC,CAAC;IAElE,SAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CACxB,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,cAAc,KAAK,SAAS,CAAC,CACrE,CAAC;IAEF,4CAA4C;IAC5C,UAAU,CAAC,GAAM;QACf,OAAO,CAAC,CAAE,GAAW,CAAC,UAAU,CAAC;IACnC,CAAC;IAED,qCAAqC;IACrC,WAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC1B,oDAAoD;QACpD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAAE,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC;QAExC,+CAA+C;QAC/C,MAAM,aAAa,GACjB,OAAO,IAAI,CAAC,OAAO,EAAE,KAAK,UAAU;YAClC,CAAC,CAAE,IAAI,CAAC,OAAO,EAAsB;YACrC,CAAC,CAAC,CAAC,GAAM,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAa,CAAC,CAAC;QAEjD,iBAAiB;QACjB,MAAM,MAAM,GAAG,IAAI,GAAG,EAAY,CAAC;QAEnC,IAAI,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAC1B,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;gBAChC,MAAM,UAAU,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;gBACtC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;gBACnD,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,GAAG,aAAa,EAAE,GAAG,CAAC,CAAC,CAAC;YAClD,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,qDAAqD;QACrD,MAAM,gBAAgB,GAAqC,EAAE,CAAC;QAE9D,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,EAAE;YACvC,qBAAqB;YACrB,MAAM,QAAQ,GAAG;gBACf,EAAE,EAAE,SAAS,UAAU,EAAE;gBACzB,UAAU,EAAE,IAAI;gBAChB,UAAU;gBACV,UAAU,EAAE,UAAU;aACmB,CAAC;YAE5C,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAChC,gBAAgB,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,OAAO,gBAAgB,CAAC;IAC1B,CAAC,CAAC,CAAC;IAEH,QAAQ;QACN,yCAAyC;QACzC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;QAC1E,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAEO,oBAAoB;QAC1B,mDAAmD;QACnD,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpC,MAAM,cAAc,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;gBACzD,MAAM,gBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAChD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,EAAE,CAChC,CAAC;gBACF,IAAI,gBAAgB,EAAE,CAAC;oBACrB,OAAO;wBACL,GAAG,MAAM;wBACT,YAAY,EAAE,gBAAgB,CAAC,YAAY;wBAC3C,gBAAgB,EAAE,gBAAgB,CAAC,gBAAgB;wBACnD,cAAc,EAAE,gBAAgB,CAAC,cAAc;wBAC/C,cAAc,EAAE,gBAAgB,CAAC,cAAc;qBAChD,CAAC;gBACJ,CAAC;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,YAAY,GAAG,CAAC,GAAM,EAAE,MAA2B,EAAO,EAAE;QAC1D,sDAAsD;QACtD,IAAI,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YACzB,OAAQ,GAAW,CAAC,UAAU,CAAC;QACjC,CAAC;QAED,iCAAiC;QACjC,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;YACvB,OAAQ,GAAW,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QAC1C,CAAC;QACD,OAAO,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAChE,CAAC,CAAC;IAEF,YAAY,GAAG,CAAC,KAAsB,EAAW,EAAE;QACjD,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC,CAAC;IAEF,aAAa,GAAG,CAAC,KAAsB,EAAE,EAAE;QACzC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YACpC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;YAC5B,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACrB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAClB,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YACnC,CAAC;YACD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEM,oBAAoB,CAAC,KAAsB;QACjD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;QACpD,IAAI,GAAG,EAAE,CAAC;YACR,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;gBACnC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;gBAC5B,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC;gBAC9B,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,OAAO,CAAC,KAAsB;QACpC,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACtD,IAAI,UAAU,EAAE,CAAC;YACf,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;YACtE,IAAI,gBAAgB,KAAK,CAAC,CAAC,EAAE,CAAC;gBAC5B,MAAM,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,gBAAgB,CAAC,EAAE,GAAG,UAAU,EAAE,CAAC;gBACvE,IAAI,CAAC,IAAI,EAAE,CAAC,gBAAgB,CAAC,GAAG,UAAU,CAAC;gBAC3C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC9B,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;oBACnC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;oBAC5B,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBACrB,OAAO,MAAM,CAAC;gBAChB,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC;IAED,aAAa,GAAG,CAAC,KAAsB,EAAW,EAAE;QAClD,OAAO,IAAI,CAAC,kBAAkB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEF,kBAAkB,GAAG,CAAC,KAAsB,EAAE,EAAE;QAC9C,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YACrC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;YAC5B,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACpB,CAAC;YACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,eAAe,GAAG,GAAY,EAAE;QAC9B,OAAO,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAC7D,CAAC,CAAC;IAEF,gBAAgB,GAAG,GAAY,EAAE;QAC/B,OAAO,CACL,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,GAAG,CAAC;YAClC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAClD,CAAC;IACJ,CAAC,CAAC;IAEF,aAAa,GAAG,GAAG,EAAE;QACnB,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;YAC3B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACzE,CAAC;QACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC,CAAC;IAEM,mBAAmB;QACzB,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAC9C,IAAI,CAAC,kBAAkB,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CACtC,CAAC;QACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAED,gBAAgB,CAAC,MAA2B;QAC1C,OAAO;YACL,SAAS,EAAE,MAAM;YACjB,MAAM;YACN,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC;IACJ,CAAC;IAED,iBAAiB,CAAC,KAAsB,EAAE,QAAiB,EAAE,KAAU;QACrE,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YACnC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;YAC5B,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAK,EAAoB,CAAC;YAC3D,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,GAAG,OAAO,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;YACrD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,uBAAuB,CACrB,KAAsB,EACtB,QAAiB,EACjB,WAAmB,EACnB,KAAU;QAEV,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YACnC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;YAC5B,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAK,EAAoB,CAAC;YAC3D,MAAM,UAAU,GAAI,OAAO,CAAC,QAAQ,CAAS,IAAI,EAAE,CAAC;YACpD,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE;gBAChB,GAAG,OAAO;gBACV,CAAC,QAAQ,CAAC,EAAE;oBACV,GAAG,UAAU;oBACb,CAAC,WAAW,CAAC,EAAE,KAAK;iBACrB;aACF,CAAC,CAAC;YACH,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,GAAM,EAAE,MAA2B,EAAE,QAAgB;QAClE,MAAM,KAAK,GAAG,GAAG,CAAC,EAAE,CAAC;QACrB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEtD,IAAI,KAAU,CAAC;QACf,IAAI,SAAS,IAAI,UAAU,IAAI,MAAM,CAAC,EAAE,IAAI,UAAU,EAAE,CAAC;YACvD,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,EAAa,CAAC,CAAC;QAC3C,CAAC;aAAM,CAAC;YACN,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACzC,CAAC;QAED,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,KAAK;YACL,GAAG;YACH,MAAM;YACN,QAAQ;YACR,SAAS;YACT,UAAU,EAAE,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;YACrC,kBAAkB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;YACxD,aAAa,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;YAC9C,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;YACtC,WAAW,EAAE,CAAC,QAAa,EAAE,EAAE,CAC7B,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,MAAM,CAAC,EAAa,EAAE,QAAQ,CAAC;YAC/D,iBAAiB,EAAE,CAAC,WAAmB,EAAE,QAAa,EAAE,EAAE,CACxD,IAAI,CAAC,uBAAuB,CAC1B,KAAK,EACL,MAAM,CAAC,EAAa,EACpB,WAAW,EACX,QAAQ,CACT;SACJ,CAAC;IACJ,CAAC;IAED,SAAS,GAAG,CAAC,KAAsB,EAAE,EAAE;QACrC,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;QAChE,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnC,CAAC;IACH,CAAC,CAAC;IAEF,gBAAgB,CAAC,MAA2B;QAC1C,OAAO;YACL,SAAS,EAAE,MAAM;YACjB,MAAM;YACN,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC;IACJ,CAAC;IAED,aAAa;QACX,OAAO;YACL,GAAG,IAAI,CAAC,WAAW;YACnB,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU;YACvC,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ;YACnC,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU;YACvC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM;YAC/B,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM;YAC/B,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC,cAAc;YAC/C,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa;YAC7C,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW;YACzC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK;SAC9B,CAAC;IACJ,CAAC;IAED,cAAc;QACZ,OAAO;YACL,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM;YAC1B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ;YAClE,GAAG,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;YACtD,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,IAAI,MAAM;SAClD,CAAC;IACJ,CAAC;IAED,cAAc;QACZ,OAAO;YACL,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM;YAC1B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ;YACrE,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;YAC5D,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,IAAI,MAAM;SAClD,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACxC,IAAI,SAAS,IAAI,MAAM,IAAI,SAAS,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;YAC3D,OAAO,QAAQ,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC;QAC7D,CAAC;aAAM,IAAI,SAAS,IAAI,KAAK,IAAI,SAAS,IAAI,SAAS,CAAC,GAAG,EAAE,CAAC;YAC5D,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,SAAS,CAAC,GAAG,CAAC;YAC1C,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7D,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,IAAI,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IAED,YAAY,CAAC,QAAgB,EAAE,QAAgB;QAC7C,MAAM,aAAa,GAAG,QAAQ,KAAK,CAAC,CAAC;QACrC,MAAM,YAAY,GAAG,QAAQ,KAAK,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;QAElE,IAAI,SAAS,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QAE9C,IAAI,aAAa,EAAE,CAAC;YAClB,SAAS,GAAG;gBACV,GAAG,SAAS;gBACZ,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW;gBAC/B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,UAAU;oBAChD,CAAC,CAAC,QAAQ;oBACV,CAAC,CAAC,QAAQ;gBACZ,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;gBAC7D,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,MAAM,IAAI,MAAM;aACvD,CAAC;QACJ,CAAC;aAAM,IAAI,YAAY,EAAE,CAAC;YACxB,SAAS,GAAG;gBACV,GAAG,SAAS;gBACZ,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU;gBAC9B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,WAAW;oBAChD,CAAC,CAAC,QAAQ;oBACV,CAAC,CAAC,QAAQ;gBACZ,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;gBAC9D,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,MAAM,IAAI,MAAM;aACtD,CAAC;QACJ,CAAC;QAED,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;YAClB,iCAAiC;YACjC,SAAS,GAAG,EAAE,GAAG,SAAS,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;QACzD,CAAC;aAAM,CAAC;YACN,SAAS,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QAC7C,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;uGA9YU,kBAAkB;2FAAlB,kBAAkB,6sBAwBZ,eAAe,6BClDlC,2mEAmEA;;2FDzCa,kBAAkB;kBAN9B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM;8BAwBtC,WAAW;sBAAnB,KAAK;gBAGN,eAAe;sBADd,eAAe;uBAAC,eAAe;gBAGtB,OAAO;sBAAhB,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,eAAe;sBAAxB,MAAM;;AAuXT,iBAAiB;AACjB,MAAM,kBAAkB,GAAgB;IACtC,MAAM,EAAE,mBAAmB;IAC3B,YAAY,EAAE,KAAK;IACnB,QAAQ,EAAE,QAAQ;IAClB,SAAS,EAAE,2BAA2B;IACtC,KAAK,EAAE,MAAM;IACb,MAAM,EAAE;QACN,eAAe,EAAE,SAAS;QAC1B,UAAU,EAAE,MAAM;QAClB,KAAK,EAAE,MAAM;QACb,SAAS,EAAE,MAAM;QACjB,OAAO,EAAE,WAAW;QACpB,YAAY,EAAE,mBAAmB;KAClC;IACD,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ,eAAe,EAAE,SAAS;SAC3B;QACD,GAAG,EAAE;YACH,eAAe,EAAE,SAAS;SAC3B;QACD,GAAG,EAAE;YACH,QAAQ,EAAE,CAAC;YACX,KAAK,EAAE;gBACL,eAAe,EAAE,SAAS;aAC3B;SACF;KACF;IACD,KAAK,EAAE;QACL,OAAO,EAAE,WAAW;QACpB,YAAY,EAAE,mBAAmB;KAClC;IACD,MAAM,EAAE;QACN,eAAe,EAAE,SAAS;QAC1B,UAAU,EAAE,MAAM;QAClB,KAAK,EAAE,MAAM;QACb,SAAS,EAAE,MAAM;QACjB,OAAO,EAAE,WAAW;QACpB,SAAS,EAAE,mBAAmB;KAC/B;CACF,CAAC","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  ContentChildren,\n  EventEmitter,\n  input,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { ColumnDefinition } from './data-table.types';\nimport { ColumnDirective } from './column.directive';\nimport { BaseStyles, TableStyles } from './style.types';\n\n@Component({\n  selector: 'lib-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrl: './data-table.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent<T extends { id: string | number }>\n  implements OnInit, AfterContentInit\n{\n  // Modify data input to use grouped data\n  data = input.required<T[]>();\n  columns = input.required<ColumnDefinition<T>[]>();\n  // @Input({ required: true })\n  // set data(value: T[]) {\n  //   this._data = value;\n  // }\n  // get data(): T[] {\n  //   return this.groupedData();\n  // }\n  // private _data: T[] = [];\n  // Modify columns input to use a signal\n  // @Input({ required: true })\n  // set columns(value: ColumnDefinition<T>[]) {\n  //   this.columnsSignal.set(value);\n  // }\n  // New inputs for grouping\n  groupBy = input<keyof T | ((row: T) => any)>();\n\n  @Input() styleConfig: TableStyles = defaultTableStyles;\n\n  @ContentChildren(ColumnDirective)\n  columnTemplates!: QueryList<ColumnDirective>;\n\n  @Output() rowEdit = new EventEmitter<T>();\n  @Output() rowSave = new EventEmitter<T>();\n  @Output() rowDelete = new EventEmitter<T>();\n  @Output() selectionChange = new EventEmitter<T[]>();\n\n  private editingRowsSignal = signal<Set<string | number>>(new Set());\n  private selectedRowsSignal = signal<Set<string | number>>(new Set());\n  private editedDataSignal = signal<Map<string | number, EditedData<T>>>(\n    new Map()\n  );\n\n  columnsSignal: WritableSignal<ColumnDefinition<T>[]> = signal([]);\n\n  hasFooter = computed(() =>\n    this.columnsSignal().some((col) => col.footerTemplate !== undefined)\n  );\n\n  // Type guard method to check for group rows\n  isGroupRow(row: T): row is T & { isGroupRow: true; groupTitle: any } {\n    return !!(row as any).isGroupRow;\n  }\n\n  // Computed property for grouped data\n  groupedData = computed(() => {\n    // If no grouping is specified, return original data\n    if (!this.groupBy()) return this.data();\n\n    // Determine group function based on input type\n    const getGroupValue =\n      typeof this.groupBy() === 'function'\n        ? (this.groupBy() as (row: T) => any)\n        : (row: T) => row[this.groupBy() as keyof T];\n\n    // Group the data\n    const groups = new Map<any, T[]>();\n\n    this.data().forEach((row) => {\n      if (getGroupValue !== undefined) {\n        const groupValue = getGroupValue(row);\n        const existingGroup = groups.get(groupValue) || [];\n        groups.set(groupValue, [...existingGroup, row]);\n      }\n    });\n\n    // Construct final grouped data array with group rows\n    const groupedDataArray: (T & { isGroupRow?: boolean })[] = [];\n\n    groups.forEach((groupRows, groupValue) => {\n      // Create a group row\n      const groupRow = {\n        id: `group-${groupValue}`,\n        isGroupRow: true,\n        groupValue,\n        groupTitle: groupValue,\n      } as unknown as T & { isGroupRow: boolean };\n\n      groupedDataArray.push(groupRow);\n      groupedDataArray.push(...groupRows);\n    });\n\n    return groupedDataArray;\n  });\n\n  ngOnInit() {\n    // Set initial columns if not already set\n    if (this.columnsSignal().length === 0) {\n      this.columnsSignal.set(this.columns());\n    }\n  }\n\n  ngAfterContentInit() {\n    this.columnTemplates.changes.subscribe(() => this.mergeColumnTemplates());\n    this.mergeColumnTemplates();\n  }\n\n  private mergeColumnTemplates() {\n    // Only merge if we have both columns and templates\n    if (this.columnsSignal().length > 0) {\n      const updatedColumns = this.columnsSignal().map((column) => {\n        const matchingTemplate = this.columnTemplates.find(\n          (t) => t.columnId === column.id\n        );\n        if (matchingTemplate) {\n          return {\n            ...column,\n            cellTemplate: matchingTemplate.cellTemplate,\n            cellEditTemplate: matchingTemplate.cellEditTemplate,\n            headerTemplate: matchingTemplate.headerTemplate,\n            footerTemplate: matchingTemplate.footerTemplate,\n          };\n        }\n        return column;\n      });\n      this.columnsSignal.set(updatedColumns);\n    }\n  }\n\n  getCellValue = (row: T, column: ColumnDefinition<T>): any => {\n    // For group rows, return the group title if it exists\n    if (this.isGroupRow(row)) {\n      return (row as any).groupTitle;\n    }\n\n    // Existing logic for normal rows\n    if (column.accessorKey) {\n      return (row as any)[column.accessorKey];\n    }\n    return column.accessorFn ? column.accessorFn(row) : undefined;\n  };\n\n  isRowEditing = (rowId: string | number): boolean => {\n    return this.editingRowsSignal().has(rowId);\n  };\n\n  toggleRowEdit = (rowId: string | number) => {\n    this.editingRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n        this.saveRow(rowId);\n      } else {\n        newSet.add(rowId);\n        this.initializeEditedData(rowId);\n      }\n      return newSet;\n    });\n  };\n\n  private initializeEditedData(rowId: string | number) {\n    const row = this.data().find((r) => r.id === rowId);\n    if (row) {\n      this.editedDataSignal.update((map) => {\n        const newMap = new Map(map);\n        newMap.set(rowId, { ...row });\n        return newMap;\n      });\n    }\n  }\n\n  private saveRow(rowId: string | number) {\n    const editedData = this.editedDataSignal().get(rowId);\n    if (editedData) {\n      const originalRowIndex = this.data().findIndex((r) => r.id === rowId);\n      if (originalRowIndex !== -1) {\n        const updatedRow = { ...this.data()[originalRowIndex], ...editedData };\n        this.data()[originalRowIndex] = updatedRow;\n        this.rowSave.emit(updatedRow);\n        this.editedDataSignal.update((map) => {\n          const newMap = new Map(map);\n          newMap.delete(rowId);\n          return newMap;\n        });\n      }\n    }\n  }\n\n  isRowSelected = (rowId: string | number): boolean => {\n    return this.selectedRowsSignal().has(rowId);\n  };\n\n  toggleRowSelection = (rowId: string | number) => {\n    this.selectedRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n      } else {\n        newSet.add(rowId);\n      }\n      this.emitSelectionChange();\n      return newSet;\n    });\n  };\n\n  allRowsSelected = (): boolean => {\n    return this.selectedRowsSignal().size === this.data.length;\n  };\n\n  someRowsSelected = (): boolean => {\n    return (\n      this.selectedRowsSignal().size > 0 &&\n      this.selectedRowsSignal().size < this.data.length\n    );\n  };\n\n  toggleAllRows = () => {\n    if (this.allRowsSelected()) {\n      this.selectedRowsSignal.set(new Set());\n    } else {\n      this.selectedRowsSignal.set(new Set(this.data().map((row) => row.id)));\n    }\n    this.emitSelectionChange();\n  };\n\n  private emitSelectionChange() {\n    const selectedRows = this.data().filter((row) =>\n      this.selectedRowsSignal().has(row.id)\n    );\n    this.selectionChange.emit(selectedRows);\n  }\n\n  getHeaderContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      allRowsSelected: this.allRowsSelected,\n      someRowsSelected: this.someRowsSelected,\n      toggleAllRows: this.toggleAllRows,\n    };\n  }\n\n  updateEditedValue(rowId: string | number, columnId: keyof T, value: any) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      newMap.set(rowId, { ...rowData, [columnId]: value });\n      return newMap;\n    });\n  }\n\n  updateNestedEditedValue(\n    rowId: string | number,\n    columnId: keyof T,\n    nestedField: string,\n    value: any\n  ) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      const columnData = (rowData[columnId] as any) || {};\n      newMap.set(rowId, {\n        ...rowData,\n        [columnId]: {\n          ...columnData,\n          [nestedField]: value,\n        },\n      });\n      return newMap;\n    });\n  }\n\n  getCellContext(row: T, column: ColumnDefinition<T>, rowIndex: number) {\n    const rowId = row.id;\n    const isEditing = this.isRowEditing(rowId);\n    const editedData = this.editedDataSignal().get(rowId);\n\n    let value: any;\n    if (isEditing && editedData && column.id in editedData) {\n      value = editedData[column.id as keyof T];\n    } else {\n      value = this.getCellValue(row, column);\n    }\n\n    return {\n      $implicit: value,\n      value,\n      row,\n      column,\n      rowIndex,\n      isEditing,\n      isSelected: this.isRowSelected(rowId),\n      toggleRowSelection: () => this.toggleRowSelection(rowId),\n      toggleRowEdit: () => this.toggleRowEdit(rowId),\n      deleteRow: () => this.deleteRow(rowId),\n      updateValue: (newValue: any) =>\n        this.updateEditedValue(rowId, column.id as keyof T, newValue),\n      updateNestedValue: (nestedField: string, newValue: any) =>\n        this.updateNestedEditedValue(\n          rowId,\n          column.id as keyof T,\n          nestedField,\n          newValue\n        ),\n    };\n  }\n\n  deleteRow = (rowId: string | number) => {\n    const rowToDelete = this.data().find((row) => row.id === rowId);\n    if (rowToDelete) {\n      this.rowDelete.emit(rowToDelete);\n    }\n  };\n\n  getFooterContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      data: this.data,\n    };\n  }\n\n  getTableStyle(): any {\n    return {\n      ...this.styleConfig,\n      fontFamily: this.styleConfig.fontFamily,\n      fontSize: this.styleConfig.fontSize,\n      whiteSpace: this.styleConfig.whiteSpace,\n      margin: this.styleConfig.margin,\n      border: this.styleConfig.border,\n      borderCollapse: this.styleConfig.borderCollapse,\n      borderSpacing: this.styleConfig.borderSpacing,\n      tableLayout: this.styleConfig.tableLayout,\n      width: this.styleConfig.width,\n    };\n  }\n\n  getHeaderStyle(): any {\n    return {\n      ...this.styleConfig.header,\n      position: this.styleConfig.header?.stickyTop ? 'sticky' : 'static',\n      top: this.styleConfig.header?.stickyTop ? '0' : 'auto',\n      zIndex: this.styleConfig.header?.zIndex || 'auto',\n    };\n  }\n\n  getFooterStyle(): any {\n    return {\n      ...this.styleConfig.footer,\n      position: this.styleConfig.footer?.stickyBottom ? 'sticky' : 'static',\n      bottom: this.styleConfig.footer?.stickyBottom ? '0' : 'auto',\n      zIndex: this.styleConfig.footer?.zIndex || 'auto',\n    };\n  }\n\n  getRowStyle(rowIndex: number): any {\n    const rowStyles = this.styleConfig.rows;\n    if (rowStyles && 'even' in rowStyles && 'odd' in rowStyles) {\n      return rowIndex % 2 === 0 ? rowStyles.even : rowStyles.odd;\n    } else if (rowStyles && 'nth' in rowStyles && rowStyles.nth) {\n      const { interval, style } = rowStyles.nth;\n      return (rowIndex + 1) % (interval || 1) === 0 ? style : {};\n    } else {\n      return rowStyles || {};\n    }\n  }\n\n  getCellStyle(rowIndex: number, colIndex: number): any {\n    const isFirstColumn = colIndex === 0;\n    const isLastColumn = colIndex === this.columnsSignal().length - 1;\n\n    let cellStyle = { ...this.styleConfig.cells };\n\n    if (isFirstColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.firstColumn,\n        position: this.styleConfig.firstColumn?.stickyLeft\n          ? 'sticky'\n          : 'static',\n        left: this.styleConfig.firstColumn?.stickyLeft ? '0' : 'auto',\n        zIndex: this.styleConfig.firstColumn?.zIndex || 'auto',\n      };\n    } else if (isLastColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.lastColumn,\n        position: this.styleConfig.lastColumn?.stickyRight\n          ? 'sticky'\n          : 'static',\n        right: this.styleConfig.lastColumn?.stickyRight ? '0' : 'auto',\n        zIndex: this.styleConfig.lastColumn?.zIndex || 'auto',\n      };\n    }\n\n    if (rowIndex >= 0) {\n      // Apply body styles to all cells\n      cellStyle = { ...cellStyle, ...this.styleConfig.body };\n    } else {\n      cellStyle = { ...this.styleConfig.header };\n    }\n\n    return cellStyle;\n  }\n}\n\ntype EditedData<T> = {\n  [K in keyof T]?: T[K] extends object ? Partial<T[K]> : T[K];\n};\n\n// Default styles\nconst defaultTableStyles: TableStyles = {\n  border: '1px solid #e0e0e0',\n  borderRadius: '4px',\n  overflow: 'hidden',\n  boxShadow: '0 2px 4px rgba(0,0,0,0.1)',\n  width: '100%',\n  header: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderBottom: '2px solid #e0e0e0',\n  },\n  rows: {\n    even: {\n      backgroundColor: '#ffffff',\n    },\n    odd: {\n      backgroundColor: '#f9f9f9',\n    },\n    nth: {\n      interval: 5,\n      style: {\n        backgroundColor: '#f0f0f0',\n      },\n    },\n  },\n  cells: {\n    padding: '12px 16px',\n    borderBottom: '1px solid #e0e0e0',\n  },\n  footer: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderTop: '2px solid #e0e0e0',\n  },\n};\n","<table [ngStyle]=\"getTableStyle()\">\n  <thead>\n    <tr [ngStyle]=\"getHeaderStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <th [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.headerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.headerTemplate\"\n          [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n        ></ng-container>\n        } @else {\n        {{ column.header }}\n        }\n      </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    @for (row of data(); track row.id; let rowIndex = $index) { @if\n    (isGroupRow(row)) {\n    <tr class=\"group-row\" [ngStyle]=\"getRowStyle(rowIndex)\">\n      <td\n        [attr.colspan]=\"columnsSignal().length\"\n        [ngStyle]=\"getCellStyle(rowIndex, 0)\"\n      >\n        {{ getCellValue(row, columnsSignal()[0]) }}\n      </td>\n    </tr>\n    } @else {\n    <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n      @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n      <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n        @if (isRowEditing(row.id) && column.cellEditTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellEditTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else if (column.cellTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else {\n        {{ getCellValue(row, column) }}\n        }\n      </td>\n      }\n    </tr>\n    } }\n  </tbody>\n  @if (hasFooter()) {\n  <tfoot>\n    <tr [ngStyle]=\"getFooterStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <td [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.footerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.footerTemplate\"\n          [ngTemplateOutletContext]=\"getFooterContext(column)\"\n        ></ng-container>\n        }\n      </td>\n      }\n    </tr>\n  </tfoot>\n  }\n</table>\n"]}
|
|
406
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  ContentChildren,\n  EventEmitter,\n  input,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { ColumnDefinition } from './data-table.types';\nimport { ColumnDirective } from './column.directive';\nimport { BaseStyles, TableStyles } from './style.types';\n\n@Component({\n  selector: 'lib-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrl: './data-table.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent<T extends { id: string | number }>\n  implements OnInit, AfterContentInit\n{\n  // Modify data input to use grouped data\n  data = input.required<T[]>();\n  columns = input.required<ColumnDefinition<T>[]>();\n  // @Input({ required: true })\n  // set data(value: T[]) {\n  //   this._data = value;\n  // }\n  // get data(): T[] {\n  //   return this.groupedData();\n  // }\n  // private _data: T[] = [];\n  // Modify columns input to use a signal\n  // @Input({ required: true })\n  // set columns(value: ColumnDefinition<T>[]) {\n  //   this.columnsSignal.set(value);\n  // }\n  // New inputs for grouping\n  groupBy = input<keyof T | ((row: T) => any)>();\n\n  @Input() styleConfig: TableStyles = defaultTableStyles;\n\n  @ContentChildren(ColumnDirective)\n  columnTemplates!: QueryList<ColumnDirective>;\n\n  @Output() rowEdit = new EventEmitter<T>();\n  @Output() rowSave = new EventEmitter<T>();\n  @Output() rowDelete = new EventEmitter<T>();\n  @Output() selectionChange = new EventEmitter<T[]>();\n\n  private editingRowsSignal = signal<Set<string | number>>(new Set());\n  private selectedRowsSignal = signal<Set<string | number>>(new Set());\n  private editedDataSignal = signal<Map<string | number, EditedData<T>>>(\n    new Map()\n  );\n\n  columnsSignal: WritableSignal<ColumnDefinition<T>[]> = signal([]);\n\n  hasFooter = computed(() =>\n    this.columnsSignal().some((col) => col.footerTemplate !== undefined)\n  );\n\n  // Type guard method to check for group rows\n  isGroupRow(row: T): row is T & { isGroupRow: true; groupTitle: any } {\n    return !!(row as any).isGroupRow;\n  }\n\n  // Computed property for grouped data\n  groupedData = computed(() => {\n    // If no grouping is specified, return original data\n    if (!this.groupBy()) return this.data();\n\n    // Determine group function based on input type\n    const getGroupValue =\n      typeof this.groupBy() === 'function'\n        ? (this.groupBy() as (row: T) => any)\n        : (row: T) => row[this.groupBy() as keyof T];\n\n    // Group the data\n    const groups = new Map<any, T[]>();\n\n    this.data().forEach((row) => {\n      if (getGroupValue !== undefined) {\n        const groupValue = getGroupValue(row);\n        const existingGroup = groups.get(groupValue) || [];\n        groups.set(groupValue, [...existingGroup, row]);\n      }\n    });\n\n    // Construct final grouped data array with group rows\n    const groupedDataArray: (T & { isGroupRow?: boolean })[] = [];\n\n    groups.forEach((groupRows, groupValue) => {\n      // Create a group row\n      const groupRow = {\n        id: `group-${groupValue}`,\n        isGroupRow: true,\n        groupValue,\n        groupTitle: groupValue,\n      } as unknown as T & { isGroupRow: boolean };\n\n      groupedDataArray.push(groupRow);\n      groupedDataArray.push(...groupRows);\n    });\n\n    return groupedDataArray;\n  });\n\n  ngOnInit() {\n    // Set initial columns if not already set\n    if (this.columnsSignal().length === 0) {\n      this.columnsSignal.set(this.columns());\n    }\n  }\n\n  ngAfterContentInit() {\n    this.columnTemplates.changes.subscribe(() => this.mergeColumnTemplates());\n    this.mergeColumnTemplates();\n  }\n\n  private mergeColumnTemplates() {\n    // Only merge if we have both columns and templates\n    if (this.columnsSignal().length > 0) {\n      const updatedColumns = this.columnsSignal().map((column) => {\n        const matchingTemplate = this.columnTemplates.find(\n          (t) => t.columnId === column.id\n        );\n        if (matchingTemplate) {\n          return {\n            ...column,\n            cellTemplate: matchingTemplate.cellTemplate,\n            cellEditTemplate: matchingTemplate.cellEditTemplate,\n            headerTemplate: matchingTemplate.headerTemplate,\n            footerTemplate: matchingTemplate.footerTemplate,\n          };\n        }\n        return column;\n      });\n      this.columnsSignal.set(updatedColumns);\n    }\n  }\n\n  getCellValue = (row: T, column: ColumnDefinition<T>): any => {\n    // For group rows, return the group title if it exists\n    if (this.isGroupRow(row)) {\n      return (row as any).groupTitle;\n    }\n\n    // Existing logic for normal rows\n    if (column.accessorKey) {\n      return (row as any)[column.accessorKey];\n    }\n    return column.accessorFn ? column.accessorFn(row) : undefined;\n  };\n\n  isRowEditing = (rowId: string | number): boolean => {\n    return this.editingRowsSignal().has(rowId);\n  };\n\n  toggleRowEdit = (rowId: string | number) => {\n    this.editingRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n        this.saveRow(rowId);\n      } else {\n        newSet.add(rowId);\n        this.initializeEditedData(rowId);\n      }\n      return newSet;\n    });\n  };\n\n  private initializeEditedData(rowId: string | number) {\n    const row = this.data().find((r) => r.id === rowId);\n    if (row) {\n      this.editedDataSignal.update((map) => {\n        const newMap = new Map(map);\n        newMap.set(rowId, { ...row });\n        return newMap;\n      });\n    }\n  }\n\n  private saveRow(rowId: string | number) {\n    const editedData = this.editedDataSignal().get(rowId);\n    if (editedData) {\n      const originalRowIndex = this.data().findIndex((r) => r.id === rowId);\n      if (originalRowIndex !== -1) {\n        const updatedRow = { ...this.data()[originalRowIndex], ...editedData };\n        this.data()[originalRowIndex] = updatedRow;\n        this.rowSave.emit(updatedRow);\n        this.editedDataSignal.update((map) => {\n          const newMap = new Map(map);\n          newMap.delete(rowId);\n          return newMap;\n        });\n      }\n    }\n  }\n\n  isRowSelected = (rowId: string | number): boolean => {\n    return this.selectedRowsSignal().has(rowId);\n  };\n\n  toggleRowSelection = (rowId: string | number) => {\n    this.selectedRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n      } else {\n        newSet.add(rowId);\n      }\n      this.emitSelectionChange();\n      return newSet;\n    });\n  };\n\n  allRowsSelected = (): boolean => {\n    const nonGroupRows = this.data().filter((row) => !this.isGroupRow(row));\n    return (\n      nonGroupRows.length > 0 &&\n      this.selectedRowsSignal().size === nonGroupRows.length\n    );\n  };\n\n  someRowsSelected = (): boolean => {\n    const nonGroupRows = this.data().filter((row) => !this.isGroupRow(row));\n    return (\n      this.selectedRowsSignal().size > 0 &&\n      this.selectedRowsSignal().size < nonGroupRows.length\n    );\n  };\n\n  toggleAllRows = () => {\n    if (this.allRowsSelected()) {\n      this.selectedRowsSignal.set(new Set());\n    } else {\n      const nonGroupRows = this.data().filter((row) => !this.isGroupRow(row));\n      this.selectedRowsSignal.set(new Set(nonGroupRows.map((row) => row.id)));\n    }\n    this.emitSelectionChange();\n  };\n\n  private emitSelectionChange() {\n    const selectedRows = this.data().filter((row) =>\n      this.selectedRowsSignal().has(row.id)\n    );\n    this.selectionChange.emit(selectedRows);\n  }\n\n  getHeaderContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      allRowsSelected: this.allRowsSelected,\n      someRowsSelected: this.someRowsSelected,\n      toggleAllRows: this.toggleAllRows,\n    };\n  }\n\n  updateEditedValue(rowId: string | number, columnId: keyof T, value: any) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      newMap.set(rowId, { ...rowData, [columnId]: value });\n      return newMap;\n    });\n  }\n\n  updateNestedEditedValue(\n    rowId: string | number,\n    columnId: keyof T,\n    nestedField: string,\n    value: any\n  ) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      const columnData = (rowData[columnId] as any) || {};\n      newMap.set(rowId, {\n        ...rowData,\n        [columnId]: {\n          ...columnData,\n          [nestedField]: value,\n        },\n      });\n      return newMap;\n    });\n  }\n\n  getCellContext(row: T, column: ColumnDefinition<T>, rowIndex: number) {\n    const rowId = row.id;\n    const isEditing = this.isRowEditing(rowId);\n    const editedData = this.editedDataSignal().get(rowId);\n\n    let value: any;\n    if (isEditing && editedData && column.id in editedData) {\n      value = editedData[column.id as keyof T];\n    } else {\n      value = this.getCellValue(row, column);\n    }\n\n    return {\n      $implicit: value,\n      value,\n      row,\n      column,\n      rowIndex,\n      isEditing,\n      isSelected: this.isRowSelected(rowId),\n      toggleRowSelection: () => this.toggleRowSelection(rowId),\n      toggleRowEdit: () => this.toggleRowEdit(rowId),\n      deleteRow: () => this.deleteRow(rowId),\n      updateValue: (newValue: any) =>\n        this.updateEditedValue(rowId, column.id as keyof T, newValue),\n      updateNestedValue: (nestedField: string, newValue: any) =>\n        this.updateNestedEditedValue(\n          rowId,\n          column.id as keyof T,\n          nestedField,\n          newValue\n        ),\n    };\n  }\n\n  deleteRow = (rowId: string | number) => {\n    const rowToDelete = this.data().find((row) => row.id === rowId);\n    if (rowToDelete) {\n      this.rowDelete.emit(rowToDelete);\n    }\n  };\n\n  getFooterContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      data: this.data,\n    };\n  }\n\n  getTableStyle(): any {\n    return {\n      ...this.styleConfig,\n      fontFamily: this.styleConfig.fontFamily,\n      fontSize: this.styleConfig.fontSize,\n      whiteSpace: this.styleConfig.whiteSpace,\n      margin: this.styleConfig.margin,\n      border: this.styleConfig.border,\n      borderCollapse: this.styleConfig.borderCollapse,\n      borderSpacing: this.styleConfig.borderSpacing,\n      tableLayout: this.styleConfig.tableLayout,\n      width: this.styleConfig.width,\n    };\n  }\n\n  getHeaderStyle(): any {\n    return {\n      ...this.styleConfig.header,\n      position: this.styleConfig.header?.stickyTop ? 'sticky' : 'static',\n      top: this.styleConfig.header?.stickyTop ? '0' : 'auto',\n      zIndex: this.styleConfig.header?.zIndex || 'auto',\n    };\n  }\n\n  getFooterStyle(): any {\n    return {\n      ...this.styleConfig.footer,\n      position: this.styleConfig.footer?.stickyBottom ? 'sticky' : 'static',\n      bottom: this.styleConfig.footer?.stickyBottom ? '0' : 'auto',\n      zIndex: this.styleConfig.footer?.zIndex || 'auto',\n    };\n  }\n\n  getRowStyle(rowIndex: number): any {\n    const rowStyles = this.styleConfig.rows;\n    if (rowStyles && 'even' in rowStyles && 'odd' in rowStyles) {\n      return rowIndex % 2 === 0 ? rowStyles.even : rowStyles.odd;\n    } else if (rowStyles && 'nth' in rowStyles && rowStyles.nth) {\n      const { interval, style } = rowStyles.nth;\n      return (rowIndex + 1) % (interval || 1) === 0 ? style : {};\n    } else {\n      return rowStyles || {};\n    }\n  }\n\n  getCellStyle(rowIndex: number, colIndex: number): any {\n    const isFirstColumn = colIndex === 0;\n    const isLastColumn = colIndex === this.columnsSignal().length - 1;\n\n    let cellStyle = { ...this.styleConfig.cells };\n\n    if (isFirstColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.firstColumn,\n        position: this.styleConfig.firstColumn?.stickyLeft\n          ? 'sticky'\n          : 'static',\n        left: this.styleConfig.firstColumn?.stickyLeft ? '0' : 'auto',\n        zIndex: this.styleConfig.firstColumn?.zIndex || 'auto',\n      };\n    } else if (isLastColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.lastColumn,\n        position: this.styleConfig.lastColumn?.stickyRight\n          ? 'sticky'\n          : 'static',\n        right: this.styleConfig.lastColumn?.stickyRight ? '0' : 'auto',\n        zIndex: this.styleConfig.lastColumn?.zIndex || 'auto',\n      };\n    }\n\n    if (rowIndex >= 0) {\n      // Apply body styles to all cells\n      cellStyle = { ...cellStyle, ...this.styleConfig.body };\n    } else {\n      cellStyle = { ...this.styleConfig.header };\n    }\n\n    return cellStyle;\n  }\n}\n\ntype EditedData<T> = {\n  [K in keyof T]?: T[K] extends object ? Partial<T[K]> : T[K];\n};\n\n// Default styles\nconst defaultTableStyles: TableStyles = {\n  border: '1px solid #e0e0e0',\n  borderRadius: '4px',\n  overflow: 'hidden',\n  boxShadow: '0 2px 4px rgba(0,0,0,0.1)',\n  width: '100%',\n  header: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderBottom: '2px solid #e0e0e0',\n  },\n  rows: {\n    even: {\n      backgroundColor: '#ffffff',\n    },\n    odd: {\n      backgroundColor: '#f9f9f9',\n    },\n    nth: {\n      interval: 5,\n      style: {\n        backgroundColor: '#f0f0f0',\n      },\n    },\n  },\n  cells: {\n    padding: '12px 16px',\n    borderBottom: '1px solid #e0e0e0',\n  },\n  footer: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderTop: '2px solid #e0e0e0',\n  },\n};\n","<table [ngStyle]=\"getTableStyle()\">\n  <thead>\n    <tr [ngStyle]=\"getHeaderStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <th [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.headerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.headerTemplate\"\n          [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n        ></ng-container>\n        } @else {\n        {{ column.header }}\n        }\n      </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    @for (row of data(); track row.id; let rowIndex = $index) { @if\n    (isGroupRow(row)) {\n    <tr class=\"group-row\" [ngStyle]=\"getRowStyle(rowIndex)\">\n      <td\n        [attr.colspan]=\"columnsSignal().length\"\n        [ngStyle]=\"getCellStyle(rowIndex, 0)\"\n      >\n        {{ getCellValue(row, columnsSignal()[0]) }}\n      </td>\n    </tr>\n    } @else {\n    <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n      @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n      <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n        @if (isRowEditing(row.id) && column.cellEditTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellEditTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else if (column.cellTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else {\n        {{ getCellValue(row, column) }}\n        }\n      </td>\n      }\n    </tr>\n    } }\n  </tbody>\n  @if (hasFooter()) {\n  <tfoot>\n    <tr [ngStyle]=\"getFooterStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <td [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.footerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.footerTemplate\"\n          [ngTemplateOutletContext]=\"getFooterContext(column)\"\n        ></ng-container>\n        }\n      </td>\n      }\n    </tr>\n  </tfoot>\n  }\n</table>\n"]}
|
|
@@ -2,9 +2,8 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
4
|
import * as i2 from "../svg/svg.component";
|
|
5
|
-
import * as i3 from "../../
|
|
6
|
-
import * as i4 from "
|
|
7
|
-
import * as i5 from "./data-view-click-outside.directive";
|
|
5
|
+
import * as i3 from "../../verbena-button/verbena-button.component";
|
|
6
|
+
import * as i4 from "./data-view-click-outside.directive";
|
|
8
7
|
export class DataViewComponent {
|
|
9
8
|
buttonClass;
|
|
10
9
|
iconClass;
|
|
@@ -60,6 +59,7 @@ export class DataViewComponent {
|
|
|
60
59
|
}
|
|
61
60
|
onSearch(event) {
|
|
62
61
|
this.searchValue = event.target.value;
|
|
62
|
+
console.log(this.searchValue);
|
|
63
63
|
this.onSearchChange.emit({ key: this.searchKey, value: this.searchValue });
|
|
64
64
|
}
|
|
65
65
|
onClearSearch() {
|
|
@@ -129,11 +129,11 @@ export class DataViewComponent {
|
|
|
129
129
|
}
|
|
130
130
|
}
|
|
131
131
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DataViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
132
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: DataViewComponent, selector: "verben-data-view", inputs: { buttonClass: "buttonClass", iconClass: "iconClass", activeIconClass: "activeIconClass", columnCustomClass: "columnCustomClass", filterCustomClass: "filterCustomClass", sortCustomClass: "sortCustomClass", exportCustomClass: "exportCustomClass", selectCustomClass: "selectCustomClass", zIndex: "zIndex", createCustomClass: "createCustomClass", tableIcon: "tableIcon", cardIcon: "cardIcon", cardClass: "cardClass", tableClass: "tableClass", searchKey: "searchKey", searchValue: "searchValue", viewState: "viewState", searchTemplate: "searchTemplate", columnTemplate: "columnTemplate", filterTemplate: "filterTemplate", sortTemplate: "sortTemplate", children: "children", exportTemplate: "exportTemplate", createTemplate: "createTemplate", selectedColumnCount: "selectedColumnCount", selectedSortCount: "selectedSortCount", selectedFilterTableCount: "selectedFilterTableCount", inputWidth: "inputWidth", showColumnChild: "showColumnChild", showSortChild: "showSortChild", showFilterChild: "showFilterChild", showExportChild: "showExportChild", create: "create", showSelected: "showSelected", isTableView: "isTableView" }, outputs: { viewChange: "viewChange", stateChange: "stateChange", onSearchChange: "onSearchChange" }, ngImport: i0, template: "<div class=\"toolbar flex gap justify-between items-center \">\n <div class=\"flex items-center gap flex-1 justify-end\">\n <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n <verben-svg\n [icon]=\"tableIcon\"\n [class.active]=\"!isTableView\"\n [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n ></verben-svg>\n <verben-svg\n [icon]=\"cardIcon\"\n [class.active]=\"isTableView\"\n [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n [width]=\"25\"\n [height]=\"25\"\n ></verben-svg>\n </button>\n </div>\n <!-- Search Input -->\n <div\n [style.width]=\"inputWidth\"\n class=\"search-input\"\n *ngIf=\"viewState.isSearch\"\n >\n <verbena-input\n [type]=\"'text'\"\n [placeHolder]=\"'Search...'\"\n (input)=\"onSearch($event)\"\n [bgColor]=\"'transparent'\"\n [border]=\"'0'\"\n [value]=\"searchValue\"\n />\n <verben-svg\n *ngIf=\"searchValue.length > 0\"\n [icon]=\"'close'\"\n [width]=\"15\"\n (click)=\"onClearSearch()\"\n class=\"close-icon-class\"\n [height]=\"15\"\n ></verben-svg>\n </div>\n </div>\n\n <div class=\"flex items-center relative gap flex-1 justify-end \">\n <!-- Column Section -->\n <ng-container\n [appOutSideClick]=\"showColumnChild\"\n (outSideClick)=\"resetChildViewsExcept('column')\"\n *ngIf=\"viewState.isColumn && isTableView\"\n >\n <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n <ng-template #defaultColumn>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n columnCustomClass ? columnCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('column')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n <span\n >Columns <sup>({{ selectedColumnCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n </ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Filter Section -->\n <ng-container\n [appOutSideClick]=\"showFilterChild\"\n (outSideClick)=\"resetChildViewsExcept('filter')\"\n *ngIf=\"viewState.isFilter\"\n >\n <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n <ng-template #defaultFilter>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n filterCustomClass ? filterCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('filter')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n <span\n >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showFilterChild\"\n select=\"[filter-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Sort Section -->\n <ng-container\n [appOutSideClick]=\"showSortChild\"\n (outSideClick)=\"resetChildViewsExcept('sort')\"\n *ngIf=\"viewState.isSort\"\n >\n <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n <ng-template #defaultSort>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n sortCustomClass ? sortCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('sort')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n <span\n >Sort <sup>({{ selectedSortCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showSortChild\"\n select=\"[sort-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Export Section -->\n <ng-container\n [appOutSideClick]=\"showExportChild\"\n (outSideClick)=\"resetChildViewsExcept('export')\"\n *ngIf=\"viewState.isExport\"\n >\n <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n <ng-template #defaultExport>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n exportCustomClass ? exportCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('export')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n Export\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showExportChild\"\n select=\"[export-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Select Section -->\n <div *ngIf=\"viewState.isSelect\">\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n selectCustomClass ? selectCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('select')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n <span>Select</span>\n <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n </span>\n </div>\n\n <!-- Create Button -->\n\n <div\n [appOutSideClick]=\"create\"\n (outSideClick)=\"resetChildViewsExcept('create')\"\n *ngIf=\"viewState.isCreate\"\n >\n <verbena-button\n class=\"text-sm font-semibold\"\n [bgColor]=\"'#FFE681'\"\n [buttonClass]=\"createCustomClass\"\n [pd]=\"'6px'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#000'\"\n [svg]=\"'add'\"\n [svgPosition]=\"'right'\"\n [text]=\"'Create New'\"\n (click)=\"toggleChildView('create')\"\n >\n </verbena-button>\n <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n <ng-template #defaultCreate>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n </div>\n </ng-template>\n </div>\n <div>\n <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n <ng-template #defaultChildren>\n <div>\n <ng-content select=\"[children]\"></ng-content>\n </div>\n </ng-template>\n </div>\n </div>\n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n \n <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n <ng-content select=\"[table-content]\"></ng-content>\n </div>\n</div>\n<ng-template #listViewTemplate>\n <div [class]=\"cardClass\">\n <ng-content select=\"[card-content]\"></ng-content>\n </div>\n</ng-template>\n", styles: [".toggle-button-container button{display:flex;justify-content:space-between;align-content:center;border:none;background-color:transparent;cursor:pointer;border:1px solid gray;padding:0;border-radius:6px;overflow:hidden;height:35px}.input-class{border:none;min-width:100%;display:block}.toggle-button-container verben-svg{transition:background-color .5s ease;padding:6px;position:relative}.toggle-button-container verben-svg.active{background-color:#d3d3d3}.justify-end{justify-self:end}.flex{display:flex}.flex-1{flex:1}.justify-between{justify-content:space-between}.items-center{align-items:center}.font-semibold{font-weight:600}.font-normal{font-weight:400}.text-sm{font-size:14px}.text-xs{font-size:12px}.gap{gap:7px}.pd{padding:5px 8px}.rounded-sm{border-radius:10px}.cursor-pointer{cursor:pointer}.search-input{position:relative;background-color:#80808018;border-radius:10px}sup{color:#3479e9;font-weight:500}.data-view-element{position:absolute;top:40px;left:0}.relative{position:relative}.z-10{z-index:100000000000}.close-icon-class{position:absolute;right:10px;cursor:pointer;top:13px}.toolbar{margin-bottom:15px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "size"] }, { kind: "component", type: i3.VerbenaInputComponent, selector: "verbena-input", inputs: ["label", "placeHolder", "required", "svgPosition", "minLength", "maxLength", "type", "bgColor", "border", "borderRadius", "textColor", "value", "labelPosition", "labelColor", "disable", "readOnly", "min", "max", "showBorder", "showErrorMessage", "errorMessageColor", "errorBorderColor", "errorPosition", "svg", "svgWidth", "svgHeight", "svgColor", "capitalization", "inputContainerClass", "inputFieldClass", "passLength", "inputWrapperClass", "passwordToggle", "customErrorMessages", "icon", "textPass"], outputs: ["valueChange"] }, { kind: "component", type: i4.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "directive", type: i5.OutSideClickDirective, selector: "[appOutSideClick]", inputs: ["appOutSideClick"], outputs: ["outSideClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
132
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: DataViewComponent, selector: "verben-data-view", inputs: { buttonClass: "buttonClass", iconClass: "iconClass", activeIconClass: "activeIconClass", columnCustomClass: "columnCustomClass", filterCustomClass: "filterCustomClass", sortCustomClass: "sortCustomClass", exportCustomClass: "exportCustomClass", selectCustomClass: "selectCustomClass", zIndex: "zIndex", createCustomClass: "createCustomClass", tableIcon: "tableIcon", cardIcon: "cardIcon", cardClass: "cardClass", tableClass: "tableClass", searchKey: "searchKey", searchValue: "searchValue", viewState: "viewState", searchTemplate: "searchTemplate", columnTemplate: "columnTemplate", filterTemplate: "filterTemplate", sortTemplate: "sortTemplate", children: "children", exportTemplate: "exportTemplate", createTemplate: "createTemplate", selectedColumnCount: "selectedColumnCount", selectedSortCount: "selectedSortCount", selectedFilterTableCount: "selectedFilterTableCount", inputWidth: "inputWidth", showColumnChild: "showColumnChild", showSortChild: "showSortChild", showFilterChild: "showFilterChild", showExportChild: "showExportChild", create: "create", showSelected: "showSelected", isTableView: "isTableView" }, outputs: { viewChange: "viewChange", stateChange: "stateChange", onSearchChange: "onSearchChange" }, ngImport: i0, template: "<div class=\"toolbar flex gap justify-between items-center \">\n <div class=\"flex items-center gap flex-1 justify-end\">\n <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n <verben-svg\n [icon]=\"tableIcon\"\n [class.active]=\"!isTableView\"\n [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n ></verben-svg>\n <verben-svg\n [icon]=\"cardIcon\"\n [class.active]=\"isTableView\"\n [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n [width]=\"25\"\n [height]=\"25\"\n ></verben-svg>\n </button>\n </div>\n <!-- Search Input -->\n <div\n [style.width]=\"inputWidth\"\n class=\"search-input\"\n *ngIf=\"viewState.isSearch\"\n >\n <verben-svg\n [icon]=\"'search2'\"\n [width]=\"20\"\n [height]=\"20\"\n ></verben-svg>\n <input\n [type]=\"'text'\"\n [placeholder]=\"'Search'\"\n (input)=\"onSearch($event)\"\n [style.border]=\"'0'\"\n [value]=\"searchValue\"\n />\n <verben-svg\n *ngIf=\"searchValue.length > 0\"\n [icon]=\"'close'\"\n [width]=\"15\"\n (click)=\"onClearSearch()\"\n class=\"close-icon-class\"\n [height]=\"15\"\n ></verben-svg>\n </div>\n </div>\n<div class=\"relative flex items-center gap-2\">\n <!-- Column Section -->\n <ng-container\n [appOutSideClick]=\"showColumnChild\"\n (outSideClick)=\"resetChildViewsExcept('column')\"\n *ngIf=\"viewState.isColumn && isTableView\"\n >\n <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n <ng-template #defaultColumn>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n columnCustomClass ? columnCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('column')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n <span\n >Columns <sup>({{ selectedColumnCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n </ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Filter Section -->\n <ng-container\n [appOutSideClick]=\"showFilterChild\"\n (outSideClick)=\"resetChildViewsExcept('filter')\"\n *ngIf=\"viewState.isFilter\"\n >\n <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n <ng-template #defaultFilter>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n filterCustomClass ? filterCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('filter')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n <span\n >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showFilterChild\"\n select=\"[filter-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Sort Section -->\n <ng-container\n [appOutSideClick]=\"showSortChild\"\n (outSideClick)=\"resetChildViewsExcept('sort')\"\n *ngIf=\"viewState.isSort\"\n >\n <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n <ng-template #defaultSort>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n sortCustomClass ? sortCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('sort')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n <span\n >Sort <sup>({{ selectedSortCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showSortChild\"\n select=\"[sort-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Export Section -->\n <ng-container\n [appOutSideClick]=\"showExportChild\"\n (outSideClick)=\"resetChildViewsExcept('export')\"\n *ngIf=\"viewState.isExport\"\n >\n <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n <ng-template #defaultExport>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n exportCustomClass ? exportCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('export')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n Export\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showExportChild\"\n select=\"[export-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Select Section -->\n <div *ngIf=\"viewState.isSelect\">\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n selectCustomClass ? selectCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('select')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n <span>Select</span>\n <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n </span>\n </div>\n\n <!-- Create Button -->\n\n <div\n [appOutSideClick]=\"create\"\n (outSideClick)=\"resetChildViewsExcept('create')\"\n *ngIf=\"viewState.isCreate\"\n >\n <verbena-button\n class=\"text-sm font-semibold\"\n [bgColor]=\"'#FFE681'\"\n [buttonClass]=\"createCustomClass\"\n [pd]=\"'6px'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#000'\"\n [svg]=\"'add'\"\n [svgPosition]=\"'right'\"\n [text]=\"'Create New'\"\n (click)=\"toggleChildView('create')\"\n >\n </verbena-button>\n <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n <ng-template #defaultCreate>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n </div>\n </ng-template>\n </div>\n</div>\n \n \n <div>\n <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n <ng-template #defaultChildren>\n <div>\n <ng-content select=\"[children]\"></ng-content>\n </div>\n </ng-template>\n </div>\n \n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n \n <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n <ng-content select=\"[table-content]\"></ng-content>\n </div>\n</div>\n<ng-template #listViewTemplate>\n <div [class]=\"cardClass\">\n <ng-content select=\"[card-content]\"></ng-content>\n </div>\n</ng-template>\n", styles: [".toggle-button-container button{display:flex;justify-content:space-between;align-content:center;border:none;background-color:transparent;cursor:pointer;border:1px solid gray;padding:0;border-radius:6px;overflow:hidden;height:35px}.input-class{border:none;min-width:100%;display:block}.toggle-button-container verben-svg{transition:background-color .5s ease;padding:6px;position:relative}.toggle-button-container verben-svg.active{background-color:#d3d3d3}.justify-end{justify-self:end}.flex{display:flex}.flex-1{flex:1}.justify-between{justify-content:space-between}.items-center{align-items:center}.font-semibold{font-weight:600}.font-normal{font-weight:400}.text-sm{font-size:14px}.text-xs{font-size:12px}.gap{gap:7px}.pd{padding:5px 8px}.rounded-sm{border-radius:10px}.cursor-pointer{cursor:pointer}.search-input{position:relative;border-radius:10px;overflow:hidden;display:flex;align-items:center;padding:8px 30px 8px 10px;background-color:#80808018;gap:10px}.search-input input{outline:0;width:100%;display:block;background-color:transparent}.search-input input::placeholder{color:#424242;font-size:14px}sup{color:#3479e9;font-weight:500}.data-view-element{position:absolute;top:40px;left:0}.relative{position:relative}.z-10{z-index:100000000000}.close-icon-class{position:absolute;right:10px;cursor:pointer;top:13px}.toolbar{margin-bottom:15px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "size"] }, { kind: "component", type: i3.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "directive", type: i4.OutSideClickDirective, selector: "[appOutSideClick]", inputs: ["appOutSideClick"], outputs: ["outSideClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
133
133
|
}
|
|
134
134
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DataViewComponent, decorators: [{
|
|
135
135
|
type: Component,
|
|
136
|
-
args: [{ selector: 'verben-data-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"toolbar flex gap justify-between items-center \">\n <div class=\"flex items-center gap flex-1 justify-end\">\n <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n <verben-svg\n [icon]=\"tableIcon\"\n [class.active]=\"!isTableView\"\n [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n ></verben-svg>\n <verben-svg\n [icon]=\"cardIcon\"\n [class.active]=\"isTableView\"\n [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n [width]=\"25\"\n [height]=\"25\"\n ></verben-svg>\n </button>\n </div>\n <!-- Search Input -->\n <div\n [style.width]=\"inputWidth\"\n class=\"search-input\"\n *ngIf=\"viewState.isSearch\"\n >\n <
|
|
136
|
+
args: [{ selector: 'verben-data-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"toolbar flex gap justify-between items-center \">\n <div class=\"flex items-center gap flex-1 justify-end\">\n <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n <verben-svg\n [icon]=\"tableIcon\"\n [class.active]=\"!isTableView\"\n [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n ></verben-svg>\n <verben-svg\n [icon]=\"cardIcon\"\n [class.active]=\"isTableView\"\n [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n [width]=\"25\"\n [height]=\"25\"\n ></verben-svg>\n </button>\n </div>\n <!-- Search Input -->\n <div\n [style.width]=\"inputWidth\"\n class=\"search-input\"\n *ngIf=\"viewState.isSearch\"\n >\n <verben-svg\n [icon]=\"'search2'\"\n [width]=\"20\"\n [height]=\"20\"\n ></verben-svg>\n <input\n [type]=\"'text'\"\n [placeholder]=\"'Search'\"\n (input)=\"onSearch($event)\"\n [style.border]=\"'0'\"\n [value]=\"searchValue\"\n />\n <verben-svg\n *ngIf=\"searchValue.length > 0\"\n [icon]=\"'close'\"\n [width]=\"15\"\n (click)=\"onClearSearch()\"\n class=\"close-icon-class\"\n [height]=\"15\"\n ></verben-svg>\n </div>\n </div>\n<div class=\"relative flex items-center gap-2\">\n <!-- Column Section -->\n <ng-container\n [appOutSideClick]=\"showColumnChild\"\n (outSideClick)=\"resetChildViewsExcept('column')\"\n *ngIf=\"viewState.isColumn && isTableView\"\n >\n <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n <ng-template #defaultColumn>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n columnCustomClass ? columnCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('column')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n <span\n >Columns <sup>({{ selectedColumnCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n </ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Filter Section -->\n <ng-container\n [appOutSideClick]=\"showFilterChild\"\n (outSideClick)=\"resetChildViewsExcept('filter')\"\n *ngIf=\"viewState.isFilter\"\n >\n <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n <ng-template #defaultFilter>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n filterCustomClass ? filterCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('filter')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n <span\n >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showFilterChild\"\n select=\"[filter-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Sort Section -->\n <ng-container\n [appOutSideClick]=\"showSortChild\"\n (outSideClick)=\"resetChildViewsExcept('sort')\"\n *ngIf=\"viewState.isSort\"\n >\n <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n <ng-template #defaultSort>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n sortCustomClass ? sortCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('sort')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n <span\n >Sort <sup>({{ selectedSortCount }})</sup></span\n >\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showSortChild\"\n select=\"[sort-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Export Section -->\n <ng-container\n [appOutSideClick]=\"showExportChild\"\n (outSideClick)=\"resetChildViewsExcept('export')\"\n *ngIf=\"viewState.isExport\"\n >\n <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n <ng-template #defaultExport>\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n exportCustomClass ? exportCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('export')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n Export\n </span>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content\n *ngIf=\"showExportChild\"\n select=\"[export-content]\"\n ></ng-content>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Select Section -->\n <div *ngIf=\"viewState.isSelect\">\n <span\n [ngClass]=\"[\n 'flex gap text-xs items-center pd rounded cursor-pointer',\n selectCustomClass ? selectCustomClass : ''\n ]\"\n [style.background-color]=\"'#D9D9D940'\"\n (click)=\"toggleChildView('select')\"\n >\n <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n <span>Select</span>\n <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n </span>\n </div>\n\n <!-- Create Button -->\n\n <div\n [appOutSideClick]=\"create\"\n (outSideClick)=\"resetChildViewsExcept('create')\"\n *ngIf=\"viewState.isCreate\"\n >\n <verbena-button\n class=\"text-sm font-semibold\"\n [bgColor]=\"'#FFE681'\"\n [buttonClass]=\"createCustomClass\"\n [pd]=\"'6px'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#000'\"\n [svg]=\"'add'\"\n [svgPosition]=\"'right'\"\n [text]=\"'Create New'\"\n (click)=\"toggleChildView('create')\"\n >\n </verbena-button>\n <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n <ng-template #defaultCreate>\n <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n </div>\n </ng-template>\n </div>\n</div>\n \n \n <div>\n <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n <ng-template #defaultChildren>\n <div>\n <ng-content select=\"[children]\"></ng-content>\n </div>\n </ng-template>\n </div>\n \n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n \n <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n <ng-content select=\"[table-content]\"></ng-content>\n </div>\n</div>\n<ng-template #listViewTemplate>\n <div [class]=\"cardClass\">\n <ng-content select=\"[card-content]\"></ng-content>\n </div>\n</ng-template>\n", styles: [".toggle-button-container button{display:flex;justify-content:space-between;align-content:center;border:none;background-color:transparent;cursor:pointer;border:1px solid gray;padding:0;border-radius:6px;overflow:hidden;height:35px}.input-class{border:none;min-width:100%;display:block}.toggle-button-container verben-svg{transition:background-color .5s ease;padding:6px;position:relative}.toggle-button-container verben-svg.active{background-color:#d3d3d3}.justify-end{justify-self:end}.flex{display:flex}.flex-1{flex:1}.justify-between{justify-content:space-between}.items-center{align-items:center}.font-semibold{font-weight:600}.font-normal{font-weight:400}.text-sm{font-size:14px}.text-xs{font-size:12px}.gap{gap:7px}.pd{padding:5px 8px}.rounded-sm{border-radius:10px}.cursor-pointer{cursor:pointer}.search-input{position:relative;border-radius:10px;overflow:hidden;display:flex;align-items:center;padding:8px 30px 8px 10px;background-color:#80808018;gap:10px}.search-input input{outline:0;width:100%;display:block;background-color:transparent}.search-input input::placeholder{color:#424242;font-size:14px}sup{color:#3479e9;font-weight:500}.data-view-element{position:absolute;top:40px;left:0}.relative{position:relative}.z-10{z-index:100000000000}.close-icon-class{position:absolute;right:10px;cursor:pointer;top:13px}.toolbar{margin-bottom:15px}\n"] }]
|
|
137
137
|
}], propDecorators: { buttonClass: [{
|
|
138
138
|
type: Input
|
|
139
139
|
}], iconClass: [{
|
|
@@ -211,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
|
|
|
211
211
|
}], onSearchChange: [{
|
|
212
212
|
type: Output
|
|
213
213
|
}] } });
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\ninterface ViewState {\n  isSearch?: boolean;\n  isColumn?: boolean;\n  isFilter?: boolean;\n  isSort?: boolean;\n  isExport?: boolean;\n  isSelect?: boolean;\n  isCreate?:boolean\n  isToggle?:boolean\n}\n\n@Component({\n  selector: 'verben-data-view',\n  templateUrl: './data-view.component.html',\n  styleUrls: ['./data-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataViewComponent implements OnInit {\n  @Input() buttonClass?: string;\n  @Input() iconClass?: string;\n  @Input() activeIconClass?: string=\"\"\n  @Input() columnCustomClass?:string=''\n  @Input() filterCustomClass?:string=''\n  @Input() sortCustomClass?:string=''\n  @Input() exportCustomClass?:string=''\n  @Input() selectCustomClass?:string=''\n  @Input() zIndex?:number=5\n  @Input() createCustomClass:string=''\n  @Input() tableIcon: string = 'grid-3';\n  @Input() cardIcon: string = 'list-view';\n  @Input() cardClass: string = '';\n  @Input() tableClass: string = '';\n  @Input() searchKey:string='search';\n  @Input() searchValue:string='';\n  @Input() viewState: ViewState = {\n    isSearch: true,\n    isColumn: true,\n    isFilter: true,\n    isSort: true,\n    isExport: true,\n    isSelect: true,\n    isCreate:true,\n    isToggle:true\n  };\n\n  @Input() searchTemplate?: Node;\n  @Input() columnTemplate?: Node;\n  @Input() filterTemplate?: Node;\n  @Input() sortTemplate?: Node;\n  @Input() children?: Node;\n  @Input() exportTemplate?: Node;\n  @Input() createTemplate?: Node;\n  @Input() selectedColumnCount?: number = 0;\n  @Input() selectedSortCount: number = 0;\n  @Input() selectedFilterTableCount: number = 0;\n  @Input() inputWidth: string=\"100%\";\n  @Input()showColumnChild: boolean = false;\n  @Input() showSortChild: boolean = false;\n  @Input() showFilterChild: boolean = false;\n  @Input() showExportChild: boolean = false;\n  @Input() create: boolean = false;\n  @Input() showSelected: boolean = false;\n  \n  @Input() isTableView: boolean = false;\n  @Output() viewChange = new EventEmitter<boolean>();\n  @Output() stateChange = new EventEmitter<{ key: string; value: boolean }>();\n  @Output() onSearchChange=new EventEmitter<{ key: string; value: string }>()\n  ngOnInit(): void {}\n\n  toggleView(): void {\n    this.isTableView = !this.isTableView;\n    this.viewChange.emit(this.isTableView);\n  }\n\n  onSearch(event:any): void {\n    this.searchValue=event.target.value\n    this.onSearchChange.emit({key:this.searchKey, value:this.searchValue});\n  }\n  \nonClearSearch(){\n this.searchValue=\"\"\n this.onSearchChange.emit({ key: this.searchKey, value: this.searchValue });\n\n}\n  toggleChildView(viewType: string): void {\n    switch (viewType) {\n      case 'column':\n        this.showColumnChild = !this.showColumnChild;\n        this.resetChildViewsExcept('column');\n        break;\n      case 'filter':\n        this.showFilterChild = !this.showFilterChild;\n        this.resetChildViewsExcept('filter');\n        break;\n      case 'sort':\n        this.showSortChild = !this.showSortChild;\n        this.resetChildViewsExcept('sort');\n        break;\n      case 'select':\n        this.showSelected = !this.showSelected;\n        this.resetChildViewsExcept('select');\n        break;\n      case 'export':\n        this.showExportChild = !this.showExportChild;\n        this.resetChildViewsExcept('export');\n        break;\n        case 'create':\n          this.create = !this.create;\n          this.resetChildViewsExcept('create');\n          break;\n    }\n    this.stateChange.emit({ key: viewType, value: this.getChildViewState(viewType) });\n    \n  }\n  resetChildViewsExcept(viewType: string): void {\n    if (viewType !== 'column') this.showColumnChild = false;\n    if (viewType !== 'filter') this.showFilterChild = false;\n    if (viewType !== 'sort') this.showSortChild = false;\n    if (viewType !== 'select') this.showSelected = false;\n    if (viewType !== 'export') this.showExportChild = false;\n    if (viewType !== 'create') this.create = false;\n  }\n\n  // Helper method to get the state of a specific child view\n  getChildViewState(viewType: string): boolean {\n    switch (viewType) {\n      case 'column':\n        return this.showColumnChild;\n      case 'filter':\n        return this.showFilterChild;\n      case 'sort':\n        return this.showSortChild;\n      case 'select':\n        return this.showSelected;\n      case 'export':\n        return this.showExportChild;\n        case 'create':\n        return this.create;\n      default:\n        return false;\n    }\n  }\n}\n","<div class=\"toolbar flex gap justify-between items-center \">\n  <div class=\"flex items-center gap flex-1 justify-end\">\n    <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n      <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n        <verben-svg\n          [icon]=\"tableIcon\"\n          [class.active]=\"!isTableView\"\n          [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n        ></verben-svg>\n        <verben-svg\n          [icon]=\"cardIcon\"\n          [class.active]=\"isTableView\"\n          [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n          [width]=\"25\"\n          [height]=\"25\"\n        ></verben-svg>\n      </button>\n    </div>\n    <!-- Search Input -->\n    <div\n      [style.width]=\"inputWidth\"\n      class=\"search-input\"\n      *ngIf=\"viewState.isSearch\"\n    >\n      <verbena-input\n        [type]=\"'text'\"\n        [placeHolder]=\"'Search...'\"\n        (input)=\"onSearch($event)\"\n        [bgColor]=\"'transparent'\"\n        [border]=\"'0'\"\n        [value]=\"searchValue\"\n      />\n      <verben-svg\n        *ngIf=\"searchValue.length > 0\"\n        [icon]=\"'close'\"\n        [width]=\"15\"\n        (click)=\"onClearSearch()\"\n        class=\"close-icon-class\"\n        [height]=\"15\"\n      ></verben-svg>\n    </div>\n  </div>\n\n  <div class=\"flex items-center relative gap flex-1 justify-end \">\n    <!-- Column Section -->\n    <ng-container\n      [appOutSideClick]=\"showColumnChild\"\n      (outSideClick)=\"resetChildViewsExcept('column')\"\n      *ngIf=\"viewState.isColumn && isTableView\"\n    >\n      <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n      <ng-template #defaultColumn>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            columnCustomClass ? columnCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('column')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n          <span\n            >Columns <sup>({{ selectedColumnCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n          </ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Filter Section -->\n    <ng-container\n      [appOutSideClick]=\"showFilterChild\"\n      (outSideClick)=\"resetChildViewsExcept('filter')\"\n      *ngIf=\"viewState.isFilter\"\n    >\n      <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n      <ng-template #defaultFilter>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            filterCustomClass ? filterCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('filter')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n          <span\n            >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showFilterChild\"\n            select=\"[filter-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Sort Section -->\n    <ng-container\n      [appOutSideClick]=\"showSortChild\"\n      (outSideClick)=\"resetChildViewsExcept('sort')\"\n      *ngIf=\"viewState.isSort\"\n    >\n      <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n      <ng-template #defaultSort>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            sortCustomClass ? sortCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('sort')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n          <span\n            >Sort <sup>({{ selectedSortCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showSortChild\"\n            select=\"[sort-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Export Section -->\n    <ng-container\n      [appOutSideClick]=\"showExportChild\"\n      (outSideClick)=\"resetChildViewsExcept('export')\"\n      *ngIf=\"viewState.isExport\"\n    >\n      <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n      <ng-template #defaultExport>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            exportCustomClass ? exportCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('export')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n          Export\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showExportChild\"\n            select=\"[export-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Select Section -->\n    <div *ngIf=\"viewState.isSelect\">\n      <span\n        [ngClass]=\"[\n          'flex gap text-xs items-center pd rounded cursor-pointer',\n          selectCustomClass ? selectCustomClass : ''\n        ]\"\n        [style.background-color]=\"'#D9D9D940'\"\n        (click)=\"toggleChildView('select')\"\n      >\n        <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n        <span>Select</span>\n        <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n      </span>\n    </div>\n\n    <!-- Create Button -->\n\n    <div\n      [appOutSideClick]=\"create\"\n      (outSideClick)=\"resetChildViewsExcept('create')\"\n      *ngIf=\"viewState.isCreate\"\n    >\n      <verbena-button\n        class=\"text-sm font-semibold\"\n        [bgColor]=\"'#FFE681'\"\n        [buttonClass]=\"createCustomClass\"\n        [pd]=\"'6px'\"\n        [borderRadius]=\"'4px'\"\n        [textColor]=\"'#000'\"\n        [svg]=\"'add'\"\n        [svgPosition]=\"'right'\"\n        [text]=\"'Create New'\"\n        (click)=\"toggleChildView('create')\"\n      >\n      </verbena-button>\n      <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n      <ng-template #defaultCreate>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n    <div>\n      <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n      <ng-template #defaultChildren>\n        <div>\n          <ng-content select=\"[children]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n  \n  <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n    <ng-content select=\"[table-content]\"></ng-content>\n  </div>\n</div>\n<ng-template #listViewTemplate>\n  <div [class]=\"cardClass\">\n    <ng-content select=\"[card-content]\"></ng-content>\n  </div>\n</ng-template>\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\ninterface ViewState {\n  isSearch?: boolean;\n  isColumn?: boolean;\n  isFilter?: boolean;\n  isSort?: boolean;\n  isExport?: boolean;\n  isSelect?: boolean;\n  isCreate?:boolean\n  isToggle?:boolean\n}\n\n@Component({\n  selector: 'verben-data-view',\n  templateUrl: './data-view.component.html',\n  styleUrls: ['./data-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataViewComponent implements OnInit {\n  @Input() buttonClass?: string;\n  @Input() iconClass?: string;\n  @Input() activeIconClass?: string=\"\"\n  @Input() columnCustomClass?:string=''\n  @Input() filterCustomClass?:string=''\n  @Input() sortCustomClass?:string=''\n  @Input() exportCustomClass?:string=''\n  @Input() selectCustomClass?:string=''\n  @Input() zIndex?:number=5\n  @Input() createCustomClass:string=''\n  @Input() tableIcon: string = 'grid-3';\n  @Input() cardIcon: string = 'list-view';\n  @Input() cardClass: string = '';\n  @Input() tableClass: string = '';\n  @Input() searchKey:string='search';\n  @Input() searchValue:string='';\n  @Input() viewState: ViewState = {\n    isSearch: true,\n    isColumn: true,\n    isFilter: true,\n    isSort: true,\n    isExport: true,\n    isSelect: true,\n    isCreate:true,\n    isToggle:true\n  };\n\n  @Input() searchTemplate?: Node;\n  @Input() columnTemplate?: Node;\n  @Input() filterTemplate?: Node;\n  @Input() sortTemplate?: Node;\n  @Input() children?: Node;\n  @Input() exportTemplate?: Node;\n  @Input() createTemplate?: Node;\n  @Input() selectedColumnCount?: number = 0;\n  @Input() selectedSortCount: number = 0;\n  @Input() selectedFilterTableCount: number = 0;\n  @Input() inputWidth: string=\"100%\";\n  @Input()showColumnChild: boolean = false;\n  @Input() showSortChild: boolean = false;\n  @Input() showFilterChild: boolean = false;\n  @Input() showExportChild: boolean = false;\n  @Input() create: boolean = false;\n  @Input() showSelected: boolean = false;\n  \n  @Input() isTableView: boolean = false;\n  @Output() viewChange = new EventEmitter<boolean>();\n  @Output() stateChange = new EventEmitter<{ key: string; value: boolean }>();\n  @Output() onSearchChange=new EventEmitter<{ key: string; value: string }>()\n  ngOnInit(): void {}\n\n  toggleView(): void {\n    this.isTableView = !this.isTableView;\n    this.viewChange.emit(this.isTableView);\n  }\n\n  onSearch(event:any): void {\n    this.searchValue=event.target.value\n    console.log(this.searchValue);\n    \n    this.onSearchChange.emit({key:this.searchKey, value:this.searchValue});\n    \n  }\n  \nonClearSearch(){\n this.searchValue=\"\"\n this.onSearchChange.emit({ key: this.searchKey, value: this.searchValue });\n}\n  toggleChildView(viewType: string): void {\n    switch (viewType) {\n      case 'column':\n        this.showColumnChild = !this.showColumnChild;\n        this.resetChildViewsExcept('column');\n        break;\n      case 'filter':\n        this.showFilterChild = !this.showFilterChild;\n        this.resetChildViewsExcept('filter');\n        break;\n      case 'sort':\n        this.showSortChild = !this.showSortChild;\n        this.resetChildViewsExcept('sort');\n        break;\n      case 'select':\n        this.showSelected = !this.showSelected;\n        this.resetChildViewsExcept('select');\n        break;\n      case 'export':\n        this.showExportChild = !this.showExportChild;\n        this.resetChildViewsExcept('export');\n        break;\n        case 'create':\n          this.create = !this.create;\n          this.resetChildViewsExcept('create');\n          break;\n    }\n    this.stateChange.emit({ key: viewType, value: this.getChildViewState(viewType) });\n    \n  }\n  resetChildViewsExcept(viewType: string): void {\n    if (viewType !== 'column') this.showColumnChild = false;\n    if (viewType !== 'filter') this.showFilterChild = false;\n    if (viewType !== 'sort') this.showSortChild = false;\n    if (viewType !== 'select') this.showSelected = false;\n    if (viewType !== 'export') this.showExportChild = false;\n    if (viewType !== 'create') this.create = false;\n  }\n\n  // Helper method to get the state of a specific child view\n  getChildViewState(viewType: string): boolean {\n    switch (viewType) {\n      case 'column':\n        return this.showColumnChild;\n      case 'filter':\n        return this.showFilterChild;\n      case 'sort':\n        return this.showSortChild;\n      case 'select':\n        return this.showSelected;\n      case 'export':\n        return this.showExportChild;\n        case 'create':\n        return this.create;\n      default:\n        return false;\n    }\n  }\n}\n","<div class=\"toolbar flex gap justify-between items-center \">\n  <div class=\"flex items-center gap flex-1 justify-end\">\n    <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n      <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n        <verben-svg\n          [icon]=\"tableIcon\"\n          [class.active]=\"!isTableView\"\n          [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n        ></verben-svg>\n        <verben-svg\n          [icon]=\"cardIcon\"\n          [class.active]=\"isTableView\"\n          [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n          [width]=\"25\"\n          [height]=\"25\"\n        ></verben-svg>\n      </button>\n    </div>\n    <!-- Search Input -->\n    <div\n      [style.width]=\"inputWidth\"\n      class=\"search-input\"\n      *ngIf=\"viewState.isSearch\"\n    >\n    <verben-svg\n    [icon]=\"'search2'\"\n    [width]=\"20\"\n    [height]=\"20\"\n  ></verben-svg>\n      <input\n        [type]=\"'text'\"\n        [placeholder]=\"'Search'\"\n        (input)=\"onSearch($event)\"\n        [style.border]=\"'0'\"\n        [value]=\"searchValue\"\n      />\n      <verben-svg\n        *ngIf=\"searchValue.length > 0\"\n        [icon]=\"'close'\"\n        [width]=\"15\"\n        (click)=\"onClearSearch()\"\n        class=\"close-icon-class\"\n        [height]=\"15\"\n      ></verben-svg>\n    </div>\n  </div>\n<div class=\"relative flex items-center gap-2\">\n     <!-- Column Section -->\n     <ng-container\n     [appOutSideClick]=\"showColumnChild\"\n     (outSideClick)=\"resetChildViewsExcept('column')\"\n     *ngIf=\"viewState.isColumn && isTableView\"\n   >\n     <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n     <ng-template #defaultColumn>\n       <span\n         [ngClass]=\"[\n           'flex gap text-xs items-center pd rounded cursor-pointer',\n           columnCustomClass ? columnCustomClass : ''\n         ]\"\n         [style.background-color]=\"'#D9D9D940'\"\n         (click)=\"toggleChildView('column')\"\n       >\n         <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n         <span\n           >Columns <sup>({{ selectedColumnCount }})</sup></span\n         >\n       </span>\n       <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n         <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n         </ng-content>\n       </div>\n     </ng-template>\n   </ng-container>\n\n   <!-- Filter Section -->\n   <ng-container\n     [appOutSideClick]=\"showFilterChild\"\n     (outSideClick)=\"resetChildViewsExcept('filter')\"\n     *ngIf=\"viewState.isFilter\"\n   >\n     <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n     <ng-template #defaultFilter>\n       <span\n         [ngClass]=\"[\n           'flex gap text-xs items-center pd rounded cursor-pointer',\n           filterCustomClass ? filterCustomClass : ''\n         ]\"\n         [style.background-color]=\"'#D9D9D940'\"\n         (click)=\"toggleChildView('filter')\"\n       >\n         <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n         <span\n           >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n         >\n       </span>\n       <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n         <ng-content\n           *ngIf=\"showFilterChild\"\n           select=\"[filter-content]\"\n         ></ng-content>\n       </div>\n     </ng-template>\n   </ng-container>\n\n   <!-- Sort Section -->\n   <ng-container\n     [appOutSideClick]=\"showSortChild\"\n     (outSideClick)=\"resetChildViewsExcept('sort')\"\n     *ngIf=\"viewState.isSort\"\n   >\n     <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n     <ng-template #defaultSort>\n       <span\n         [ngClass]=\"[\n           'flex gap text-xs items-center pd rounded cursor-pointer',\n           sortCustomClass ? sortCustomClass : ''\n         ]\"\n         [style.background-color]=\"'#D9D9D940'\"\n         (click)=\"toggleChildView('sort')\"\n       >\n         <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n         <span\n           >Sort <sup>({{ selectedSortCount }})</sup></span\n         >\n       </span>\n       <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n         <ng-content\n           *ngIf=\"showSortChild\"\n           select=\"[sort-content]\"\n         ></ng-content>\n       </div>\n     </ng-template>\n   </ng-container>\n\n   <!-- Export Section -->\n   <ng-container\n     [appOutSideClick]=\"showExportChild\"\n     (outSideClick)=\"resetChildViewsExcept('export')\"\n     *ngIf=\"viewState.isExport\"\n   >\n     <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n     <ng-template #defaultExport>\n       <span\n         [ngClass]=\"[\n           'flex gap text-xs items-center pd rounded cursor-pointer',\n           exportCustomClass ? exportCustomClass : ''\n         ]\"\n         [style.background-color]=\"'#D9D9D940'\"\n         (click)=\"toggleChildView('export')\"\n       >\n         <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n         Export\n       </span>\n       <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n         <ng-content\n           *ngIf=\"showExportChild\"\n           select=\"[export-content]\"\n         ></ng-content>\n       </div>\n     </ng-template>\n   </ng-container>\n\n   <!-- Select Section -->\n   <div *ngIf=\"viewState.isSelect\">\n     <span\n       [ngClass]=\"[\n         'flex gap text-xs items-center pd rounded cursor-pointer',\n         selectCustomClass ? selectCustomClass : ''\n       ]\"\n       [style.background-color]=\"'#D9D9D940'\"\n       (click)=\"toggleChildView('select')\"\n     >\n       <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n       <span>Select</span>\n       <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n     </span>\n   </div>\n\n   <!-- Create Button -->\n\n   <div\n     [appOutSideClick]=\"create\"\n     (outSideClick)=\"resetChildViewsExcept('create')\"\n     *ngIf=\"viewState.isCreate\"\n   >\n     <verbena-button\n       class=\"text-sm font-semibold\"\n       [bgColor]=\"'#FFE681'\"\n       [buttonClass]=\"createCustomClass\"\n       [pd]=\"'6px'\"\n       [borderRadius]=\"'4px'\"\n       [textColor]=\"'#000'\"\n       [svg]=\"'add'\"\n       [svgPosition]=\"'right'\"\n       [text]=\"'Create New'\"\n       (click)=\"toggleChildView('create')\"\n     >\n     </verbena-button>\n     <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n     <ng-template #defaultCreate>\n       <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n         <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n       </div>\n     </ng-template>\n   </div>\n</div>\n  \n \n    <div>\n      <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n      <ng-template #defaultChildren>\n        <div>\n          <ng-content select=\"[children]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n  \n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n  \n  <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n    <ng-content select=\"[table-content]\"></ng-content>\n  </div>\n</div>\n<ng-template #listViewTemplate>\n  <div [class]=\"cardClass\">\n    <ng-content select=\"[card-content]\"></ng-content>\n  </div>\n</ng-template>\n"]}
|