osl-base-extended 0.0.3 → 0.0.5

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,15 +1,21 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Component, Inject, inject, Injector, Injectable } from '@angular/core';
2
+ import { Component, Inject, inject, Injector, Injectable, EventEmitter, Output, Input, HostListener, NgModule } from '@angular/core';
3
3
  import * as i1 from '@angular/material/dialog';
4
4
  import { MAT_DIALOG_DATA, MatDialogModule, MatDialog } from '@angular/material/dialog';
5
5
  import { MatSnackBar } from '@angular/material/snack-bar';
6
6
  import { Router } from '@angular/router';
7
+ import * as i1$2 from '@angular/common';
7
8
  import { NgTemplateOutlet } from '@angular/common';
8
9
  import { MatIconButton } from '@angular/material/button';
9
10
  import * as i2 from '@angular/material/icon';
10
11
  import { MatIconModule } from '@angular/material/icon';
11
12
  import { HttpHeaders, HttpParams, HttpClient } from '@angular/common/http';
12
13
  import { firstValueFrom, timeout } from 'rxjs';
14
+ import * as i1$1 from '@angular/forms';
15
+ import { FormsModule } from '@angular/forms';
16
+ import * as i2$1 from '@angular/material/form-field';
17
+ import { MatFormFieldModule, MatHint } from '@angular/material/form-field';
18
+ import { MatInputModule } from '@angular/material/input';
13
19
 
14
20
  class OslBaseExtended {
15
21
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslBaseExtended, deps: [], target: i0.ɵɵFactoryTarget.Component });
@@ -33,11 +39,11 @@ class DialogWrapper {
33
39
  this.dialogData.data = data.data;
34
40
  }
35
41
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: DialogWrapper, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
36
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: DialogWrapper, isStandalone: true, selector: "dialog-wrapper", ngImport: i0, template: "<div>\n @if(typeof dialogData.header == 'string'){\n <div class=\"dialog-header\" mat-dialog-title>\n <span class=\"dialog-heading\">{{dialogData.header}}</span>\n <button mat-dialog-close mat-icon-button><mat-icon>close</mat-icon></button>\n </div>\n }@else{\n <ng-container *ngTemplateOutlet=\"dialogData.header; context: { $implicit: dialogData }\"></ng-container>\n\n }\n \n\n</div>\n<mat-dialog-content>\n <div class=\"dialog-body\">\n @if(dialogData.formBody){\n <ng-container *ngTemplateOutlet=\"dialogData.formBody; context: { $implicit: dialogData }\"></ng-container>\n\n }\n\n </div>\n\n\n</mat-dialog-content>\n<mat-dialog-actions>\n @if(dialogData.formFooter){\n <div class=\"dialog-footer\">\n <ng-container *ngTemplateOutlet=\"dialogData.formFooter; context: { $implicit: dialogData }\"></ng-container>\n </div>\n\n }\n\n</mat-dialog-actions>", styles: [".dialog-header{display:flex;align-items:center;justify-content:space-between}.mat-dialog-close{margin-left:2px;margin-right:2px}.dialog-body,.dialog-footer{padding:0 5px}.mat-mdc-dialog-title:before{display:none}.dialog-heading{font-size:20px;font-weight:500}\n"], dependencies: [{ kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: MatIconButton, selector: "button[mat-icon-button], a[mat-icon-button], button[matIconButton], a[matIconButton]", exportAs: ["matButton", "matAnchor"] }] });
42
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: DialogWrapper, isStandalone: true, selector: "dialog-wrapper", ngImport: i0, template: "<div>\n @if(typeof dialogData.header == 'string'){\n <div class=\"dialog-header\" mat-dialog-title>\n <span class=\"dialog-heading\">{{dialogData.header}}</span>\n <button mat-dialog-close mat-icon-button><mat-icon>close</mat-icon></button>\n </div>\n }@else{\n <ng-container *ngTemplateOutlet=\"dialogData.header; context: { $implicit: dialogData }\"></ng-container>\n\n }\n \n\n</div>\n<mat-dialog-content>\n @if(dialogData.formBody){\n <div class=\"dialog-body\">\n <ng-container *ngTemplateOutlet=\"dialogData.formBody; context: { $implicit: dialogData }\"></ng-container>\n </div>\n\n }\n\n\n</mat-dialog-content>\n<mat-dialog-actions>\n @if(dialogData.formFooter){\n <div class=\"dialog-footer\">\n <ng-container *ngTemplateOutlet=\"dialogData.formFooter; context: { $implicit: dialogData }\"></ng-container>\n </div>\n}\n\n</mat-dialog-actions>", styles: [".dialog-header{display:flex;align-items:center;justify-content:space-between}.mat-dialog-close{margin-left:2px;margin-right:2px}.dialog-body,.dialog-footer{padding:0 5px}.mat-mdc-dialog-title:before{display:none}.dialog-heading{font-size:20px;font-weight:500}\n"], dependencies: [{ kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: MatIconButton, selector: "button[mat-icon-button], a[mat-icon-button], button[matIconButton], a[matIconButton]", exportAs: ["matButton", "matAnchor"] }] });
37
43
  }
