nira-falcon 0.1.13 → 0.1.15
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/core-date-picker/core-date-picker.component.mjs +11 -17
- package/esm2022/lib/core-input/core-input.component.mjs +13 -1
- package/fesm2022/nira-falcon.mjs +21 -15
- package/fesm2022/nira-falcon.mjs.map +1 -1
- package/lib/core-date-picker/core-date-picker.component.d.ts +3 -3
- package/lib/core-input/core-input.component.d.ts +2 -0
- package/package.json +2 -2
|
@@ -1,45 +1,39 @@
|
|
|
1
1
|
import { Component, Input, } from '@angular/core';
|
|
2
|
-
import { FormControl
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "nira-date-picker";
|
|
5
5
|
import * as i2 from "../core-input/core-input.component";
|
|
6
6
|
export class CoreDatePickerComponent {
|
|
7
|
+
set inputFormControl(value) {
|
|
8
|
+
this._inputFormControl = value;
|
|
9
|
+
}
|
|
7
10
|
constructor(changeDetectorRef) {
|
|
8
11
|
this.changeDetectorRef = changeDetectorRef;
|
|
12
|
+
this._inputFormControl = new FormControl('', []);
|
|
9
13
|
this.canSelectToday = false;
|
|
10
14
|
this.defaultDate = '';
|
|
11
15
|
this.label = '';
|
|
12
|
-
this.inputFormControl = new FormControl('', []);
|
|
13
|
-
this.niraDatePickerForm = {};
|
|
14
16
|
this.isOpenCalendar = false;
|
|
15
17
|
this.date = '';
|
|
16
18
|
}
|
|
17
|
-
ngOnInit() {
|
|
18
|
-
this.niraDatePickerForm = new FormGroup({
|
|
19
|
-
niraDatePickerFormCtrl: this.inputFormControl,
|
|
20
|
-
});
|
|
21
|
-
}
|
|
19
|
+
ngOnInit() { }
|
|
22
20
|
ngAfterViewInit() {
|
|
23
21
|
this.changeDetectorRef.detectChanges();
|
|
24
22
|
}
|
|
25
23
|
onDatePickerResult(result) {
|
|
26
|
-
this.
|
|
27
|
-
niraDatePickerFormCtrl: result,
|
|
28
|
-
});
|
|
24
|
+
this._inputFormControl.setValue(result);
|
|
29
25
|
this.date = result;
|
|
30
26
|
}
|
|
31
27
|
onTodayDate(todayDate) {
|
|
32
28
|
this.date = todayDate;
|
|
33
|
-
this.
|
|
34
|
-
niraDatePickerFormCtrl: todayDate,
|
|
35
|
-
});
|
|
29
|
+
this._inputFormControl.setValue(todayDate);
|
|
36
30
|
}
|
|
37
31
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreDatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
38
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreDatePickerComponent, selector: "core-date-picker", inputs: { canSelectToday: "canSelectToday", defaultDate: "defaultDate", label: "label", inputFormControl: "inputFormControl" }, ngImport: i0, template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"
|
|
32
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreDatePickerComponent, selector: "core-date-picker", inputs: { canSelectToday: "canSelectToday", defaultDate: "defaultDate", label: "label", inputFormControl: "inputFormControl" }, ngImport: i0, template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"_inputFormControl\"\r\n (click)=\"isOpenCalendar = true\"\r\n>\r\n</core-input>\r\n<lib-nira-date-picker\r\n [(isOpenCalendar)]=\"isOpenCalendar\"\r\n [defaultDate]=\"date ? date : defaultDate\"\r\n (datePickerResult)=\"onDatePickerResult($event)\"\r\n [selectToday]=\"canSelectToday\"\r\n (todayDate)=\"onTodayDate($event)\"\r\n>\r\n</lib-nira-date-picker>\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.NiraDatePickerComponent, selector: "lib-nira-date-picker", inputs: ["selectToday", "disable", "changableYears", "theme", "defaultDate", "isOpenCalendar"], outputs: ["isOpenCalendarChange", "todayDate", "datePickerResult"] }, { kind: "component", type: i2.CoreInputComponent, selector: "core-input", inputs: ["type", "canShowWordifyFa", "canSplitNumber", "canHighlightBackground", "maxLength", "inputFormControl", "disable", "placeholder"], outputs: ["onChange", "onBlurEmit"] }] }); }
|
|
39
33
|
}
|
|
40
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreDatePickerComponent, decorators: [{
|
|
41
35
|
type: Component,
|
|
42
|
-
args: [{ selector: 'core-date-picker', template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"
|
|
36
|
+
args: [{ selector: 'core-date-picker', template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"_inputFormControl\"\r\n (click)=\"isOpenCalendar = true\"\r\n>\r\n</core-input>\r\n<lib-nira-date-picker\r\n [(isOpenCalendar)]=\"isOpenCalendar\"\r\n [defaultDate]=\"date ? date : defaultDate\"\r\n (datePickerResult)=\"onDatePickerResult($event)\"\r\n [selectToday]=\"canSelectToday\"\r\n (todayDate)=\"onTodayDate($event)\"\r\n>\r\n</lib-nira-date-picker>\r\n" }]
|
|
43
37
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { canSelectToday: [{
|
|
44
38
|
type: Input
|
|
45
39
|
}], defaultDate: [{
|
|
@@ -49,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
49
43
|
}], inputFormControl: [{
|
|
50
44
|
type: Input
|
|
51
45
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS1kYXRlLXBpY2tlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mYWxjb24tbGliL3NyYy9saWIvY29yZS1kYXRlLXBpY2tlci9jb3JlLWRhdGUtcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZhbGNvbi1saWIvc3JjL2xpYi9jb3JlLWRhdGUtcGlja2VyL2NvcmUtZGF0ZS1waWNrZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxLQUFLLEdBR04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBeUIsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU9wRSxNQUFNLE9BQU8sdUJBQXVCO0lBTWxDLElBQWEsZ0JBQWdCLENBQUMsS0FBa0I7UUFDOUMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLEtBQUssQ0FBQztJQUNqQyxDQUFDO0lBSUQsWUFBb0IsaUJBQW9DO1FBQXBDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFYeEQsc0JBQWlCLEdBQUcsSUFBSSxXQUFXLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRW5DLG1CQUFjLEdBQVksS0FBSyxDQUFDO1FBQ2hDLGdCQUFXLEdBQVcsRUFBRSxDQUFDO1FBQ3pCLFVBQUssR0FBVyxFQUFFLENBQUM7UUFLNUIsbUJBQWMsR0FBWSxLQUFLLENBQUM7UUFDaEMsU0FBSSxHQUFXLEVBQUUsQ0FBQztJQUN5QyxDQUFDO0lBQzVELFFBQVEsS0FBVSxDQUFDO0lBRW5CLGVBQWU7UUFDYixJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDekMsQ0FBQztJQUVELGtCQUFrQixDQUFDLE1BQWM7UUFDL0IsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBQ0QsV0FBVyxDQUFDLFNBQWlCO1FBQzNCLElBQUksQ0FBQyxJQUFJLEdBQUcsU0FBUyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDN0MsQ0FBQzsrR0ExQlUsdUJBQXVCO21HQUF2Qix1QkFBdUIsd0xDZnBDLG9iQWNBOzs0RkRDYSx1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0Usa0JBQWtCO3dHQU9uQixjQUFjO3NCQUF0QixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNPLGdCQUFnQjtzQkFBNUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbnB1dCxcclxuICBPbkluaXQsXHJcbiAgT3V0cHV0LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtQ29udHJvbCwgRm9ybUdyb3VwLCBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjb3JlLWRhdGUtcGlja2VyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY29yZS1kYXRlLXBpY2tlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY29yZS1kYXRlLXBpY2tlci5jb21wb25lbnQuc2NzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29yZURhdGVQaWNrZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIF9pbnB1dEZvcm1Db250cm9sID0gbmV3IEZvcm1Db250cm9sKCcnLCBbXSk7XHJcblxyXG4gIEBJbnB1dCgpIGNhblNlbGVjdFRvZGF5OiBib29sZWFuID0gZmFsc2U7XHJcbiAgQElucHV0KCkgZGVmYXVsdERhdGU6IHN0cmluZyA9ICcnO1xyXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBzZXQgaW5wdXRGb3JtQ29udHJvbCh2YWx1ZTogRm9ybUNvbnRyb2wpIHtcclxuICAgIHRoaXMuX2lucHV0Rm9ybUNvbnRyb2wgPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIGlzT3BlbkNhbGVuZGFyOiBib29sZWFuID0gZmFsc2U7XHJcbiAgZGF0ZTogc3RyaW5nID0gJyc7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XHJcbiAgbmdPbkluaXQoKTogdm9pZCB7fVxyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcclxuICB9XHJcblxyXG4gIG9uRGF0ZVBpY2tlclJlc3VsdChyZXN1bHQ6IHN0cmluZykge1xyXG4gICAgdGhpcy5faW5wdXRGb3JtQ29udHJvbC5zZXRWYWx1ZShyZXN1bHQpO1xyXG4gICAgdGhpcy5kYXRlID0gcmVzdWx0O1xyXG4gIH1cclxuICBvblRvZGF5RGF0ZSh0b2RheURhdGU6IHN0cmluZykge1xyXG4gICAgdGhpcy5kYXRlID0gdG9kYXlEYXRlO1xyXG4gICAgdGhpcy5faW5wdXRGb3JtQ29udHJvbC5zZXRWYWx1ZSh0b2RheURhdGUpO1xyXG4gIH1cclxufVxyXG4iLCI8Y29yZS1pbnB1dFxyXG4gIFtwbGFjZWhvbGRlcl09XCJsYWJlbFwiXHJcbiAgW2lucHV0Rm9ybUNvbnRyb2xdPVwiX2lucHV0Rm9ybUNvbnRyb2xcIlxyXG4gIChjbGljayk9XCJpc09wZW5DYWxlbmRhciA9IHRydWVcIlxyXG4+XHJcbjwvY29yZS1pbnB1dD5cclxuPGxpYi1uaXJhLWRhdGUtcGlja2VyXHJcbiAgWyhpc09wZW5DYWxlbmRhcildPVwiaXNPcGVuQ2FsZW5kYXJcIlxyXG4gIFtkZWZhdWx0RGF0ZV09XCJkYXRlID8gZGF0ZSA6IGRlZmF1bHREYXRlXCJcclxuICAoZGF0ZVBpY2tlclJlc3VsdCk9XCJvbkRhdGVQaWNrZXJSZXN1bHQoJGV2ZW50KVwiXHJcbiAgW3NlbGVjdFRvZGF5XT1cImNhblNlbGVjdFRvZGF5XCJcclxuICAodG9kYXlEYXRlKT1cIm9uVG9kYXlEYXRlKCRldmVudClcIlxyXG4+XHJcbjwvbGliLW5pcmEtZGF0ZS1waWNrZXI+XHJcbiJdfQ==
|
|
@@ -8,6 +8,7 @@ import * as i4 from "../pipes/persian-digits.pipe";
|
|
|
8
8
|
export class CoreInputComponent {
|
|
9
9
|
constructor() {
|
|
10
10
|
this.isDisable = false;
|
|
11
|
+
this.lastValue = '';
|
|
11
12
|
this.canShowWordifyFa = false;
|
|
12
13
|
this.canSplitNumber = false;
|
|
13
14
|
this.canHighlightBackground = false;
|
|
@@ -29,6 +30,14 @@ export class CoreInputComponent {
|
|
|
29
30
|
this.inputFormControl.enable();
|
|
30
31
|
}
|
|
31
32
|
}
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this.inputFormControl.valueChanges.subscribe((change) => {
|
|
35
|
+
console.log(change);
|
|
36
|
+
if (this.lastValue !== change) {
|
|
37
|
+
this.formatPrice(change.toString());
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
}
|
|
32
41
|
change(event) {
|
|
33
42
|
this.formatPrice(event.srcElement.value);
|
|
34
43
|
}
|
|
@@ -37,6 +46,7 @@ export class CoreInputComponent {
|
|
|
37
46
|
const value = event.srcElement.value;
|
|
38
47
|
this.inputFormControl.markAsTouched();
|
|
39
48
|
this.inputFormControl.setValue(value);
|
|
49
|
+
this.lastValue = value;
|
|
40
50
|
if (this.inputType === 'number' && this.canSplitNumber) {
|
|
41
51
|
this.onChange.emit(value.replaceAll(',', ''));
|
|
42
52
|
}
|
|
@@ -73,12 +83,14 @@ export class CoreInputComponent {
|
|
|
73
83
|
value = Number(value.replaceAll(',', ''));
|
|
74
84
|
if (isNaN(value)) {
|
|
75
85
|
this.inputFormControl.setValue('');
|
|
86
|
+
this.lastValue = value;
|
|
76
87
|
}
|
|
77
88
|
else {
|
|
78
89
|
const formatValue = value
|
|
79
90
|
.toString()
|
|
80
91
|
.replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
|
81
92
|
this.inputFormControl.setValue(formatValue);
|
|
93
|
+
this.lastValue = formatValue;
|
|
82
94
|
}
|
|
83
95
|
if (!this.inputFormControl.errors) {
|
|
84
96
|
this.onChange.emit(this.inputFormControl.value.replaceAll(',', ''));
|
|
@@ -118,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
118
130
|
}], onBlurEmit: [{
|
|
119
131
|
type: Output
|
|
120
132
|
}] } });
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-input.component.js","sourceRoot":"","sources":["../../../../../projects/falcon-lib/src/lib/core-input/core-input.component.ts","../../../../../projects/falcon-lib/src/lib/core-input/core-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\ntype InputType = 'number' | 'password' | 'text';\r\n@Component({\r\n  selector: 'core-input',\r\n  templateUrl: './core-input.component.html',\r\n  styleUrls: ['./core-input.component.scss'],\r\n})\r\nexport class CoreInputComponent {\r\n  inputType!: InputType;\r\n  isDisable = false;\r\n  @Input() set type(value: InputType) {\r\n    this.inputType = value;\r\n  }\r\n  @Input() canShowWordifyFa = false;\r\n  @Input() canSplitNumber = false;\r\n  @Input() canHighlightBackground = false;\r\n  @Input() maxLength = 2000;\r\n\r\n  @Input() inputFormControl: FormControl = new FormControl('', []);\r\n  @Input() set disable(value: boolean) {\r\n    this.isDisable = value;\r\n    if (value) {\r\n      this.inputFormControl.disable();\r\n    } else {\r\n      this.inputFormControl.enable();\r\n    }\r\n  }\r\n  @Input() placeholder = '';\r\n  @Output() onChange: EventEmitter<string> = new EventEmitter();\r\n  @Output() onBlurEmit: EventEmitter<string> = new EventEmitter();\r\n\r\n  change(event: any) {\r\n    this.formatPrice(event.srcElement.value);\r\n  }\r\n\r\n  onPaste(event: any) {\r\n    setTimeout(() => {\r\n      const value = event.srcElement.value;\r\n      this.inputFormControl.markAsTouched();\r\n      this.inputFormControl.setValue(value);\r\n      if (this.inputType === 'number' && this.canSplitNumber) {\r\n        this.onChange.emit(value.replaceAll(',', ''));\r\n      } else {\r\n        if (!this.inputFormControl.errors) {\r\n          this.onChange.emit(value);\r\n        }\r\n      }\r\n    }, 10);\r\n  }\r\n\r\n  onBlur() {\r\n    if (this.inputType === 'number' && this.canSplitNumber) {\r\n      this.onChange.emit(this.inputFormControl.value.replaceAll(',', ''));\r\n    } else {\r\n      if (!this.inputFormControl.errors) {\r\n        this.onChange.emit(this.inputFormControl.value);\r\n      }\r\n    }\r\n    this.onBlurEmit.emit(this.inputFormControl.value);\r\n  }\r\n\r\n  onKeyPress() {\r\n    if (this.inputFormControl.value.toString().length == this.maxLength) {\r\n      return false;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  formatPrice(event: any) {\r\n    if (this.inputType === 'number' && this.canSplitNumber) {\r\n      setTimeout(() => {\r\n        let value = event;\r\n        value = Number(value.replaceAll(',', ''));\r\n        if (isNaN(value)) {\r\n          this.inputFormControl.setValue('');\r\n        } else {\r\n          const formatValue = value\r\n            .toString()\r\n            .replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',');\r\n          this.inputFormControl.setValue(formatValue);\r\n        }\r\n        if (!this.inputFormControl.errors) {\r\n          this.onChange.emit(this.inputFormControl.value.replaceAll(',', ''));\r\n        }\r\n      }, 10);\r\n    } else {\r\n      if (!this.inputFormControl.errors) {\r\n        this.onChange.emit(this.inputFormControl.value);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div>\r\n  <div\r\n    class=\"container-input\"\r\n    [ngClass]=\"{\r\n      error:\r\n        (inputFormControl.touched || inputFormControl.dirty) &&\r\n        inputFormControl.errors\r\n    }\"\r\n  >\r\n    <input\r\n      [type]=\"'text'\"\r\n      class=\"a-input-style\"\r\n      [formControl]=\"inputFormControl\"\r\n      (blur)=\"onBlur()\"\r\n      (keyup)=\"change($event)\"\r\n      (paste)=\"onPaste($event)\"\r\n      [ngClass]=\"{\r\n        'have-value': inputFormControl.value.toString().length > 0,\r\n        'highlight-background':\r\n          canHighlightBackground &&\r\n          inputFormControl.value.toString().length === 0 &&\r\n          !(\r\n            (inputFormControl.touched || inputFormControl.dirty) &&\r\n            inputFormControl.errors\r\n          ),\r\n        'disable-input': isDisable\r\n      }\"\r\n      (keypress)=\"onKeyPress()\"\r\n    />\r\n    <label *ngIf=\"placeholder.length > 0\">{{ placeholder }} </label>\r\n    <div class=\"label-error overflow-hidden\">\r\n      <span\r\n        class=\"label-number\"\r\n        *ngIf=\"\r\n          canShowWordifyFa &&\r\n          inputFormControl.value.toString().length > 0 &&\r\n          inputType === 'number'\r\n        \"\r\n        ><app-core-number\r\n          [canShowWordInToolTip]=\"false\"\r\n          [type]=\"'word'\"\r\n          [number]=\"inputFormControl.value\"\r\n        ></app-core-number\r\n      ></span>\r\n\r\n      <span\r\n        *ngIf=\"\r\n        (inputFormControl.touched || inputFormControl.dirty) &&\r\n        inputFormControl.errors?.['required']\r\n      \"\r\n        >این فیلد خالی است</span\r\n      >\r\n      <span\r\n        *ngIf=\"\r\n        (inputFormControl.touched || inputFormControl.dirty) &&\r\n        inputFormControl.errors?.['prePayment']\r\n      \"\r\n        >مبلغ صحیح نیست</span\r\n      >\r\n      <span\r\n        *ngIf=\"\r\n      (inputFormControl.touched || inputFormControl.dirty) &&\r\n      inputFormControl.errors?.['minlength']\r\n    \"\r\n      >\r\n        حداقل تعداد کارکتر\r\n        {{inputFormControl.errors?.['minlength'].requiredLength|persianDigits}}\r\n        عدد باشد\r\n      </span>\r\n      <span\r\n        *ngIf=\"\r\n      (inputFormControl.touched || inputFormControl.dirty) &&\r\n      inputFormControl.errors?.['maxlength']\r\n    \"\r\n      >\r\n        حداکثر تعداد کارکتر\r\n        {{inputFormControl.errors?.['maxlength'].requiredLength |persianDigits}}\r\n        عدد باشد\r\n      </span>\r\n      <span\r\n        *ngIf=\"\r\n      (inputFormControl.touched || inputFormControl.dirty) &&\r\n      inputFormControl.errors?.['pattern']?.requiredPattern=='^09[0-9]{9}$'\r\n    \"\r\n      >\r\n        شماره همراه اشتباه هست\r\n      </span>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-input.component.js","sourceRoot":"","sources":["../../../../../projects/falcon-lib/src/lib/core-input/core-input.component.ts","../../../../../projects/falcon-lib/src/lib/core-input/core-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\ntype InputType = 'number' | 'password' | 'text';\r\n@Component({\r\n  selector: 'core-input',\r\n  templateUrl: './core-input.component.html',\r\n  styleUrls: ['./core-input.component.scss'],\r\n})\r\nexport class CoreInputComponent {\r\n  inputType!: InputType;\r\n  isDisable = false;\r\n  lastValue = '';\r\n  @Input() set type(value: InputType) {\r\n    this.inputType = value;\r\n  }\r\n  @Input() canShowWordifyFa = false;\r\n  @Input() canSplitNumber = false;\r\n  @Input() canHighlightBackground = false;\r\n  @Input() maxLength = 2000;\r\n\r\n  @Input() inputFormControl: FormControl = new FormControl('', []);\r\n  @Input() set disable(value: boolean) {\r\n    this.isDisable = value;\r\n    if (value) {\r\n      this.inputFormControl.disable();\r\n    } else {\r\n      this.inputFormControl.enable();\r\n    }\r\n  }\r\n  @Input() placeholder = '';\r\n  @Output() onChange: EventEmitter<string> = new EventEmitter();\r\n  @Output() onBlurEmit: EventEmitter<string> = new EventEmitter();\r\n\r\n  ngOnInit() {\r\n    this.inputFormControl.valueChanges.subscribe((change) => {\r\n      console.log(change);\r\n      if (this.lastValue !== change) {\r\n        this.formatPrice(change.toString());\r\n      }\r\n    });\r\n  }\r\n  change(event: any) {\r\n    this.formatPrice(event.srcElement.value);\r\n  }\r\n\r\n  onPaste(event: any) {\r\n    setTimeout(() => {\r\n      const value = event.srcElement.value;\r\n      this.inputFormControl.markAsTouched();\r\n      this.inputFormControl.setValue(value);\r\n      this.lastValue = value;\r\n      if (this.inputType === 'number' && this.canSplitNumber) {\r\n        this.onChange.emit(value.replaceAll(',', ''));\r\n      } else {\r\n        if (!this.inputFormControl.errors) {\r\n          this.onChange.emit(value);\r\n        }\r\n      }\r\n    }, 10);\r\n  }\r\n\r\n  onBlur() {\r\n    if (this.inputType === 'number' && this.canSplitNumber) {\r\n      this.onChange.emit(this.inputFormControl.value.replaceAll(',', ''));\r\n    } else {\r\n      if (!this.inputFormControl.errors) {\r\n        this.onChange.emit(this.inputFormControl.value);\r\n      }\r\n    }\r\n    this.onBlurEmit.emit(this.inputFormControl.value);\r\n  }\r\n\r\n  onKeyPress() {\r\n    if (this.inputFormControl.value.toString().length == this.maxLength) {\r\n      return false;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  formatPrice(event: any) {\r\n    if (this.inputType === 'number' && this.canSplitNumber) {\r\n      setTimeout(() => {\r\n        let value = event;\r\n        value = Number(value.replaceAll(',', ''));\r\n        if (isNaN(value)) {\r\n          this.inputFormControl.setValue('');\r\n          this.lastValue = value;\r\n        } else {\r\n          const formatValue = value\r\n            .toString()\r\n            .replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',');\r\n          this.inputFormControl.setValue(formatValue);\r\n          this.lastValue = formatValue;\r\n        }\r\n        if (!this.inputFormControl.errors) {\r\n          this.onChange.emit(this.inputFormControl.value.replaceAll(',', ''));\r\n        }\r\n      }, 10);\r\n    } else {\r\n      if (!this.inputFormControl.errors) {\r\n        this.onChange.emit(this.inputFormControl.value);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div>\r\n  <div\r\n    class=\"container-input\"\r\n    [ngClass]=\"{\r\n      error:\r\n        (inputFormControl.touched || inputFormControl.dirty) &&\r\n        inputFormControl.errors\r\n    }\"\r\n  >\r\n    <input\r\n      [type]=\"'text'\"\r\n      class=\"a-input-style\"\r\n      [formControl]=\"inputFormControl\"\r\n      (blur)=\"onBlur()\"\r\n      (keyup)=\"change($event)\"\r\n      (paste)=\"onPaste($event)\"\r\n      [ngClass]=\"{\r\n        'have-value': inputFormControl.value.toString().length > 0,\r\n        'highlight-background':\r\n          canHighlightBackground &&\r\n          inputFormControl.value.toString().length === 0 &&\r\n          !(\r\n            (inputFormControl.touched || inputFormControl.dirty) &&\r\n            inputFormControl.errors\r\n          ),\r\n        'disable-input': isDisable\r\n      }\"\r\n      (keypress)=\"onKeyPress()\"\r\n    />\r\n    <label *ngIf=\"placeholder.length > 0\">{{ placeholder }} </label>\r\n    <div class=\"label-error overflow-hidden\">\r\n      <span\r\n        class=\"label-number\"\r\n        *ngIf=\"\r\n          canShowWordifyFa &&\r\n          inputFormControl.value.toString().length > 0 &&\r\n          inputType === 'number'\r\n        \"\r\n        ><app-core-number\r\n          [canShowWordInToolTip]=\"false\"\r\n          [type]=\"'word'\"\r\n          [number]=\"inputFormControl.value\"\r\n        ></app-core-number\r\n      ></span>\r\n\r\n      <span\r\n        *ngIf=\"\r\n        (inputFormControl.touched || inputFormControl.dirty) &&\r\n        inputFormControl.errors?.['required']\r\n      \"\r\n        >این فیلد خالی است</span\r\n      >\r\n      <span\r\n        *ngIf=\"\r\n        (inputFormControl.touched || inputFormControl.dirty) &&\r\n        inputFormControl.errors?.['prePayment']\r\n      \"\r\n        >مبلغ صحیح نیست</span\r\n      >\r\n      <span\r\n        *ngIf=\"\r\n      (inputFormControl.touched || inputFormControl.dirty) &&\r\n      inputFormControl.errors?.['minlength']\r\n    \"\r\n      >\r\n        حداقل تعداد کارکتر\r\n        {{inputFormControl.errors?.['minlength'].requiredLength|persianDigits}}\r\n        عدد باشد\r\n      </span>\r\n      <span\r\n        *ngIf=\"\r\n      (inputFormControl.touched || inputFormControl.dirty) &&\r\n      inputFormControl.errors?.['maxlength']\r\n    \"\r\n      >\r\n        حداکثر تعداد کارکتر\r\n        {{inputFormControl.errors?.['maxlength'].requiredLength |persianDigits}}\r\n        عدد باشد\r\n      </span>\r\n      <span\r\n        *ngIf=\"\r\n      (inputFormControl.touched || inputFormControl.dirty) &&\r\n      inputFormControl.errors?.['pattern']?.requiredPattern=='^09[0-9]{9}$'\r\n    \"\r\n      >\r\n        شماره همراه اشتباه هست\r\n      </span>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
package/fesm2022/nira-falcon.mjs
CHANGED
|
@@ -463,6 +463,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
463
463
|
class CoreInputComponent {
|
|
464
464
|
constructor() {
|
|
465
465
|
this.isDisable = false;
|
|
466
|
+
this.lastValue = '';
|
|
466
467
|
this.canShowWordifyFa = false;
|
|
467
468
|
this.canSplitNumber = false;
|
|
468
469
|
this.canHighlightBackground = false;
|
|
@@ -484,6 +485,14 @@ class CoreInputComponent {
|
|
|
484
485
|
this.inputFormControl.enable();
|
|
485
486
|
}
|
|
486
487
|
}
|
|
488
|
+
ngOnInit() {
|
|
489
|
+
this.inputFormControl.valueChanges.subscribe((change) => {
|
|
490
|
+
console.log(change);
|
|
491
|
+
if (this.lastValue !== change) {
|
|
492
|
+
this.formatPrice(change.toString());
|
|
493
|
+
}
|
|
494
|
+
});
|
|
495
|
+
}
|
|
487
496
|
change(event) {
|
|
488
497
|
this.formatPrice(event.srcElement.value);
|
|
489
498
|
}
|
|
@@ -492,6 +501,7 @@ class CoreInputComponent {
|
|
|
492
501
|
const value = event.srcElement.value;
|
|
493
502
|
this.inputFormControl.markAsTouched();
|
|
494
503
|
this.inputFormControl.setValue(value);
|
|
504
|
+
this.lastValue = value;
|
|
495
505
|
if (this.inputType === 'number' && this.canSplitNumber) {
|
|
496
506
|
this.onChange.emit(value.replaceAll(',', ''));
|
|
497
507
|
}
|
|
@@ -528,12 +538,14 @@ class CoreInputComponent {
|
|
|
528
538
|
value = Number(value.replaceAll(',', ''));
|
|
529
539
|
if (isNaN(value)) {
|
|
530
540
|
this.inputFormControl.setValue('');
|
|
541
|
+
this.lastValue = value;
|
|
531
542
|
}
|
|
532
543
|
else {
|
|
533
544
|
const formatValue = value
|
|
534
545
|
.toString()
|
|
535
546
|
.replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
|
536
547
|
this.inputFormControl.setValue(formatValue);
|
|
548
|
+
this.lastValue = formatValue;
|
|
537
549
|
}
|
|
538
550
|
if (!this.inputFormControl.errors) {
|
|
539
551
|
this.onChange.emit(this.inputFormControl.value.replaceAll(',', ''));
|
|
@@ -575,42 +587,36 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
575
587
|
}] } });
|
|
576
588
|
|
|
577
589
|
class CoreDatePickerComponent {
|
|
590
|
+
set inputFormControl(value) {
|
|
591
|
+
this._inputFormControl = value;
|
|
592
|
+
}
|
|
578
593
|
constructor(changeDetectorRef) {
|
|
579
594
|
this.changeDetectorRef = changeDetectorRef;
|
|
595
|
+
this._inputFormControl = new FormControl('', []);
|
|
580
596
|
this.canSelectToday = false;
|
|
581
597
|
this.defaultDate = '';
|
|
582
598
|
this.label = '';
|
|
583
|
-
this.inputFormControl = new FormControl('', []);
|
|
584
|
-
this.niraDatePickerForm = {};
|
|
585
599
|
this.isOpenCalendar = false;
|
|
586
600
|
this.date = '';
|
|
587
601
|
}
|
|
588
|
-
ngOnInit() {
|
|
589
|
-
this.niraDatePickerForm = new FormGroup({
|
|
590
|
-
niraDatePickerFormCtrl: this.inputFormControl,
|
|
591
|
-
});
|
|
592
|
-
}
|
|
602
|
+
ngOnInit() { }
|
|
593
603
|
ngAfterViewInit() {
|
|
594
604
|
this.changeDetectorRef.detectChanges();
|
|
595
605
|
}
|
|
596
606
|
onDatePickerResult(result) {
|
|
597
|
-
this.
|
|
598
|
-
niraDatePickerFormCtrl: result,
|
|
599
|
-
});
|
|
607
|
+
this._inputFormControl.setValue(result);
|
|
600
608
|
this.date = result;
|
|
601
609
|
}
|
|
602
610
|
onTodayDate(todayDate) {
|
|
603
611
|
this.date = todayDate;
|
|
604
|
-
this.
|
|
605
|
-
niraDatePickerFormCtrl: todayDate,
|
|
606
|
-
});
|
|
612
|
+
this._inputFormControl.setValue(todayDate);
|
|
607
613
|
}
|
|
608
614
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreDatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
609
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreDatePickerComponent, selector: "core-date-picker", inputs: { canSelectToday: "canSelectToday", defaultDate: "defaultDate", label: "label", inputFormControl: "inputFormControl" }, ngImport: i0, template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"
|
|
615
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreDatePickerComponent, selector: "core-date-picker", inputs: { canSelectToday: "canSelectToday", defaultDate: "defaultDate", label: "label", inputFormControl: "inputFormControl" }, ngImport: i0, template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"_inputFormControl\"\r\n (click)=\"isOpenCalendar = true\"\r\n>\r\n</core-input>\r\n<lib-nira-date-picker\r\n [(isOpenCalendar)]=\"isOpenCalendar\"\r\n [defaultDate]=\"date ? date : defaultDate\"\r\n (datePickerResult)=\"onDatePickerResult($event)\"\r\n [selectToday]=\"canSelectToday\"\r\n (todayDate)=\"onTodayDate($event)\"\r\n>\r\n</lib-nira-date-picker>\r\n", styles: [""], dependencies: [{ kind: "component", type: i1$3.NiraDatePickerComponent, selector: "lib-nira-date-picker", inputs: ["selectToday", "disable", "changableYears", "theme", "defaultDate", "isOpenCalendar"], outputs: ["isOpenCalendarChange", "todayDate", "datePickerResult"] }, { kind: "component", type: CoreInputComponent, selector: "core-input", inputs: ["type", "canShowWordifyFa", "canSplitNumber", "canHighlightBackground", "maxLength", "inputFormControl", "disable", "placeholder"], outputs: ["onChange", "onBlurEmit"] }] }); }
|
|
610
616
|
}
|
|
611
617
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreDatePickerComponent, decorators: [{
|
|
612
618
|
type: Component,
|
|
613
|
-
args: [{ selector: 'core-date-picker', template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"
|
|
619
|
+
args: [{ selector: 'core-date-picker', template: "<core-input\r\n [placeholder]=\"label\"\r\n [inputFormControl]=\"_inputFormControl\"\r\n (click)=\"isOpenCalendar = true\"\r\n>\r\n</core-input>\r\n<lib-nira-date-picker\r\n [(isOpenCalendar)]=\"isOpenCalendar\"\r\n [defaultDate]=\"date ? date : defaultDate\"\r\n (datePickerResult)=\"onDatePickerResult($event)\"\r\n [selectToday]=\"canSelectToday\"\r\n (todayDate)=\"onTodayDate($event)\"\r\n>\r\n</lib-nira-date-picker>\r\n" }]
|
|
614
620
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { canSelectToday: [{
|
|
615
621
|
type: Input
|
|
616
622
|
}], defaultDate: [{
|