@ldw-framework/material-langs 0.1.0 → 0.2.0
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,3 +1,4 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
1
2
|
import { CommonModule } from '@angular/common';
|
|
2
3
|
import * as i0 from '@angular/core';
|
|
3
4
|
import { InjectionToken, inject, EventEmitter, Injectable, Input, Component, NgModule } from '@angular/core';
|
|
@@ -69,6 +70,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImpor
|
|
|
69
70
|
|
|
70
71
|
class LDwMaterialMultiLangInputComponent {
|
|
71
72
|
service = inject(LDwMaterialMultiLangService);
|
|
73
|
+
loaded = false;
|
|
74
|
+
readonly$ = false;
|
|
75
|
+
required$ = false;
|
|
72
76
|
formGroup = new FormGroup({
|
|
73
77
|
value: new FormControl(null, [])
|
|
74
78
|
});
|
|
@@ -77,11 +81,9 @@ class LDwMaterialMultiLangInputComponent {
|
|
|
77
81
|
});
|
|
78
82
|
formParentControlName = 'value';
|
|
79
83
|
label = 'Value';
|
|
80
|
-
required = false;
|
|
81
|
-
requiredLabel = 'required';
|
|
82
84
|
appearance = 'outline';
|
|
83
|
-
readonly =
|
|
84
|
-
|
|
85
|
+
set readonly(v) { this.readonly$ = coerceBooleanProperty(v); }
|
|
86
|
+
set required(v) { this.required$ = coerceBooleanProperty(v); }
|
|
85
87
|
constructor() {
|
|
86
88
|
this.service.onChange().subscribe(lang => this.read(lang.value));
|
|
87
89
|
}
|
|
@@ -124,6 +126,10 @@ class LDwMaterialMultiLangInputComponent {
|
|
|
124
126
|
json[lang] = this.langValue.value;
|
|
125
127
|
this.langJson.setValue(JSON.stringify(json));
|
|
126
128
|
}
|
|
129
|
+
get readonly() { return this.readonly$; }
|
|
130
|
+
;
|
|
131
|
+
get required() { return this.required$; }
|
|
132
|
+
;
|
|
127
133
|
get langValue() {
|
|
128
134
|
return this.formGroup?.get('value');
|
|
129
135
|
}
|
|
@@ -131,7 +137,7 @@ class LDwMaterialMultiLangInputComponent {
|
|
|
131
137
|
return this.formParent?.get(this.formParentControlName);
|
|
132
138
|
}
|
|
133
139
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: LDwMaterialMultiLangInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
134
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
140
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.2.0", type: LDwMaterialMultiLangInputComponent, isStandalone: true, selector: "ldw-mat-multi-lang-input", inputs: { formParent: "formParent", formParentControlName: "formParentControlName", label: "label", appearance: "appearance", readonly: "readonly", required: "required" }, host: { classAttribute: "ldw-mat-multi-lang-input" }, ngImport: i0, template: `
|
|
135
141
|
<form
|
|
136
142
|
[formGroup]="formGroup"
|
|
137
143
|
novalidate
|
|
@@ -146,17 +152,10 @@ class LDwMaterialMultiLangInputComponent {
|
|
|
146
152
|
[required]="required"
|
|
147
153
|
(change)="onChange()"
|
|
148
154
|
/>
|
|
149
|
-
|
|
150
|
-
{
|
|
151
|
-
@if (langValue.hasError('required'))
|
|
152
|
-
{
|
|
153
|
-
<mat-error
|
|
154
|
-
[innerHTML]="requiredLabel" />
|
|
155
|
-
}
|
|
156
|
-
}
|
|
155
|
+
<ng-content />
|
|
157
156
|
</mat-form-field>
|
|
158
157
|
</form>
|
|
159
|
-
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],[formArray],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "
|
|
158
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],[formArray],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }] });
|
|
160
159
|
}
|
|
161
160
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: LDwMaterialMultiLangInputComponent, decorators: [{
|
|
162
161
|
type: Component,
|
|
@@ -185,14 +184,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImpor
|
|
|
185
184
|
[required]="required"
|
|
186
185
|
(change)="onChange()"
|
|
187
186
|
/>
|
|
188
|
-
|
|
189
|
-
{
|
|
190
|
-
@if (langValue.hasError('required'))
|
|
191
|
-
{
|
|
192
|
-
<mat-error
|
|
193
|
-
[innerHTML]="requiredLabel" />
|
|
194
|
-
}
|
|
195
|
-
}
|
|
187
|
+
<ng-content />
|
|
196
188
|
</mat-form-field>
|
|
197
189
|
</form>
|
|
198
190
|
`
|
|
@@ -206,15 +198,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImpor
|
|
|
206
198
|
}], label: [{
|
|
207
199
|
type: Input,
|
|
208
200
|
args: [{ required: true }]
|
|
209
|
-
}], required: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], requiredLabel: [{
|
|
212
|
-
type: Input
|
|
213
201
|
}], appearance: [{
|
|
214
202
|
type: Input
|
|
215
203
|
}], readonly: [{
|
|
216
204
|
type: Input
|
|
217
|
-
}],
|
|
205
|
+
}], required: [{
|
|
218
206
|
type: Input
|
|
219
207
|
}] } });
|
|
220
208
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ldw-framework-material-langs.mjs","sources":["../../../lib/src/config/ldw-mat-multi-lang.config.ts","../../../lib/src/services/ldw-mat-multi-lang.service.ts","../../../lib/src/components/ldw-mat-multi-lang-input.component.ts","../../../lib/src/components/ldw-mat-multi-lang-selector.component.ts","../../../lib/src/modules/ldw-mat-multi-lang.module.ts","../../../lib/src/ldw-framework-material-langs.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\nimport { LDwMaterialMultiLang } from '../models/ldw-mat-multi-lang.model';\n\nexport const LDW_MAT_MULTI_LANG = new InjectionToken<{\n storageKey: string;\n langs: LDwMaterialMultiLang[];\n}>('LDW_MAT_MULTI_LANG');\n","import { EventEmitter, inject, Injectable } from '@angular/core';\nimport { LDW_MAT_MULTI_LANG } from '../config/ldw-mat-multi-lang.config';\nimport { LDwMaterialMultiLang } from '../models/ldw-mat-multi-lang.model';\n\n@Injectable({ providedIn: 'root' })\nexport class LDwMaterialMultiLangService {\n\n protected readonly ENV$ = inject(LDW_MAT_MULTI_LANG);\n\n protected readonly storage$ = localStorage;\n\n protected readonly key = this.ENV.storageKey;\n\n protected selectedLang: LDwMaterialMultiLang | null | undefined;\n\n protected selectedLangIdx: number | null | undefined;\n\n protected selectedLangChange = new EventEmitter<LDwMaterialMultiLang>();\n\n onInit() {\n if (!this.check()) {\n this.setByIdx(0);\n } else {\n this.setByValue(this.get() ?? '');\n }\n }\n\n onChange() {\n return this.selectedLangChange;\n }\n\n setByIdx(idx: number) {\n this.selectedLangIdx = idx;\n this.selectedLang = this.langs[this.selectedLangIdx];\n this.set(this.selectedLang.value);\n this.selectedLangChange.emit(this.selectedLang);\n }\n\n getSelectedValue() {\n return this.selectedLang?.value ?? '-';\n }\n\n setByValue(value: string) {\n this.setByIdx(this.langs.findIndex(lang => lang.value === value));\n }\n\n protected check() {\n return !!this.get();\n }\n\n protected get() {\n return this.storage.getItem(this.key);\n }\n\n protected set(value: string) {\n this.storage.setItem(this.key, value);\n }\n\n protected remove() {\n this.storage.removeItem(this.key);\n }\n\n get ENV() { return this.ENV$; }\n\n get storage() { return this.storage$; }\n\n get langs() { return this.ENV.langs ?? []; }\n\n get langIdx() { return this.selectedLangIdx ?? 0; }\n}\n","import { CommonModule } from '@angular/common';\nimport { Component, inject, Input, OnInit } from '@angular/core';\nimport { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { LDwMaterialMultiLangService } from '../services/ldw-mat-multi-lang.service';\n\n@Component({\n selector: 'ldw-mat-multi-lang-input',\n host: { class: 'ldw-mat-multi-lang-input' },\n imports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n MatFormFieldModule,\n MatInputModule,\n ],\n template: `\n <form\n [formGroup]=\"formGroup\"\n novalidate\n ><mat-form-field\n [appearance]=\"appearance\"\n ><mat-label\n [innerHTML]=\"label\" />\n <input matInput\n name=\"value\"\n formControlName=\"value\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n (change)=\"onChange()\"\n />\n @if (langValue.touched)\n {\n @if (langValue.hasError('required'))\n {\n <mat-error\n [innerHTML]=\"requiredLabel\" />\n }\n }\n </mat-form-field>\n </form>\n`})\nexport class LDwMaterialMultiLangInputComponent implements OnInit {\n\n private readonly service = inject(LDwMaterialMultiLangService);\n\n formGroup = new FormGroup({\n value: new FormControl<string | null | undefined>(null, [])\n });\n\n @Input({ required: true })\n formParent: FormGroup = new FormGroup({\n value: new FormControl<string | null | undefined>(null, [])\n });\n\n @Input({ required: true }) formParentControlName = 'value';\n\n @Input({ required: true }) label = 'Value';\n\n @Input() required = false;\n\n @Input() requiredLabel = 'required';\n\n @Input() appearance: 'fill' | 'outline' = 'outline';\n\n @Input() readonly = false;\n\n @Input() loaded = false;\n\n constructor() {\n this.service.onChange().subscribe(lang => this.read(lang.value));\n }\n\n ngOnInit() {\n this.fill();\n this.read(this.service.getSelectedValue());\n this.langJson.registerOnChange(() => {\n if (!this.loaded) {\n this.loaded = true;\n this.read(this.service.getSelectedValue());\n }\n });\n }\n\n onChange() {\n this.write(this.service.getSelectedValue());\n }\n\n private fill() {\n let filled = false;\n const json = JSON.parse(this.langJson?.value ?? '{}');\n this.service.langs.forEach(l => {\n if (!json[l.value]) {\n json[l.value] = '';\n filled = true;\n }\n });\n if (filled) {\n this.langJson.setValue(JSON.stringify(json));\n }\n }\n\n private read(lang: string) {\n const json = JSON.parse(this.langJson?.value ?? '{}');\n if (!json[lang]) {\n json[lang] = '';\n }\n this.langValue.setValue(json[lang]);\n this.langJson.setValue(JSON.stringify(json));\n }\n\n private write(lang: string) {\n const json = JSON.parse(this.langJson?.value ?? '{}');\n json[lang] = this.langValue.value;\n this.langJson.setValue(JSON.stringify(json));\n }\n\n get langValue() {\n return this.formGroup?.get('value') as FormControl<string | null | undefined>;\n }\n\n get langJson() {\n return this.formParent?.get(this.formParentControlName) as FormControl<string | null | undefined>;\n }\n}\n","import { CommonModule } from '@angular/common';\nimport { Component, inject, OnInit } from '@angular/core';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { LDuAnguBootTranslationPipe } from '@ldu-anguboot/i18n';\nimport { LDwMaterialMultiLangService } from '../services/ldw-mat-multi-lang.service';\n\n@Component({\n selector: 'ldw-mat-multi-lang-selector',\n host: { class: 'ldw-mat-multi-lang-selector' },\n imports: [\n CommonModule,\n LDuAnguBootTranslationPipe,\n MatTabsModule,\n ],\n template: `\n <mat-tab-group\n animationDuration=\"0ms\"\n [selectedIndex]=\"langIdx\"\n (selectedIndexChange)=\"onChange($event)\"\n >\n @for (lang of langs; track lang.value)\n {\n <mat-tab [label]=\"lang.label | i18n\"></mat-tab>\n }\n </mat-tab-group>\n`})\nexport class LDwMaterialMultiLangSelectorComponent implements OnInit {\n\n private readonly service = inject(LDwMaterialMultiLangService);\n\n readonly langs = this.service.langs;\n\n langIdx = 0;\n\n ngOnInit() {\n this.langIdx = this.service.langIdx ?? 0;\n }\n\n onChange($event: number) {\n this.service.setByIdx($event);\n }\n}\n","import { NgModule } from '@angular/core';\nimport { LDwMaterialMultiLangInputComponent } from '../components/ldw-mat-multi-lang-input.component';\nimport { LDwMaterialMultiLangSelectorComponent } from '../components/ldw-mat-multi-lang-selector.component';\n\nconst components = [\n LDwMaterialMultiLangSelectorComponent,\n LDwMaterialMultiLangInputComponent,\n];\n\n@NgModule({\n imports: [...components],\n exports: [...components]\n})\nexport class LDwMaterialMultiLangModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1"],"mappings":";;;;;;;;;;;;;MAGa,kBAAkB,GAAG,IAAI,cAAc,CAGjD,oBAAoB;;MCDV,2BAA2B,CAAA;AAEjB,IAAA,IAAI,GAAG,MAAM,CAAC,kBAAkB,CAAC;IAEjC,QAAQ,GAAG,YAAY;AAEvB,IAAA,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU;AAElC,IAAA,YAAY;AAEZ,IAAA,eAAe;AAEf,IAAA,kBAAkB,GAAG,IAAI,YAAY,EAAwB;IAEvE,MAAM,GAAA;AACF,QAAA,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE;AACf,YAAA,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QACpB;aAAO;YACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC;QACrC;IACJ;IAEA,QAAQ,GAAA;QACJ,OAAO,IAAI,CAAC,kBAAkB;IAClC;AAEA,IAAA,QAAQ,CAAC,GAAW,EAAA;AAChB,QAAA,IAAI,CAAC,eAAe,GAAG,GAAG;QAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;QACpD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;IACnD;IAEA,gBAAgB,GAAA;AACZ,QAAA,OAAO,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,GAAG;IAC1C;AAEA,IAAA,UAAU,CAAC,KAAa,EAAA;QACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;IACrE;IAEU,KAAK,GAAA;AACX,QAAA,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;IACvB;IAEU,GAAG,GAAA;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;IACzC;AAEU,IAAA,GAAG,CAAC,KAAa,EAAA;QACvB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC;IACzC;IAEU,MAAM,GAAA;QACZ,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC;IACrC;IAEA,IAAI,GAAG,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC;IAE9B,IAAI,OAAO,KAAK,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC;AAEtC,IAAA,IAAI,KAAK,GAAA,EAAK,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;IAE3C,IAAI,OAAO,GAAA,EAAK,OAAO,IAAI,CAAC,eAAe,IAAI,CAAC,CAAC,CAAC;uGA/DzC,2BAA2B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA;AAA3B,IAAA,OAAA,KAAA,GAAA,EAAA,CAAA,qBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,2BAA2B,cADd,MAAM,EAAA,CAAA;;2FACnB,2BAA2B,EAAA,UAAA,EAAA,CAAA;kBADvC,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;;MCuCrB,kCAAkC,CAAA;AAE1B,IAAA,OAAO,GAAG,MAAM,CAAC,2BAA2B,CAAC;IAE9D,SAAS,GAAG,IAAI,SAAS,CAAC;AACtB,QAAA,KAAK,EAAE,IAAI,WAAW,CAA4B,IAAI,EAAE,EAAE;AAC7D,KAAA,CAAC;IAGF,UAAU,GAAc,IAAI,SAAS,CAAC;AAClC,QAAA,KAAK,EAAE,IAAI,WAAW,CAA4B,IAAI,EAAE,EAAE;AAC7D,KAAA,CAAC;IAEyB,qBAAqB,GAAG,OAAO;IAE/B,KAAK,GAAG,OAAO;IAEjC,QAAQ,GAAG,KAAK;IAEhB,aAAa,GAAG,UAAU;IAE1B,UAAU,GAAuB,SAAS;IAE1C,QAAQ,GAAG,KAAK;IAEhB,MAAM,GAAG,KAAK;AAEvB,IAAA,WAAA,GAAA;QACI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpE;IAEA,QAAQ,GAAA;QACJ,IAAI,CAAC,IAAI,EAAE;QACX,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;AAC1C,QAAA,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,MAAK;AAChC,YAAA,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,GAAG,IAAI;gBAClB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;YAC9C;AACJ,QAAA,CAAC,CAAC;IACN;IAEA,QAAQ,GAAA;QACJ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAC/C;IAEQ,IAAI,GAAA;QACR,IAAI,MAAM,GAAG,KAAK;AAClB,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI,CAAC;QACrD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAG;YAC3B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;AAChB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;gBAClB,MAAM,GAAG,IAAI;YACjB;AACJ,QAAA,CAAC,CAAC;QACF,IAAI,MAAM,EAAE;AACR,YAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAChD;IACJ;AAEQ,IAAA,IAAI,CAAC,IAAY,EAAA;AACrB,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI,CAAC;AACrD,QAAA,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;AACb,YAAA,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;QACnB;QACA,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACnC,QAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAChD;AAEQ,IAAA,KAAK,CAAC,IAAY,EAAA;AACtB,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI,CAAC;QACrD,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK;AACjC,QAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAChD;AAEA,IAAA,IAAI,SAAS,GAAA;QACT,OAAO,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC,OAAO,CAA2C;IACjF;AAEA,IAAA,IAAI,QAAQ,GAAA;QACR,OAAO,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAA2C;IACrG;uGAjFS,kCAAkC,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAAlC,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,kCAAkC,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,0BAAA,EAAA,MAAA,EAAA,EAAA,UAAA,EAAA,YAAA,EAAA,qBAAA,EAAA,uBAAA,EAAA,KAAA,EAAA,OAAA,EAAA,QAAA,EAAA,UAAA,EAAA,aAAA,EAAA,eAAA,EAAA,UAAA,EAAA,YAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,QAAA,EAAA,EAAA,IAAA,EAAA,EAAA,cAAA,EAAA,0BAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EA1BjC;;;;;;;;;;;;;;;;;;;;;;;;;CAyBb,EAAA,QAAA,EAAA,IAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EA/BO,YAAY,8BACZ,WAAW,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,aAAA,EAAA,QAAA,EAAA,8CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,oBAAA,EAAA,QAAA,EAAA,8MAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,2CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,oBAAA,EAAA,QAAA,EAAA,sGAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,iBAAA,EAAA,QAAA,EAAA,wIAAA,EAAA,MAAA,EAAA,CAAA,UAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EACX,mBAAmB,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,kBAAA,EAAA,QAAA,EAAA,aAAA,EAAA,MAAA,EAAA,CAAA,WAAA,CAAA,EAAA,OAAA,EAAA,CAAA,UAAA,CAAA,EAAA,QAAA,EAAA,CAAA,QAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,MAAA,EAAA,CAAA,iBAAA,EAAA,UAAA,EAAA,SAAA,CAAA,EAAA,OAAA,EAAA,CAAA,eAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EACnB,kBAAkB,uYAClB,cAAc,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,QAAA,EAAA,QAAA,EAAA,yHAAA,EAAA,MAAA,EAAA,CAAA,UAAA,EAAA,IAAA,EAAA,aAAA,EAAA,MAAA,EAAA,UAAA,EAAA,MAAA,EAAA,mBAAA,EAAA,kBAAA,EAAA,OAAA,EAAA,UAAA,EAAA,qBAAA,CAAA,EAAA,QAAA,EAAA,CAAA,UAAA,CAAA,EAAA,CAAA,EAAA,CAAA;;2FA4BT,kCAAkC,EAAA,UAAA,EAAA,CAAA;kBApC9C,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,QAAQ,EAAE,0BAA0B;AACpC,oBAAA,IAAI,EAAE,EAAE,KAAK,EAAE,0BAA0B,EAAE;AAC3C,oBAAA,OAAO,EAAE;wBACL,YAAY;wBACZ,WAAW;wBACX,mBAAmB;wBACnB,kBAAkB;wBAClB,cAAc;AACjB,qBAAA;AACD,oBAAA,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;AAyBb;AAAC,iBAAA;;sBASG,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;;sBAKxB,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;;sBAExB,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;;sBAExB;;sBAEA;;sBAEA;;sBAEA;;sBAEA;;;MC1CQ,qCAAqC,CAAA;AAE7B,IAAA,OAAO,GAAG,MAAM,CAAC,2BAA2B,CAAC;AAErD,IAAA,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK;IAEnC,OAAO,GAAG,CAAC;IAEX,QAAQ,GAAA;QACJ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC;IAC5C;AAEA,IAAA,QAAQ,CAAC,MAAc,EAAA;AACnB,QAAA,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;IACjC;uGAdS,qCAAqC,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAArC,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,qCAAqC,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,6BAAA,EAAA,IAAA,EAAA,EAAA,cAAA,EAAA,6BAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAZpC;;;;;;;;;;;AAWb,CAAA,EAAA,QAAA,EAAA,IAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAfO,YAAY,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAEZ,aAAa,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,MAAA,EAAA,QAAA,EAAA,SAAA,EAAA,MAAA,EAAA,CAAA,UAAA,EAAA,OAAA,EAAA,YAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,WAAA,EAAA,IAAA,CAAA,EAAA,QAAA,EAAA,CAAA,QAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,WAAA,EAAA,QAAA,EAAA,eAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,oBAAA,EAAA,kBAAA,EAAA,gBAAA,EAAA,eAAA,EAAA,eAAA,EAAA,gBAAA,EAAA,mBAAA,EAAA,iBAAA,EAAA,mBAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,iBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,qBAAA,EAAA,aAAA,EAAA,eAAA,EAAA,mBAAA,CAAA,EAAA,QAAA,EAAA,CAAA,aAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EADb,0BAA0B,EAAA,IAAA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA;;2FAerB,qCAAqC,EAAA,UAAA,EAAA,CAAA;kBApBjD,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,QAAQ,EAAE,6BAA6B;AACvC,oBAAA,IAAI,EAAE,EAAE,KAAK,EAAE,6BAA6B,EAAE;AAC9C,oBAAA,OAAO,EAAE;wBACL,YAAY;wBACZ,0BAA0B;wBAC1B,aAAa;AAChB,qBAAA;AACD,oBAAA,QAAQ,EAAE;;;;;;;;;;;AAWb;AAAC,iBAAA;;;ACrBF,MAAM,UAAU,GAAG;IACf,qCAAqC;IACrC,kCAAkC;CACrC;MAMY,0BAA0B,CAAA;uGAA1B,0BAA0B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA;AAA1B,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,0BAA0B,YARnC,qCAAqC;AACrC,YAAA,kCAAkC,aADlC,qCAAqC;YACrC,kCAAkC,CAAA,EAAA,CAAA;AAOzB,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,0BAA0B,YAHtB,UAAU,CAAA,EAAA,CAAA;;2FAGd,0BAA0B,EAAA,UAAA,EAAA,CAAA;kBAJtC,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACN,oBAAA,OAAO,EAAE,CAAC,GAAG,UAAU,CAAC;AACxB,oBAAA,OAAO,EAAE,CAAC,GAAG,UAAU;AAC1B,iBAAA;;;ACZD;;AAEG;;;;"}
|
|
1
|
+
{"version":3,"file":"ldw-framework-material-langs.mjs","sources":["../../../lib/src/config/ldw-mat-multi-lang.config.ts","../../../lib/src/services/ldw-mat-multi-lang.service.ts","../../../lib/src/components/ldw-mat-multi-lang-input.component.ts","../../../lib/src/components/ldw-mat-multi-lang-selector.component.ts","../../../lib/src/modules/ldw-mat-multi-lang.module.ts","../../../lib/src/ldw-framework-material-langs.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\nimport { LDwMaterialMultiLang } from '../models/ldw-mat-multi-lang.model';\n\nexport const LDW_MAT_MULTI_LANG = new InjectionToken<{\n storageKey: string;\n langs: LDwMaterialMultiLang[];\n}>('LDW_MAT_MULTI_LANG');\n","import { EventEmitter, inject, Injectable } from '@angular/core';\nimport { LDW_MAT_MULTI_LANG } from '../config/ldw-mat-multi-lang.config';\nimport { LDwMaterialMultiLang } from '../models/ldw-mat-multi-lang.model';\n\n@Injectable({ providedIn: 'root' })\nexport class LDwMaterialMultiLangService {\n\n protected readonly ENV$ = inject(LDW_MAT_MULTI_LANG);\n\n protected readonly storage$ = localStorage;\n\n protected readonly key = this.ENV.storageKey;\n\n protected selectedLang: LDwMaterialMultiLang | null | undefined;\n\n protected selectedLangIdx: number | null | undefined;\n\n protected selectedLangChange = new EventEmitter<LDwMaterialMultiLang>();\n\n onInit() {\n if (!this.check()) {\n this.setByIdx(0);\n } else {\n this.setByValue(this.get() ?? '');\n }\n }\n\n onChange() {\n return this.selectedLangChange;\n }\n\n setByIdx(idx: number) {\n this.selectedLangIdx = idx;\n this.selectedLang = this.langs[this.selectedLangIdx];\n this.set(this.selectedLang.value);\n this.selectedLangChange.emit(this.selectedLang);\n }\n\n getSelectedValue() {\n return this.selectedLang?.value ?? '-';\n }\n\n setByValue(value: string) {\n this.setByIdx(this.langs.findIndex(lang => lang.value === value));\n }\n\n protected check() {\n return !!this.get();\n }\n\n protected get() {\n return this.storage.getItem(this.key);\n }\n\n protected set(value: string) {\n this.storage.setItem(this.key, value);\n }\n\n protected remove() {\n this.storage.removeItem(this.key);\n }\n\n get ENV() { return this.ENV$; }\n\n get storage() { return this.storage$; }\n\n get langs() { return this.ENV.langs ?? []; }\n\n get langIdx() { return this.selectedLangIdx ?? 0; }\n}\n","import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { CommonModule } from '@angular/common';\nimport { Component, inject, Input, OnInit } from '@angular/core';\nimport { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { LDwMaterialMultiLangService } from '../services/ldw-mat-multi-lang.service';\n\n@Component({\n selector: 'ldw-mat-multi-lang-input',\n host: { class: 'ldw-mat-multi-lang-input' },\n imports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n MatFormFieldModule,\n MatInputModule,\n ],\n template: `\n <form\n [formGroup]=\"formGroup\"\n novalidate\n ><mat-form-field\n [appearance]=\"appearance\"\n ><mat-label\n [innerHTML]=\"label\" />\n <input matInput\n name=\"value\"\n formControlName=\"value\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n (change)=\"onChange()\"\n />\n <ng-content />\n </mat-form-field>\n </form>\n`})\nexport class LDwMaterialMultiLangInputComponent implements OnInit {\n\n private readonly service = inject(LDwMaterialMultiLangService);\n\n private loaded = false;\n\n private readonly$: string | boolean = false;\n\n private required$: string | boolean = false;\n\n formGroup = new FormGroup({\n value: new FormControl<string | null | undefined>(null, [])\n });\n\n @Input({ required: true })\n formParent: FormGroup = new FormGroup({\n value: new FormControl<string | null | undefined>(null, [])\n });\n\n @Input({ required: true })\n formParentControlName = 'value';\n\n @Input({ required: true })\n label = 'Value';\n\n @Input()\n appearance: 'fill' | 'outline' = 'outline';\n\n @Input()\n set readonly(v) { this.readonly$ = coerceBooleanProperty(v); }\n\n @Input()\n set required(v) { this.required$ = coerceBooleanProperty(v); }\n\n constructor() {\n this.service.onChange().subscribe(lang => this.read(lang.value));\n }\n\n ngOnInit() {\n this.fill();\n this.read(this.service.getSelectedValue());\n this.langJson.registerOnChange(() => {\n if (!this.loaded) {\n this.loaded = true;\n this.read(this.service.getSelectedValue());\n }\n });\n }\n\n onChange() {\n this.write(this.service.getSelectedValue());\n }\n\n private fill() {\n let filled = false;\n const json = JSON.parse(this.langJson?.value ?? '{}');\n this.service.langs.forEach(l => {\n if (!json[l.value]) {\n json[l.value] = '';\n filled = true;\n }\n });\n if (filled) {\n this.langJson.setValue(JSON.stringify(json));\n }\n }\n\n private read(lang: string) {\n const json = JSON.parse(this.langJson?.value ?? '{}');\n if (!json[lang]) {\n json[lang] = '';\n }\n this.langValue.setValue(json[lang]);\n this.langJson.setValue(JSON.stringify(json));\n }\n\n private write(lang: string) {\n const json = JSON.parse(this.langJson?.value ?? '{}');\n json[lang] = this.langValue.value;\n this.langJson.setValue(JSON.stringify(json));\n }\n\n get readonly() { return this.readonly$; };\n\n get required() { return this.required$; };\n\n get langValue() {\n return this.formGroup?.get('value') as FormControl<string | null | undefined>;\n }\n\n get langJson() {\n return this.formParent?.get(this.formParentControlName) as FormControl<string | null | undefined>;\n }\n}\n","import { CommonModule } from '@angular/common';\nimport { Component, inject, OnInit } from '@angular/core';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { LDuAnguBootTranslationPipe } from '@ldu-anguboot/i18n';\nimport { LDwMaterialMultiLangService } from '../services/ldw-mat-multi-lang.service';\n\n@Component({\n selector: 'ldw-mat-multi-lang-selector',\n host: { class: 'ldw-mat-multi-lang-selector' },\n imports: [\n CommonModule,\n LDuAnguBootTranslationPipe,\n MatTabsModule,\n ],\n template: `\n <mat-tab-group\n animationDuration=\"0ms\"\n [selectedIndex]=\"langIdx\"\n (selectedIndexChange)=\"onChange($event)\"\n >\n @for (lang of langs; track lang.value)\n {\n <mat-tab [label]=\"lang.label | i18n\"></mat-tab>\n }\n </mat-tab-group>\n`})\nexport class LDwMaterialMultiLangSelectorComponent implements OnInit {\n\n private readonly service = inject(LDwMaterialMultiLangService);\n\n readonly langs = this.service.langs;\n\n langIdx = 0;\n\n ngOnInit() {\n this.langIdx = this.service.langIdx ?? 0;\n }\n\n onChange($event: number) {\n this.service.setByIdx($event);\n }\n}\n","import { NgModule } from '@angular/core';\nimport { LDwMaterialMultiLangInputComponent } from '../components/ldw-mat-multi-lang-input.component';\nimport { LDwMaterialMultiLangSelectorComponent } from '../components/ldw-mat-multi-lang-selector.component';\n\nconst components = [\n LDwMaterialMultiLangSelectorComponent,\n LDwMaterialMultiLangInputComponent,\n];\n\n@NgModule({\n imports: [...components],\n exports: [...components]\n})\nexport class LDwMaterialMultiLangModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ldw-framework/material-langs",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^21.0.0",
|
|
6
6
|
"@angular/core": "^21.0.0",
|
|
7
7
|
"@angular/forms": "^21.0.0",
|
|
8
8
|
"@angular/material": "^21.0.0",
|
|
9
|
-
"@ldu-anguboot/i18n": "latest"
|
|
9
|
+
"@ldu-anguboot/i18n": "latest",
|
|
10
|
+
"ngx-editor": "latest"
|
|
10
11
|
},
|
|
11
12
|
"module": "fesm2022/ldw-framework-material-langs.mjs",
|
|
12
13
|
"typings": "types/ldw-framework-material-langs.d.ts",
|
|
@@ -11,4 +11,26 @@
|
|
|
11
11
|
.ldw-mat-multi-lang-selector {
|
|
12
12
|
margin-bottom: 1rem;
|
|
13
13
|
display: block;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.ldw-mat-multi-lang-html-editor {
|
|
17
|
+
width: 100%;
|
|
18
|
+
height: 100%;
|
|
19
|
+
|
|
20
|
+
.ldw-mat-multi-lang-html-editor--instance {
|
|
21
|
+
height: 425px;
|
|
22
|
+
overflow: hidden;
|
|
23
|
+
|
|
24
|
+
.NgxEditor__MenuBar,
|
|
25
|
+
.NgxEditor {
|
|
26
|
+
background: inherit;
|
|
27
|
+
border-color: transparent;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
ngx-editor {
|
|
31
|
+
display: block;
|
|
32
|
+
height: calc(100% - 2rem);
|
|
33
|
+
overflow: auto;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
14
36
|
}
|
|
@@ -5,27 +5,30 @@ import * as _ldw_framework_material_langs from '@ldw-framework/material-langs';
|
|
|
5
5
|
|
|
6
6
|
declare class LDwMaterialMultiLangInputComponent implements OnInit {
|
|
7
7
|
private readonly service;
|
|
8
|
+
private loaded;
|
|
9
|
+
private readonly$;
|
|
10
|
+
private required$;
|
|
8
11
|
formGroup: FormGroup<{
|
|
9
12
|
value: FormControl<string | null | undefined>;
|
|
10
13
|
}>;
|
|
11
14
|
formParent: FormGroup;
|
|
12
15
|
formParentControlName: string;
|
|
13
16
|
label: string;
|
|
14
|
-
required: boolean;
|
|
15
|
-
requiredLabel: string;
|
|
16
17
|
appearance: 'fill' | 'outline';
|
|
17
|
-
readonly: boolean;
|
|
18
|
-
|
|
18
|
+
set readonly(v: string | boolean);
|
|
19
|
+
set required(v: string | boolean);
|
|
19
20
|
constructor();
|
|
20
21
|
ngOnInit(): void;
|
|
21
22
|
onChange(): void;
|
|
22
23
|
private fill;
|
|
23
24
|
private read;
|
|
24
25
|
private write;
|
|
26
|
+
get readonly(): string | boolean;
|
|
27
|
+
get required(): string | boolean;
|
|
25
28
|
get langValue(): FormControl<string | null | undefined>;
|
|
26
29
|
get langJson(): FormControl<string | null | undefined>;
|
|
27
30
|
static ɵfac: i0.ɵɵFactoryDeclaration<LDwMaterialMultiLangInputComponent, never>;
|
|
28
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<LDwMaterialMultiLangInputComponent, "ldw-mat-multi-lang-input", never, { "formParent": { "alias": "formParent"; "required": true; }; "formParentControlName": { "alias": "formParentControlName"; "required": true; }; "label": { "alias": "label"; "required": true; }; "
|
|
31
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<LDwMaterialMultiLangInputComponent, "ldw-mat-multi-lang-input", never, { "formParent": { "alias": "formParent"; "required": true; }; "formParentControlName": { "alias": "formParentControlName"; "required": true; }; "label": { "alias": "label"; "required": true; }; "appearance": { "alias": "appearance"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "required": { "alias": "required"; "required": false; }; }, {}, never, ["*"], true, never>;
|
|
29
32
|
}
|
|
30
33
|
|
|
31
34
|
declare class LDwMaterialMultiLangSelectorComponent implements OnInit {
|