38
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: DialogWrapper, decorators: [{
39
45
  type: Component,
40
- args: [{ selector: 'dialog-wrapper', imports: [MatDialogModule, MatIconModule, NgTemplateOutlet, MatIconButton], template: "<div>\n @if(typeof dialogData.header == 'string'){\n <div class=\"dialog-header\" mat-dialog-title>\n <span class=\"dialog-heading\">{{dialogData.header}}</span>\n <button mat-dialog-close mat-icon-button><mat-icon>close</mat-icon></button>\n </div>\n }@else{\n <ng-container *ngTemplateOutlet=\"dialogData.header; context: { $implicit: dialogData }\"></ng-container>\n\n }\n \n\n</div>\n<mat-dialog-content>\n <div class=\"dialog-body\">\n @if(dialogData.formBody){\n <ng-container *ngTemplateOutlet=\"dialogData.formBody; context: { $implicit: dialogData }\"></ng-container>\n\n }\n\n </div>\n\n\n</mat-dialog-content>\n<mat-dialog-actions>\n @if(dialogData.formFooter){\n <div class=\"dialog-footer\">\n <ng-container *ngTemplateOutlet=\"dialogData.formFooter; context: { $implicit: dialogData }\"></ng-container>\n </div>\n\n }\n\n</mat-dialog-actions>", styles: [".dialog-header{display:flex;align-items:center;justify-content:space-between}.mat-dialog-close{margin-left:2px;margin-right:2px}.dialog-body,.dialog-footer{padding:0 5px}.mat-mdc-dialog-title:before{display:none}.dialog-heading{font-size:20px;font-weight:500}\n"] }]
46
+ args: [{ selector: 'dialog-wrapper', imports: [MatDialogModule, MatIconModule, NgTemplateOutlet, MatIconButton], template: "<div>\n @if(typeof dialogData.header == 'string'){\n <div class=\"dialog-header\" mat-dialog-title>\n <span class=\"dialog-heading\">{{dialogData.header}}</span>\n <button mat-dialog-close mat-icon-button><mat-icon>close</mat-icon></button>\n </div>\n }@else{\n <ng-container *ngTemplateOutlet=\"dialogData.header; context: { $implicit: dialogData }\"></ng-container>\n\n }\n \n\n</div>\n<mat-dialog-content>\n @if(dialogData.formBody){\n <div class=\"dialog-body\">\n <ng-container *ngTemplateOutlet=\"dialogData.formBody; context: { $implicit: dialogData }\"></ng-container>\n </div>\n\n }\n\n\n</mat-dialog-content>\n<mat-dialog-actions>\n @if(dialogData.formFooter){\n <div class=\"dialog-footer\">\n <ng-container *ngTemplateOutlet=\"dialogData.formFooter; context: { $implicit: dialogData }\"></ng-container>\n </div>\n}\n\n</mat-dialog-actions>", styles: [".dialog-header{display:flex;align-items:center;justify-content:space-between}.mat-dialog-close{margin-left:2px;margin-right:2px}.dialog-body,.dialog-footer{padding:0 5px}.mat-mdc-dialog-title:before{display:none}.dialog-heading{font-size:20px;font-weight:500}\n"] }]
41
47
  }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: Dialog, decorators: [{
42
48
  type: Inject,
43
49
  args: [MAT_DIALOG_DATA]
@@ -189,6 +195,574 @@ class Httpbase {
189
195
  }
190
196
  }
191
197
 
198
+ class Oslinput {
199
+ label = "";
200
+ required = false;
201
+ disabled = false;
202
+ model = {};
203
+ modelChange = new EventEmitter();
204
+ changeEv = new EventEmitter();
205
+ onModelChange(event) {
206
+ this.model = event;
207
+ this.modelChange.emit(this.model);
208
+ }
209
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: Oslinput, deps: [], target: i0.ɵɵFactoryTarget.Component });
210
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: Oslinput, isStandalone: false, selector: "osl-input", inputs: { label: "label", required: "required", disabled: "disabled", model: "model" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input (change)=\"changeEv.emit(model)\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\"\n [required]=\"required\" [disabled]=\"disabled\" #myField=\"ngModel\" type=\"text\" [class.error]=\"myField.touched && myField.invalid\">\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n\n }\n \n</div>", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}input{height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);outline:none;border:none;padding:5px;font-size:var(--osl-text-font-size);border:1px solid var(--osl-border-color)}input:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"], dependencies: [{ kind: "directive", type: i1$1.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2$1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }] });
211
+ }
212
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: Oslinput, decorators: [{
213
+ type: Component,
214
+ args: [{ selector: 'osl-input', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input (change)=\"changeEv.emit(model)\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\"\n [required]=\"required\" [disabled]=\"disabled\" #myField=\"ngModel\" type=\"text\" [class.error]=\"myField.touched && myField.invalid\">\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n\n }\n \n</div>", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}input{height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);outline:none;border:none;padding:5px;font-size:var(--osl-text-font-size);border:1px solid var(--osl-border-color)}input:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
215
+ }], propDecorators: { label: [{
216
+ type: Input,
217
+ args: ['label']
218
+ }], required: [{
219
+ type: Input,
220
+ args: ['required']
221
+ }], disabled: [{
222
+ type: Input,
223
+ args: ['disabled']
224
+ }], model: [{
225
+ type: Input,
226
+ args: ['model']
227
+ }], modelChange: [{
228
+ type: Output
229
+ }], changeEv: [{
230
+ type: Output
231
+ }] } });
232
+
233
+ class Osltextarea {
234
+ textareaRows = "3";
235
+ label = "";
236
+ rows = "10";
237
+ required = false;
238
+ disabled = false;
239
+ model = {};
240
+ modelChange = new EventEmitter();
241
+ changeEv = new EventEmitter();
242
+ onModelChange(event) {
243
+ this.model = event;
244
+ this.modelChange.emit(this.model);
245
+ }
246
+ ngAfterViewInit() {
247
+ if (this.rows) {
248
+ this.textareaRows = this.rows;
249
+ }
250
+ }
251
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: Osltextarea, deps: [], target: i0.ɵɵFactoryTarget.Component });
252
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: Osltextarea, isStandalone: false, selector: "osl-textarea", inputs: { label: "label", rows: "rows", required: "required", disabled: "disabled", model: "model" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <textarea [rows]=\"textareaRows\" (change)=\"changeEv.emit(model)\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\"\n [required]=\"required\" [disabled]=\"disabled\" #myField=\"ngModel\" type=\"text\" [class.error]=\"myField.touched && myField.invalid\"></textarea>\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n\n }\n \n</div>", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}textarea{width:100%;border-radius:var(--osl-border-radius);outline:none;border:none;padding:5px;border:1px solid var(--osl-border-color);resize:none}textarea:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"], dependencies: [{ kind: "directive", type: i1$1.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2$1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }] });
253
+ }
254
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: Osltextarea, decorators: [{
255
+ type: Component,
256
+ args: [{ selector: 'osl-textarea', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <textarea [rows]=\"textareaRows\" (change)=\"changeEv.emit(model)\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\"\n [required]=\"required\" [disabled]=\"disabled\" #myField=\"ngModel\" type=\"text\" [class.error]=\"myField.touched && myField.invalid\"></textarea>\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n\n }\n \n</div>", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}textarea{width:100%;border-radius:var(--osl-border-radius);outline:none;border:none;padding:5px;border:1px solid var(--osl-border-color);resize:none}textarea:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
257
+ }], propDecorators: { label: [{
258
+ type: Input,
259
+ args: ['label']
260
+ }], rows: [{
261
+ type: Input,
262
+ args: ['rows']
263
+ }], required: [{
264
+ type: Input,
265
+ args: ['required']
266
+ }], disabled: [{
267
+ type: Input,
268
+ args: ['disabled']
269
+ }], model: [{
270
+ type: Input,
271
+ args: ['model']
272
+ }], modelChange: [{
273
+ type: Output
274
+ }], changeEv: [{
275
+ type: Output
276
+ }] } });
277
+
278
+ class OslSelect {
279
+ label = '';
280
+ required = false;
281
+ disabled = false;
282
+ model = null;
283
+ datasource = [];
284
+ displayField = '';
285
+ valueField = '';
286
+ modelChange = new EventEmitter();
287
+ changeEv = new EventEmitter();
288
+ getDisplay(item) {
289
+ return this.displayField ? item[this.displayField] : item;
290
+ }
291
+ getValue(item) {
292
+ return this.valueField ? item[this.valueField] : item;
293
+ }
294
+ onModelChange(event) {
295
+ this.model = event;
296
+ this.modelChange.emit(this.model);
297
+ }
298
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslSelect, deps: [], target: i0.ɵɵFactoryTarget.Component });
299
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: OslSelect, isStandalone: false, selector: "osl-select", inputs: { label: "label", required: "required", disabled: "disabled", model: "model", datasource: "datasource", displayField: "displayField", valueField: "valueField" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <select [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [required]=\"required\" [disabled]=\"disabled\"\n #myField=\"ngModel\" [class.error]=\"myField.touched && myField.invalid\" (change)=\"changeEv.emit(model)\">\n <option value=\"\" disabled selected hidden>Select...</option>\n @for(item of datasource; track item){\n <option [value]=\"getValue(item)\">{{getDisplay(item)}}</option>\n }\n </select>\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}select{height:var(--osl-control-height);width:100%;font-size:var(--osl-text-font-size);border-radius:var(--osl-border-radius);outline:none;border:1px solid var(--osl-border-color);padding:0 5px;background:#fff;cursor:pointer;appearance:auto}select:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}select:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"], dependencies: [{ kind: "directive", type: i1$1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2$1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }] });
300
+ }
301
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslSelect, decorators: [{
302
+ type: Component,
303
+ args: [{ selector: 'osl-select', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <select [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [required]=\"required\" [disabled]=\"disabled\"\n #myField=\"ngModel\" [class.error]=\"myField.touched && myField.invalid\" (change)=\"changeEv.emit(model)\">\n <option value=\"\" disabled selected hidden>Select...</option>\n @for(item of datasource; track item){\n <option [value]=\"getValue(item)\">{{getDisplay(item)}}</option>\n }\n </select>\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}select{height:var(--osl-control-height);width:100%;font-size:var(--osl-text-font-size);border-radius:var(--osl-border-radius);outline:none;border:1px solid var(--osl-border-color);padding:0 5px;background:#fff;cursor:pointer;appearance:auto}select:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}select:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
304
+ }], propDecorators: { label: [{
305
+ type: Input,
306
+ args: ['label']
307
+ }], required: [{
308
+ type: Input,
309
+ args: ['required']
310
+ }], disabled: [{
311
+ type: Input,
312
+ args: ['disabled']
313
+ }], model: [{
314
+ type: Input,
315
+ args: ['model']
316
+ }], datasource: [{
317
+ type: Input,
318
+ args: ['datasource']
319
+ }], displayField: [{
320
+ type: Input,
321
+ args: ['displayField']
322
+ }], valueField: [{
323
+ type: Input,
324
+ args: ['valueField']
325
+ }], modelChange: [{
326
+ type: Output
327
+ }], changeEv: [{
328
+ type: Output
329
+ }] } });
330
+
331
+ class OslRadio {
332
+ label = '';
333
+ required = false;
334
+ disabled = false;
335
+ model = null;
336
+ datasource = [];
337
+ displayField = '';
338
+ valueField = '';
339
+ modelChange = new EventEmitter();
340
+ changeEv = new EventEmitter();
341
+ get groupName() {
342
+ return 'radio_' + this.label.replace(/\s+/g, '_');
343
+ }
344
+ getDisplay(item) {
345
+ return this.displayField ? item[this.displayField] : item;
346
+ }
347
+ getValue(item) {
348
+ return this.valueField ? item[this.valueField] : item;
349
+ }
350
+ isChecked(item) {
351
+ return this.model === this.getValue(item);
352
+ }
353
+ onSelect(item) {
354
+ this.model = this.getValue(item);
355
+ this.modelChange.emit(this.model);
356
+ this.changeEv.emit(this.model);
357
+ }
358
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslRadio, deps: [], target: i0.ɵɵFactoryTarget.Component });
359
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: OslRadio, isStandalone: false, selector: "osl-radio", inputs: { label: "label", required: "required", disabled: "disabled", model: "model", datasource: "datasource", displayField: "displayField", valueField: "valueField" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <div class=\"radio-group\">\n @for(item of datasource; track item){\n <label class=\"radio-item\" [class.disabled]=\"disabled\">\n <input type=\"radio\" [name]=\"groupName\" [checked]=\"isChecked(item)\" [disabled]=\"disabled\"\n (change)=\"onSelect(item)\">\n <span>{{getDisplay(item)}}</span>\n </label>\n }\n </div>\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.radio-group{display:flex;flex-wrap:wrap;gap:16px;padding:6px 0}.radio-item{display:flex;align-items:center;gap:6px;font-size:var(--osl-label-font-size);cursor:pointer}.radio-item input[type=radio]{width:15px;height:15px;cursor:pointer;accent-color:#333}.radio-item.disabled{opacity:.6;cursor:not-allowed}.radio-item.disabled input[type=radio]{cursor:not-allowed}.txt-clr-red{color:var(--osl-error-color)}\n"] });
360
+ }
361
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslRadio, decorators: [{
362
+ type: Component,
363
+ args: [{ selector: 'osl-radio', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <div class=\"radio-group\">\n @for(item of datasource; track item){\n <label class=\"radio-item\" [class.disabled]=\"disabled\">\n <input type=\"radio\" [name]=\"groupName\" [checked]=\"isChecked(item)\" [disabled]=\"disabled\"\n (change)=\"onSelect(item)\">\n <span>{{getDisplay(item)}}</span>\n </label>\n }\n </div>\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.radio-group{display:flex;flex-wrap:wrap;gap:16px;padding:6px 0}.radio-item{display:flex;align-items:center;gap:6px;font-size:var(--osl-label-font-size);cursor:pointer}.radio-item input[type=radio]{width:15px;height:15px;cursor:pointer;accent-color:#333}.radio-item.disabled{opacity:.6;cursor:not-allowed}.radio-item.disabled input[type=radio]{cursor:not-allowed}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
364
+ }], propDecorators: { label: [{
365
+ type: Input,
366
+ args: ['label']
367
+ }], required: [{
368
+ type: Input,
369
+ args: ['required']
370
+ }], disabled: [{
371
+ type: Input,
372
+ args: ['disabled']
373
+ }], model: [{
374
+ type: Input,
375
+ args: ['model']
376
+ }], datasource: [{
377
+ type: Input,
378
+ args: ['datasource']
379
+ }], displayField: [{
380
+ type: Input,
381
+ args: ['displayField']
382
+ }], valueField: [{
383
+ type: Input,
384
+ args: ['valueField']
385
+ }], modelChange: [{
386
+ type: Output
387
+ }], changeEv: [{
388
+ type: Output
389
+ }] } });
390
+
391
+ class OslSlideToggle {
392
+ label = '';
393
+ disabled = false;
394
+ model = false;
395
+ modelChange = new EventEmitter();
396
+ changeEv = new EventEmitter();
397
+ onModelChange(event) {
398
+ this.model = event;
399
+ this.modelChange.emit(this.model);
400
+ this.changeEv.emit(this.model);
401
+ }
402
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslSlideToggle, deps: [], target: i0.ɵɵFactoryTarget.Component });
403
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.2.9", type: OslSlideToggle, isStandalone: false, selector: "osl-slide-toggle", inputs: { label: "label", disabled: "disabled", model: "model" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}}</label>\n <label class=\"toggle\" [class.toggle-disabled]=\"disabled\">\n <input type=\"checkbox\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [disabled]=\"disabled\">\n <span class=\"slider\"></span>\n </label>\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.toggle{position:relative;display:inline-block;width:46px;height:24px;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle .slider{position:absolute;inset:0;background-color:var(--osl-border-color);border-radius:24px;transition:.3s}.toggle .slider:before{content:\"\";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #0003}.toggle input:checked+.slider{background-color:#333}.toggle input:checked+.slider:before{transform:translate(22px)}.toggle.toggle-disabled{opacity:.6;cursor:not-allowed}\n"], dependencies: [{ kind: "directive", type: i1$1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
404
+ }
405
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslSlideToggle, decorators: [{
406
+ type: Component,
407
+ args: [{ selector: 'osl-slide-toggle', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}}</label>\n <label class=\"toggle\" [class.toggle-disabled]=\"disabled\">\n <input type=\"checkbox\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [disabled]=\"disabled\">\n <span class=\"slider\"></span>\n </label>\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.toggle{position:relative;display:inline-block;width:46px;height:24px;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle .slider{position:absolute;inset:0;background-color:var(--osl-border-color);border-radius:24px;transition:.3s}.toggle .slider:before{content:\"\";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #0003}.toggle input:checked+.slider{background-color:#333}.toggle input:checked+.slider:before{transform:translate(22px)}.toggle.toggle-disabled{opacity:.6;cursor:not-allowed}\n"] }]
408
+ }], propDecorators: { label: [{
409
+ type: Input,
410
+ args: ['label']
411
+ }], disabled: [{
412
+ type: Input,
413
+ args: ['disabled']
414
+ }], model: [{
415
+ type: Input,
416
+ args: ['model']
417
+ }], modelChange: [{
418
+ type: Output
419
+ }], changeEv: [{
420
+ type: Output
421
+ }] } });
422
+
423
+ class OslAutocomplete {
424
+ elRef;
425
+ label = '';
426
+ required = false;
427
+ disabled = false;
428
+ model = null;
429
+ datasource = [];
430
+ displayField = '';
431
+ valueField = '';
432
+ modelChange = new EventEmitter();
433
+ changeEv = new EventEmitter();
434
+ inputValue = '';
435
+ showDropdown = false;
436
+ filteredItems = [];
437
+ touched = false;
438
+ constructor(elRef) {
439
+ this.elRef = elRef;
440
+ }
441
+ ngOnInit() {
442
+ this.filteredItems = [...this.datasource];
443
+ this.syncInputFromModel();
444
+ }
445
+ ngOnChanges() {
446
+ this.filteredItems = [...this.datasource];
447
+ this.syncInputFromModel();
448
+ }
449
+ syncInputFromModel() {
450
+ if (this.model !== null && this.model !== undefined) {
451
+ const found = this.datasource.find(item => this.getValue(item) === this.model);
452
+ if (found)
453
+ this.inputValue = this.getDisplay(found);
454
+ }
455
+ }
456
+ getDisplay(item) {
457
+ return this.displayField ? item[this.displayField] : String(item);
458
+ }
459
+ getValue(item) {
460
+ return this.valueField ? item[this.valueField] : item;
461
+ }
462
+ get isInvalid() {
463
+ return this.touched && this.required && !this.model;
464
+ }
465
+ onInput(val) {
466
+ this.inputValue = val;
467
+ this.showDropdown = true;
468
+ this.filteredItems = this.datasource.filter(item => this.getDisplay(item).toLowerCase().includes(val.toLowerCase()));
469
+ if (!val) {
470
+ this.model = null;
471
+ this.modelChange.emit(null);
472
+ }
473
+ }
474
+ onFocus() {
475
+ this.showDropdown = true;
476
+ this.filteredItems = this.datasource.filter(item => this.getDisplay(item).toLowerCase().includes(this.inputValue.toLowerCase()));
477
+ }
478
+ onBlur() {
479
+ this.touched = true;
480
+ }
481
+ selectItem(item) {
482
+ this.inputValue = this.getDisplay(item);
483
+ this.model = this.getValue(item);
484
+ this.modelChange.emit(this.model);
485
+ this.changeEv.emit(this.model);
486
+ this.showDropdown = false;
487
+ }
488
+ onDocumentClick(event) {
489
+ if (!this.elRef.nativeElement.contains(event.target)) {
490
+ this.showDropdown = false;
491
+ }
492
+ }
493
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslAutocomplete, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
494
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: OslAutocomplete, isStandalone: false, selector: "osl-autocomplete", inputs: { label: "label", required: "required", disabled: "disabled", model: "model", datasource: "datasource", displayField: "displayField", valueField: "valueField" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"isInvalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <div class=\"autocomplete-wrapper\">\n <input [value]=\"inputValue\" (input)=\"onInput($any($event.target).value)\" (focus)=\"onFocus()\"\n (blur)=\"onBlur()\" [disabled]=\"disabled\" [class.error]=\"isInvalid\" autocomplete=\"off\"\n placeholder=\"Type to search...\">\n @if(showDropdown){\n <div class=\"dropdown\">\n @if(filteredItems.length > 0){\n @for(item of filteredItems; track item){\n <div class=\"dropdown-item\" (mousedown)=\"selectItem(item)\">{{getDisplay(item)}}</div>\n }\n } @else {\n <div class=\"no-results\">No results found</div>\n }\n </div>\n }\n </div>\n @if(isInvalid){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.autocomplete-wrapper{position:relative}input{height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);outline:none;border:1px solid var(--osl-border-color);padding:5px;font-size:var(--osl-text-font-size)}input:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}input::placeholder{padding-left:5px;font-size:var(--osl-label-font-size)}.error{border:1px solid var(--osl-error-color)}.dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:#fff;border:1px solid var(--osl-border-color);border-top:none;border-radius:0 0 var(--osl-border-radius) var(--osl-border-radius);max-height:200px;overflow-y:auto;box-shadow:0 var(--osl-border-radius) 8px #00000014}.dropdown-item{padding:8px 10px;font-size:var(--osl-label-font-size);cursor:pointer}.dropdown-item:hover{background:#f5f5f5}.no-results{padding:8px 10px;font-size:var(--osl-label-font-size);color:gray}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"], dependencies: [{ kind: "directive", type: i2$1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }] });
495
+ }
496
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslAutocomplete, decorators: [{
497
+ type: Component,
498
+ args: [{ selector: 'osl-autocomplete', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"isInvalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <div class=\"autocomplete-wrapper\">\n <input [value]=\"inputValue\" (input)=\"onInput($any($event.target).value)\" (focus)=\"onFocus()\"\n (blur)=\"onBlur()\" [disabled]=\"disabled\" [class.error]=\"isInvalid\" autocomplete=\"off\"\n placeholder=\"Type to search...\">\n @if(showDropdown){\n <div class=\"dropdown\">\n @if(filteredItems.length > 0){\n @for(item of filteredItems; track item){\n <div class=\"dropdown-item\" (mousedown)=\"selectItem(item)\">{{getDisplay(item)}}</div>\n }\n } @else {\n <div class=\"no-results\">No results found</div>\n }\n </div>\n }\n </div>\n @if(isInvalid){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.autocomplete-wrapper{position:relative}input{height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);outline:none;border:1px solid var(--osl-border-color);padding:5px;font-size:var(--osl-text-font-size)}input:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}input::placeholder{padding-left:5px;font-size:var(--osl-label-font-size)}.error{border:1px solid var(--osl-error-color)}.dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:#fff;border:1px solid var(--osl-border-color);border-top:none;border-radius:0 0 var(--osl-border-radius) var(--osl-border-radius);max-height:200px;overflow-y:auto;box-shadow:0 var(--osl-border-radius) 8px #00000014}.dropdown-item{padding:8px 10px;font-size:var(--osl-label-font-size);cursor:pointer}.dropdown-item:hover{background:#f5f5f5}.no-results{padding:8px 10px;font-size:var(--osl-label-font-size);color:gray}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
499
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { label: [{
500
+ type: Input,
501
+ args: ['label']
502
+ }], required: [{
503
+ type: Input,
504
+ args: ['required']
505
+ }], disabled: [{
506
+ type: Input,
507
+ args: ['disabled']
508
+ }], model: [{
509
+ type: Input,
510
+ args: ['model']
511
+ }], datasource: [{
512
+ type: Input,
513
+ args: ['datasource']
514
+ }], displayField: [{
515
+ type: Input,
516
+ args: ['displayField']
517
+ }], valueField: [{
518
+ type: Input,
519
+ args: ['valueField']
520
+ }], modelChange: [{
521
+ type: Output
522
+ }], changeEv: [{
523
+ type: Output
524
+ }], onDocumentClick: [{
525
+ type: HostListener,
526
+ args: ['document:click', ['$event']]
527
+ }] } });
528
+
529
+ class OslFileUpload {
530
+ label = '';
531
+ required = false;
532
+ disabled = false;
533
+ model = null;
534
+ accept = '';
535
+ modelChange = new EventEmitter();
536
+ changeEv = new EventEmitter();
537
+ touched = false;
538
+ get fileName() {
539
+ return this.model ? this.model.name : '';
540
+ }
541
+ get isInvalid() {
542
+ return this.touched && this.required && !this.model;
543
+ }
544
+ onFileChange(event) {
545
+ this.touched = true;
546
+ const input = event.target;
547
+ const file = input.files?.[0] ?? null;
548
+ this.model = file;
549
+ this.modelChange.emit(this.model);
550
+ this.changeEv.emit(this.model);
551
+ }
552
+ triggerInput(fileInput) {
553
+ if (!this.disabled) {
554
+ fileInput.click();
555
+ }
556
+ }
557
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslFileUpload, deps: [], target: i0.ɵɵFactoryTarget.Component });
558
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: OslFileUpload, isStandalone: false, selector: "osl-file-upload", inputs: { label: "label", required: "required", disabled: "disabled", model: "model", accept: "accept" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"isInvalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input type=\"file\" [accept]=\"accept\" [disabled]=\"disabled\" (change)=\"onFileChange($event)\" #fileInput class=\"file-input\">\n <div class=\"file-display\" [class.error]=\"isInvalid\" [class.file-disabled]=\"disabled\" (click)=\"triggerInput(fileInput)\">\n <span class=\"file-name\" [class.selected]=\"!!fileName\">{{fileName || 'Choose file...'}}</span>\n <span class=\"browse-btn\">Browse</span>\n </div>\n @if(isInvalid){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.file-input{display:none}.file-display{display:flex;align-items:center;justify-content:space-between;height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);border:1px solid var(--osl-border-color);padding:0 8px;cursor:pointer}.file-display:hover:not(.file-disabled){border:1px solid var(--osl-focus-border-color);transition:.5s}.file-display.error{border:1px solid var(--osl-error-color)}.file-display.file-disabled{opacity:.6;cursor:not-allowed;background:#f5f5f5}.file-name{font-size:var(--osl-text-font-size);color:#aaa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80%}.file-name.selected{color:#333}.browse-btn{font-size:var(--osl-hint-font-size);padding:2px 10px;border:1px solid var(--osl-border-color);border-radius:3px;background:#f5f5f5;white-space:nowrap}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"], dependencies: [{ kind: "directive", type: i2$1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }] });
559
+ }
560
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslFileUpload, decorators: [{
561
+ type: Component,
562
+ args: [{ selector: 'osl-file-upload', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"isInvalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input type=\"file\" [accept]=\"accept\" [disabled]=\"disabled\" (change)=\"onFileChange($event)\" #fileInput class=\"file-input\">\n <div class=\"file-display\" [class.error]=\"isInvalid\" [class.file-disabled]=\"disabled\" (click)=\"triggerInput(fileInput)\">\n <span class=\"file-name\" [class.selected]=\"!!fileName\">{{fileName || 'Choose file...'}}</span>\n <span class=\"browse-btn\">Browse</span>\n </div>\n @if(isInvalid){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.file-input{display:none}.file-display{display:flex;align-items:center;justify-content:space-between;height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);border:1px solid var(--osl-border-color);padding:0 8px;cursor:pointer}.file-display:hover:not(.file-disabled){border:1px solid var(--osl-focus-border-color);transition:.5s}.file-display.error{border:1px solid var(--osl-error-color)}.file-display.file-disabled{opacity:.6;cursor:not-allowed;background:#f5f5f5}.file-name{font-size:var(--osl-text-font-size);color:#aaa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80%}.file-name.selected{color:#333}.browse-btn{font-size:var(--osl-hint-font-size);padding:2px 10px;border:1px solid var(--osl-border-color);border-radius:3px;background:#f5f5f5;white-space:nowrap}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
563
+ }], propDecorators: { label: [{
564
+ type: Input,
565
+ args: ['label']
566
+ }], required: [{
567
+ type: Input,
568
+ args: ['required']
569
+ }], disabled: [{
570
+ type: Input,
571
+ args: ['disabled']
572
+ }], model: [{
573
+ type: Input,
574
+ args: ['model']
575
+ }], accept: [{
576
+ type: Input,
577
+ args: ['accept']
578
+ }], modelChange: [{
579
+ type: Output
580
+ }], changeEv: [{
581
+ type: Output
582
+ }] } });
583
+
584
+ class OslDatepicker {
585
+ label = '';
586
+ required = false;
587
+ disabled = false;
588
+ model = '';
589
+ modelChange = new EventEmitter();
590
+ changeEv = new EventEmitter();
591
+ onModelChange(event) {
592
+ this.model = event;
593
+ this.modelChange.emit(this.model);
594
+ }
595
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslDatepicker, deps: [], target: i0.ɵɵFactoryTarget.Component });
596
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: OslDatepicker, isStandalone: false, selector: "osl-datepicker", inputs: { label: "label", required: "required", disabled: "disabled", model: "model" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input type=\"date\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [required]=\"required\"\n [disabled]=\"disabled\" #myField=\"ngModel\" [class.error]=\"myField.touched && myField.invalid\"\n (change)=\"changeEv.emit(model)\">\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}input[type=date]{height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);outline:none;border:1px solid var(--osl-border-color);padding:5px}input[type=date]:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}input[type=date]:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"], dependencies: [{ kind: "directive", type: i1$1.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2$1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }] });
597
+ }
598
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslDatepicker, decorators: [{
599
+ type: Component,
600
+ args: [{ selector: 'osl-datepicker', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input type=\"date\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [required]=\"required\"\n [disabled]=\"disabled\" #myField=\"ngModel\" [class.error]=\"myField.touched && myField.invalid\"\n (change)=\"changeEv.emit(model)\">\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}input[type=date]{height:var(--osl-control-height);width:100%;border-radius:var(--osl-border-radius);outline:none;border:1px solid var(--osl-border-color);padding:5px}input[type=date]:focus{border:1px solid var(--osl-focus-border-color);transition:.5s}input[type=date]:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.error{border:1px solid var(--osl-error-color)}.hint{color:var(--osl-error-color);margin-top:2px;font-size:var(--osl-hint-font-size)}.txt-clr-red{color:var(--osl-error-color)}\n"] }]
601
+ }], propDecorators: { label: [{
602
+ type: Input,
603
+ args: ['label']
604
+ }], required: [{
605
+ type: Input,
606
+ args: ['required']
607
+ }], disabled: [{
608
+ type: Input,
609
+ args: ['disabled']
610
+ }], model: [{
611
+ type: Input,
612
+ args: ['model']
613
+ }], modelChange: [{
614
+ type: Output
615
+ }], changeEv: [{
616
+ type: Output
617
+ }] } });
618
+
619
+ class OslCheckbox {
620
+ label = '';
621
+ disabled = false;
622
+ model = false;
623
+ modelChange = new EventEmitter();
624
+ changeEv = new EventEmitter();
625
+ onModelChange(event) {
626
+ this.model = event;
627
+ this.modelChange.emit(this.model);
628
+ this.changeEv.emit(this.model);
629
+ }
630
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslCheckbox, deps: [], target: i0.ɵɵFactoryTarget.Component });
631
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.2.9", type: OslCheckbox, isStandalone: false, selector: "osl-checkbox", inputs: { label: "label", disabled: "disabled", model: "model" }, outputs: { modelChange: "modelChange", changeEv: "changeEv" }, ngImport: i0, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}}</label>\n <label class=\"checkbox-wrapper\" [class.checkbox-disabled]=\"disabled\">\n <input type=\"checkbox\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [disabled]=\"disabled\">\n <span class=\"checkbox-label\">{{label}}</span>\n </label>\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.checkbox-wrapper{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--osl-label-font-size);width:fit-content}.checkbox-wrapper input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#333;flex-shrink:0}.checkbox-wrapper .checkbox-label{-webkit-user-select:none;user-select:none}.checkbox-wrapper.checkbox-disabled{opacity:.6;cursor:not-allowed}.checkbox-wrapper.checkbox-disabled input[type=checkbox]{cursor:not-allowed}\n"], dependencies: [{ kind: "directive", type: i1$1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
632
+ }
633
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslCheckbox, decorators: [{
634
+ type: Component,
635
+ args: [{ selector: 'osl-checkbox', standalone: false, template: "<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}}</label>\n <label class=\"checkbox-wrapper\" [class.checkbox-disabled]=\"disabled\">\n <input type=\"checkbox\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [disabled]=\"disabled\">\n <span class=\"checkbox-label\">{{label}}</span>\n </label>\n</div>\n", styles: [".label{font-size:var(--osl-label-font-size);margin-bottom:5px}.checkbox-wrapper{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--osl-label-font-size);width:fit-content}.checkbox-wrapper input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#333;flex-shrink:0}.checkbox-wrapper .checkbox-label{-webkit-user-select:none;user-select:none}.checkbox-wrapper.checkbox-disabled{opacity:.6;cursor:not-allowed}.checkbox-wrapper.checkbox-disabled input[type=checkbox]{cursor:not-allowed}\n"] }]
636
+ }], propDecorators: { label: [{
637
+ type: Input,
638
+ args: ['label']
639
+ }], disabled: [{
640
+ type: Input,
641
+ args: ['disabled']
642
+ }], model: [{
643
+ type: Input,
644
+ args: ['model']
645
+ }], modelChange: [{
646
+ type: Output
647
+ }], changeEv: [{
648
+ type: Output
649
+ }] } });
650
+
651
+ class OslButton {
652
+ label = 'Button';
653
+ variant = 'primary';
654
+ size = 'md';
655
+ disabled = false;
656
+ loading = false;
657
+ type = 'button';
658
+ fullWidth = false;
659
+ clickEv = new EventEmitter();
660
+ get classes() {
661
+ return [
662
+ 'osl-btn',
663
+ `osl-btn--${this.variant}`,
664
+ `osl-btn--${this.size}`,
665
+ this.fullWidth ? 'osl-btn--full' : '',
666
+ ]
667
+ .filter(Boolean)
668
+ .join(' ');
669
+ }
670
+ onClick() {
671
+ if (!this.disabled && !this.loading) {
672
+ this.clickEv.emit();
673
+ }
674
+ }
675
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslButton, deps: [], target: i0.ɵɵFactoryTarget.Component });
676
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: OslButton, isStandalone: false, selector: "osl-button", inputs: { label: "label", variant: "variant", size: "size", disabled: "disabled", loading: "loading", type: "type", fullWidth: "fullWidth" }, outputs: { clickEv: "clickEv" }, ngImport: i0, template: "<button [class]=\"classes\" [type]=\"type\" [disabled]=\"disabled || loading\" (click)=\"onClick()\">\n @if(loading){\n <span class=\"osl-btn__spinner\"></span>\n }\n <span class=\"osl-btn__label\">{{label}}</span>\n</button>\n", styles: [".osl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--osl-border-radius);cursor:pointer;font-size:var(--osl-label-font-size);font-weight:500;line-height:1;transition:background-color .2s ease,border-color .2s ease,opacity .2s ease;white-space:nowrap;outline:none}.osl-btn--sm{height:28px;padding:0 var(--osl-hint-font-size);font-size:var(--osl-hint-font-size)}.osl-btn--md{height:36px;padding:0 18px;font-size:var(--osl-label-font-size)}.osl-btn--lg{height:44px;padding:0 24px;font-size:16px}.osl-btn--full{width:100%}.osl-btn:disabled{opacity:var(--osl-disabled-opacity);cursor:not-allowed}.osl-btn--primary{background-color:var(--osl-primary);color:var(--osl-primary-text)}.osl-btn--primary:hover:not(:disabled){background-color:var(--osl-primary-hover)}.osl-btn--secondary{background-color:var(--osl-secondary);color:var(--osl-secondary-text)}.osl-btn--secondary:hover:not(:disabled){background-color:var(--osl-secondary-hover)}.osl-btn--success{background-color:var(--osl-success);color:var(--osl-success-text)}.osl-btn--success:hover:not(:disabled){background-color:var(--osl-success-hover)}.osl-btn--danger{background-color:var(--osl-danger);color:var(--osl-danger-text)}.osl-btn--danger:hover:not(:disabled){background-color:var(--osl-danger-hover)}.osl-btn--warning{background-color:var(--osl-warning);color:var(--osl-warning-text)}.osl-btn--warning:hover:not(:disabled){background-color:var(--osl-warning-hover)}.osl-btn--info{background-color:var(--osl-info);color:var(--osl-info-text)}.osl-btn--info:hover:not(:disabled){background-color:var(--osl-info-hover)}.osl-btn--outline-primary{background-color:transparent;border:1.5px solid var(--osl-primary);color:var(--osl-primary)}.osl-btn--outline-primary:hover:not(:disabled){background-color:var(--osl-primary);color:var(--osl-primary-text)}.osl-btn--outline-secondary{background-color:transparent;border:1.5px solid var(--osl-secondary);color:var(--osl-secondary)}.osl-btn--outline-secondary:hover:not(:disabled){background-color:var(--osl-secondary);color:var(--osl-secondary-text)}.osl-btn--outline-success{background-color:transparent;border:1.5px solid var(--osl-success);color:var(--osl-success)}.osl-btn--outline-success:hover:not(:disabled){background-color:var(--osl-success);color:var(--osl-success-text)}.osl-btn--outline-danger{background-color:transparent;border:1.5px solid var(--osl-danger);color:var(--osl-danger)}.osl-btn--outline-danger:hover:not(:disabled){background-color:var(--osl-danger);color:var(--osl-danger-text)}.osl-btn--outline-warning{background-color:transparent;border:1.5px solid var(--osl-warning);color:var(--osl-warning)}.osl-btn--outline-warning:hover:not(:disabled){background-color:var(--osl-warning);color:var(--osl-warning-text)}.osl-btn--outline-info{background-color:transparent;border:1.5px solid var(--osl-info);color:var(--osl-info)}.osl-btn--outline-info:hover:not(:disabled){background-color:var(--osl-info);color:var(--osl-info-text)}.osl-btn__spinner{display:inline-block;width:var(--osl-label-font-size);height:var(--osl-label-font-size);border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:osl-spin .7s linear infinite}@keyframes osl-spin{to{transform:rotate(360deg)}}\n"] });
677
+ }
678
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: OslButton, decorators: [{
679
+ type: Component,
680
+ args: [{ selector: 'osl-button', standalone: false, template: "<button [class]=\"classes\" [type]=\"type\" [disabled]=\"disabled || loading\" (click)=\"onClick()\">\n @if(loading){\n <span class=\"osl-btn__spinner\"></span>\n }\n <span class=\"osl-btn__label\">{{label}}</span>\n</button>\n", styles: [".osl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--osl-border-radius);cursor:pointer;font-size:var(--osl-label-font-size);font-weight:500;line-height:1;transition:background-color .2s ease,border-color .2s ease,opacity .2s ease;white-space:nowrap;outline:none}.osl-btn--sm{height:28px;padding:0 var(--osl-hint-font-size);font-size:var(--osl-hint-font-size)}.osl-btn--md{height:36px;padding:0 18px;font-size:var(--osl-label-font-size)}.osl-btn--lg{height:44px;padding:0 24px;font-size:16px}.osl-btn--full{width:100%}.osl-btn:disabled{opacity:var(--osl-disabled-opacity);cursor:not-allowed}.osl-btn--primary{background-color:var(--osl-primary);color:var(--osl-primary-text)}.osl-btn--primary:hover:not(:disabled){background-color:var(--osl-primary-hover)}.osl-btn--secondary{background-color:var(--osl-secondary);color:var(--osl-secondary-text)}.osl-btn--secondary:hover:not(:disabled){background-color:var(--osl-secondary-hover)}.osl-btn--success{background-color:var(--osl-success);color:var(--osl-success-text)}.osl-btn--success:hover:not(:disabled){background-color:var(--osl-success-hover)}.osl-btn--danger{background-color:var(--osl-danger);color:var(--osl-danger-text)}.osl-btn--danger:hover:not(:disabled){background-color:var(--osl-danger-hover)}.osl-btn--warning{background-color:var(--osl-warning);color:var(--osl-warning-text)}.osl-btn--warning:hover:not(:disabled){background-color:var(--osl-warning-hover)}.osl-btn--info{background-color:var(--osl-info);color:var(--osl-info-text)}.osl-btn--info:hover:not(:disabled){background-color:var(--osl-info-hover)}.osl-btn--outline-primary{background-color:transparent;border:1.5px solid var(--osl-primary);color:var(--osl-primary)}.osl-btn--outline-primary:hover:not(:disabled){background-color:var(--osl-primary);color:var(--osl-primary-text)}.osl-btn--outline-secondary{background-color:transparent;border:1.5px solid var(--osl-secondary);color:var(--osl-secondary)}.osl-btn--outline-secondary:hover:not(:disabled){background-color:var(--osl-secondary);color:var(--osl-secondary-text)}.osl-btn--outline-success{background-color:transparent;border:1.5px solid var(--osl-success);color:var(--osl-success)}.osl-btn--outline-success:hover:not(:disabled){background-color:var(--osl-success);color:var(--osl-success-text)}.osl-btn--outline-danger{background-color:transparent;border:1.5px solid var(--osl-danger);color:var(--osl-danger)}.osl-btn--outline-danger:hover:not(:disabled){background-color:var(--osl-danger);color:var(--osl-danger-text)}.osl-btn--outline-warning{background-color:transparent;border:1.5px solid var(--osl-warning);color:var(--osl-warning)}.osl-btn--outline-warning:hover:not(:disabled){background-color:var(--osl-warning);color:var(--osl-warning-text)}.osl-btn--outline-info{background-color:transparent;border:1.5px solid var(--osl-info);color:var(--osl-info)}.osl-btn--outline-info:hover:not(:disabled){background-color:var(--osl-info);color:var(--osl-info-text)}.osl-btn__spinner{display:inline-block;width:var(--osl-label-font-size);height:var(--osl-label-font-size);border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:osl-spin .7s linear infinite}@keyframes osl-spin{to{transform:rotate(360deg)}}\n"] }]
681
+ }], propDecorators: { label: [{
682
+ type: Input,
683
+ args: ['label']
684
+ }], variant: [{
685
+ type: Input,
686
+ args: ['variant']
687
+ }], size: [{
688
+ type: Input,
689
+ args: ['size']
690
+ }], disabled: [{
691
+ type: Input,
692
+ args: ['disabled']
693
+ }], loading: [{
694
+ type: Input,
695
+ args: ['loading']
696
+ }], type: [{
697
+ type: Input,
698
+ args: ['type']
699
+ }], fullWidth: [{
700
+ type: Input,
701
+ args: ['fullWidth']
702
+ }], clickEv: [{
703
+ type: Output
704
+ }] } });
705
+
706
+ class DynamicForm {
707
+ elements = [];
708
+ model = {};
709
+ modelChange = new EventEmitter();
710
+ onModelChange(event, key) {
711
+ this.model[key] = event;
712
+ this.modelChange.emit(this.model);
713
+ }
714
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: DynamicForm, deps: [], target: i0.ɵɵFactoryTarget.Component });
715
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: DynamicForm, isStandalone: false, selector: "osl-dynamic-form", inputs: { elements: "elements", model: "model" }, outputs: { modelChange: "modelChange" }, ngImport: i0, template: "@if(elements && elements.length > 0){\n <div class=\"row w-100\">\n @for(elem of elements;track elem){\n @if(!(elem.hideIf ? elem.hideIf(model) : elem.hide)){\n <ng-container *ngTemplateOutlet=\"recursiveForm; context: { $implicit: elem }\"></ng-container>\n }\n }\n </div>\n}\n\n<ng-template #recursiveForm let-elem>\n @if(elem.hideIf? !elem.hideIf(model):true){\n @switch (elem.elementType) {\n @case (\"textbox\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-input (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-input>\n </div>\n }\n @case (\"textarea\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-textarea [rows]=\"elem.textareaRows ? elem.textareaRows.toString() : undefined\"\n (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-textarea>\n </div>\n }\n @case (\"select\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-select (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-select>\n </div>\n }\n @case (\"radio\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-radio (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-radio>\n </div>\n }\n @case (\"slide-toggle\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-slide-toggle (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [(model)]=\"model[elem.key]\"></osl-slide-toggle>\n </div>\n }\n @case (\"autocomplete\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-autocomplete (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-autocomplete>\n </div>\n }\n @case (\"file-uploader\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-file-upload (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [accept]=\"elem.accept || ''\"\n [(model)]=\"model[elem.key]\"></osl-file-upload>\n </div>\n }\n @case (\"datepicker\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-datepicker (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-datepicker>\n </div>\n }\n @case (\"checkbox\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-checkbox (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [(model)]=\"model[elem.key]\"></osl-checkbox>\n </div>\n }\n @case (\"button\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-button (clickEv)=\"elem.change($event)\" [loading]=\"elem.loadingIf? elem.loadingIf(model):false\" [variant]=\"'secondary'\" [label]=\"elem.label\"></osl-button>\n </div>\n }\n }\n}\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i1$2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: Oslinput, selector: "osl-input", inputs: ["label", "required", "disabled", "model"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: Osltextarea, selector: "osl-textarea", inputs: ["label", "rows", "required", "disabled", "model"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslSelect, selector: "osl-select", inputs: ["label", "required", "disabled", "model", "datasource", "displayField", "valueField"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslRadio, selector: "osl-radio", inputs: ["label", "required", "disabled", "model", "datasource", "displayField", "valueField"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslSlideToggle, selector: "osl-slide-toggle", inputs: ["label", "disabled", "model"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslAutocomplete, selector: "osl-autocomplete", inputs: ["label", "required", "disabled", "model", "datasource", "displayField", "valueField"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslFileUpload, selector: "osl-file-upload", inputs: ["label", "required", "disabled", "model", "accept"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslDatepicker, selector: "osl-datepicker", inputs: ["label", "required", "disabled", "model"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslCheckbox, selector: "osl-checkbox", inputs: ["label", "disabled", "model"], outputs: ["modelChange", "changeEv"] }, { kind: "component", type: OslButton, selector: "osl-button", inputs: ["label", "variant", "size", "disabled", "loading", "type", "fullWidth"], outputs: ["clickEv"] }] });
716
+ }
717
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: DynamicForm, decorators: [{
718
+ type: Component,
719
+ args: [{ selector: 'osl-dynamic-form', standalone: false, template: "@if(elements && elements.length > 0){\n <div class=\"row w-100\">\n @for(elem of elements;track elem){\n @if(!(elem.hideIf ? elem.hideIf(model) : elem.hide)){\n <ng-container *ngTemplateOutlet=\"recursiveForm; context: { $implicit: elem }\"></ng-container>\n }\n }\n </div>\n}\n\n<ng-template #recursiveForm let-elem>\n @if(elem.hideIf? !elem.hideIf(model):true){\n @switch (elem.elementType) {\n @case (\"textbox\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-input (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-input>\n </div>\n }\n @case (\"textarea\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-textarea [rows]=\"elem.textareaRows ? elem.textareaRows.toString() : undefined\"\n (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-textarea>\n </div>\n }\n @case (\"select\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-select (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-select>\n </div>\n }\n @case (\"radio\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-radio (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-radio>\n </div>\n }\n @case (\"slide-toggle\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-slide-toggle (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [(model)]=\"model[elem.key]\"></osl-slide-toggle>\n </div>\n }\n @case (\"autocomplete\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-autocomplete (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-autocomplete>\n </div>\n }\n @case (\"file-uploader\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-file-upload (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [accept]=\"elem.accept || ''\"\n [(model)]=\"model[elem.key]\"></osl-file-upload>\n </div>\n }\n @case (\"datepicker\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-datepicker (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-datepicker>\n </div>\n }\n @case (\"checkbox\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-checkbox (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [(model)]=\"model[elem.key]\"></osl-checkbox>\n </div>\n }\n @case (\"button\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-button (clickEv)=\"elem.change($event)\" [loading]=\"elem.loadingIf? elem.loadingIf(model):false\" [variant]=\"'secondary'\" [label]=\"elem.label\"></osl-button>\n </div>\n }\n }\n}\n</ng-template>\n" }]
720
+ }], propDecorators: { elements: [{
721
+ type: Input,
722
+ args: ['elements']
723
+ }], model: [{
724
+ type: Input,
725
+ args: ['model']
726
+ }], modelChange: [{
727
+ type: Output
728
+ }] } });
729
+
730
+ class formStructureModule {
731
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: formStructureModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
732
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.2.9", ngImport: i0, type: formStructureModule, declarations: [DynamicForm,
733
+ Oslinput,
734
+ Osltextarea,
735
+ OslSelect,
736
+ OslRadio,
737
+ OslSlideToggle,
738
+ OslAutocomplete,
739
+ OslFileUpload,
740
+ OslDatepicker,
741
+ OslCheckbox,
742
+ OslButton], imports: [NgTemplateOutlet, FormsModule, MatFormFieldModule, MatInputModule, MatHint], exports: [DynamicForm] });
743
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: formStructureModule, imports: [FormsModule, MatFormFieldModule, MatInputModule] });
744
+ }
745
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: formStructureModule, decorators: [{
746
+ type: NgModule,
747
+ args: [{
748
+ declarations: [
749
+ DynamicForm,
750
+ Oslinput,
751
+ Osltextarea,
752
+ OslSelect,
753
+ OslRadio,
754
+ OslSlideToggle,
755
+ OslAutocomplete,
756
+ OslFileUpload,
757
+ OslDatepicker,
758
+ OslCheckbox,
759
+ OslButton
760
+ ],
761
+ imports: [NgTemplateOutlet, FormsModule, MatFormFieldModule, MatInputModule, MatHint],
762
+ exports: [DynamicForm],
763
+ }]
764
+ }] });
765
+
192
766
  /*
193
767
  * Public API Surface of osl-base-extended
194
768
  */
