@ng-formworks/material 16.6.7 → 16.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.
- package/esm2022/lib/material-design-framework.component.mjs +4 -4
- package/esm2022/lib/widgets/material-tabs.component.mjs +16 -7
- package/fesm2022/ng-formworks-material.mjs +18 -9
- package/fesm2022/ng-formworks-material.mjs.map +1 -1
- package/lib/material-design-framework.module.d.ts +2 -2
- package/lib/widgets/material-tabs.component.d.ts +6 -3
- package/package.json +3 -3
|
@@ -5,8 +5,9 @@ import * as i2 from "@angular/common";
|
|
|
5
5
|
import * as i3 from "@angular/material/radio";
|
|
6
6
|
import * as i4 from "@angular/material/tabs";
|
|
7
7
|
export class MaterialTabsComponent {
|
|
8
|
-
constructor(jsf) {
|
|
8
|
+
constructor(jsf, cdr) {
|
|
9
9
|
this.jsf = jsf;
|
|
10
|
+
this.cdr = cdr;
|
|
10
11
|
this.selectedItem = 0;
|
|
11
12
|
this.showAddTab = true;
|
|
12
13
|
}
|
|
@@ -38,8 +39,16 @@ export class MaterialTabsComponent {
|
|
|
38
39
|
setTabTitle(item, index) {
|
|
39
40
|
return this.jsf.setArrayItemTitle(this, item, index);
|
|
40
41
|
}
|
|
41
|
-
|
|
42
|
-
|
|
42
|
+
ngOnChanges(changes) {
|
|
43
|
+
//TODO review/test-introduced to fix dynamic titles not updating
|
|
44
|
+
//when their conditional linked field is destroyed
|
|
45
|
+
//-forces change detection!
|
|
46
|
+
this.cdr.detectChanges();
|
|
47
|
+
}
|
|
48
|
+
ngOnDestroy() {
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MaterialTabsComponent, deps: [{ token: i1.JsonSchemaFormService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MaterialTabsComponent, selector: "material-tabs-widget", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, usesOnChanges: true, ngImport: i0, template: `
|
|
43
52
|
<nav mat-tab-nav-bar [tabPanel]="tabPanel"
|
|
44
53
|
[attr.aria-label]="options?.label || layoutNode.options?.title || ''"
|
|
45
54
|
[style.width]="'100%'">
|
|
@@ -88,7 +97,7 @@ export class MaterialTabsComponent {
|
|
|
88
97
|
[layoutNode]="layoutItem"></select-framework-widget>
|
|
89
98
|
</ng-container>
|
|
90
99
|
<ng-container *ngIf="options?.tabMode !='oneOfMode'">
|
|
91
|
-
<select-framework-widget
|
|
100
|
+
<select-framework-widget
|
|
92
101
|
[class]="(options?.fieldHtmlClass || '') + ' ' + (options?.activeClass || '') + ' ' + (options?.style?.selected || '')"
|
|
93
102
|
[dataIndex]="layoutNode?.dataType === 'array' ? (dataIndex || []).concat(i) : dataIndex"
|
|
94
103
|
[layoutIndex]="(layoutIndex || []).concat(i)"
|
|
@@ -150,7 +159,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
150
159
|
[layoutNode]="layoutItem"></select-framework-widget>
|
|
151
160
|
</ng-container>
|
|
152
161
|
<ng-container *ngIf="options?.tabMode !='oneOfMode'">
|
|
153
|
-
<select-framework-widget
|
|
162
|
+
<select-framework-widget
|
|
154
163
|
[class]="(options?.fieldHtmlClass || '') + ' ' + (options?.activeClass || '') + ' ' + (options?.style?.selected || '')"
|
|
155
164
|
[dataIndex]="layoutNode?.dataType === 'array' ? (dataIndex || []).concat(i) : dataIndex"
|
|
156
165
|
[layoutIndex]="(layoutIndex || []).concat(i)"
|
|
@@ -160,11 +169,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
160
169
|
</mat-tab-nav-panel>
|
|
161
170
|
|
|
162
171
|
`, standalone: false, styles: ["a{cursor:pointer}.ngf-hidden{display:none}\n"] }]
|
|
163
|
-
}], ctorParameters: function () { return [{ type: i1.JsonSchemaFormService }]; }, propDecorators: { layoutNode: [{
|
|
172
|
+
}], ctorParameters: function () { return [{ type: i1.JsonSchemaFormService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { layoutNode: [{
|
|
164
173
|
type: Input
|
|
165
174
|
}], layoutIndex: [{
|
|
166
175
|
type: Input
|
|
167
176
|
}], dataIndex: [{
|
|
168
177
|
type: Input
|
|
169
178
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-tabs.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/material-tabs.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,KAAK,EAA+C,MAAM,eAAe,CAAC;;;;;;AAsEjH,MAAM,OAAO,qBAAqB;IAShC,YACU,GAA0B,EAC1B,GAAsB;QADtB,QAAG,GAAH,GAAG,CAAuB;QAC1B,QAAG,GAAH,GAAG,CAAmB;QARhC,iBAAY,GAAG,CAAC,CAAC;QACjB,eAAU,GAAG,IAAI,CAAC;IAQd,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,EAAE,CAAC;QAC7C,IAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;SAC9C;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,KAAK;QACV,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,MAAM,EAAE;YAChD,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC;gBACf,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC;gBACxC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC;gBAC3C,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC;aACxC,CAAC,CAAC;YACH,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QACD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,IAAI,KAAK,MAAM;YACxC,IAAI,CAAC,SAAS,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;IACzD,CAAC;IAED,WAAW,CAAC,IAAS,EAAE,KAAa;QAClC,OAAO,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACvD,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,gEAAgE;QAChE,kDAAkD;QAClD,2BAA2B;QAC3B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IACD,WAAW;IAEX,CAAC;+GAtDU,qBAAqB;mGAArB,qBAAqB,2KAhEtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0DX;;4FAMY,qBAAqB;kBAnEjC,SAAS;+BAEE,sBAAsB,YACtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0DX,cAIe,KAAK;4IAOV,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'material-tabs-widget',\r\n  template: `\r\n    <nav mat-tab-nav-bar [tabPanel]=\"tabPanel\"\r\n      [attr.aria-label]=\"options?.label || layoutNode.options?.title || ''\"\r\n      [style.width]=\"'100%'\">\r\n      \r\n        <a mat-tab-link *ngFor=\"let item of layoutNode?.items; let i = index\"\r\n          [active]=\"selectedItem === i\"\r\n          (click)=\"select(i)\">\r\n          \r\n\r\n         <!--   \r\n          <input \r\n      type=\"radio\" \r\n      name=\"tabSelection\" \r\n      [(ngModel)]=\"selectedItem\" \r\n      [value]=\"i\" \r\n      (change)=\"select(i)\" class=\"mat-mdc-radio-button\" />\r\n\r\n    {{ setTabTitle(item, i) }}\r\n     -->\r\n        <mat-radio-button *ngIf=\"options?.tabMode=='oneOfMode'\"\r\n          [checked]=\"selectedItem === i\" \r\n          [value]=\"i\"\r\n          >\r\n        </mat-radio-button>\r\n\r\n          <span *ngIf=\"showAddTab || item.type !== '$ref'\"\r\n            [innerHTML]=\"setTabTitle(item, i)\"></span>\r\n                  \r\n        </a>\r\n\r\n        \r\n    </nav>\r\n        <mat-tab-nav-panel #tabPanel>\r\n          <div *ngFor=\"let layoutItem of layoutNode?.items; let i = index\" \r\n            [class]=\"(options?.htmlClass || '') + (selectedItem != i?' ngf-hidden':'')\">\r\n               <!--for now the only difference between oneOfMode and the default \r\n                is that oneOfMode uses the *ngIf=\"selectedItem === i\" clause, which automatically\r\n                destroys the tabs that are not rendered while default mode only hide them\r\n                the upshot is that only the active tabs value will be used\r\n              -->\r\n            <ng-container *ngIf=\"options?.tabMode=='oneOfMode'\">\r\n              <select-framework-widget *ngIf=\"selectedItem === i\"\r\n                [class]=\"(options?.fieldHtmlClass || '') + ' ' + (options?.activeClass || '') + ' ' + (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 || '') + ' ' + (options?.activeClass || '') + ' ' + (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        </mat-tab-nav-panel>\r\n\r\n`,\r\n    styles: [` a { cursor: pointer; } \r\n            .ngf-hidden{display:none}\r\n      `],\r\n    standalone: false\r\n})\r\nexport class MaterialTabsComponent implements OnInit,OnDestroy,OnChanges {\r\n  options: any;\r\n  itemCount: number;\r\n  selectedItem = 0;\r\n  showAddTab = true;\r\n  @Input() layoutNode: any;\r\n  @Input() layoutIndex: number[];\r\n  @Input() dataIndex: number[];\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\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    if (this.layoutNode.items[index].type === '$ref') {\r\n      this.jsf.addItem({\r\n        layoutNode: this.layoutNode.items[index],\r\n        layoutIndex: this.layoutIndex.concat(index),\r\n        dataIndex: 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    this.itemCount = this.layoutNode.items.length - 1;\r\n    const lastItem = this.layoutNode.items[this.layoutNode.items.length - 1];\r\n    this.showAddTab = lastItem.type === '$ref' &&\r\n      this.itemCount < (lastItem.options.maxItems || 1000);\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  ngOnChanges(changes: SimpleChanges): void {\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.cdr.detectChanges();\r\n  }\r\n  ngOnDestroy(): void {\r\n    \r\n  }\r\n}\r\n"]}
|