@ng-formworks/daisyui 18.6.7 → 18.6.8

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.
@@ -1,4 +1,4 @@
1
- import { Component, inject, input, signal } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, inject, input, signal } from '@angular/core';
2
2
  import { JsonSchemaFormService } from '@ng-formworks/core';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@ng-formworks/core";
@@ -7,6 +7,7 @@ import * as i3 from "@angular/forms";
7
7
  export class DaisyUITabsComponent {
8
8
  constructor() {
9
9
  this.jsf = inject(JsonSchemaFormService);
10
+ this.cdr = inject(ChangeDetectorRef);
10
11
  this.selectedItem = 0;
11
12
  this.showAddTab = true;
12
13
  this.layoutNode = input(undefined);
@@ -20,6 +21,12 @@ export class DaisyUITabsComponent {
20
21
  }
21
22
  this.itemCount = this.layoutNode().items.length - 1;
22
23
  this.updateControl();
24
+ //TODO review/test-introduced to fix dynamic titles not updating
25
+ //when their conditional linked field is destroyed
26
+ //-forces change detection!
27
+ this.jsf.dataChanges.subscribe((val) => {
28
+ this.cdr.detectChanges();
29
+ });
23
30
  }
24
31
  select(index) {
25
32
  const layoutNode = this.layoutNode();
@@ -44,6 +51,9 @@ export class DaisyUITabsComponent {
44
51
  setTabTitle(item, index) {
45
52
  return this.jsf.setArrayItemTitle(this, item, index);
46
53
  }
54
+ ngOnDestroy() {
55
+ this.dataChangesSubs?.unsubscribe();
56
+ }
47
57
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DaisyUITabsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
48
58
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DaisyUITabsComponent, selector: "daisyui-tabs-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
49
59
  <div
@@ -155,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
155
165
  </ng-container>
156
166
  </div>`, standalone: false, styles: ["a{cursor:pointer}.ngf-hidden{display:none}\n"] }]
157
167
  }] });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daisyui-tabs.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-daisyui/src/lib/widgets/daisyui-tabs.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;;;;;AAiE3D,MAAM,OAAO,oBAAoB;IA7DjC;QA8DU,QAAG,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAI5C,iBAAY,GAAG,CAAC,CAAC;QACjB,eAAU,GAAG,IAAI,CAAC;QACT,eAAU,GAAG,KAAK,CAAM,SAAS,CAAC,CAAC;QACnC,gBAAW,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;QACzC,cAAS,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;KAqCjD;IAnCC,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC;QAC/C,IAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAC,CAAC;YAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACpD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,KAAK;QACV,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACrC,IAAI,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YAC5C,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC;gBACf,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC3C,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACrD,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;aAClD,CAAC,CAAC;YACH,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,aAAa;QACX,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC7E,IAAI,QAAQ,CAAC,IAAI,KAAK,MAAM;YAC1B,IAAI,CAAC,SAAS,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,EACrD,CAAC;YACD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,WAAW,CAAC,IAAS,EAAE,KAAa;QAClC,OAAO,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACvD,CAAC;+GA7CU,oBAAoB;mGAApB,oBAAoB,4dA1DnB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAoDH;;4FAME,oBAAoB;kBA7DhC,SAAS;+BAEI,qBAAqB,YACrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAoDH,cAIK,KAAK","sourcesContent":["import { Component, OnInit, inject, input, signal } from '@angular/core';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\n\r\n\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'daisyui-tabs-widget',\r\n    template: `\r\n    <div\r\n      [class]=\"options?.labelHtmlClass || ''\">\r\n      <a *ngFor=\"let item of layoutNode()?.items; let i = index\"\r\n        [class]=\"(options?.itemLabelHtmlClass || '') + (selectedItem === i ?\r\n          (' ' + (options?.activeClass || '') + ' ' + (options?.style?.selected || '')) :\r\n          (' ' + options?.style?.unselected))\"\r\n          (click)=\"select(i)\"\r\n        >\r\n          <input type=\"radio\" [value]=\"i\" *ngIf=\"options?.tabMode=='oneOfMode'\" \r\n           name=\"tabSelection\" \r\n           [(ngModel)]=\"selectedItem\"\r\n           [class]=\"(options?.widget_radioClass || '')\"\r\n           [value]=\"i\" \r\n           (change)=\"select(i)\"\r\n          />\r\n        <span *ngIf=\"showAddTab || item.type !== '$ref'\"\r\n        [class]=\"(selectedItem === i ? (' ' + options?.activeClass + ' ' + options?.style?.selected) :\r\n        (' ' + options?.style?.unselected))\">{{setTabTitle(item, i)}}</span>\r\n          \r\n      </a>\r\n\r\n    </div>\r\n\r\n    <!--\r\n    <div class=\"tabs tabs-boxed\">\r\n  <a class=\"tab\">Tab 1</a> \r\n  <a class=\"tab tab-active\">Tab 2</a> \r\n  <a class=\"tab\">Tab 3</a>\r\n</div>\r\n-->\r\n\r\n    <div *ngFor=\"let layoutItem of layoutNode()?.items; let i = index\"\r\n      [class]=\"(options?.htmlClass || '') + (selectedItem != i?' ngf-hidden':'')\">\r\n      <ng-container *ngIf=\"options?.tabMode=='oneOfMode'\">\r\n        <select-framework-widget *ngIf=\"selectedItem === i\"\r\n          [class]=\"(options?.fieldHtmlClass || '') +\r\n            ' ' + (options?.activeClass || '') +\r\n            ' ' + (options?.style?.selected || '')\"\r\n          [dataIndex]=\"layoutNode()?.dataType === 'array' ? (dataIndex() || []).concat(i) : dataIndex()\"\r\n          [layoutIndex]=\"(layoutIndex() || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"options?.tabMode != 'oneOfMode'\">\r\n        <select-framework-widget \r\n          [class]=\"(options?.fieldHtmlClass || '') +\r\n            ' ' + (options?.activeClass || '') +\r\n            ' ' + (options?.style?.selected || '')\"\r\n          [dataIndex]=\"layoutNode()?.dataType === 'array' ? (dataIndex() || []).concat(i) : dataIndex()\"\r\n          [layoutIndex]=\"(layoutIndex() || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n      </ng-container>\r\n    </div>`,\r\n    styles: [` a { cursor: pointer; }\r\n      .ngf-hidden{display:none}\r\n       `],\r\n    standalone: false\r\n})\r\nexport class DaisyUITabsComponent implements OnInit {\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  options: any;\r\n  itemCount: number;\r\n  selectedItem = 0;\r\n  showAddTab = true;\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode().options || {};\r\n    if(this.options.selectedTab){\r\n      this.selectedItem = this.options.selectedTab;\r\n    }\r\n    this.itemCount = this.layoutNode().items.length - 1;\r\n    this.updateControl();\r\n  }\r\n\r\n  select(index) {\r\n    const layoutNode = this.layoutNode();\r\n    if (layoutNode.items[index].type === '$ref') {\r\n      this.itemCount = layoutNode.items.length;\r\n      this.jsf.addItem({\r\n        layoutNode: signal(layoutNode.items[index]),\r\n        layoutIndex: signal(this.layoutIndex().concat(index)),\r\n        dataIndex: signal(this.dataIndex().concat(index))\r\n      });\r\n      this.updateControl();\r\n    }\r\n    this.selectedItem = index;\r\n  }\r\n\r\n  updateControl() {\r\n    const lastItem = this.layoutNode().items[this.layoutNode().items.length - 1];\r\n    if (lastItem.type === '$ref' &&\r\n      this.itemCount >= (lastItem.options.maxItems || 1000)\r\n    ) {\r\n      this.showAddTab = false;\r\n    }\r\n  }\r\n\r\n  setTabTitle(item: any, index: number): string {\r\n    return this.jsf.setArrayItemTitle(this, item, index);\r\n  }\r\n}\r\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daisyui-tabs.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-daisyui/src/lib/widgets/daisyui-tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnDestroy, OnInit, inject, input, signal } from '@angular/core';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'daisyui-tabs-widget',\r\n    template: `\r\n    <div\r\n      [class]=\"options?.labelHtmlClass || ''\">\r\n      <a *ngFor=\"let item of layoutNode()?.items; let i = index\"\r\n        [class]=\"(options?.itemLabelHtmlClass || '') + (selectedItem === i ?\r\n          (' ' + (options?.activeClass || '') + ' ' + (options?.style?.selected || '')) :\r\n          (' ' + options?.style?.unselected))\"\r\n          (click)=\"select(i)\"\r\n        >\r\n          <input type=\"radio\" [value]=\"i\" *ngIf=\"options?.tabMode=='oneOfMode'\" \r\n           name=\"tabSelection\" \r\n           [(ngModel)]=\"selectedItem\"\r\n           [class]=\"(options?.widget_radioClass || '')\"\r\n           [value]=\"i\" \r\n           (change)=\"select(i)\"\r\n          />\r\n        <span *ngIf=\"showAddTab || item.type !== '$ref'\"\r\n        [class]=\"(selectedItem === i ? (' ' + options?.activeClass + ' ' + options?.style?.selected) :\r\n        (' ' + options?.style?.unselected))\">{{setTabTitle(item, i)}}</span>\r\n          \r\n      </a>\r\n\r\n    </div>\r\n\r\n    <!--\r\n    <div class=\"tabs tabs-boxed\">\r\n  <a class=\"tab\">Tab 1</a> \r\n  <a class=\"tab tab-active\">Tab 2</a> \r\n  <a class=\"tab\">Tab 3</a>\r\n</div>\r\n-->\r\n\r\n    <div *ngFor=\"let layoutItem of layoutNode()?.items; let i = index\"\r\n      [class]=\"(options?.htmlClass || '') + (selectedItem != i?' ngf-hidden':'')\">\r\n      <ng-container *ngIf=\"options?.tabMode=='oneOfMode'\">\r\n        <select-framework-widget *ngIf=\"selectedItem === i\"\r\n          [class]=\"(options?.fieldHtmlClass || '') +\r\n            ' ' + (options?.activeClass || '') +\r\n            ' ' + (options?.style?.selected || '')\"\r\n          [dataIndex]=\"layoutNode()?.dataType === 'array' ? (dataIndex() || []).concat(i) : dataIndex()\"\r\n          [layoutIndex]=\"(layoutIndex() || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"options?.tabMode != 'oneOfMode'\">\r\n        <select-framework-widget \r\n          [class]=\"(options?.fieldHtmlClass || '') +\r\n            ' ' + (options?.activeClass || '') +\r\n            ' ' + (options?.style?.selected || '')\"\r\n          [dataIndex]=\"layoutNode()?.dataType === 'array' ? (dataIndex() || []).concat(i) : dataIndex()\"\r\n          [layoutIndex]=\"(layoutIndex() || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n      </ng-container>\r\n    </div>`,\r\n    styles: [` a { cursor: pointer; }\r\n      .ngf-hidden{display:none}\r\n       `],\r\n    standalone: false\r\n})\r\nexport class DaisyUITabsComponent implements OnInit,OnDestroy {\r\n  private jsf = inject(JsonSchemaFormService);\r\n  private cdr = inject(ChangeDetectorRef);\r\n  options: any;\r\n  itemCount: number;\r\n  selectedItem = 0;\r\n  showAddTab = true;\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n  dataChangesSubs:Subscription;\r\n  ngOnInit() {\r\n    this.options = this.layoutNode().options || {};\r\n    if(this.options.selectedTab){\r\n      this.selectedItem = this.options.selectedTab;\r\n    }\r\n    this.itemCount = this.layoutNode().items.length - 1;\r\n    this.updateControl();\r\n    //TODO review/test-introduced to fix dynamic titles not updating\r\n    //when their conditional linked field is destroyed\r\n    //-forces change detection!\r\n    this.jsf.dataChanges.subscribe((val)=>{\r\n      this.cdr.detectChanges();\r\n  })\r\n  }\r\n\r\n  select(index) {\r\n    const layoutNode = this.layoutNode();\r\n    if (layoutNode.items[index].type === '$ref') {\r\n      this.itemCount = layoutNode.items.length;\r\n      this.jsf.addItem({\r\n        layoutNode: signal(layoutNode.items[index]),\r\n        layoutIndex: signal(this.layoutIndex().concat(index)),\r\n        dataIndex: signal(this.dataIndex().concat(index))\r\n      });\r\n      this.updateControl();\r\n    }\r\n    this.selectedItem = index;\r\n  }\r\n\r\n  updateControl() {\r\n    const lastItem = this.layoutNode().items[this.layoutNode().items.length - 1];\r\n    if (lastItem.type === '$ref' &&\r\n      this.itemCount >= (lastItem.options.maxItems || 1000)\r\n    ) {\r\n      this.showAddTab = false;\r\n    }\r\n  }\r\n\r\n  setTabTitle(item: any, index: number): string {\r\n    return this.jsf.setArrayItemTitle(this, item, index);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.dataChangesSubs?.unsubscribe();\r\n  }\r\n}\r\n"]}