@@ -197,5 +771,5 @@ class Httpbase {
197
771
  * Generated bundle index. Do not edit.
198
772
  */
199
773
 
200
- export { Dialog, DialogWrapper, Httpbase, OslBaseExtended, baseComponent };
774
+ export { Dialog, DialogWrapper, DynamicForm, Httpbase, OslBaseExtended, baseComponent, formStructureModule };
201
775
  //# sourceMappingURL=osl-base-extended.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"osl-base-extended.mjs","sources":["../../../projects/osl-base-extended/src/lib/osl-base-extended.ts","../../../projects/osl-base-extended/src/lib/core/shared/components/dialog-wrapper/dialog-wrapper.ts","../../../projects/osl-base-extended/src/lib/core/shared/components/dialog-wrapper/dialog-wrapper.html","../../../projects/osl-base-extended/src/lib/core/base/base.component.ts","../../../projects/osl-base-extended/src/lib/core/http/httpbase.ts","../../../projects/osl-base-extended/src/public-api.ts","../../../projects/osl-base-extended/src/osl-base-extended.ts"],"sourcesContent":["import { Component } from '@angular/core';\n\n@Component({\n selector: 'lib-osl-base-extended',\n imports: [],\n template: ` <p>osl-base-extended works!</p> `,\n styles: ``,\n})\nexport class OslBaseExtended {}\n","import { NgTemplateOutlet } from '@angular/common';\nimport { Component, Inject, TemplateRef } from '@angular/core';\nimport { MatIconButton } from '@angular/material/button';\nimport { MAT_DIALOG_DATA, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatIconModule } from '@angular/material/icon';\n\n\n@Component({\n selector: 'dialog-wrapper',\n imports: [MatDialogModule, MatIconModule, NgTemplateOutlet, MatIconButton],\n templateUrl: './dialog-wrapper.html',\n styleUrl: './dialog-wrapper.scss',\n})\nexport class DialogWrapper {\n public dialogData:Dialog= new Dialog()\n constructor(public dialogRef:MatDialogRef<DialogWrapper>,@Inject(MAT_DIALOG_DATA) public data: Dialog){\n this.dialogData.header = data.header;\n this.dialogData.formBody = data.formBody;\n this.dialogData.formFooter = data.formFooter;\n this.dialogData.data = data.data\n }\n}\n\nexport class Dialog{\n header:string|TemplateRef<any>= \"No Title Found\";\n formBody:TemplateRef<any> | undefined;\n formFooter:TemplateRef<any> | undefined;\n data?:any;\n\n\n\n}\n","<div>\n @if(typeof dialogData.header == 'string'){\n <div class=\"dialog-header\" mat-dialog-title>\n <span class=\"dialog-heading\">{{dialogData.header}}</span>\n <button mat-dialog-close mat-icon-button><mat-icon>close</mat-icon></button>\n </div>\n }@else{\n <ng-container *ngTemplateOutlet=\"dialogData.header; context: { $implicit: dialogData }\"></ng-container>\n\n }\n \n\n</div>\n<mat-dialog-content>\n <div class=\"dialog-body\">\n @if(dialogData.formBody){\n <ng-container *ngTemplateOutlet=\"dialogData.formBody; context: { $implicit: dialogData }\"></ng-container>\n\n }\n\n </div>\n\n\n</mat-dialog-content>\n<mat-dialog-actions>\n @if(dialogData.formFooter){\n <div class=\"dialog-footer\">\n <ng-container *ngTemplateOutlet=\"dialogData.formFooter; context: { $implicit: dialogData }\"></ng-container>\n </div>\n\n }\n\n</mat-dialog-actions>","import { inject, Injectable, Injector, TemplateRef } from \"@angular/core\";\r\nimport { MatDialog, MatDialogRef } from \"@angular/material/dialog\";\r\nimport { MatSnackBar } from \"@angular/material/snack-bar\";\r\nimport { Router } from \"@angular/router\";\r\nimport { Dialog, DialogWrapper } from \"../shared/components/dialog-wrapper/dialog-wrapper\";\r\n@Injectable()\r\n\r\nexport class baseComponent{\r\n private _injector = inject(Injector);\r\n\r\n protected showSuccess(message:any){\r\n if(Array.isArray(message)){\r\n message = message.join(',')\r\n }\r\n this.showSnack(message)\r\n }\r\n\r\n\r\n protected showError(error:string|string[]){\r\n if(Array.isArray(error)){\r\n error = error.join(',')\r\n }\r\n this.showSnack(error)\r\n }\r\n\r\n protected navigate(url:string){\r\n this._injector.get(Router).navigate([url])\r\n }\r\n\r\n private showSnack(message:string){\r\n this._injector.get(MatSnackBar).open(message,'Ok',{\r\n duration:3000\r\n })\r\n }\r\n\r\n protected openDialog(\r\n header:string|TemplateRef<any>, \r\n formBody:TemplateRef<any>,\r\n formFooter:TemplateRef<any>,\r\n width:string = '40vw',\r\n data?:any,\r\n ):MatDialogRef<any>{\r\n const dialogData:Dialog= {\r\n header:header,\r\n formBody:formBody,\r\n formFooter:formFooter\r\n }\r\n const dialogRef = this._injector.get(MatDialog)?.open(DialogWrapper,{\r\n width:width,\r\n data:{...dialogData,...data},\r\n\r\n })\r\n return dialogRef;\r\n \r\n\r\n }\r\n\r\n}","import { HttpClient, HttpErrorResponse, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { inject } from '@angular/core';\nimport { firstValueFrom, timeout } from 'rxjs';\n\nexport interface HttpResponse<T = any> {\n isSuccessful: boolean;\n statusCode: number;\n error: string;\n result: T;\n}\nexport interface myParams {\n property: string;\n value: any;\n}\nexport abstract class Httpbase {\n private controllerName: string = '';\n constructor(private controller: string) {\n this.controllerName = controller;\n }\n\n private getEndPoint(methodName: string) {\n return `${this.baseUrl}${this.controllerName}/${methodName}`;\n }\n private getHeaders() {\n const token = localStorage.getItem('token');\n return new HttpHeaders({\n 'Content-Type': 'application/json',\n Authorization: token ? `Bearer ${token}` : '',\n });\n }\n private handleSuccess<T>(statusCode: number, result: any): HttpResponse<T> {\n return {\n isSuccessful: statusCode >= 200 && statusCode < 300,\n error: '',\n result: result,\n statusCode: statusCode,\n };\n }\n\n private handleError<T>(error: any): HttpResponse<T> {\n return {\n isSuccessful: false,\n error: this.mapError(error),\n statusCode: error.status,\n result: null as any,\n };\n }\n\n private mapError(error: HttpErrorResponse): any {\n let errorMessage = '';\n switch (error.status) {\n case 0:\n errorMessage = 'Connection Error! Please Contact Adminsitration';\n break;\n case 400:\n errorMessage = error.error.message || 'Something Went Wrong';\n break;\n case 401:\n errorMessage = 'Unauthorized Access';\n break;\n case 403:\n errorMessage = \"You don't have rights to perform this action\";\n break;\n case 500:\n errorMessage = 'An error has occured,Please contact support';\n break;\n default:\n errorMessage = 'Something went wrong';\n }\n return errorMessage;\n }\n private buildParams(paramsArray: myParams[]): HttpParams {\n return (paramsArray || []).reduce((params, { property, value }) => {\n if (property && value != null) {\n return Array.isArray(value)\n ? value.reduce((p, v) => p.append(property, v), params)\n : params.set(property, value);\n }\n return params;\n }, new HttpParams());\n }\n protected http = inject(HttpClient);\n\n private baseUrl = '/api/'; // Change later\n protected async post<T>(methodName: string, body: any): Promise<HttpResponse<T>> {\n try {\n const res = await firstValueFrom(\n this.http\n .post(this.getEndPoint(methodName), body, {\n observe: 'response',\n headers: this.getHeaders(),\n })\n .pipe(timeout(30000)),\n );\n return this.handleSuccess(res.status, res.body);\n } catch (error: any) {\n return this.handleError(error);\n }\n }\n protected async get<T>(methodName: string, params?: myParams[]): Promise<HttpResponse<T>> {\n try {\n const res = await firstValueFrom(\n this.http\n .get(this.getEndPoint(methodName), {\n observe: 'response',\n headers: this.getHeaders(),\n params: this.buildParams(params || []),\n })\n .pipe(timeout(30000)),\n );\n\n return this.handleSuccess(res.status, res.body);\n } catch (error: any) {\n return this.handleError(error);\n }\n }\n}\n","/*\n * Public API Surface of osl-base-extended\n */\n\nexport * from './lib/osl-base-extended';\nexport * from './lib/core/base/base.component';\nexport * from './lib/core/http/httpbase';\nexport * from './lib/core/shared/components/dialog-wrapper/dialog-wrapper';\n\n\n\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"osl-base-extended.mjs","sources":["../../../projects/osl-base-extended/src/lib/osl-base-extended.ts","../../../projects/osl-base-extended/src/lib/core/shared/components/dialog-wrapper/dialog-wrapper.ts","../../../projects/osl-base-extended/src/lib/core/shared/components/dialog-wrapper/dialog-wrapper.html","../../../projects/osl-base-extended/src/lib/core/base/base.component.ts","../../../projects/osl-base-extended/src/lib/core/http/httpbase.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/input/input.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/input/input.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/textarea/textarea.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/textarea/textarea.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/select/select.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/select/select.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/radio/radio.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/radio/radio.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/slide-toggle/slide-toggle.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/slide-toggle/slide-toggle.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/autocomplete/autocomplete.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/autocomplete/autocomplete.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/file-upload/file-upload.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/file-upload/file-upload.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/datepicker/datepicker.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/datepicker/datepicker.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/checkbox/checkbox.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/checkbox/checkbox.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/button/button.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/button/button.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/dynamic-form/dynamic-form.ts","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/dynamic-form/dynamic-form.html","../../../projects/osl-base-extended/src/lib/core/shared/form-structure/form-structure.module.ts","../../../projects/osl-base-extended/src/public-api.ts","../../../projects/osl-base-extended/src/osl-base-extended.ts"],"sourcesContent":["import { Component } from '@angular/core';\n\n@Component({\n selector: 'lib-osl-base-extended',\n imports: [],\n template: ` <p>osl-base-extended works!</p> `,\n styles: ``,\n})\nexport class OslBaseExtended {}\n","import { NgTemplateOutlet } from '@angular/common';\nimport { Component, Inject, TemplateRef } from '@angular/core';\nimport { MatIconButton } from '@angular/material/button';\nimport { MAT_DIALOG_DATA, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatIconModule } from '@angular/material/icon';\n\n\n@Component({\n selector: 'dialog-wrapper',\n imports: [MatDialogModule, MatIconModule, NgTemplateOutlet, MatIconButton],\n templateUrl: './dialog-wrapper.html',\n styleUrl: './dialog-wrapper.scss',\n})\nexport class DialogWrapper {\n dialogData:Dialog= new Dialog()\n constructor(public dialogRef:MatDialogRef<DialogWrapper>,@Inject(MAT_DIALOG_DATA) public data: Dialog){\n this.dialogData.header = data.header;\n this.dialogData.formBody = data.formBody;\n this.dialogData.formFooter = data.formFooter;\n this.dialogData.data = data.data\n }\n}\n\nexport class Dialog{\n header:string|TemplateRef<any>= \"No Title Found\";\n formBody:TemplateRef<any> | undefined;\n formFooter:TemplateRef<any> | undefined;\n data?:any;\n\n\n\n}\n","<div>\n @if(typeof dialogData.header == 'string'){\n <div class=\"dialog-header\" mat-dialog-title>\n <span class=\"dialog-heading\">{{dialogData.header}}</span>\n <button mat-dialog-close mat-icon-button><mat-icon>close</mat-icon></button>\n </div>\n }@else{\n <ng-container *ngTemplateOutlet=\"dialogData.header; context: { $implicit: dialogData }\"></ng-container>\n\n }\n \n\n</div>\n<mat-dialog-content>\n @if(dialogData.formBody){\n <div class=\"dialog-body\">\n <ng-container *ngTemplateOutlet=\"dialogData.formBody; context: { $implicit: dialogData }\"></ng-container>\n </div>\n\n }\n\n\n</mat-dialog-content>\n<mat-dialog-actions>\n @if(dialogData.formFooter){\n <div class=\"dialog-footer\">\n <ng-container *ngTemplateOutlet=\"dialogData.formFooter; context: { $implicit: dialogData }\"></ng-container>\n </div>\n}\n\n</mat-dialog-actions>","import { inject, Injectable, Injector, TemplateRef } from \"@angular/core\";\r\nimport { MatDialog, MatDialogRef } from \"@angular/material/dialog\";\r\nimport { MatSnackBar } from \"@angular/material/snack-bar\";\r\nimport { Router } from \"@angular/router\";\r\nimport { Dialog, DialogWrapper } from \"../shared/components/dialog-wrapper/dialog-wrapper\";\r\n@Injectable()\r\n\r\nexport class baseComponent{\r\n private _injector = inject(Injector);\r\n\r\n protected showSuccess(message:any){\r\n if(Array.isArray(message)){\r\n message = message.join(',')\r\n }\r\n this.showSnack(message)\r\n }\r\n\r\n\r\n protected showError(error:string|string[]){\r\n if(Array.isArray(error)){\r\n error = error.join(',')\r\n }\r\n this.showSnack(error)\r\n }\r\n\r\n protected navigate(url:string){\r\n this._injector.get(Router).navigate([url])\r\n }\r\n\r\n private showSnack(message:string){\r\n this._injector.get(MatSnackBar).open(message,'Ok',{\r\n duration:3000\r\n })\r\n }\r\n\r\n protected openDialog(\r\n header:string|TemplateRef<any>, \r\n formBody:TemplateRef<any>,\r\n formFooter:TemplateRef<any>,\r\n width:string = '40vw',\r\n data?:any,\r\n ):MatDialogRef<any>{\r\n const dialogData:Dialog= {\r\n header:header,\r\n formBody:formBody,\r\n formFooter:formFooter\r\n }\r\n const dialogRef = this._injector.get(MatDialog)?.open(DialogWrapper,{\r\n width:width,\r\n data:{...dialogData,...data},\r\n\r\n })\r\n return dialogRef;\r\n \r\n\r\n }\r\n\r\n}","import { HttpClient, HttpErrorResponse, HttpHeaders, HttpParams } from '@angular/common/http';\nimport { inject } from '@angular/core';\nimport { firstValueFrom, timeout } from 'rxjs';\n\nexport interface HttpResponse<T = any> {\n isSuccessful: boolean;\n statusCode: number;\n error: string;\n result: T;\n}\nexport interface myParams {\n property: string;\n value: any;\n}\nexport abstract class Httpbase {\n private controllerName: string = '';\n constructor(private controller: string) {\n this.controllerName = controller;\n }\n\n private getEndPoint(methodName: string) {\n return `${this.baseUrl}${this.controllerName}/${methodName}`;\n }\n private getHeaders() {\n const token = localStorage.getItem('token');\n return new HttpHeaders({\n 'Content-Type': 'application/json',\n Authorization: token ? `Bearer ${token}` : '',\n });\n }\n private handleSuccess<T>(statusCode: number, result: any): HttpResponse<T> {\n return {\n isSuccessful: statusCode >= 200 && statusCode < 300,\n error: '',\n result: result,\n statusCode: statusCode,\n };\n }\n\n private handleError<T>(error: any): HttpResponse<T> {\n return {\n isSuccessful: false,\n error: this.mapError(error),\n statusCode: error.status,\n result: null as any,\n };\n }\n\n private mapError(error: HttpErrorResponse): any {\n let errorMessage = '';\n switch (error.status) {\n case 0:\n errorMessage = 'Connection Error! Please Contact Adminsitration';\n break;\n case 400:\n errorMessage = error.error.message || 'Something Went Wrong';\n break;\n case 401:\n errorMessage = 'Unauthorized Access';\n break;\n case 403:\n errorMessage = \"You don't have rights to perform this action\";\n break;\n case 500:\n errorMessage = 'An error has occured,Please contact support';\n break;\n default:\n errorMessage = 'Something went wrong';\n }\n return errorMessage;\n }\n private buildParams(paramsArray: myParams[]): HttpParams {\n return (paramsArray || []).reduce((params, { property, value }) => {\n if (property && value != null) {\n return Array.isArray(value)\n ? value.reduce((p, v) => p.append(property, v), params)\n : params.set(property, value);\n }\n return params;\n }, new HttpParams());\n }\n protected http = inject(HttpClient);\n\n private baseUrl = '/api/'; // Change later\n protected async post<T>(methodName: string, body: any): Promise<HttpResponse<T>> {\n try {\n const res = await firstValueFrom(\n this.http\n .post(this.getEndPoint(methodName), body, {\n observe: 'response',\n headers: this.getHeaders(),\n })\n .pipe(timeout(30000)),\n );\n return this.handleSuccess(res.status, res.body);\n } catch (error: any) {\n return this.handleError(error);\n }\n }\n protected async get<T>(methodName: string, params?: myParams[]): Promise<HttpResponse<T>> {\n try {\n const res = await firstValueFrom(\n this.http\n .get(this.getEndPoint(methodName), {\n observe: 'response',\n headers: this.getHeaders(),\n params: this.buildParams(params || []),\n })\n .pipe(timeout(30000)),\n );\n\n return this.handleSuccess(res.status, res.body);\n } catch (error: any) {\n return this.handleError(error);\n }\n }\n}\n","import { Component,EventEmitter,Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-input',\n standalone:false,\n templateUrl: './input.html',\n styleUrl: './input.scss',\n})\nexport class Oslinput {\n @Input('label') label:string=\"\"\n @Input('required') required:boolean = false\n @Input('disabled')disabled:boolean = false\n @Input('model') model:any = {}\n @Output() modelChange = new EventEmitter<any>();\n @Output() changeEv = new EventEmitter<any>();\n onModelChange(event:any){\n this.model=event;\n this.modelChange.emit(this.model)\n\n\n }\n \n \n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input (change)=\"changeEv.emit(model)\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\"\n [required]=\"required\" [disabled]=\"disabled\" #myField=\"ngModel\" type=\"text\" [class.error]=\"myField.touched && myField.invalid\">\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n\n }\n \n</div>","import { Component,EventEmitter,Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-textarea',\n standalone:false,\n templateUrl: './textarea.html',\n styleUrl: './textarea.scss',\n})\nexport class Osltextarea {\n textareaRows:string = \"3\";\n @Input('label') label:string=\"\"\n @Input('rows') rows:string=\"10\"\n @Input('required') required:boolean = false\n @Input('disabled')disabled:boolean = false\n @Input('model') model:any = {}\n @Output() modelChange = new EventEmitter<any>();\n @Output() changeEv = new EventEmitter<any>();\n onModelChange(event:any){\n this.model=event;\n this.modelChange.emit(this.model)\n\n\n }\n ngAfterViewInit(){\n if(this.rows){\n this.textareaRows = this.rows\n\n }\n }\n \n \n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <textarea [rows]=\"textareaRows\" (change)=\"changeEv.emit(model)\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\"\n [required]=\"required\" [disabled]=\"disabled\" #myField=\"ngModel\" type=\"text\" [class.error]=\"myField.touched && myField.invalid\"></textarea>\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n\n }\n \n</div>","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-select',\n standalone: false,\n templateUrl: './select.html',\n styleUrl: './select.scss',\n})\nexport class OslSelect {\n @Input('label') label: string = '';\n @Input('required') required: boolean = false;\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: any = null;\n @Input('datasource') datasource: any[] = [];\n @Input('displayField') displayField: string = '';\n @Input('valueField') valueField: string = '';\n @Output() modelChange = new EventEmitter<any>();\n @Output() changeEv = new EventEmitter<any>();\n\n getDisplay(item: any): string {\n return this.displayField ? item[this.displayField] : item;\n }\n\n getValue(item: any): any {\n return this.valueField ? item[this.valueField] : item;\n }\n\n onModelChange(event: any) {\n this.model = event;\n this.modelChange.emit(this.model);\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <select [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [required]=\"required\" [disabled]=\"disabled\"\n #myField=\"ngModel\" [class.error]=\"myField.touched && myField.invalid\" (change)=\"changeEv.emit(model)\">\n <option value=\"\" disabled selected hidden>Select...</option>\n @for(item of datasource; track item){\n <option [value]=\"getValue(item)\">{{getDisplay(item)}}</option>\n }\n </select>\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-radio',\n standalone: false,\n templateUrl: './radio.html',\n styleUrl: './radio.scss',\n})\nexport class OslRadio {\n @Input('label') label: string = '';\n @Input('required') required: boolean = false;\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: any = null;\n @Input('datasource') datasource: any[] = [];\n @Input('displayField') displayField: string = '';\n @Input('valueField') valueField: string = '';\n @Output() modelChange = new EventEmitter<any>();\n @Output() changeEv = new EventEmitter<any>();\n\n get groupName(): string {\n return 'radio_' + this.label.replace(/\\s+/g, '_');\n }\n\n getDisplay(item: any): string {\n return this.displayField ? item[this.displayField] : item;\n }\n\n getValue(item: any): any {\n return this.valueField ? item[this.valueField] : item;\n }\n\n isChecked(item: any): boolean {\n return this.model === this.getValue(item);\n }\n\n onSelect(item: any) {\n this.model = this.getValue(item);\n this.modelChange.emit(this.model);\n this.changeEv.emit(this.model);\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <div class=\"radio-group\">\n @for(item of datasource; track item){\n <label class=\"radio-item\" [class.disabled]=\"disabled\">\n <input type=\"radio\" [name]=\"groupName\" [checked]=\"isChecked(item)\" [disabled]=\"disabled\"\n (change)=\"onSelect(item)\">\n <span>{{getDisplay(item)}}</span>\n </label>\n }\n </div>\n</div>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-slide-toggle',\n standalone: false,\n templateUrl: './slide-toggle.html',\n styleUrl: './slide-toggle.scss',\n})\nexport class OslSlideToggle {\n @Input('label') label: string = '';\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: boolean = false;\n @Output() modelChange = new EventEmitter<boolean>();\n @Output() changeEv = new EventEmitter<boolean>();\n\n onModelChange(event: boolean) {\n this.model = event;\n this.modelChange.emit(this.model);\n this.changeEv.emit(this.model);\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}}</label>\n <label class=\"toggle\" [class.toggle-disabled]=\"disabled\">\n <input type=\"checkbox\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [disabled]=\"disabled\">\n <span class=\"slider\"></span>\n </label>\n</div>\n","import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnInit, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-autocomplete',\n standalone: false,\n templateUrl: './autocomplete.html',\n styleUrl: './autocomplete.scss',\n})\nexport class OslAutocomplete implements OnInit, OnChanges {\n @Input('label') label: string = '';\n @Input('required') required: boolean = false;\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: any = null;\n @Input('datasource') datasource: any[] = [];\n @Input('displayField') displayField: string = '';\n @Input('valueField') valueField: string = '';\n @Output() modelChange = new EventEmitter<any>();\n @Output() changeEv = new EventEmitter<any>();\n\n inputValue: string = '';\n showDropdown: boolean = false;\n filteredItems: any[] = [];\n touched: boolean = false;\n\n constructor(private elRef: ElementRef) {}\n\n ngOnInit() {\n this.filteredItems = [...this.datasource];\n this.syncInputFromModel();\n }\n\n ngOnChanges() {\n this.filteredItems = [...this.datasource];\n this.syncInputFromModel();\n }\n\n private syncInputFromModel() {\n if (this.model !== null && this.model !== undefined) {\n const found = this.datasource.find(item => this.getValue(item) === this.model);\n if (found) this.inputValue = this.getDisplay(found);\n }\n }\n\n getDisplay(item: any): string {\n return this.displayField ? item[this.displayField] : String(item);\n }\n\n getValue(item: any): any {\n return this.valueField ? item[this.valueField] : item;\n }\n\n get isInvalid(): boolean {\n return this.touched && this.required && !this.model;\n }\n\n onInput(val: string) {\n this.inputValue = val;\n this.showDropdown = true;\n this.filteredItems = this.datasource.filter(item =>\n this.getDisplay(item).toLowerCase().includes(val.toLowerCase())\n );\n if (!val) {\n this.model = null;\n this.modelChange.emit(null);\n }\n }\n\n onFocus() {\n this.showDropdown = true;\n this.filteredItems = this.datasource.filter(item =>\n this.getDisplay(item).toLowerCase().includes(this.inputValue.toLowerCase())\n );\n }\n\n onBlur() {\n this.touched = true;\n }\n\n selectItem(item: any) {\n this.inputValue = this.getDisplay(item);\n this.model = this.getValue(item);\n this.modelChange.emit(this.model);\n this.changeEv.emit(this.model);\n this.showDropdown = false;\n }\n\n @HostListener('document:click', ['$event'])\n onDocumentClick(event: MouseEvent) {\n if (!this.elRef.nativeElement.contains(event.target)) {\n this.showDropdown = false;\n }\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"isInvalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <div class=\"autocomplete-wrapper\">\n <input [value]=\"inputValue\" (input)=\"onInput($any($event.target).value)\" (focus)=\"onFocus()\"\n (blur)=\"onBlur()\" [disabled]=\"disabled\" [class.error]=\"isInvalid\" autocomplete=\"off\"\n placeholder=\"Type to search...\">\n @if(showDropdown){\n <div class=\"dropdown\">\n @if(filteredItems.length > 0){\n @for(item of filteredItems; track item){\n <div class=\"dropdown-item\" (mousedown)=\"selectItem(item)\">{{getDisplay(item)}}</div>\n }\n } @else {\n <div class=\"no-results\">No results found</div>\n }\n </div>\n }\n </div>\n @if(isInvalid){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-file-upload',\n standalone: false,\n templateUrl: './file-upload.html',\n styleUrl: './file-upload.scss',\n})\nexport class OslFileUpload {\n @Input('label') label: string = '';\n @Input('required') required: boolean = false;\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: File | null = null;\n @Input('accept') accept: string = '';\n @Output() modelChange = new EventEmitter<File | null>();\n @Output() changeEv = new EventEmitter<File | null>();\n\n touched: boolean = false;\n\n get fileName(): string {\n return this.model ? this.model.name : '';\n }\n\n get isInvalid(): boolean {\n return this.touched && this.required && !this.model;\n }\n\n onFileChange(event: Event) {\n this.touched = true;\n const input = event.target as HTMLInputElement;\n const file = input.files?.[0] ?? null;\n this.model = file;\n this.modelChange.emit(this.model);\n this.changeEv.emit(this.model);\n }\n\n triggerInput(fileInput: HTMLInputElement) {\n if (!this.disabled) {\n fileInput.click();\n }\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"isInvalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input type=\"file\" [accept]=\"accept\" [disabled]=\"disabled\" (change)=\"onFileChange($event)\" #fileInput class=\"file-input\">\n <div class=\"file-display\" [class.error]=\"isInvalid\" [class.file-disabled]=\"disabled\" (click)=\"triggerInput(fileInput)\">\n <span class=\"file-name\" [class.selected]=\"!!fileName\">{{fileName || 'Choose file...'}}</span>\n <span class=\"browse-btn\">Browse</span>\n </div>\n @if(isInvalid){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-datepicker',\n standalone: false,\n templateUrl: './datepicker.html',\n styleUrl: './datepicker.scss',\n})\nexport class OslDatepicker {\n @Input('label') label: string = '';\n @Input('required') required: boolean = false;\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: string = '';\n @Output() modelChange = new EventEmitter<string>();\n @Output() changeEv = new EventEmitter<string>();\n\n onModelChange(event: string) {\n this.model = event;\n this.modelChange.emit(this.model);\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\" [class.txt-clr-red]=\"myField.touched && myField.invalid\">{{label}} <span class=\"txt-clr-red\">{{required?'*':''}}</span></label>\n <input type=\"date\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [required]=\"required\"\n [disabled]=\"disabled\" #myField=\"ngModel\" [class.error]=\"myField.touched && myField.invalid\"\n (change)=\"changeEv.emit(model)\">\n @if(myField.touched && myField.invalid && required){\n <mat-hint class=\"hint\">{{label}} is Required!</mat-hint>\n }\n</div>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-checkbox',\n standalone: false,\n templateUrl: './checkbox.html',\n styleUrl: './checkbox.scss',\n})\nexport class OslCheckbox {\n @Input('label') label: string = '';\n @Input('disabled') disabled: boolean = false;\n @Input('model') model: boolean = false;\n @Output() modelChange = new EventEmitter<boolean>();\n @Output() changeEv = new EventEmitter<boolean>();\n\n onModelChange(event: boolean) {\n this.model = event;\n this.modelChange.emit(this.model);\n this.changeEv.emit(this.model);\n }\n}\n","<div class=\"d-flex flex-column\">\n <label class=\"label\">{{label}}</label>\n <label class=\"checkbox-wrapper\" [class.checkbox-disabled]=\"disabled\">\n <input type=\"checkbox\" [ngModel]=\"model\" (ngModelChange)=\"onModelChange($event)\" [disabled]=\"disabled\">\n <span class=\"checkbox-label\">{{label}}</span>\n </label>\n</div>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\nexport type ButtonVariant =\n | 'primary'\n | 'secondary'\n | 'success'\n | 'danger'\n | 'warning'\n | 'info'\n | 'outline-primary'\n | 'outline-secondary'\n | 'outline-success'\n | 'outline-danger'\n | 'outline-warning'\n | 'outline-info';\n\nexport type ButtonSize = 'sm' | 'md' | 'lg';\n\n@Component({\n selector: 'osl-button',\n standalone: false,\n templateUrl: './button.html',\n styleUrl: './button.scss',\n})\nexport class OslButton {\n @Input('label') label: string = 'Button';\n @Input('variant') variant: ButtonVariant = 'primary';\n @Input('size') size: ButtonSize = 'md';\n @Input('disabled') disabled: boolean = false;\n @Input('loading') loading: boolean = false;\n @Input('type') type: 'button' | 'submit' | 'reset' = 'button';\n @Input('fullWidth') fullWidth: boolean = false;\n @Output() clickEv = new EventEmitter<void>();\n\n get classes(): string {\n return [\n 'osl-btn',\n `osl-btn--${this.variant}`,\n `osl-btn--${this.size}`,\n this.fullWidth ? 'osl-btn--full' : '',\n ]\n .filter(Boolean)\n .join(' ');\n }\n\n onClick() {\n if (!this.disabled && !this.loading) {\n this.clickEv.emit();\n }\n }\n}\n","<button [class]=\"classes\" [type]=\"type\" [disabled]=\"disabled || loading\" (click)=\"onClick()\">\n @if(loading){\n <span class=\"osl-btn__spinner\"></span>\n }\n <span class=\"osl-btn__label\">{{label}}</span>\n</button>\n","import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n selector: 'osl-dynamic-form',\n standalone: false,\n templateUrl: './dynamic-form.html',\n styleUrl: './dynamic-form.scss',\n})\nexport class DynamicForm {\n @Input('elements') elements: elements[] = [];\n @Input('model') model: any = {};\n @Output() modelChange = new EventEmitter<any>();\n\n onModelChange(event: any, key: any) {\n this.model[key] = event;\n this.modelChange.emit(this.model);\n }\n}\n\nexport interface elements {\n columns: number;\n label: string;\n elementType: 'button' | 'checkbox' | 'textbox' | 'textarea' | 'radio' | 'select' | 'datepicker' | 'file-uploader' | 'autocomplete' | 'slide-toggle';\n key: string;\n change?: (model: any) => void;\n disabled?: boolean;\n hide?: boolean;\n disabledIf?: () => boolean;\n hideIf?: (model:any) => boolean;\n datasource?: any[];\n displayField?: string;\n valueField?: string;\n required?: boolean;\n requiredIf?: (model: any) => boolean;\n textareaRows?: number;\n accept?: string;\n loadingIf?:(model:any)=>boolean\n}\n","@if(elements && elements.length > 0){\n <div class=\"row w-100\">\n @for(elem of elements;track elem){\n @if(!(elem.hideIf ? elem.hideIf(model) : elem.hide)){\n <ng-container *ngTemplateOutlet=\"recursiveForm; context: { $implicit: elem }\"></ng-container>\n }\n }\n </div>\n}\n\n<ng-template #recursiveForm let-elem>\n @if(elem.hideIf? !elem.hideIf(model):true){\n @switch (elem.elementType) {\n @case (\"textbox\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-input (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-input>\n </div>\n }\n @case (\"textarea\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-textarea [rows]=\"elem.textareaRows ? elem.textareaRows.toString() : undefined\"\n (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-textarea>\n </div>\n }\n @case (\"select\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-select (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-select>\n </div>\n }\n @case (\"radio\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-radio (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-radio>\n </div>\n }\n @case (\"slide-toggle\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-slide-toggle (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [(model)]=\"model[elem.key]\"></osl-slide-toggle>\n </div>\n }\n @case (\"autocomplete\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-autocomplete (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [datasource]=\"elem.datasource || []\"\n [displayField]=\"elem.displayField || ''\"\n [valueField]=\"elem.valueField || ''\"\n [(model)]=\"model[elem.key]\"></osl-autocomplete>\n </div>\n }\n @case (\"file-uploader\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-file-upload (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [accept]=\"elem.accept || ''\"\n [(model)]=\"model[elem.key]\"></osl-file-upload>\n </div>\n }\n @case (\"datepicker\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-datepicker (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [required]=\"elem.requiredIf ? elem.requiredIf(model) : !!elem.required\"\n [(model)]=\"model[elem.key]\"></osl-datepicker>\n </div>\n }\n @case (\"checkbox\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-checkbox (changeEv)=\"elem.change ? elem.change(model) : null\" [label]=\"elem.label\"\n [disabled]=\"elem.disabledIf ? elem.disabledIf() : !!elem.disabled\"\n [(model)]=\"model[elem.key]\"></osl-checkbox>\n </div>\n }\n @case (\"button\") {\n <div [class]=\"'col-md-'+elem.columns+' mt-2'\">\n <osl-button (clickEv)=\"elem.change($event)\" [loading]=\"elem.loadingIf? elem.loadingIf(model):false\" [variant]=\"'secondary'\" [label]=\"elem.label\"></osl-button>\n </div>\n }\n }\n}\n</ng-template>\n","import { NgModule } from \"@angular/core\";\nimport { DynamicForm } from \"./dynamic-form/dynamic-form\";\nimport { FormsModule } from \"@angular/forms\";\nimport { NgTemplateOutlet } from \"@angular/common\";\nimport { MatFormFieldModule, MatHint } from \"@angular/material/form-field\";\nimport { MatInputModule } from \"@angular/material/input\";\nimport { Oslinput } from \"./input/input\";\nimport { Osltextarea } from \"./textarea/textarea\";\nimport { OslSelect } from \"./select/select\";\nimport { OslRadio } from \"./radio/radio\";\nimport { OslSlideToggle } from \"./slide-toggle/slide-toggle\";\nimport { OslAutocomplete } from \"./autocomplete/autocomplete\";\nimport { OslFileUpload } from \"./file-upload/file-upload\";\nimport { OslDatepicker } from \"./datepicker/datepicker\";\nimport { OslCheckbox } from \"./checkbox/checkbox\";\nimport { OslButton } from \"./button/button\";\n\n@NgModule({\n declarations: [\n DynamicForm,\n Oslinput,\n Osltextarea,\n OslSelect,\n OslRadio,\n OslSlideToggle,\n OslAutocomplete,\n OslFileUpload,\n OslDatepicker,\n OslCheckbox,\n OslButton\n ],\n imports: [NgTemplateOutlet, FormsModule, MatFormFieldModule, MatInputModule,MatHint],\n exports: [DynamicForm],\n})\nexport class formStructureModule {}\n","/*\n * Public API Surface of osl-base-extended\n */\n\nexport * from './lib/osl-base-extended';\nexport * from './lib/core/base/base.component';\nexport * from './lib/core/http/httpbase';\nexport * from './lib/core/shared/components/dialog-wrapper/dialog-wrapper';\nexport * from './lib/core/shared/form-structure/form-structure.module'\nexport * from './lib/core/shared/form-structure/dynamic-form/dynamic-form'\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1","i2","i2.Oslinput","i3.Osltextarea","i4.OslSelect","i5.OslRadio","i6.OslSlideToggle","i7.OslAutocomplete","i8.OslFileUpload","i9.OslDatepicker","i10.OslCheckbox","i11.OslButton"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "osl-base-extended",
3
- "version": "0.0.3",
3
+ "version": "0.0.5",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^21.2.0",
6
6
  "@angular/core": "^21.2.0"
@@ -10,7 +10,6 @@
10
10
  },
