@tsi-developpement/tsi-shared-ui 1.7.39 → 1.8.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/consts/app-providers.mjs +4 -2
- package/esm2022/lib/models/common/entity-properties.mjs +1 -1
- package/esm2022/lib/services/form/form-state.service.mjs +13 -0
- package/esm2022/lib/services/validation/input-registry.service.mjs +9 -1
- package/esm2022/lib/tsi-base/components/tsi-form-base/tsi-form-base.component.mjs +44 -7
- package/esm2022/lib/tsi-base/tsi-input-base/tsi-input-base.component.mjs +16 -9
- package/esm2022/lib/tsi-components/create-or-edit-entity-informations/create-or-edit-entity-informations.component.mjs +3 -3
- package/esm2022/lib/tsi-components/create-or-edit-modele-import/create-or-edit-modele-import.component.mjs +3 -3
- package/esm2022/lib/tsi-components/input-components/editable-grid/editable-grid.component.mjs +12 -10
- package/esm2022/lib/tsi-components/input-components/tsi-checkbox/tsi-checkbox.component.mjs +2 -1
- package/esm2022/lib/tsi-components/input-components/tsi-currency-other-input/tsi-currency-other-input.component.mjs +6 -4
- package/esm2022/lib/tsi-components/input-components/tsi-currency-societe-input/tsi-currency-societe-input.component.mjs +6 -4
- package/esm2022/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.mjs +8 -5
- package/esm2022/lib/tsi-components/input-components/tsi-decimal-input/tsi-decimal-input.component.mjs +6 -4
- package/esm2022/lib/tsi-components/input-components/tsi-file-manager/tsi-file-manager.component.mjs +5 -1
- package/esm2022/lib/tsi-components/input-components/tsi-formula-box/tsi-formula-box.component.mjs +5 -3
- package/esm2022/lib/tsi-components/input-components/tsi-integer/tsi-integer.component.mjs +6 -4
- package/esm2022/lib/tsi-components/input-components/tsi-radio-button/tsi-radio-button.component.mjs +2 -1
- package/esm2022/lib/tsi-components/input-components/tsi-rate-input/tsi-rate-input.component.mjs +6 -4
- package/esm2022/lib/tsi-components/input-components/tsi-search-combo/tsi-search-combo.component.mjs +2 -1
- package/esm2022/lib/tsi-components/input-components/tsi-text-area/tsi-text-area.component.mjs +2 -1
- package/esm2022/lib/tsi-components/input-components/tsi-text-box/tsi-text-box.component.mjs +4 -3
- package/esm2022/lib/tsi-components/input-components/tsi-time-picker/tsi-time-picker.component.mjs +10 -8
- package/esm2022/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.mjs +3 -3
- package/esm2022/lib/tsi-components/output-components/tsi-generic-grid/tsi-generic-grid.component.mjs +3 -3
- package/esm2022/lib/tsi-components/reporting/reporting.component.mjs +16 -9
- package/esm2022/lib/tsi-components/tsi-change-password/tsi-change-password.component.mjs +3 -3
- package/esm2022/lib/tsi-components/tsi-dynamic-form/create-or-edit-dynamic-form/create-or-edit-dynamic-form.component.mjs +3 -3
- package/esm2022/lib/tsi-components/tsi-form/tsi-form.component.mjs +11 -3
- package/esm2022/lib/tsi-components/tsi-generic-form/tsi-generic-form.component.mjs +3 -3
- package/esm2022/lib/tsi-components/tsi-modal-footer/tsi-modal-footer.component.mjs +20 -9
- package/esm2022/lib/tsi-components/tsi-modal-header/tsi-modal-header.component.mjs +8 -1
- package/esm2022/lib/tsi-components/tsi-notes-createoredit/tsi-notes.component.mjs +3 -3
- package/esm2022/lib/tsi-components/tsi-upload-fiche/tsi-upload-fiche.component.mjs +3 -3
- package/fesm2022/tsi-developpement-tsi-shared-ui.mjs +202 -83
- package/fesm2022/tsi-developpement-tsi-shared-ui.mjs.map +1 -1
- package/lib/consts/app-providers.d.ts +2 -1
- package/lib/models/common/entity-properties.d.ts +1 -0
- package/lib/providers/shared-ui-tsi.provider.d.ts +1 -1
- package/lib/services/form/form-state.service.d.ts +7 -0
- package/lib/services/validation/input-registry.service.d.ts +1 -0
- package/lib/tsi-base/components/tsi-form-base/tsi-form-base.component.d.ts +15 -5
- package/lib/tsi-base/tsi-input-base/tsi-input-base.component.d.ts +5 -1
- package/lib/tsi-components/input-components/editable-grid/editable-grid.component.d.ts +3 -4
- package/lib/tsi-components/input-components/tsi-currency-other-input/tsi-currency-other-input.component.d.ts +1 -1
- package/lib/tsi-components/input-components/tsi-currency-societe-input/tsi-currency-societe-input.component.d.ts +1 -1
- package/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.d.ts +3 -2
- package/lib/tsi-components/input-components/tsi-decimal-input/tsi-decimal-input.component.d.ts +1 -1
- package/lib/tsi-components/input-components/tsi-integer/tsi-integer.component.d.ts +1 -1
- package/lib/tsi-components/input-components/tsi-rate-input/tsi-rate-input.component.d.ts +1 -1
- package/lib/tsi-components/input-components/tsi-time-picker/tsi-time-picker.component.d.ts +1 -1
- package/lib/tsi-components/reporting/reporting.component.d.ts +4 -1
- package/lib/tsi-components/tsi-form/tsi-form.component.d.ts +4 -1
- package/lib/tsi-components/tsi-modal-footer/tsi-modal-footer.component.d.ts +6 -2
- package/lib/tsi-components/tsi-modal-header/tsi-modal-header.component.d.ts +3 -1
- package/package.json +1 -1
|
@@ -48,6 +48,7 @@ export class TsiCheckboxComponent extends TsiInputBase {
|
|
|
48
48
|
onChangeofOptions(event) {
|
|
49
49
|
this.toggleCheckbox();
|
|
50
50
|
this.inputField = this.checked;
|
|
51
|
+
this.isDirty = true;
|
|
51
52
|
//console.log(">>> this.inputField:", this.inputField);
|
|
52
53
|
this.inputFieldChange.emit(this.inputField);
|
|
53
54
|
}
|
|
@@ -117,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
117
118
|
}], checkedChange: [{
|
|
118
119
|
type: Output
|
|
119
120
|
}] } });
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsi-checkbox.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-checkbox/tsi-checkbox.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-checkbox/tsi-checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewEncapsulation,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  OnInit,\r\n} from '@angular/core';\r\nimport { TsiInputBase } from '../../../tsi-base/tsi-input-base/tsi-input-base.component';\r\nimport { TooltipPosition } from '../../../enums/tooltipPosition.enum';\r\n\r\n@Component({\r\n  selector: 'Tsi-CheckBox',\r\n  templateUrl: './tsi-checkbox.component.html',\r\n  styleUrls: ['./tsi-checkbox.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class TsiCheckboxComponent extends TsiInputBase<boolean | undefined> implements OnChanges, OnInit {\r\n  \r\n  //#region inputs\r\n  @Input('class') class: any = {};\r\n  @Input() isBinary: boolean = false;\r\n\r\n  private _checked: boolean | undefined = undefined;\r\n\r\n  // @Input()\r\n  // set inputField(value: boolean | undefined) {\r\n  //   this._checked = value;\r\n  // }\r\n\r\n  // get inputField(): boolean | undefined {\r\n  //   return this._checked;\r\n  // }\r\n\r\n  @Input()\r\n  set checked(value: boolean | undefined) {\r\n    this._checked = value;\r\n  }\r\n\r\n  get checked(): boolean | undefined {\r\n    return this._checked;\r\n  }\r\n  //#endregion\r\n\r\n  @Input() tooltipText: any;\r\n  @Input() tooltipPosition: string | any = TooltipPosition.Top;\r\n\r\n  //#region outputs\r\n  @Output() inputFieldChange = new EventEmitter<boolean>();\r\n  @Output() checkedChange = new EventEmitter<any>();\r\n  //#endregion\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    // if (this.inputField === undefined || this.inputField === null) {\r\n    //   this.inputField = false;\r\n    //   this.inputFieldChange.emit(this.inputField);\r\n    // }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputField']) {\r\n      this.checked = changes['inputField'].currentValue;\r\n      this.updateTooltipText();\r\n    }\r\n  }\r\n\r\n  onChangeofOptions(event: boolean) {\r\n    this.toggleCheckbox();\r\n    this.inputField = this.checked;\r\n    this.isDirty = true;\r\n    //console.log(\">>> this.inputField:\", this.inputField);\r\n    this.inputFieldChange.emit(this.inputField);\r\n  }\r\n\r\n  toggleCheckbox() {\r\n\r\n    if (this.isBinary) {\r\n      this.checked = this.checked === true ? false : true;\r\n    } else {\r\n      if (this.checked === undefined) {\r\n        this.checked = true;\r\n      } else if (this.checked === true) {\r\n        this.checked = false;\r\n      } else {\r\n        this.checked = undefined;\r\n      }\r\n    }\r\n\r\n    this.updateTooltipText();\r\n    this.checkedChange.emit(this.checked);\r\n  }\r\n\r\n  getCheckboxClass() {\r\n    if (this.isBinary) {\r\n      return {\r\n        'checkbox-true': this.checked === true,\r\n        'checkbox-false': this.checked === false\r\n      };\r\n    } else {\r\n      return {\r\n        'checkbox-true': this.checked === true,\r\n        'checkbox-false': this.checked === false,\r\n        'checkbox-indeterminate': this.checked === undefined\r\n      };\r\n    }\r\n  }\r\n\r\n  private updateTooltipText() {\r\n    if (this.checked === true) {\r\n      this.tooltipText = 'True';\r\n    } else if (this.checked === false) {\r\n      this.tooltipText = 'False';\r\n    } else {\r\n      this.tooltipText = 'Undefined';\r\n    }\r\n  }\r\n\r\n}\r\n","<div class=\"flex\">\r\n    <p-checkbox \r\n        class=\"{{validationStatusCssClass}}\"\r\n        [ngModel]=\"checked\" \r\n        [binary]=\"true\" \r\n        (ngModelChange)=\"onChangeofOptions($event)\"\r\n        [disabled]=\"disabled\"\r\n        [ngClass]=\"getCheckboxClass()\"\r\n        [tooltipPosition]=\"tooltipPosition\"\r\n        [pTooltip]=\"tooltipText\">\r\n    </p-checkbox>\r\n</div>\r\n"]}
|
|
@@ -21,8 +21,10 @@ export class TsiCurrencyOtherInputComponent extends TsiInputBase {
|
|
|
21
21
|
//#endregion
|
|
22
22
|
this.isValueChanged = false;
|
|
23
23
|
}
|
|
24
|
-
valueChanged() {
|
|
24
|
+
valueChanged(event) {
|
|
25
25
|
this.isValueChanged = true;
|
|
26
|
+
this.inputField = event;
|
|
27
|
+
this.isDirty = true;
|
|
26
28
|
}
|
|
27
29
|
onChangeofOptions() {
|
|
28
30
|
if (this.isValueChanged) {
|
|
@@ -35,11 +37,11 @@ export class TsiCurrencyOtherInputComponent extends TsiInputBase {
|
|
|
35
37
|
this.currency = this._localizationPipe.transform(this.currency ?? "");
|
|
36
38
|
}
|
|
37
39
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiCurrencyOtherInputComponent, deps: [{ token: i1.LocalizePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
38
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiCurrencyOtherInputComponent, selector: "Tsi-Currency-Other-Input", inputs: { numOfDecimal: "numOfDecimal", currency: "currency", class: "class" }, outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber \r\n autoSelect\r\n [disabled]=\"disabled\"\r\n (onBlur)=\"onChangeofOptions()\"\r\n [
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiCurrencyOtherInputComponent, selector: "Tsi-Currency-Other-Input", inputs: { numOfDecimal: "numOfDecimal", currency: "currency", class: "class" }, outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber \r\n autoSelect\r\n [disabled]=\"disabled\"\r\n (onBlur)=\"onChangeofOptions()\"\r\n [ngModel]=\"inputField\" \r\n (ngModelChange)=\"valueChanged($event)\"\r\n class=\"{{myStyleClass}}\" styleClass=\"{{myStyleClass}} border-radius-7 {{validationStatusCssClass}}\" \r\n inputStyleClass=\"{{myStyleClass}}\" name=\"{{inputName}}\"\r\n id=\"{{inputId}}\" [suffix]=\"currency\" [minFractionDigits]=\"numOfDecimal ?? 0\" [maxFractionDigits]=\"numOfDecimal ?? 0\"\r\n [locale]=\"locale\">\r\n </p-inputNumber>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i4.TsiBubbleInfoComponent, selector: "Tsi-Bubble-Info", inputs: ["infoText"] }, { kind: "directive", type: i5.AutoSelectDirective, selector: "[autoSelect]" }] }); }
|
|
39
41
|
}
|
|
40
42
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiCurrencyOtherInputComponent, decorators: [{
|
|
41
43
|
type: Component,
|
|
42
|
-
args: [{ selector: 'Tsi-Currency-Other-Input', standalone: false, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber \r\n autoSelect\r\n [disabled]=\"disabled\"\r\n (onBlur)=\"onChangeofOptions()\"\r\n [
|
|
44
|
+
args: [{ selector: 'Tsi-Currency-Other-Input', standalone: false, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber \r\n autoSelect\r\n [disabled]=\"disabled\"\r\n (onBlur)=\"onChangeofOptions()\"\r\n [ngModel]=\"inputField\" \r\n (ngModelChange)=\"valueChanged($event)\"\r\n class=\"{{myStyleClass}}\" styleClass=\"{{myStyleClass}} border-radius-7 {{validationStatusCssClass}}\" \r\n inputStyleClass=\"{{myStyleClass}}\" name=\"{{inputName}}\"\r\n id=\"{{inputId}}\" [suffix]=\"currency\" [minFractionDigits]=\"numOfDecimal ?? 0\" [maxFractionDigits]=\"numOfDecimal ?? 0\"\r\n [locale]=\"locale\">\r\n </p-inputNumber>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>" }]
|
|
43
45
|
}], ctorParameters: () => [{ type: i1.LocalizePipe }], propDecorators: { numOfDecimal: [{
|
|
44
46
|
type: Input
|
|
45
47
|
}], currency: [{
|
|
@@ -50,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
50
52
|
}], inputFieldChange: [{
|
|
51
53
|
type: Output
|
|
52
54
|
}] } });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNpLWN1cnJlbmN5LW90aGVyLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RzaS1zaGFyZWQtdWkvc3JjL2xpYi90c2ktY29tcG9uZW50cy9pbnB1dC1jb21wb25lbnRzL3RzaS1jdXJyZW5jeS1vdGhlci1pbnB1dC90c2ktY3VycmVuY3ktb3RoZXItaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLWN1cnJlbmN5LW90aGVyLWlucHV0L3RzaS1jdXJyZW5jeS1vdGhlci1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyREFBMkQsQ0FBQzs7Ozs7OztBQVN6RixNQUFNLE9BQU8sOEJBQStCLFNBQVEsWUFBZ0M7SUFhbEYsWUFBb0IsaUJBQStCO1FBQ2pELEtBQUssRUFBRSxDQUFBO1FBRFcsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFjO1FBWm5ELGdCQUFnQjtRQUNQLGlCQUFZLEdBQVksQ0FBQyxDQUFBO1FBQ2xDLGdDQUFnQztRQUN2QixhQUFRLEdBQVksS0FBSyxDQUFDO1FBQ25CLFVBQUssR0FBUSxFQUFFLENBQUM7UUFDaEMsWUFBWTtRQUVaLGlCQUFpQjtRQUNQLHFCQUFnQixHQUF5QixJQUFJLFlBQVksRUFBVSxDQUFDO1FBQzlFLFlBQVk7UUFFSixtQkFBYyxHQUFZLEtBQUssQ0FBQTtJQUd2QyxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQVc7UUFDdEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUE7UUFDMUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7UUFDeEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUE7SUFDckIsQ0FBQztJQUVELGlCQUFpQjtRQUNmLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3hCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQzVDLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxDQUFBO1FBQzdCLENBQUM7SUFDSCxDQUFDO0lBR1EsUUFBUTtRQUNmLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxFQUFFLENBQUMsQ0FBQTtJQUN2RSxDQUFDOytHQWxDVSw4QkFBOEI7bUdBQTlCLDhCQUE4QiwwTkNWM0MsMHJCQWFNOzs0RkRITyw4QkFBOEI7a0JBTjFDLFNBQVM7K0JBQ0UsMEJBQTBCLGNBR3hCLEtBQUs7aUZBSVIsWUFBWTtzQkFBcEIsS0FBSztnQkFFRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNVLEtBQUs7c0JBQXBCLEtBQUs7dUJBQUMsT0FBTztnQkFJSixnQkFBZ0I7c0JBQXpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRzaUlucHV0QmFzZSB9IGZyb20gJy4uLy4uLy4uL3RzaS1iYXNlL3RzaS1pbnB1dC1iYXNlL3RzaS1pbnB1dC1iYXNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IExvY2FsaXplUGlwZSB9IGZyb20gJy4uLy4uLy4uL3BpcGVzL2xvY2FsaXplLnBpcGUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdUc2ktQ3VycmVuY3ktT3RoZXItSW5wdXQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi90c2ktY3VycmVuY3ktb3RoZXItaW5wdXQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RzaS1jdXJyZW5jeS1vdGhlci1pbnB1dC5jb21wb25lbnQuc2NzcyddLFxyXG4gIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUc2lDdXJyZW5jeU90aGVySW5wdXRDb21wb25lbnQgZXh0ZW5kcyBUc2lJbnB1dEJhc2U8bnVtYmVyIHwgdW5kZWZpbmVkPiBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgLy8jcmVnaW9uIGlucHV0c1xyXG4gIEBJbnB1dCgpIG51bU9mRGVjaW1hbD86IG51bWJlciA9IDJcclxuICAvLyBASW5wdXQoKSBpbnB1dEZpZWxkPzogbnVtYmVyO1xyXG4gIEBJbnB1dCgpIGN1cnJlbmN5Pzogc3RyaW5nID0gJ1RORCc7XHJcbiAgQElucHV0KCdjbGFzcycpIGNsYXNzOiBhbnkgPSB7fTtcclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIG91dHB1dHNcclxuICBAT3V0cHV0KCkgaW5wdXRGaWVsZENoYW5nZTogRXZlbnRFbWl0dGVyPG51bWJlcj4gPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgcHJpdmF0ZSBpc1ZhbHVlQ2hhbmdlZDogYm9vbGVhbiA9IGZhbHNlXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfbG9jYWxpemF0aW9uUGlwZTogTG9jYWxpemVQaXBlKSB7XHJcbiAgICBzdXBlcigpXHJcbiAgfVxyXG5cclxuICB2YWx1ZUNoYW5nZWQoZXZlbnQgOiBhbnkpIHtcclxuICAgIHRoaXMuaXNWYWx1ZUNoYW5nZWQgPSB0cnVlXHJcbiAgICB0aGlzLmlucHV0RmllbGQgPSBldmVudDtcclxuICAgIHRoaXMuaXNEaXJ0eSA9IHRydWVcclxuICB9XHJcblxyXG4gIG9uQ2hhbmdlb2ZPcHRpb25zKCk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMuaXNWYWx1ZUNoYW5nZWQpIHtcclxuICAgICAgdGhpcy5pbnB1dEZpZWxkQ2hhbmdlLmVtaXQodGhpcy5pbnB1dEZpZWxkKTtcclxuICAgICAgdGhpcy5pc1ZhbHVlQ2hhbmdlZCA9IGZhbHNlXHJcbiAgICB9XHJcbiAgfVxyXG5cclxuXHJcbiAgb3ZlcnJpZGUgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgdGhpcy5jdXJyZW5jeSA9IHRoaXMuX2xvY2FsaXphdGlvblBpcGUudHJhbnNmb3JtKHRoaXMuY3VycmVuY3kgPz8gXCJcIilcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImZsZXggaC0ycmVtXCI+XHJcbiAgICA8cC1pbnB1dE51bWJlciBcclxuICAgICAgICBhdXRvU2VsZWN0XHJcbiAgICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgICAgICAob25CbHVyKT1cIm9uQ2hhbmdlb2ZPcHRpb25zKClcIlxyXG4gICAgICAgIFtuZ01vZGVsXT1cImlucHV0RmllbGRcIiBcclxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJ2YWx1ZUNoYW5nZWQoJGV2ZW50KVwiXHJcbiAgICAgICAgY2xhc3M9XCJ7e215U3R5bGVDbGFzc319XCIgc3R5bGVDbGFzcz1cInt7bXlTdHlsZUNsYXNzfX0gYm9yZGVyLXJhZGl1cy03IHt7dmFsaWRhdGlvblN0YXR1c0Nzc0NsYXNzfX1cIiBcclxuICAgICAgICBpbnB1dFN0eWxlQ2xhc3M9XCJ7e215U3R5bGVDbGFzc319XCIgbmFtZT1cInt7aW5wdXROYW1lfX1cIlxyXG4gICAgICAgIGlkPVwie3tpbnB1dElkfX1cIiBbc3VmZml4XT1cImN1cnJlbmN5XCIgW21pbkZyYWN0aW9uRGlnaXRzXT1cIm51bU9mRGVjaW1hbCA/PyAwXCIgW21heEZyYWN0aW9uRGlnaXRzXT1cIm51bU9mRGVjaW1hbCA/PyAwXCJcclxuICAgICAgICBbbG9jYWxlXT1cImxvY2FsZVwiPlxyXG4gICAgPC9wLWlucHV0TnVtYmVyPlxyXG4gICAgPFRzaS1CdWJibGUtSW5mbyBbaW5mb1RleHRdPVwiaW5mb1RleHRcIj48L1RzaS1CdWJibGUtSW5mbz5cclxuPC9kaXY+Il19
|
|
@@ -35,8 +35,10 @@ export class TsiCurrencySocieteInputComponent extends TsiInputBase {
|
|
|
35
35
|
// this.inputField = 0;
|
|
36
36
|
// }
|
|
37
37
|
}
|
|
38
|
-
valueChanged() {
|
|
38
|
+
valueChanged(event) {
|
|
39
39
|
this.isValueChanged = true;
|
|
40
|
+
this.inputField = event;
|
|
41
|
+
this.isDirty = true;
|
|
40
42
|
}
|
|
41
43
|
onChangeofOptions() {
|
|
42
44
|
if (this.isValueChanged) {
|
|
@@ -45,15 +47,15 @@ export class TsiCurrencySocieteInputComponent extends TsiInputBase {
|
|
|
45
47
|
}
|
|
46
48
|
}
|
|
47
49
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiCurrencySocieteInputComponent, deps: [{ token: i1.AppSettingsService }, { token: i2.LocalizePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
48
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiCurrencySocieteInputComponent, selector: "Tsi-Currency-Societe-Input", inputs: { class: "class" }, outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber\r\n autoSelect\r\n class=\"{{ myStyleClass }} {{ class }}\"\r\n styleClass=\"{{ myStyleClass }} border-radius-7 {{validationStatusCssClass}}\"\r\n inputStyleClass=\"{{ myStyleClass }}\"\r\n [disabled]=\"disabled\"\r\n [
|
|
50
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiCurrencySocieteInputComponent, selector: "Tsi-Currency-Societe-Input", inputs: { class: "class" }, outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber\r\n autoSelect\r\n class=\"{{ myStyleClass }} {{ class }}\"\r\n styleClass=\"{{ myStyleClass }} border-radius-7 {{validationStatusCssClass}}\"\r\n inputStyleClass=\"{{ myStyleClass }}\"\r\n [disabled]=\"disabled\"\r\n [ngModel]=\"inputField\"\r\n (ngModelChange)=\"valueChanged($event)\"\r\n (onBlur)=\"onChangeofOptions()\"\r\n name=\"{{ inputName }}\"\r\n id=\"{{ inputId }}\"\r\n suffix=\" {{currency}}\" \r\n locale=\"en-US\"\r\n [minFractionDigits]=\"numOfDecimal ?? 0\"\r\n [maxFractionDigits]=\"numOfDecimal ?? 0\"\r\n [locale]=\"locale\">\r\n </p-inputNumber>\r\n\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [":host{width:inherit}\n"], dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i5.TsiBubbleInfoComponent, selector: "Tsi-Bubble-Info", inputs: ["infoText"] }, { kind: "directive", type: i6.AutoSelectDirective, selector: "[autoSelect]" }] }); }
|
|
49
51
|
}
|
|
50
52
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiCurrencySocieteInputComponent, decorators: [{
|
|
51
53
|
type: Component,
|
|
52
|
-
args: [{ selector: 'Tsi-Currency-Societe-Input', template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber\r\n autoSelect\r\n class=\"{{ myStyleClass }} {{ class }}\"\r\n styleClass=\"{{ myStyleClass }} border-radius-7 {{validationStatusCssClass}}\"\r\n inputStyleClass=\"{{ myStyleClass }}\"\r\n [disabled]=\"disabled\"\r\n [
|
|
54
|
+
args: [{ selector: 'Tsi-Currency-Societe-Input', template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber\r\n autoSelect\r\n class=\"{{ myStyleClass }} {{ class }}\"\r\n styleClass=\"{{ myStyleClass }} border-radius-7 {{validationStatusCssClass}}\"\r\n inputStyleClass=\"{{ myStyleClass }}\"\r\n [disabled]=\"disabled\"\r\n [ngModel]=\"inputField\"\r\n (ngModelChange)=\"valueChanged($event)\"\r\n (onBlur)=\"onChangeofOptions()\"\r\n name=\"{{ inputName }}\"\r\n id=\"{{ inputId }}\"\r\n suffix=\" {{currency}}\" \r\n locale=\"en-US\"\r\n [minFractionDigits]=\"numOfDecimal ?? 0\"\r\n [maxFractionDigits]=\"numOfDecimal ?? 0\"\r\n [locale]=\"locale\">\r\n </p-inputNumber>\r\n\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [":host{width:inherit}\n"] }]
|
|
53
55
|
}], ctorParameters: () => [{ type: i1.AppSettingsService }, { type: i2.LocalizePipe }], propDecorators: { class: [{
|
|
54
56
|
type: Input,
|
|
55
57
|
args: ['class']
|
|
56
58
|
}], inputFieldChange: [{
|
|
57
59
|
type: Output
|
|
58
60
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNpLWN1cnJlbmN5LXNvY2lldGUtaW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLWN1cnJlbmN5LXNvY2lldGUtaW5wdXQvdHNpLWN1cnJlbmN5LXNvY2lldGUtaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLWN1cnJlbmN5LXNvY2lldGUtaW5wdXQvdHNpLWN1cnJlbmN5LXNvY2lldGUtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sR0FFUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkRBQTJELENBQUM7QUFHekYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7Ozs7O0FBT2xFLE1BQU0sT0FBTyxnQ0FBaUMsU0FBUSxZQUFnQztJQWlCcEYsWUFBb0Isa0JBQXNDLEVBQ2hELGlCQUErQjtRQUN2QyxLQUFLLEVBQUUsQ0FBQztRQUZVLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFDaEQsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFjO1FBaEJ6QyxhQUFRLEdBQVcsb0JBQW9CLENBQUMsVUFBVSxDQUFDO1FBQ3pDLGlCQUFZLEdBQVksQ0FBQyxDQUFDO1FBRXBDLFVBQUssR0FBUSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsQ0FBQztRQUVsQyxpQkFBaUI7UUFDRCxVQUFLLEdBQVEsRUFBRSxDQUFDO1FBQ2hDLFlBQVk7UUFFWixpQkFBaUI7UUFDUCxxQkFBZ0IsR0FBeUIsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUM5RSxZQUFZO1FBRUosbUJBQWMsR0FBWSxLQUFLLENBQUM7UUFLdEMsSUFBSSxDQUFDLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLFVBQVUsSUFBSSxvQkFBb0IsQ0FBQyxVQUFVLENBQUM7UUFDM0csSUFBSSxDQUFDLFlBQVk7WUFDZixrQkFBa0IsQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLGVBQWU7Z0JBQzVELG9CQUFvQixDQUFDLGVBQWUsQ0FBQztJQUN6QyxDQUFDO0lBRVEsUUFBUTtRQUNmLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hFLG1FQUFtRTtRQUNuRSx5QkFBeUI7UUFDekIsSUFBSTtJQUNOLENBQUM7SUFFRCxZQUFZLENBQUMsS0FBVztRQUN0QixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQztRQUMzQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztJQUN0QixDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDNUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUM7UUFDOUIsQ0FBQztJQUNILENBQUM7K0dBN0NVLGdDQUFnQzttR0FBaEMsZ0NBQWdDLHdLQ2xCN0Msc3VCQW9CTTs7NEZERk8sZ0NBQWdDO2tCQUw1QyxTQUFTOytCQUNFLDRCQUE0QjtrSEFZdEIsS0FBSztzQkFBcEIsS0FBSzt1QkFBQyxPQUFPO2dCQUlKLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbnB1dCxcclxuICBPbkluaXQsXHJcbiAgT3V0cHV0LFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUc2lJbnB1dEJhc2UgfSBmcm9tICcuLi8uLi8uLi90c2ktYmFzZS90c2ktaW5wdXQtYmFzZS90c2ktaW5wdXQtYmFzZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBcHBTZXR0aW5nc1NlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy9zZXR0aW5ncy9hcHAtc2V0dGluZ3Muc2VydmljZSc7XHJcbmltcG9ydCB7IExvY2FsaXplUGlwZSB9IGZyb20gJy4uLy4uLy4uL3BpcGVzL2xvY2FsaXplLnBpcGUnO1xyXG5pbXBvcnQgeyBEZWZhdWx0U29jaWV0ZURldmlzZSB9IGZyb20gJy4uLy4uLy4uL2NvbnN0cy90c2ktY29uc3RzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnVHNpLUN1cnJlbmN5LVNvY2lldGUtSW5wdXQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi90c2ktY3VycmVuY3ktc29jaWV0ZS1pbnB1dC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdHNpLWN1cnJlbmN5LXNvY2lldGUtaW5wdXQuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFRzaUN1cnJlbmN5U29jaWV0ZUlucHV0Q29tcG9uZW50IGV4dGVuZHMgVHNpSW5wdXRCYXNlPG51bWJlciB8IHVuZGVmaW5lZD4gaW1wbGVtZW50cyBPbkluaXRcclxue1xyXG4gIGN1cnJlbmN5OiBzdHJpbmcgPSBEZWZhdWx0U29jaWV0ZURldmlzZS5jb2RlRGV2aXNlO1xyXG4gIHByb3RlY3RlZCBudW1PZkRlY2ltYWw/OiBudW1iZXIgPSAzO1xyXG4gIFxyXG4gIHN0eWxlOiBhbnkgPSB7IHdpZHRoOiAnaW5oZXJpdCcgfTtcclxuICBcclxuICAvLyNyZWdpb24gb3V0cHV0c1xyXG4gIEBJbnB1dCgnY2xhc3MnKSBjbGFzczogYW55ID0ge307XHJcbiAgLy8jZW5kcmVnaW9uXHJcbiBcclxuICAvLyNyZWdpb24gb3V0cHV0c1xyXG4gIEBPdXRwdXQoKSBpbnB1dEZpZWxkQ2hhbmdlOiBFdmVudEVtaXR0ZXI8bnVtYmVyPiA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xyXG4gIC8vI2VuZHJlZ2lvblxyXG4gXHJcbiAgcHJpdmF0ZSBpc1ZhbHVlQ2hhbmdlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGFwcFNldHRpbmdzU2VydmljZTogQXBwU2V0dGluZ3NTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBfbG9jYWxpemF0aW9uUGlwZTogTG9jYWxpemVQaXBlKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gICAgdGhpcy5jdXJyZW5jeSA9IGFwcFNldHRpbmdzU2VydmljZS5hcHBTZXR0aW5ncy5kZXZpc2VTb2NpZXRlLmNvZGVEZXZpc2UgPz8gRGVmYXVsdFNvY2lldGVEZXZpc2UuY29kZURldmlzZTtcclxuICAgIHRoaXMubnVtT2ZEZWNpbWFsID1cclxuICAgICAgYXBwU2V0dGluZ3NTZXJ2aWNlLmFwcFNldHRpbmdzLmRldmlzZVNvY2lldGUubm9tYnJlRGVjaW1hbGVzID8/XHJcbiAgICAgIERlZmF1bHRTb2NpZXRlRGV2aXNlLm5vbWJyZURlY2ltYWxlcztcclxuICB9XHJcblxyXG4gIG92ZXJyaWRlIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgIHRoaXMuY3VycmVuY3kgPSB0aGlzLl9sb2NhbGl6YXRpb25QaXBlLnRyYW5zZm9ybSh0aGlzLmN1cnJlbmN5KTtcclxuICAgIC8vIGlmICh0aGlzLmlucHV0RmllbGQgPT09IHVuZGVmaW5lZCB8fCB0aGlzLmlucHV0RmllbGQgPT09IG51bGwpIHtcclxuICAgIC8vICAgdGhpcy5pbnB1dEZpZWxkID0gMDtcclxuICAgIC8vIH1cclxuICB9XHJcblxyXG4gIHZhbHVlQ2hhbmdlZChldmVudCA6IGFueSkge1xyXG4gICAgdGhpcy5pc1ZhbHVlQ2hhbmdlZCA9IHRydWU7XHJcbiAgICB0aGlzLmlucHV0RmllbGQgPSBldmVudDtcclxuICAgIHRoaXMuaXNEaXJ0eSA9IHRydWU7XHJcbiAgfVxyXG5cclxuICBvbkNoYW5nZW9mT3B0aW9ucygpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLmlzVmFsdWVDaGFuZ2VkKSB7XHJcbiAgICAgIHRoaXMuaW5wdXRGaWVsZENoYW5nZS5lbWl0KHRoaXMuaW5wdXRGaWVsZCk7XHJcbiAgICAgIHRoaXMuaXNWYWx1ZUNoYW5nZWQgPSBmYWxzZTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImZsZXggaC0ycmVtXCI+XHJcbiAgPHAtaW5wdXROdW1iZXJcclxuICAgIGF1dG9TZWxlY3RcclxuICAgIGNsYXNzPVwie3sgbXlTdHlsZUNsYXNzIH19IHt7IGNsYXNzIH19XCJcclxuICAgIHN0eWxlQ2xhc3M9XCJ7eyBteVN0eWxlQ2xhc3MgfX0gYm9yZGVyLXJhZGl1cy03IHt7dmFsaWRhdGlvblN0YXR1c0Nzc0NsYXNzfX1cIlxyXG4gICAgaW5wdXRTdHlsZUNsYXNzPVwie3sgbXlTdHlsZUNsYXNzIH19XCJcclxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXHJcbiAgICBbbmdNb2RlbF09XCJpbnB1dEZpZWxkXCJcclxuICAgIChuZ01vZGVsQ2hhbmdlKT1cInZhbHVlQ2hhbmdlZCgkZXZlbnQpXCJcclxuICAgIChvbkJsdXIpPVwib25DaGFuZ2VvZk9wdGlvbnMoKVwiXHJcbiAgICBuYW1lPVwie3sgaW5wdXROYW1lIH19XCJcclxuICAgIGlkPVwie3sgaW5wdXRJZCB9fVwiXHJcbiAgICBzdWZmaXg9XCIge3tjdXJyZW5jeX19XCIgXHJcbiAgICBsb2NhbGU9XCJlbi1VU1wiXHJcbiAgICBbbWluRnJhY3Rpb25EaWdpdHNdPVwibnVtT2ZEZWNpbWFsID8/IDBcIlxyXG4gICAgW21heEZyYWN0aW9uRGlnaXRzXT1cIm51bU9mRGVjaW1hbCA/PyAwXCJcclxuICAgIFtsb2NhbGVdPVwibG9jYWxlXCI+XHJcbiAgPC9wLWlucHV0TnVtYmVyPlxyXG5cclxuICA8VHNpLUJ1YmJsZS1JbmZvIFtpbmZvVGV4dF09XCJpbmZvVGV4dFwiPjwvVHNpLUJ1YmJsZS1JbmZvPlxyXG48L2Rpdj4iXX0=
|
package/esm2022/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.mjs
CHANGED
|
@@ -38,10 +38,10 @@ export class TsiDatePickerComponent extends TsiInputBase {
|
|
|
38
38
|
}
|
|
39
39
|
//#endregion
|
|
40
40
|
//#region handle events
|
|
41
|
-
onFocusOut(
|
|
41
|
+
onFocusOut() {
|
|
42
42
|
this._handleDateChange();
|
|
43
43
|
}
|
|
44
|
-
onSelect(
|
|
44
|
+
onSelect() {
|
|
45
45
|
this._handleDateChange();
|
|
46
46
|
}
|
|
47
47
|
//#endregion
|
|
@@ -74,6 +74,9 @@ export class TsiDatePickerComponent extends TsiInputBase {
|
|
|
74
74
|
: undefined;
|
|
75
75
|
this._value = date;
|
|
76
76
|
}
|
|
77
|
+
onModelChange(event) {
|
|
78
|
+
this.isDirty = true;
|
|
79
|
+
}
|
|
77
80
|
_handleDateChange() {
|
|
78
81
|
this._updateInputFieldFromStringDate();
|
|
79
82
|
this.inputFieldChange.emit(this.inputField);
|
|
@@ -96,11 +99,11 @@ export class TsiDatePickerComponent extends TsiInputBase {
|
|
|
96
99
|
this.calendarRef.overlayVisible = false;
|
|
97
100
|
}
|
|
98
101
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiDatePickerComponent, deps: [{ token: i1.DatePipe }, { token: i2.DateHelperService }, { token: i3.PrimeNGConfig }, { token: i4.LayoutService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
99
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiDatePickerComponent, selector: "Tsi-Date-Picker", inputs: { required: "required", showTime: "showTime", showButtonBar: "showButtonBar" }, outputs: { inputFieldChange: "inputFieldChange" }, viewQueries: [{ propertyName: "calendarRef", first: true, predicate: ["calendarRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"flex\">\r\n <p-calendar #calendarRef\r\n [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}}\"\r\n styleClass=\"{{myStyleClass}} border-radius-7\"\r\n inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n [showTime]=\"showTime\"\r\n [showSeconds]=\"showTime\"\r\n [(ngModel)]=\"dateString\"\r\n (onBlur)=\"onFocusOut(
|
|
102
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiDatePickerComponent, selector: "Tsi-Date-Picker", inputs: { required: "required", showTime: "showTime", showButtonBar: "showButtonBar" }, outputs: { inputFieldChange: "inputFieldChange" }, viewQueries: [{ propertyName: "calendarRef", first: true, predicate: ["calendarRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"flex\">\r\n <p-calendar #calendarRef\r\n [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}}\"\r\n styleClass=\"{{myStyleClass}} border-radius-7\"\r\n inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n [showTime]=\"showTime\"\r\n [showSeconds]=\"showTime\"\r\n [(ngModel)]=\"dateString\"\r\n (onBlur)=\"onFocusOut()\"\r\n (onSelect)=\"onSelect()\"\r\n (onFocus)=\"onFocusHandler($event)\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n >\r\n </p-calendar>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [".ColorClass{background-color:#2bff00;text-align:right}.p-datepicker-trigger{border-top-right-radius:7px!important;border-bottom-right-radius:7px!important}\n"], dependencies: [{ kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i7.TsiBubbleInfoComponent, selector: "Tsi-Bubble-Info", inputs: ["infoText"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
100
103
|
}
|
|
101
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiDatePickerComponent, decorators: [{
|
|
102
105
|
type: Component,
|
|
103
|
-
args: [{ selector: 'Tsi-Date-Picker', encapsulation: ViewEncapsulation.None, template: "<div class=\"flex\">\r\n <p-calendar #calendarRef\r\n [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}}\"\r\n styleClass=\"{{myStyleClass}} border-radius-7\"\r\n inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n [showTime]=\"showTime\"\r\n [showSeconds]=\"showTime\"\r\n [(ngModel)]=\"dateString\"\r\n (onBlur)=\"onFocusOut(
|
|
106
|
+
args: [{ selector: 'Tsi-Date-Picker', encapsulation: ViewEncapsulation.None, template: "<div class=\"flex\">\r\n <p-calendar #calendarRef\r\n [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}}\"\r\n styleClass=\"{{myStyleClass}} border-radius-7\"\r\n inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n [showTime]=\"showTime\"\r\n [showSeconds]=\"showTime\"\r\n [(ngModel)]=\"dateString\"\r\n (onBlur)=\"onFocusOut()\"\r\n (onSelect)=\"onSelect()\"\r\n (onFocus)=\"onFocusHandler($event)\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n >\r\n </p-calendar>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [".ColorClass{background-color:#2bff00;text-align:right}.p-datepicker-trigger{border-top-right-radius:7px!important;border-bottom-right-radius:7px!important}\n"] }]
|
|
104
107
|
}], ctorParameters: () => [{ type: i1.DatePipe }, { type: i2.DateHelperService }, { type: i3.PrimeNGConfig }, { type: i4.LayoutService }], propDecorators: { calendarRef: [{
|
|
105
108
|
type: ViewChild,
|
|
106
109
|
args: ['calendarRef']
|
|
@@ -113,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
113
116
|
}], inputFieldChange: [{
|
|
114
117
|
type: Output
|
|
115
118
|
}] } });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsi-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnInit, Output, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { PrimeNGConfig } from 'primeng/api';\r\nimport { TsiInputBase } from '../../../tsi-base/tsi-input-base/tsi-input-base.component';\r\nimport { DateFormat, DatePickerDateFormat, DateTimeFormat, TimeZoneLocale } from '../../../consts/tsi-consts';\r\nimport { DateHelperService } from '../../../services/date-helper.service';\r\nimport { LayoutService } from '../../../services/application/app.layout.service';\r\nimport { primengDateLocalAr } from '../../../tsi-helpers/primeng-translate-config';\r\n\r\n\r\n@Component({\r\n  selector: 'Tsi-Date-Picker',\r\n  templateUrl: './tsi-date-picker.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  styleUrls: ['./tsi-date-picker.component.css']\r\n})\r\nexport class TsiDatePickerComponent extends TsiInputBase<Date | undefined> implements OnInit {\r\n\r\n  @ViewChild('calendarRef') calendarRef!: any;\r\n\r\n  //#region local properties\r\n  private _value: Date | undefined;\r\n\r\n  dateString: string | undefined;\r\n  datePickerFormat: string = DatePickerDateFormat;\r\n  //#endregion\r\n\r\n  //#region inputs\r\n  @Input() required?: boolean;\r\n  @Input() showTime: boolean = false; \r\n  @Input() showButtonBar: boolean = true; \r\n\r\n  override get inputField(): Date | undefined {\r\n    return this._value;\r\n  }\r\n\r\n  override set inputField(value: Date | undefined) {\r\n    this._value = value ? this._createUtcDate(value) : undefined;\r\n    this.dateString = this._toString(this.inputField);\r\n  }\r\n  //#endregion\r\n\r\n  //#region outputs\r\n  @Output() inputFieldChange = new EventEmitter<Date>();\r\n  //#endregion\r\n\r\n  //#region ctor\r\n  /**\r\n   *\r\n   */\r\n  constructor(private _datePipe: DatePipe\r\n    , private _dateHelperService : DateHelperService,\r\n    private primeNGConfig: PrimeNGConfig,\r\n  private _layoutService : LayoutService) {\r\n    super();\r\n\r\n  }\r\n  //#endregion\r\n\r\n  //#region handle events\r\n  onFocusOut(event: any) {\r\n    this._handleDateChange();\r\n  }\r\n\r\n  onSelect(event: any) {\r\n    this._handleDateChange();\r\n  }\r\n\r\n  //#endregion\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit()\r\n    this._layoutService.enableRtlModeSubject$.subscribe({\r\n      next:(data)=>{\r\n        if (data && data == true) {\r\n          this._initArabicLocal()\r\n        }\r\n      }\r\n    })\r\n\r\n    if(this._layoutService.isRtlModeEnabled()){\r\n      this._initArabicLocal()\r\n    }\r\n  }\r\n\r\n  //#region private methods\r\n  private _toString(value: Date | undefined): string | undefined {\r\n    if(value){\r\n      let dateString: string | undefined\r\n        = this._datePipe.transform(value\r\n            , this.showTime ? DateTimeFormat : DateFormat, TimeZoneLocale\r\n          ) ?? undefined ;\r\n\r\n      return dateString;\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n  _updateInputFieldFromStringDate(): void {\r\n    let date: Date | undefined = this.dateString && this.dateString != ''\r\n      ? this.showTime\r\n                    ? this._dateHelperService.parseDateTimeString(this.dateString)\r\n                    : this._dateHelperService.parseDateString(this.dateString)\r\n      : undefined;\r\n    this._value = date;\r\n  }\r\n\r\n  private _handleDateChange(): void {\r\n    this._updateInputFieldFromStringDate();\r\n    this.inputFieldChange.emit(this.inputField);\r\n  }\r\n\r\n  private _createUtcDate(value: any): Date | undefined{\r\n    if(value instanceof Date){\r\n      return value;\r\n    }\r\n    else{\r\n      return this._dateHelperService.createUtcDateFromString(value);\r\n    }\r\n  }\r\n  //#endregion\r\n\r\n  //#region add arabic region\r\n\r\n  _initArabicLocal(){\r\n    this.primeNGConfig.setTranslation(primengDateLocalAr)\r\n  }\r\n\r\n  //#endregion\r\n  onFocusHandler(event: any) {\r\n    this.calendarRef.overlayVisible = false;\r\n  }\r\n}\r\n","<div class=\"flex\">\r\n    <p-calendar #calendarRef\r\n    [dataType]=\"'string'\"\r\n    [appendTo]=\"'body'\"\r\n    [disabled]=\"disabled\"\r\n    [showIcon]=\"true\"\r\n    [showButtonBar]=\"showButtonBar\"\r\n    [dateFormat]=\"datePickerFormat\"\r\n    class=\"{{myStyleClass}}\"\r\n    styleClass=\"{{myStyleClass}} border-radius-7\"\r\n    inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n    [showTime]=\"showTime\"\r\n    [showSeconds]=\"showTime\"\r\n    [(ngModel)]=\"dateString\"\r\n    (onBlur)=\"onFocusOut($event)\"\r\n    (onSelect)=\"onSelect($event)\"\r\n    (onFocus)=\"onFocusHandler($event)\"\r\n    >\r\n    </p-calendar>\r\n    <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsi-date-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-date-picker/tsi-date-picker.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAE7G,OAAO,EAAE,YAAY,EAAE,MAAM,2DAA2D,CAAC;AACzF,OAAO,EAAE,UAAU,EAAE,oBAAoB,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAG9G,OAAO,EAAE,kBAAkB,EAAE,MAAM,+CAA+C,CAAC;;;;;;;;;AASnF,MAAM,OAAO,sBAAuB,SAAQ,YAA8B;IAgBxE,IAAa,UAAU;QACrB,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAa,UAAU,CAAC,KAAuB;QAC7C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC;IAKD,YAAY;IAEZ,cAAc;IACd;;OAEG;IACH,YAAoB,SAAmB,EAC3B,kBAAsC,EACxC,aAA4B,EAC9B,cAA8B;QACpC,KAAK,EAAE,CAAC;QAJU,cAAS,GAAT,SAAS,CAAU;QAC3B,uBAAkB,GAAlB,kBAAkB,CAAoB;QACxC,kBAAa,GAAb,aAAa,CAAe;QAC9B,mBAAc,GAAd,cAAc,CAAgB;QA7BtC,qBAAgB,GAAW,oBAAoB,CAAC;QAKvC,aAAQ,GAAY,KAAK,CAAC;QAC1B,kBAAa,GAAY,IAAI,CAAC;QAUvC,YAAY;QAEZ,iBAAiB;QACP,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;IAatD,CAAC;IACD,YAAY;IAEZ,uBAAuB;IACvB,UAAU;QACR,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY;IAEH,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAA;QAChB,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAAC,SAAS,CAAC;YAClD,IAAI,EAAC,CAAC,IAAI,EAAC,EAAE;gBACX,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;oBACzB,IAAI,CAAC,gBAAgB,EAAE,CAAA;gBACzB,CAAC;YACH,CAAC;SACF,CAAC,CAAA;QAEF,IAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,EAAE,EAAC,CAAC;YACzC,IAAI,CAAC,gBAAgB,EAAE,CAAA;QACzB,CAAC;IACH,CAAC;IAED,yBAAyB;IACjB,SAAS,CAAC,KAAuB;QACvC,IAAG,KAAK,EAAC,CAAC;YACR,IAAI,UAAU,GACV,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,EAC1B,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,EAAE,cAAc,CAC9D,IAAI,SAAS,CAAE;YAEpB,OAAO,UAAU,CAAC;QACpB,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,+BAA+B;QAC7B,IAAI,IAAI,GAAqB,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,IAAI,EAAE;YACnE,CAAC,CAAC,IAAI,CAAC,QAAQ;gBACD,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;gBAC9D,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC;YACxE,CAAC,CAAC,SAAS,CAAC;QACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACrB,CAAC;IAED,aAAa,CAAC,KAAW;QACvB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;IACrB,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,+BAA+B,EAAE,CAAC;QACvC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9C,CAAC;IAEO,cAAc,CAAC,KAAU;QAC/B,IAAG,KAAK,YAAY,IAAI,EAAC,CAAC;YACxB,OAAO,KAAK,CAAC;QACf,CAAC;aACG,CAAC;YACH,OAAO,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAChE,CAAC;IACH,CAAC;IACD,YAAY;IAEZ,2BAA2B;IAE3B,gBAAgB;QACd,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,kBAAkB,CAAC,CAAA;IACvD,CAAC;IAED,YAAY;IACZ,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,WAAW,CAAC,cAAc,GAAG,KAAK,CAAC;IAC1C,CAAC;+GAxHU,sBAAsB;mGAAtB,sBAAsB,qUChBnC,6wBAqBM;;4FDLO,sBAAsB;kBANlC,SAAS;+BACE,iBAAiB,iBAEZ,iBAAiB,CAAC,IAAI;qKAKX,WAAW;sBAApC,SAAS;uBAAC,aAAa;gBAUf,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAaI,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { DatePipe } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnInit, Output, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { PrimeNGConfig } from 'primeng/api';\r\nimport { TsiInputBase } from '../../../tsi-base/tsi-input-base/tsi-input-base.component';\r\nimport { DateFormat, DatePickerDateFormat, DateTimeFormat, TimeZoneLocale } from '../../../consts/tsi-consts';\r\nimport { DateHelperService } from '../../../services/date-helper.service';\r\nimport { LayoutService } from '../../../services/application/app.layout.service';\r\nimport { primengDateLocalAr } from '../../../tsi-helpers/primeng-translate-config';\r\n\r\n\r\n@Component({\r\n  selector: 'Tsi-Date-Picker',\r\n  templateUrl: './tsi-date-picker.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  styleUrls: ['./tsi-date-picker.component.css']\r\n})\r\nexport class TsiDatePickerComponent extends TsiInputBase<Date | undefined> implements OnInit {\r\n\r\n  @ViewChild('calendarRef') calendarRef!: any;\r\n\r\n  //#region local properties\r\n  private _value: Date | undefined;\r\n\r\n  dateString: string | undefined;\r\n  datePickerFormat: string = DatePickerDateFormat;\r\n  //#endregion\r\n\r\n  //#region inputs\r\n  @Input() required?: boolean;\r\n  @Input() showTime: boolean = false; \r\n  @Input() showButtonBar: boolean = true; \r\n\r\n  override get inputField(): Date | undefined {\r\n    return this._value;\r\n  }\r\n\r\n  override set inputField(value: Date | undefined) {\r\n    this._value = value ? this._createUtcDate(value) : undefined;\r\n    this.dateString = this._toString(this.inputField);\r\n  }\r\n  //#endregion\r\n\r\n  //#region outputs\r\n  @Output() inputFieldChange = new EventEmitter<Date>();\r\n  //#endregion\r\n\r\n  //#region ctor\r\n  /**\r\n   *\r\n   */\r\n  constructor(private _datePipe: DatePipe\r\n    , private _dateHelperService : DateHelperService,\r\n    private primeNGConfig: PrimeNGConfig,\r\n  private _layoutService : LayoutService) {\r\n    super();\r\n\r\n  }\r\n  //#endregion\r\n\r\n  //#region handle events\r\n  onFocusOut() {\r\n    this._handleDateChange();\r\n  }\r\n\r\n  onSelect() {\r\n    this._handleDateChange();\r\n  }\r\n\r\n  //#endregion\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit()\r\n    this._layoutService.enableRtlModeSubject$.subscribe({\r\n      next:(data)=>{\r\n        if (data && data == true) {\r\n          this._initArabicLocal()\r\n        }\r\n      }\r\n    })\r\n\r\n    if(this._layoutService.isRtlModeEnabled()){\r\n      this._initArabicLocal()\r\n    }\r\n  }\r\n\r\n  //#region private methods\r\n  private _toString(value: Date | undefined): string | undefined {\r\n    if(value){\r\n      let dateString: string | undefined\r\n        = this._datePipe.transform(value\r\n            , this.showTime ? DateTimeFormat : DateFormat, TimeZoneLocale\r\n          ) ?? undefined ;\r\n\r\n      return dateString;\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n  _updateInputFieldFromStringDate(): void {\r\n    let date: Date | undefined = this.dateString && this.dateString != ''\r\n      ? this.showTime\r\n                    ? this._dateHelperService.parseDateTimeString(this.dateString)\r\n                    : this._dateHelperService.parseDateString(this.dateString)\r\n      : undefined;\r\n    this._value = date;\r\n  }\r\n\r\n  onModelChange(event : any){\r\n    this.isDirty = true\r\n  }\r\n\r\n  private _handleDateChange(): void {\r\n    this._updateInputFieldFromStringDate();\r\n    this.inputFieldChange.emit(this.inputField);\r\n  }\r\n\r\n  private _createUtcDate(value: any): Date | undefined{\r\n    if(value instanceof Date){\r\n      return value;\r\n    }\r\n    else{\r\n      return this._dateHelperService.createUtcDateFromString(value);\r\n    }\r\n  }\r\n  //#endregion\r\n\r\n  //#region add arabic region\r\n\r\n  _initArabicLocal(){\r\n    this.primeNGConfig.setTranslation(primengDateLocalAr)\r\n  }\r\n\r\n  //#endregion\r\n  onFocusHandler(event: any) {\r\n    this.calendarRef.overlayVisible = false;\r\n  }\r\n}\r\n","<div class=\"flex\">\r\n    <p-calendar #calendarRef\r\n    [dataType]=\"'string'\"\r\n    [appendTo]=\"'body'\"\r\n    [disabled]=\"disabled\"\r\n    [showIcon]=\"true\"\r\n    [showButtonBar]=\"showButtonBar\"\r\n    [dateFormat]=\"datePickerFormat\"\r\n    class=\"{{myStyleClass}}\"\r\n    styleClass=\"{{myStyleClass}} border-radius-7\"\r\n    inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n    [showTime]=\"showTime\"\r\n    [showSeconds]=\"showTime\"\r\n    [(ngModel)]=\"dateString\"\r\n    (onBlur)=\"onFocusOut()\"\r\n    (onSelect)=\"onSelect()\"\r\n    (onFocus)=\"onFocusHandler($event)\"\r\n    (ngModelChange)=\"onModelChange($event)\"\r\n    >\r\n    </p-calendar>\r\n    <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>"]}
|
|
@@ -18,8 +18,10 @@ export class TsiDecimalInputComponent extends TsiInputBase {
|
|
|
18
18
|
//#endregion
|
|
19
19
|
this.isValueChanged = false;
|
|
20
20
|
}
|
|
21
|
-
valueChange() {
|
|
21
|
+
valueChange(event) {
|
|
22
22
|
this.isValueChanged = true;
|
|
23
|
+
this.inputField = event;
|
|
24
|
+
this.isDirty = true;
|
|
23
25
|
}
|
|
24
26
|
ngOnInit() {
|
|
25
27
|
super.ngOnInit();
|
|
@@ -35,11 +37,11 @@ export class TsiDecimalInputComponent extends TsiInputBase {
|
|
|
35
37
|
}
|
|
36
38
|
}
|
|
37
39
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiDecimalInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
38
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiDecimalInputComponent, selector: "Tsi-Decimal-Input", inputs: { numOfDecimal: "numOfDecimal", class: "class" }, outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber autoSelect [disabled]=\"disabled\" [
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiDecimalInputComponent, selector: "Tsi-Decimal-Input", inputs: { numOfDecimal: "numOfDecimal", class: "class" }, outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber autoSelect [disabled]=\"disabled\" [ngModel]=\"inputField\" (ngModelChange)=\"valueChange($event)\"\r\n name=\"{{inputName}}\" id=\"{{inputId}}\" [minFractionDigits]=\"numOfDecimal ?? 2\" [maxFractionDigits]=\"numOfDecimal ?? 2\"\r\n class=\"{{myStyleClass}}\"\r\n styleClass=\"{{myStyleClass}} border-radius-7\" \r\n inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\" \r\n (onBlur)=\"onChangeofOptions()\"\r\n [locale]=\"locale\">\r\n </p-inputNumber>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i3.TsiBubbleInfoComponent, selector: "Tsi-Bubble-Info", inputs: ["infoText"] }, { kind: "directive", type: i4.AutoSelectDirective, selector: "[autoSelect]" }] }); }
|
|
39
41
|
}
|
|
40
42
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiDecimalInputComponent, decorators: [{
|
|
41
43
|
type: Component,
|
|
42
|
-
args: [{ selector: 'Tsi-Decimal-Input', template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber autoSelect [disabled]=\"disabled\" [
|
|
44
|
+
args: [{ selector: 'Tsi-Decimal-Input', template: "<div class=\"flex h-2rem\">\r\n <p-inputNumber autoSelect [disabled]=\"disabled\" [ngModel]=\"inputField\" (ngModelChange)=\"valueChange($event)\"\r\n name=\"{{inputName}}\" id=\"{{inputId}}\" [minFractionDigits]=\"numOfDecimal ?? 2\" [maxFractionDigits]=\"numOfDecimal ?? 2\"\r\n class=\"{{myStyleClass}}\"\r\n styleClass=\"{{myStyleClass}} border-radius-7\" \r\n inputStyleClass=\"{{myStyleClass}} {{validationStatusCssClass}}\" \r\n (onBlur)=\"onChangeofOptions()\"\r\n [locale]=\"locale\">\r\n </p-inputNumber>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>" }]
|
|
43
45
|
}], propDecorators: { numOfDecimal: [{
|
|
44
46
|
type: Input
|
|
45
47
|
}], class: [{
|
|
@@ -48,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
48
50
|
}], inputFieldChange: [{
|
|
49
51
|
type: Output
|
|
50
52
|
}] } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNpLWRlY2ltYWwtaW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLWRlY2ltYWwtaW5wdXQvdHNpLWRlY2ltYWwtaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLWRlY2ltYWwtaW5wdXQvdHNpLWRlY2ltYWwtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkRBQTJELENBQUM7Ozs7OztBQU96RixNQUFNLE9BQU8sd0JBQXlCLFNBQVEsWUFBZ0M7SUFMOUU7O1FBTUUsZ0JBQWdCO1FBQ2hCLGdDQUFnQztRQUN2QixpQkFBWSxHQUFZLENBQUMsQ0FBQztRQUNuQixVQUFLLEdBQVEsRUFBRSxDQUFDO1FBQ2hDLFlBQVk7UUFFWixpQkFBaUI7UUFDUCxxQkFBZ0IsR0FBeUIsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUM5RSxZQUFZO1FBRUosbUJBQWMsR0FBYSxLQUFLLENBQUE7S0FxQnpDO0lBbkJDLFdBQVcsQ0FBQyxLQUFXO1FBQ3JCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFBO1FBQzFCLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFBO0lBQ3JCLENBQUM7SUFDUSxRQUFRO1FBQ2YsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLG1FQUFtRTtRQUNuRSx5QkFBeUI7UUFDekIsaURBQWlEO1FBQ2pELElBQUk7SUFDTixDQUFDO0lBQ0QsaUJBQWlCO1FBQ2YsSUFBRyxJQUFJLENBQUMsY0FBYyxFQUFDLENBQUM7WUFDdEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDNUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUE7UUFDN0IsQ0FBQztJQUNILENBQUM7K0dBOUJVLHdCQUF3QjttR0FBeEIsd0JBQXdCLDZMQ1JyQyxpb0JBVU07OzRGREZPLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxtQkFBbUI7OEJBT3BCLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSzt1QkFBQyxPQUFPO2dCQUlKLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRzaUlucHV0QmFzZSB9IGZyb20gJy4uLy4uLy4uL3RzaS1iYXNlL3RzaS1pbnB1dC1iYXNlL3RzaS1pbnB1dC1iYXNlLmNvbXBvbmVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ1RzaS1EZWNpbWFsLUlucHV0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdHNpLWRlY2ltYWwtaW5wdXQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RzaS1kZWNpbWFsLWlucHV0LmNvbXBvbmVudC5jc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHNpRGVjaW1hbElucHV0Q29tcG9uZW50IGV4dGVuZHMgVHNpSW5wdXRCYXNlPG51bWJlciB8IHVuZGVmaW5lZD4ge1xyXG4gIC8vI3JlZ2lvbiBpbnB1dHNcclxuICAvLyBASW5wdXQoKSBpbnB1dEZpZWxkPzogbnVtYmVyO1xyXG4gIEBJbnB1dCgpIG51bU9mRGVjaW1hbD86IG51bWJlciA9IDI7XHJcbiAgQElucHV0KCdjbGFzcycpIGNsYXNzOiBhbnkgPSB7fTtcclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIG91dHB1dHNcclxuICBAT3V0cHV0KCkgaW5wdXRGaWVsZENoYW5nZTogRXZlbnRFbWl0dGVyPG51bWJlcj4gPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgcHJpdmF0ZSBpc1ZhbHVlQ2hhbmdlZCA6IGJvb2xlYW4gPSBmYWxzZVxyXG5cclxuICB2YWx1ZUNoYW5nZShldmVudCA6IGFueSl7XHJcbiAgICB0aGlzLmlzVmFsdWVDaGFuZ2VkID0gdHJ1ZVxyXG4gICAgdGhpcy5pbnB1dEZpZWxkID0gZXZlbnQ7XHJcbiAgICB0aGlzLmlzRGlydHkgPSB0cnVlXHJcbiAgfVxyXG4gIG92ZXJyaWRlIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgIC8vIGlmICh0aGlzLmlucHV0RmllbGQgPT09IHVuZGVmaW5lZCB8fCB0aGlzLmlucHV0RmllbGQgPT09IG51bGwpIHtcclxuICAgIC8vICAgdGhpcy5pbnB1dEZpZWxkID0gMDtcclxuICAgIC8vICAgdGhpcy5pbnB1dEZpZWxkQ2hhbmdlLmVtaXQodGhpcy5pbnB1dEZpZWxkKTtcclxuICAgIC8vIH1cclxuICB9XHJcbiAgb25DaGFuZ2VvZk9wdGlvbnMoKTogdm9pZCB7XHJcbiAgICBpZih0aGlzLmlzVmFsdWVDaGFuZ2VkKXtcclxuICAgICAgdGhpcy5pbnB1dEZpZWxkQ2hhbmdlLmVtaXQodGhpcy5pbnB1dEZpZWxkKTtcclxuICAgICAgdGhpcy5pc1ZhbHVlQ2hhbmdlZCA9IGZhbHNlXHJcbiAgICB9XHJcbiAgfVxyXG4gIFxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJmbGV4IGgtMnJlbVwiPlxyXG4gICAgPHAtaW5wdXROdW1iZXIgYXV0b1NlbGVjdCBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIiBbbmdNb2RlbF09XCJpbnB1dEZpZWxkXCIgKG5nTW9kZWxDaGFuZ2UpPVwidmFsdWVDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgbmFtZT1cInt7aW5wdXROYW1lfX1cIiBpZD1cInt7aW5wdXRJZH19XCIgW21pbkZyYWN0aW9uRGlnaXRzXT1cIm51bU9mRGVjaW1hbCA/PyAyXCIgW21heEZyYWN0aW9uRGlnaXRzXT1cIm51bU9mRGVjaW1hbCA/PyAyXCJcclxuICAgICAgICBjbGFzcz1cInt7bXlTdHlsZUNsYXNzfX1cIlxyXG4gICAgICAgIHN0eWxlQ2xhc3M9XCJ7e215U3R5bGVDbGFzc319IGJvcmRlci1yYWRpdXMtN1wiIFxyXG4gICAgICAgIGlucHV0U3R5bGVDbGFzcz1cInt7bXlTdHlsZUNsYXNzfX0ge3t2YWxpZGF0aW9uU3RhdHVzQ3NzQ2xhc3N9fVwiIFxyXG4gICAgICAgIChvbkJsdXIpPVwib25DaGFuZ2VvZk9wdGlvbnMoKVwiXHJcbiAgICAgICAgW2xvY2FsZV09XCJsb2NhbGVcIj5cclxuICAgIDwvcC1pbnB1dE51bWJlcj5cclxuICAgIDxUc2ktQnViYmxlLUluZm8gW2luZm9UZXh0XT1cImluZm9UZXh0XCI+PC9Uc2ktQnViYmxlLUluZm8+XHJcbjwvZGl2PiJdfQ==
|
package/esm2022/lib/tsi-components/input-components/tsi-file-manager/tsi-file-manager.component.mjs
CHANGED
|
@@ -63,6 +63,7 @@ export class TsiFileManagerComponent extends TsiInputBase {
|
|
|
63
63
|
${(files[0].size / (1024 * 1024)).toFixed(2)}
|
|
64
64
|
${this.localize.transform("tsi_file_upload_auto_validation_max_length_detail_2")}
|
|
65
65
|
${(this.maxFileSize / (1024 * 1024)).toFixed(2)} Mo`, this.localize.transform("tsi_file_upload_auto_validation_max_length_title"));
|
|
66
|
+
this.isDirty = this.inputField != undefined && this.inputField != null;
|
|
66
67
|
this.inputField = undefined;
|
|
67
68
|
return;
|
|
68
69
|
}
|
|
@@ -71,9 +72,11 @@ export class TsiFileManagerComponent extends TsiInputBase {
|
|
|
71
72
|
this.onSelectFileManager.emit({ event, files, inputField: this.inputField, fileName: fileName });
|
|
72
73
|
this.inputFieldChange.emit(this.inputField);
|
|
73
74
|
this.fileNameChange.emit(this.fileName);
|
|
75
|
+
this.isDirty = true;
|
|
74
76
|
}, 200);
|
|
75
77
|
}
|
|
76
78
|
onFileClear() {
|
|
79
|
+
this.isDirty = this.inputField != undefined && this.inputField != null;
|
|
77
80
|
this.inputField = null;
|
|
78
81
|
this.fileName = '';
|
|
79
82
|
this.imageUrl = null;
|
|
@@ -85,6 +88,7 @@ export class TsiFileManagerComponent extends TsiInputBase {
|
|
|
85
88
|
const file = event.file;
|
|
86
89
|
//this.inputField = this.inputField.filter((f: any) => f !== file);
|
|
87
90
|
//this.fileName = this.inputField.map((f: any) => f.name).join(', ');
|
|
91
|
+
this.isDirty = this.inputField != undefined && this.inputField != null;
|
|
88
92
|
this.inputField = null;
|
|
89
93
|
this.fileName = '';
|
|
90
94
|
this.imageUrl = null;
|
|
@@ -193,4 +197,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
193
197
|
}], fileNameChange: [{
|
|
194
198
|
type: Output
|
|
195
199
|
}] } });
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsi-file-manager.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-file-manager/tsi-file-manager.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-file-manager/tsi-file-manager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, Input, Output, EventEmitter, ChangeDetectorRef } from \"@angular/core\";\r\nimport { SafeUrl, DomSanitizer } from \"@angular/platform-browser\";\r\nimport { TsiInputBase } from \"../../../tsi-base/tsi-input-base/tsi-input-base.component\";\r\nimport { LocalizePipe } from \"../../../pipes/localize.pipe\";\r\nimport { TsiNotificationService } from \"../../../services/notification/tsi-notification.service\";\r\n\r\n@Component({\r\n  selector: 'Tsi-File-Manager',\r\n  templateUrl: './tsi-file-manager.component.html',\r\n  styleUrls: ['./tsi-file-manager.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TsiFileManagerComponent extends TsiInputBase<string | ArrayBuffer | undefined | null> {\r\n  // @Input() inputField: string | ArrayBuffer |undefined | null;\r\n  @Input() fileName: string | undefined;\r\n  @Input() name: string = '';\r\n  @Input() id: string | undefined;\r\n  @Input() accept: string = '';\r\n  @Input() maxFileSize: number = 10485760;\r\n  @Input() multiple: boolean = false;\r\n  @Input() exploreOnDownload: boolean = false;\r\n  @Input() showUploadButton: boolean = false;\r\n  @Input() showCancelButton: boolean = false;\r\n  @Input() showDownloadButton: boolean = false;\r\n  @Input() chooseIcon: string = '';\r\n  @Input() chooseLabel: string = '';\r\n  @Input() showSelectButton: boolean = true;\r\n  @Input() showFileUpload: boolean = true;\r\n\r\n  @Output() onSelectFileManager = new EventEmitter<any>();\r\n  @Output() onClear = new EventEmitter<void>();\r\n  @Output() onRemove = new EventEmitter<any>();\r\n  @Output() inputFieldChange = new EventEmitter<any>();\r\n  @Output() fileNameChange = new EventEmitter<string>();\r\n\r\n\r\n  imageUrl: string | null = null;\r\n\r\n  fileExtension?: string;\r\n\r\n  fileSizeError: string = '';\r\n  /* ngAfterViewInit() {\r\n    if (this.showSelectButton && this.fileUploadInput) {\r\n      this.fileUploadInput.nativeElement.style.display = 'none';\r\n    }\r\n  } */\r\n\r\n  constructor(\r\n    private localize: LocalizePipe,\r\n    private notificationService: TsiNotificationService,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private domSanitizer: DomSanitizer\r\n  ) {\r\n    super();\r\n  }\r\n\r\n\r\n  getFileExtension(fileName: string) {\r\n    return fileName?.split('.')?.pop();\r\n  }\r\n\r\n  onFileSelect(event: any) {\r\n    const files: File[] = event.files;\r\n    // this.convertFileToBase64(files[0]).then((base64String: string) => {\r\n    // this.inputField = base64String;\r\n    // });\r\n    const reader = new FileReader();\r\n    reader.onload = () => {\r\n      this.inputField = (reader.result as string).split(',')[1];\r\n    };\r\n    reader.onerror = (error) => {\r\n    };\r\n    reader.readAsDataURL(files[0]);\r\n    this.fileName = files[0].name;\r\n    const fileName: string = this.fileName!;\r\n\r\n    if (files[0].size > this.maxFileSize) {\r\n      this.notificationService.warn(`\r\n        ${this.localize.transform(\"tsi_file_upload_auto_validation_max_length_detail_1\")} \r\n        ${(files[0].size / (1024 * 1024)).toFixed(2)} \r\n        ${this.localize.transform(\"tsi_file_upload_auto_validation_max_length_detail_2\")}\r\n        ${(this.maxFileSize / (1024 * 1024)).toFixed(2)} Mo`,\r\n        this.localize.transform(\"tsi_file_upload_auto_validation_max_length_title\"))\r\n      this.inputField = undefined\r\n      return;\r\n    }\r\n    setTimeout(() => {\r\n      //this.fileName = files.map((file: any) => file.name).join(', ');\r\n      this.onSelectFileManager.emit({ event, files, inputField: this.inputField, fileName: fileName });\r\n      this.inputFieldChange.emit(this.inputField);\r\n      this.fileNameChange.emit(this.fileName);\r\n    }, 200);\r\n\r\n\r\n  }\r\n\r\n  onFileClear() {\r\n    this.inputField = null;\r\n    this.fileName = '';\r\n    this.imageUrl = null;\r\n    this.inputFieldChange.emit(this.inputField);\r\n    this.fileNameChange.emit(this.fileName);\r\n    this.onClear.emit();\r\n  }\r\n\r\n  onFileRemove(event: any) {\r\n    const file = event.file;\r\n    //this.inputField = this.inputField.filter((f: any) => f !== file);\r\n    //this.fileName = this.inputField.map((f: any) => f.name).join(', ');\r\n    this.inputField = null;\r\n    this.fileName = '';\r\n    this.imageUrl = null;\r\n    this.onRemove.emit(file);\r\n    this.inputFieldChange.emit(this.inputField);\r\n    this.fileNameChange.emit(this.fileName);\r\n  }\r\n\r\n  convertFileToBase64(file: File): Promise<string> {\r\n    return new Promise((resolve, reject) => {\r\n      const reader = new FileReader();\r\n      reader.readAsDataURL(file);\r\n      reader.onload = () => {\r\n        const base64String = reader.result as string; // Conversion explicite en string\r\n        resolve(base64String);\r\n      };\r\n      reader.onerror = error => reject(error);\r\n    });\r\n  }\r\n\r\n  downloadFile() {\r\n    if (!this.inputField) {\r\n      return;\r\n    }\r\n\r\n    const byteCharacters = atob(this.inputField as string);\r\n    const byteNumbers = new Array(byteCharacters.length);\r\n    for (let i = 0; i < byteCharacters.length; i++) {\r\n      byteNumbers[i] = byteCharacters.charCodeAt(i);\r\n    }\r\n    const byteArray = new Uint8Array(byteNumbers);\r\n    const blob = new Blob([byteArray], { type: 'application/octet-stream' });\r\n\r\n    const url = window.URL.createObjectURL(blob);\r\n\r\n    const a = document.createElement('a');\r\n    document.body.appendChild(a);\r\n    a.style.display = 'none';\r\n    a.href = url;\r\n    a.download = this.fileName!;\r\n    a.click();\r\n\r\n    //window.URL.revokeObjectURL(url);\r\n  }\r\n\r\n  arrayBufferToBase64(buffer: ArrayBuffer): string {\r\n    const bytes = new Uint8Array(buffer);\r\n    let binary = '';\r\n    for (let i = 0; i < bytes.byteLength; i++) {\r\n      binary += String.fromCharCode(bytes[i]);\r\n    }\r\n    return 'data:application/octet-stream;base64,' + btoa(binary);\r\n  }\r\n\r\n  get fileUrl(): SafeUrl {\r\n    if (!this.inputField) {\r\n      return '';\r\n    }\r\n\r\n    const byteCharacters = atob(this.inputField as string);\r\n    const byteNumbers = new Array(byteCharacters.length);\r\n    for (let i = 0; i < byteCharacters.length; i++) {\r\n      byteNumbers[i] = byteCharacters.charCodeAt(i);\r\n    }\r\n    const byteArray = new Uint8Array(byteNumbers);\r\n    const blob = new Blob([byteArray], { type: 'application/octet-stream' });\r\n\r\n    const url = window.URL.createObjectURL(blob);\r\n\r\n    return this.domSanitizer.bypassSecurityTrustUrl(url);\r\n  }\r\n\r\n  fileExtensionImage(): boolean {\r\n    return this.getFileExtension(this.fileName!) == 'jpg'\r\n  }\r\n}","<!-- <p-fileUpload class=\"file-manager\" #fileUpload [name]=\"name\" [id]=\"id\" [accept]=\"accept\" [maxFileSize]=\"maxFileSize\"\r\n  [multiple]=\"multiple\" [showUploadButton]=\"showUploadButton\" [showCancelButton]=\"showCancelButton\"\r\n  chooseIcon=\"pi pi-upload\" chooseLabel=\" \" (onSelect)=\"onFileSelect($event)\" (onClear)=\"onFileClear()\"\r\n  (onRemove)=\"onFileRemove($event)\" class=\"custom-file-upload\" icon=\"pi pi-upload\">\r\n</p-fileUpload>\r\n\r\n<BR>\r\n<div *ngIf=\"showDownloadButton\">\r\n  <button pButton type=\"button\" icon=\"pi pi-download\" (click)=\"downloadFile()\" class=\"h-2rem w-full text-center\">\r\n  </button>\r\n</div> -->\r\n<div class=\"{{validationStatusCssClass}}\">\r\n\r\n  <p-fileUpload class=\"file-manager custom-file-upload \" \r\n    #fileUpload\r\n    [name]=\"name\"\r\n    [id]=\"id\" \r\n    [accept]=\"accept\" \r\n    [multiple]=\"multiple\"\r\n    [disabled]=\"disabled\"\r\n    [showUploadButton]=\"showUploadButton\" \r\n    [showCancelButton]=\"showCancelButton\"\r\n    chooseIcon=\"pi pi-upload\"\r\n    chooseLabel= \"Upload\" \r\n    (onSelect)=\"onFileSelect($event)\"\r\n    (onClear)=\"onFileClear()\"\r\n    (onRemove)=\"onFileRemove($event)\"\r\n    >\r\n    \r\n    \r\n    \r\n    <!-- <ng-template pTemplate=\"content\">\r\n      <button type=\"button\" pButton icon=\"pi pi-upload\" class=\"ml-4 h-2rem w-full text-center\">\r\n      </button>\r\n    </ng-template> -->\r\n    <ng-template pTemplate=\"content\" let-files>\r\n      <div *ngIf=\"fileExtensionImage() || inputField\">\r\n        <img [src]=\"fileUrl\" style=\"width: 15rem;\"/>\r\n      </div>\r\n      <div *ngIf=\"fileName != undefined && fileName != null\">\r\n        <p>File Name: {{ fileName }}</p>\r\n        <p>File Extension: {{ getFileExtension(fileName) }}</p>\r\n      </div>\r\n      <div *ngIf=\"fileName != undefined && showDownloadButton\">\r\n        <button pButton type=\"button\" icon=\"pi pi-download\" (click)=\"downloadFile()\" class=\" h-2rem w-full text-center\">\r\n          <!-- <span class=\"font-bold ml-2\" >Download</span> -->\r\n        </button>\r\n      </div>\r\n    </ng-template>\r\n    \r\n  </p-fileUpload>\r\n  \r\n</div>"]}
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tsi-file-manager.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-file-manager/tsi-file-manager.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/tsi-file-manager/tsi-file-manager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, Input, Output, EventEmitter, ChangeDetectorRef } from \"@angular/core\";\r\nimport { SafeUrl, DomSanitizer } from \"@angular/platform-browser\";\r\nimport { TsiInputBase } from \"../../../tsi-base/tsi-input-base/tsi-input-base.component\";\r\nimport { LocalizePipe } from \"../../../pipes/localize.pipe\";\r\nimport { TsiNotificationService } from \"../../../services/notification/tsi-notification.service\";\r\n\r\n@Component({\r\n  selector: 'Tsi-File-Manager',\r\n  templateUrl: './tsi-file-manager.component.html',\r\n  styleUrls: ['./tsi-file-manager.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TsiFileManagerComponent extends TsiInputBase<string | ArrayBuffer | undefined | null> {\r\n  // @Input() inputField: string | ArrayBuffer |undefined | null;\r\n  @Input() fileName: string | undefined;\r\n  @Input() name: string = '';\r\n  @Input() id: string | undefined;\r\n  @Input() accept: string = '';\r\n  @Input() maxFileSize: number = 10485760;\r\n  @Input() multiple: boolean = false;\r\n  @Input() exploreOnDownload: boolean = false;\r\n  @Input() showUploadButton: boolean = false;\r\n  @Input() showCancelButton: boolean = false;\r\n  @Input() showDownloadButton: boolean = false;\r\n  @Input() chooseIcon: string = '';\r\n  @Input() chooseLabel: string = '';\r\n  @Input() showSelectButton: boolean = true;\r\n  @Input() showFileUpload: boolean = true;\r\n\r\n  @Output() onSelectFileManager = new EventEmitter<any>();\r\n  @Output() onClear = new EventEmitter<void>();\r\n  @Output() onRemove = new EventEmitter<any>();\r\n  @Output() inputFieldChange = new EventEmitter<any>();\r\n  @Output() fileNameChange = new EventEmitter<string>();\r\n\r\n\r\n  imageUrl: string | null = null;\r\n\r\n  fileExtension?: string;\r\n\r\n  fileSizeError: string = '';\r\n  /* ngAfterViewInit() {\r\n    if (this.showSelectButton && this.fileUploadInput) {\r\n      this.fileUploadInput.nativeElement.style.display = 'none';\r\n    }\r\n  } */\r\n\r\n  constructor(\r\n    private localize: LocalizePipe,\r\n    private notificationService: TsiNotificationService,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private domSanitizer: DomSanitizer\r\n  ) {\r\n    super();\r\n  }\r\n\r\n\r\n  getFileExtension(fileName: string) {\r\n    return fileName?.split('.')?.pop();\r\n  }\r\n\r\n  onFileSelect(event: any) {\r\n    const files: File[] = event.files;\r\n    // this.convertFileToBase64(files[0]).then((base64String: string) => {\r\n    // this.inputField = base64String;\r\n    // });\r\n    const reader = new FileReader();\r\n    reader.onload = () => {\r\n      this.inputField = (reader.result as string).split(',')[1];\r\n    };\r\n    reader.onerror = (error) => {\r\n    };\r\n    reader.readAsDataURL(files[0]);\r\n    this.fileName = files[0].name;\r\n    const fileName: string = this.fileName!;\r\n\r\n    if (files[0].size > this.maxFileSize) {\r\n      this.notificationService.warn(`\r\n        ${this.localize.transform(\"tsi_file_upload_auto_validation_max_length_detail_1\")} \r\n        ${(files[0].size / (1024 * 1024)).toFixed(2)} \r\n        ${this.localize.transform(\"tsi_file_upload_auto_validation_max_length_detail_2\")}\r\n        ${(this.maxFileSize / (1024 * 1024)).toFixed(2)} Mo`,\r\n        this.localize.transform(\"tsi_file_upload_auto_validation_max_length_title\"))\r\n\r\n      this.isDirty = this.inputField != undefined && this.inputField != null\r\n      this.inputField = undefined\r\n\r\n      return;\r\n    }\r\n    setTimeout(() => {\r\n      //this.fileName = files.map((file: any) => file.name).join(', ');\r\n      this.onSelectFileManager.emit({ event, files, inputField: this.inputField, fileName: fileName });\r\n      this.inputFieldChange.emit(this.inputField);\r\n      this.fileNameChange.emit(this.fileName);\r\n      this.isDirty = true\r\n    }, 200);\r\n\r\n\r\n  }\r\n\r\n  onFileClear() {\r\n    this.isDirty = this.inputField != undefined && this.inputField != null\r\n    this.inputField = null;\r\n    this.fileName = '';\r\n    this.imageUrl = null;\r\n    this.inputFieldChange.emit(this.inputField);\r\n    this.fileNameChange.emit(this.fileName);\r\n    this.onClear.emit();\r\n  }\r\n\r\n  onFileRemove(event: any) {\r\n    const file = event.file;\r\n    //this.inputField = this.inputField.filter((f: any) => f !== file);\r\n    //this.fileName = this.inputField.map((f: any) => f.name).join(', ');\r\n    this.isDirty = this.inputField != undefined && this.inputField != null\r\n    this.inputField = null;\r\n    this.fileName = '';\r\n    this.imageUrl = null;\r\n    this.onRemove.emit(file);\r\n    this.inputFieldChange.emit(this.inputField);\r\n    this.fileNameChange.emit(this.fileName);\r\n  }\r\n\r\n  convertFileToBase64(file: File): Promise<string> {\r\n    return new Promise((resolve, reject) => {\r\n      const reader = new FileReader();\r\n      reader.readAsDataURL(file);\r\n      reader.onload = () => {\r\n        const base64String = reader.result as string; // Conversion explicite en string\r\n        resolve(base64String);\r\n      };\r\n      reader.onerror = error => reject(error);\r\n    });\r\n  }\r\n\r\n  downloadFile() {\r\n    if (!this.inputField) {\r\n      return;\r\n    }\r\n\r\n    const byteCharacters = atob(this.inputField as string);\r\n    const byteNumbers = new Array(byteCharacters.length);\r\n    for (let i = 0; i < byteCharacters.length; i++) {\r\n      byteNumbers[i] = byteCharacters.charCodeAt(i);\r\n    }\r\n    const byteArray = new Uint8Array(byteNumbers);\r\n    const blob = new Blob([byteArray], { type: 'application/octet-stream' });\r\n\r\n    const url = window.URL.createObjectURL(blob);\r\n\r\n    const a = document.createElement('a');\r\n    document.body.appendChild(a);\r\n    a.style.display = 'none';\r\n    a.href = url;\r\n    a.download = this.fileName!;\r\n    a.click();\r\n\r\n    //window.URL.revokeObjectURL(url);\r\n  }\r\n\r\n  arrayBufferToBase64(buffer: ArrayBuffer): string {\r\n    const bytes = new Uint8Array(buffer);\r\n    let binary = '';\r\n    for (let i = 0; i < bytes.byteLength; i++) {\r\n      binary += String.fromCharCode(bytes[i]);\r\n    }\r\n    return 'data:application/octet-stream;base64,' + btoa(binary);\r\n  }\r\n\r\n  get fileUrl(): SafeUrl {\r\n    if (!this.inputField) {\r\n      return '';\r\n    }\r\n\r\n    const byteCharacters = atob(this.inputField as string);\r\n    const byteNumbers = new Array(byteCharacters.length);\r\n    for (let i = 0; i < byteCharacters.length; i++) {\r\n      byteNumbers[i] = byteCharacters.charCodeAt(i);\r\n    }\r\n    const byteArray = new Uint8Array(byteNumbers);\r\n    const blob = new Blob([byteArray], { type: 'application/octet-stream' });\r\n\r\n    const url = window.URL.createObjectURL(blob);\r\n\r\n    return this.domSanitizer.bypassSecurityTrustUrl(url);\r\n  }\r\n\r\n  fileExtensionImage(): boolean {\r\n    return this.getFileExtension(this.fileName!) == 'jpg'\r\n  }\r\n}","<!-- <p-fileUpload class=\"file-manager\" #fileUpload [name]=\"name\" [id]=\"id\" [accept]=\"accept\" [maxFileSize]=\"maxFileSize\"\r\n  [multiple]=\"multiple\" [showUploadButton]=\"showUploadButton\" [showCancelButton]=\"showCancelButton\"\r\n  chooseIcon=\"pi pi-upload\" chooseLabel=\" \" (onSelect)=\"onFileSelect($event)\" (onClear)=\"onFileClear()\"\r\n  (onRemove)=\"onFileRemove($event)\" class=\"custom-file-upload\" icon=\"pi pi-upload\">\r\n</p-fileUpload>\r\n\r\n<BR>\r\n<div *ngIf=\"showDownloadButton\">\r\n  <button pButton type=\"button\" icon=\"pi pi-download\" (click)=\"downloadFile()\" class=\"h-2rem w-full text-center\">\r\n  </button>\r\n</div> -->\r\n<div class=\"{{validationStatusCssClass}}\">\r\n\r\n  <p-fileUpload class=\"file-manager custom-file-upload \" \r\n    #fileUpload\r\n    [name]=\"name\"\r\n    [id]=\"id\" \r\n    [accept]=\"accept\" \r\n    [multiple]=\"multiple\"\r\n    [disabled]=\"disabled\"\r\n    [showUploadButton]=\"showUploadButton\" \r\n    [showCancelButton]=\"showCancelButton\"\r\n    chooseIcon=\"pi pi-upload\"\r\n    chooseLabel= \"Upload\" \r\n    (onSelect)=\"onFileSelect($event)\"\r\n    (onClear)=\"onFileClear()\"\r\n    (onRemove)=\"onFileRemove($event)\"\r\n    >\r\n    \r\n    \r\n    \r\n    <!-- <ng-template pTemplate=\"content\">\r\n      <button type=\"button\" pButton icon=\"pi pi-upload\" class=\"ml-4 h-2rem w-full text-center\">\r\n      </button>\r\n    </ng-template> -->\r\n    <ng-template pTemplate=\"content\" let-files>\r\n      <div *ngIf=\"fileExtensionImage() || inputField\">\r\n        <img [src]=\"fileUrl\" style=\"width: 15rem;\"/>\r\n      </div>\r\n      <div *ngIf=\"fileName != undefined && fileName != null\">\r\n        <p>File Name: {{ fileName }}</p>\r\n        <p>File Extension: {{ getFileExtension(fileName) }}</p>\r\n      </div>\r\n      <div *ngIf=\"fileName != undefined && showDownloadButton\">\r\n        <button pButton type=\"button\" icon=\"pi pi-download\" (click)=\"downloadFile()\" class=\" h-2rem w-full text-center\">\r\n          <!-- <span class=\"font-bold ml-2\" >Download</span> -->\r\n        </button>\r\n      </div>\r\n    </ng-template>\r\n    \r\n  </p-fileUpload>\r\n  \r\n</div>"]}
|
package/esm2022/lib/tsi-components/input-components/tsi-formula-box/tsi-formula-box.component.mjs
CHANGED
|
@@ -16,6 +16,7 @@ export class TsiFormulaBoxComponent extends TsiInputBase {
|
|
|
16
16
|
}
|
|
17
17
|
onInputChange(val) {
|
|
18
18
|
this.value = val;
|
|
19
|
+
this.isDirty = true;
|
|
19
20
|
this.valueChange.emit(this.value);
|
|
20
21
|
// Détecter `TOTAL(` suivi de tout ce qui n'est pas une parenthèse fermante
|
|
21
22
|
const match = /TOTAL\(([^)]*)$/i.exec(val);
|
|
@@ -35,15 +36,16 @@ export class TsiFormulaBoxComponent extends TsiInputBase {
|
|
|
35
36
|
}
|
|
36
37
|
onSuggestionSelect(s) {
|
|
37
38
|
this.value = this.value.replace(/TOTAL\([^\)]*$/, `TOTAL(${s}`);
|
|
39
|
+
this.isDirty = true;
|
|
38
40
|
this.valueChange.emit(this.value);
|
|
39
41
|
this.suggestions = [];
|
|
40
42
|
}
|
|
41
43
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiFormulaBoxComponent, deps: [{ token: i1.FormulaService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiFormulaBoxComponent, selector: "Tsi-Formula-Box", inputs: { value: "value", endPoint: "endPoint" }, outputs: { valueChange: "valueChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"formula-wrapper {{validationStatusCssClass}}\" style=\"position: relative; z-index: 9999;\">\r\n <input type=\"text\" class=\"form-control\" [
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiFormulaBoxComponent, selector: "Tsi-Formula-Box", inputs: { value: "value", endPoint: "endPoint" }, outputs: { valueChange: "valueChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"formula-wrapper {{validationStatusCssClass}}\" style=\"position: relative; z-index: 9999;\">\r\n <input type=\"text\" class=\"form-control\" [ngModel]=\"value\" (ngModelChange)=\"onInputChange($event)\"\r\n placeholder=\"\" maxlength=\"{{maxLength}}\"/>\r\n\r\n <ul *ngIf=\"suggestions.length > 0\">\r\n <li *ngFor=\"let s of suggestions\" (click)=\"onSuggestionSelect(s)\">\r\n {{ s }}\r\n </li>\r\n </ul>\r\n</div>", styles: [".formula-wrapper{position:relative;width:100%}::ng-deep ul li{list-style:none!important}::ng-deep ul li:hover{text-decoration:underline!important}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
43
45
|
}
|
|
44
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiFormulaBoxComponent, decorators: [{
|
|
45
47
|
type: Component,
|
|
46
|
-
args: [{ selector: 'Tsi-Formula-Box', template: "<div class=\"formula-wrapper {{validationStatusCssClass}}\" style=\"position: relative; z-index: 9999;\">\r\n <input type=\"text\" class=\"form-control\" [
|
|
48
|
+
args: [{ selector: 'Tsi-Formula-Box', template: "<div class=\"formula-wrapper {{validationStatusCssClass}}\" style=\"position: relative; z-index: 9999;\">\r\n <input type=\"text\" class=\"form-control\" [ngModel]=\"value\" (ngModelChange)=\"onInputChange($event)\"\r\n placeholder=\"\" maxlength=\"{{maxLength}}\"/>\r\n\r\n <ul *ngIf=\"suggestions.length > 0\">\r\n <li *ngFor=\"let s of suggestions\" (click)=\"onSuggestionSelect(s)\">\r\n {{ s }}\r\n </li>\r\n </ul>\r\n</div>", styles: [".formula-wrapper{position:relative;width:100%}::ng-deep ul li{list-style:none!important}::ng-deep ul li:hover{text-decoration:underline!important}\n"] }]
|
|
47
49
|
}], ctorParameters: () => [{ type: i1.FormulaService }, { type: i0.ChangeDetectorRef }], propDecorators: { value: [{
|
|
48
50
|
type: Input
|
|
49
51
|
}], endPoint: [{
|
|
@@ -51,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
51
53
|
}], valueChange: [{
|
|
52
54
|
type: Output
|
|
53
55
|
}] } });
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNpLWZvcm11bGEtYm94LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RzaS1zaGFyZWQtdWkvc3JjL2xpYi90c2ktY29tcG9uZW50cy9pbnB1dC1jb21wb25lbnRzL3RzaS1mb3JtdWxhLWJveC90c2ktZm9ybXVsYS1ib3guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLWZvcm11bGEtYm94L1RzaS1Gb3JtdWxhLUJveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkRBQTJELENBQUM7Ozs7O0FBUXpGLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxZQUFZO0lBT3RELFlBQW9CLGVBQStCLEVBQWtCLEtBQXdCO1FBQzNGLEtBQUssRUFBRSxDQUFDO1FBRFUsb0JBQWUsR0FBZixlQUFlLENBQWdCO1FBQWtCLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBTnBGLFVBQUssR0FBVyxFQUFFLENBQUM7UUFDbkIsYUFBUSxHQUFXLEVBQUUsQ0FBQztRQUNyQixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFFbkQsZ0JBQVcsR0FBYSxFQUFFLENBQUM7SUFJM0IsQ0FBQztJQUVELGFBQWEsQ0FBQyxHQUFXO1FBQ3ZCLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDO1FBQ2pCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVsQywyRUFBMkU7UUFDM0UsTUFBTSxLQUFLLEdBQUcsa0JBQWtCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzNDLElBQUksS0FBSyxFQUFFLENBQUM7WUFDVixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEIsSUFBSSxJQUFJLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxFQUFFLENBQUM7Z0JBQzNDLElBQUksQ0FBQyxlQUFlLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUU7b0JBQzlFLElBQUksQ0FBQyxXQUFXLEdBQUcsR0FBRyxDQUFDO29CQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUM3QixDQUFDLENBQUMsQ0FBQztZQUNMLENBQUM7UUFDSCxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDN0IsQ0FBQztJQUNILENBQUM7SUFDRCxrQkFBa0IsQ0FBQyxDQUFTO1FBQzFCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ2hFLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFBO1FBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsQyxJQUFJLENBQUMsV0FBVyxHQUFHLEVBQUUsQ0FBQztJQUN4QixDQUFDOytHQXBDVSxzQkFBc0I7bUdBQXRCLHNCQUFzQix5S0NUbkMsd2dCQVNNOzs0RkRBTyxzQkFBc0I7a0JBTGxDLFNBQVM7K0JBQ0UsaUJBQWlCO21IQUtsQixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDSSxXQUFXO3NCQUFwQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRzaUlucHV0QmFzZSB9IGZyb20gJy4uLy4uLy4uL3RzaS1iYXNlL3RzaS1pbnB1dC1iYXNlL3RzaS1pbnB1dC1iYXNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZvcm11bGFTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvZm9ybXVsYS5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnVHNpLUZvcm11bGEtQm94JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vVHNpLUZvcm11bGEtQm94LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9Uc2ktRm9ybXVsYS1Cb3guY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFRzaUZvcm11bGFCb3hDb21wb25lbnQgZXh0ZW5kcyBUc2lJbnB1dEJhc2Uge1xyXG4gIEBJbnB1dCgpIHZhbHVlOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBlbmRQb2ludDogc3RyaW5nID0gJyc7XHJcbiAgQE91dHB1dCgpIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XHJcblxyXG4gIHN1Z2dlc3Rpb25zOiBzdHJpbmdbXSA9IFtdO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9mb3JtdWxhU2VydmljZTogRm9ybXVsYVNlcnZpY2UsIHB1YmxpYyBvdmVycmlkZSBjZFJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgfVxyXG5cclxuICBvbklucHV0Q2hhbmdlKHZhbDogc3RyaW5nKSB7XHJcbiAgICB0aGlzLnZhbHVlID0gdmFsO1xyXG4gICAgdGhpcy5pc0RpcnR5ID0gdHJ1ZTtcclxuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdCh0aGlzLnZhbHVlKTtcclxuICBcclxuICAgIC8vIETDqXRlY3RlciBgVE9UQUwoYCBzdWl2aSBkZSB0b3V0IGNlIHF1aSBuJ2VzdCBwYXMgdW5lIHBhcmVudGjDqHNlIGZlcm1hbnRlXHJcbiAgICBjb25zdCBtYXRjaCA9IC9UT1RBTFxcKChbXildKikkL2kuZXhlYyh2YWwpO1xyXG4gICAgaWYgKG1hdGNoKSB7XHJcbiAgICAgIGNvbnN0IHRlcm0gPSBtYXRjaFsxXTtcclxuICAgICAgaWYgKHRlcm0gIT09IHVuZGVmaW5lZCAmJiB0ZXJtLmxlbmd0aCA+PSAwKSB7XHJcbiAgICAgICAgdGhpcy5fZm9ybXVsYVNlcnZpY2UuZ2V0Rm9ybXVsYVN1Z2dlc3Rpb25zKHRoaXMuZW5kUG9pbnQsIHRlcm0pLnN1YnNjcmliZShyZXMgPT4ge1xyXG4gICAgICAgICAgdGhpcy5zdWdnZXN0aW9ucyA9IHJlcztcclxuICAgICAgICAgIHRoaXMuY2RSZWYuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgICAgIH0pO1xyXG4gICAgICB9XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLnN1Z2dlc3Rpb25zID0gW107XHJcbiAgICAgIHRoaXMuY2RSZWYuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgfVxyXG4gIH1cclxuICBvblN1Z2dlc3Rpb25TZWxlY3Qoczogc3RyaW5nKSB7XHJcbiAgICB0aGlzLnZhbHVlID0gdGhpcy52YWx1ZS5yZXBsYWNlKC9UT1RBTFxcKFteXFwpXSokLywgYFRPVEFMKCR7c31gKTtcclxuICAgIHRoaXMuaXNEaXJ0eSA9IHRydWVcclxuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdCh0aGlzLnZhbHVlKTtcclxuICAgIHRoaXMuc3VnZ2VzdGlvbnMgPSBbXTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImZvcm11bGEtd3JhcHBlciB7e3ZhbGlkYXRpb25TdGF0dXNDc3NDbGFzc319XCIgc3R5bGU9XCJwb3NpdGlvbjogcmVsYXRpdmU7IHotaW5kZXg6IDk5OTk7XCI+XHJcbiAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiBbbmdNb2RlbF09XCJ2YWx1ZVwiIChuZ01vZGVsQ2hhbmdlKT1cIm9uSW5wdXRDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICBwbGFjZWhvbGRlcj1cIlwiIG1heGxlbmd0aD1cInt7bWF4TGVuZ3RofX1cIi8+XHJcblxyXG4gICAgICAgIDx1bCAqbmdJZj1cInN1Z2dlc3Rpb25zLmxlbmd0aCA+IDBcIj5cclxuICAgICAgICAgICAgICAgIDxsaSAqbmdGb3I9XCJsZXQgcyBvZiBzdWdnZXN0aW9uc1wiIChjbGljayk9XCJvblN1Z2dlc3Rpb25TZWxlY3QocylcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAge3sgcyB9fVxyXG4gICAgICAgICAgICAgICAgPC9saT5cclxuICAgICAgICA8L3VsPlxyXG48L2Rpdj4iXX0=
|