11
11
  "sideEffects": false,
12
12
  "description": "This project was generated using [Angular CLI](https://github.com/angular/angular-cli) version 21.2.0.",
13
- "main": "index.js",
14
13
  "author": "Bilal Raza",
15
14
  "license": "ISC",
16
15
  "module": "fesm2022/osl-base-extended.mjs",
@@ -1,7 +1,11 @@
1
1
  import * as i0 from '@angular/core';
2
- import { TemplateRef } from '@angular/core';
2
+ import { TemplateRef, EventEmitter, OnInit, OnChanges, ElementRef } from '@angular/core';
3
3
  import { MatDialogRef } from '@angular/material/dialog';
4
4
  import { HttpClient } from '@angular/common/http';
5
+ import * as i12 from '@angular/common';
6
+ import * as i13 from '@angular/forms';
7
+ import * as i14 from '@angular/material/form-field';
8
+ import * as i15 from '@angular/material/input';
5
9
 
6
10
  declare class OslBaseExtended {
7
11
  static ɵfac: i0.ɵɵFactoryDeclaration<OslBaseExtended, never>;
@@ -60,5 +64,201 @@ declare class Dialog {
60
64
  data?: any;
61
65
  }
62
66
 
63
- export { Dialog, DialogWrapper, Httpbase, OslBaseExtended, baseComponent };
64
- export type { HttpResponse, myParams };
67
+ declare class DynamicForm {
68
+ elements: elements[];
69
+ model: any;
70
+ modelChange: EventEmitter<any>;
71
+ onModelChange(event: any, key: any): void;
72
+ static ɵfac: i0.ɵɵFactoryDeclaration<DynamicForm, never>;
73
+ static ɵcmp: i0.ɵɵComponentDeclaration<DynamicForm, "osl-dynamic-form", never, { "elements": { "alias": "elements"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "modelChange": "modelChange"; }, never, never, false, never>;
74
+ }
75
+ interface elements {
76
+ columns: number;
77
+ label: string;
78
+ elementType: 'button' | 'checkbox' | 'textbox' | 'textarea' | 'radio' | 'select' | 'datepicker' | 'file-uploader' | 'autocomplete' | 'slide-toggle';
79
+ key: string;
80
+ change?: (model: any) => void;
81
+ disabled?: boolean;
82
+ hide?: boolean;
83
+ disabledIf?: () => boolean;
84
+ hideIf?: (model: any) => boolean;
85
+ datasource?: any[];
86
+ displayField?: string;
87
+ valueField?: string;
88
+ required?: boolean;
89
+ requiredIf?: (model: any) => boolean;
90
+ textareaRows?: number;
91
+ accept?: string;
92
+ loadingIf?: (model: any) => boolean;
93
+ }
94
+
95
+ declare class Oslinput {
96
+ label: string;
97
+ required: boolean;
98
+ disabled: boolean;
99
+ model: any;
100
+ modelChange: EventEmitter<any>;
101
+ changeEv: EventEmitter<any>;
102
+ onModelChange(event: any): void;
103
+ static ɵfac: i0.ɵɵFactoryDeclaration<Oslinput, never>;
104
+ static ɵcmp: i0.ɵɵComponentDeclaration<Oslinput, "osl-input", never, { "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
105
+ }
106
+
107
+ declare class Osltextarea {
108
+ textareaRows: string;
109
+ label: string;
110
+ rows: string;
111
+ required: boolean;
112
+ disabled: boolean;
113
+ model: any;
114
+ modelChange: EventEmitter<any>;
115
+ changeEv: EventEmitter<any>;
116
+ onModelChange(event: any): void;
117
+ ngAfterViewInit(): void;
118
+ static ɵfac: i0.ɵɵFactoryDeclaration<Osltextarea, never>;
119
+ static ɵcmp: i0.ɵɵComponentDeclaration<Osltextarea, "osl-textarea", never, { "label": { "alias": "label"; "required": false; }; "rows": { "alias": "rows"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
120
+ }
121
+
122
+ declare class OslSelect {
123
+ label: string;
124
+ required: boolean;
125
+ disabled: boolean;
126
+ model: any;
127
+ datasource: any[];
128
+ displayField: string;
129
+ valueField: string;
130
+ modelChange: EventEmitter<any>;
131
+ changeEv: EventEmitter<any>;
132
+ getDisplay(item: any): string;
133
+ getValue(item: any): any;
134
+ onModelChange(event: any): void;
135
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslSelect, never>;
136
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslSelect, "osl-select", never, { "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; "datasource": { "alias": "datasource"; "required": false; }; "displayField": { "alias": "displayField"; "required": false; }; "valueField": { "alias": "valueField"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
137
+ }
138
+
139
+ declare class OslRadio {
140
+ label: string;
141
+ required: boolean;
142
+ disabled: boolean;
143
+ model: any;
144
+ datasource: any[];
145
+ displayField: string;
146
+ valueField: string;
147
+ modelChange: EventEmitter<any>;
148
+ changeEv: EventEmitter<any>;
149
+ get groupName(): string;
150
+ getDisplay(item: any): string;
151
+ getValue(item: any): any;
152
+ isChecked(item: any): boolean;
153
+ onSelect(item: any): void;
154
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslRadio, never>;
155
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslRadio, "osl-radio", never, { "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; "datasource": { "alias": "datasource"; "required": false; }; "displayField": { "alias": "displayField"; "required": false; }; "valueField": { "alias": "valueField"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
156
+ }
157
+
158
+ declare class OslSlideToggle {
159
+ label: string;
160
+ disabled: boolean;
161
+ model: boolean;
162
+ modelChange: EventEmitter<boolean>;
163
+ changeEv: EventEmitter<boolean>;
164
+ onModelChange(event: boolean): void;
165
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslSlideToggle, never>;
166
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslSlideToggle, "osl-slide-toggle", never, { "label": { "alias": "label"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
167
+ }
168
+
169
+ declare class OslAutocomplete implements OnInit, OnChanges {
170
+ private elRef;
171
+ label: string;
172
+ required: boolean;
173
+ disabled: boolean;
174
+ model: any;
175
+ datasource: any[];
176
+ displayField: string;
177
+ valueField: string;
178
+ modelChange: EventEmitter<any>;
179
+ changeEv: EventEmitter<any>;
180
+ inputValue: string;
181
+ showDropdown: boolean;
182
+ filteredItems: any[];
183
+ touched: boolean;
184
+ constructor(elRef: ElementRef);
185
+ ngOnInit(): void;
186
+ ngOnChanges(): void;
187
+ private syncInputFromModel;
188
+ getDisplay(item: any): string;
189
+ getValue(item: any): any;
190
+ get isInvalid(): boolean;
191
+ onInput(val: string): void;
192
+ onFocus(): void;
193
+ onBlur(): void;
194
+ selectItem(item: any): void;
195
+ onDocumentClick(event: MouseEvent): void;
196
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslAutocomplete, never>;
197
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslAutocomplete, "osl-autocomplete", never, { "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; "datasource": { "alias": "datasource"; "required": false; }; "displayField": { "alias": "displayField"; "required": false; }; "valueField": { "alias": "valueField"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
198
+ }
199
+
200
+ declare class OslFileUpload {
201
+ label: string;
202
+ required: boolean;
203
+ disabled: boolean;
204
+ model: File | null;
205
+ accept: string;
206
+ modelChange: EventEmitter<File | null>;
207
+ changeEv: EventEmitter<File | null>;
208
+ touched: boolean;
209
+ get fileName(): string;
210
+ get isInvalid(): boolean;
211
+ onFileChange(event: Event): void;
212
+ triggerInput(fileInput: HTMLInputElement): void;
213
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslFileUpload, never>;
214
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslFileUpload, "osl-file-upload", never, { "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; "accept": { "alias": "accept"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
215
+ }
216
+
217
+ declare class OslDatepicker {
218
+ label: string;
219
+ required: boolean;
220
+ disabled: boolean;
221
+ model: string;
222
+ modelChange: EventEmitter<string>;
223
+ changeEv: EventEmitter<string>;
224
+ onModelChange(event: string): void;
225
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslDatepicker, never>;
226
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslDatepicker, "osl-datepicker", never, { "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
227
+ }
228
+
229
+ declare class OslCheckbox {
230
+ label: string;
231
+ disabled: boolean;
232
+ model: boolean;
233
+ modelChange: EventEmitter<boolean>;
234
+ changeEv: EventEmitter<boolean>;
235
+ onModelChange(event: boolean): void;
236
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslCheckbox, never>;
237
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslCheckbox, "osl-checkbox", never, { "label": { "alias": "label"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "modelChange": "modelChange"; "changeEv": "changeEv"; }, never, never, false, never>;
238
+ }
239
+
240
+ type ButtonVariant = 'primary' | 'secondary' | 'success' | 'danger' | 'warning' | 'info' | 'outline-primary' | 'outline-secondary' | 'outline-success' | 'outline-danger' | 'outline-warning' | 'outline-info';
241
+ type ButtonSize = 'sm' | 'md' | 'lg';
242
+ declare class OslButton {
243
+ label: string;
244
+ variant: ButtonVariant;
245
+ size: ButtonSize;
246
+ disabled: boolean;
247
+ loading: boolean;
248
+ type: 'button' | 'submit' | 'reset';
249
+ fullWidth: boolean;
250
+ clickEv: EventEmitter<void>;
251
+ get classes(): string;
252
+ onClick(): void;
253
+ static ɵfac: i0.ɵɵFactoryDeclaration<OslButton, never>;
254
+ static ɵcmp: i0.ɵɵComponentDeclaration<OslButton, "osl-button", never, { "label": { "alias": "label"; "required": false; }; "variant": { "alias": "variant"; "required": false; }; "size": { "alias": "size"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "type": { "alias": "type"; "required": false; }; "fullWidth": { "alias": "fullWidth"; "required": false; }; }, { "clickEv": "clickEv"; }, never, never, false, never>;
255
+ }
256
+
257
+ declare class formStructureModule {
258
+ static ɵfac: i0.ɵɵFactoryDeclaration<formStructureModule, never>;
259
+ static ɵmod: i0.ɵɵNgModuleDeclaration<formStructureModule, [typeof DynamicForm, typeof Oslinput, typeof Osltextarea, typeof OslSelect, typeof OslRadio, typeof OslSlideToggle, typeof OslAutocomplete, typeof OslFileUpload, typeof OslDatepicker, typeof OslCheckbox, typeof OslButton], [typeof i12.NgTemplateOutlet, typeof i13.FormsModule, typeof i14.MatFormFieldModule, typeof i15.MatInputModule, typeof i14.MatHint], [typeof DynamicForm]>;
260
+ static ɵinj: i0.ɵɵInjectorDeclaration<formStructureModule>;
261
+ }
262
+
263
+ export { Dialog, DialogWrapper, DynamicForm, Httpbase, OslBaseExtended, baseComponent, formStructureModule };
264
+ export type { HttpResponse, elements, myParams };