ngx-sumax-erp-components 0.0.1
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/README.md +24 -0
- package/esm2022/lib/date-picker/CustomDatePickerFormat.mjs +43 -0
- package/esm2022/lib/date-picker/CustomDatePickerI18n.mjs +50 -0
- package/esm2022/lib/date-picker/date-picker.component.mjs +366 -0
- package/esm2022/lib/date-picker/date-picker.mjs +3 -0
- package/esm2022/lib/date-picker/date-picker.module.mjs +69 -0
- package/esm2022/lib/date-picker/date-picker.service.mjs +68 -0
- package/esm2022/lib/date-time-picker/date-time-picker.component.mjs +311 -0
- package/esm2022/lib/date-time-picker/date-time-picker.mjs +3 -0
- package/esm2022/lib/date-time-picker/date-time-picker.module.mjs +76 -0
- package/esm2022/lib/date-time-picker/date-time-picker.service.mjs +64 -0
- package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.component.mjs +1140 -0
- package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.module.mjs +93 -0
- package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.service.mjs +85 -0
- package/esm2022/lib/dialog-ag-grid-search/dialog-ag-grid-search.component.mjs +283 -0
- package/esm2022/lib/dialog-ag-grid-search/dialog-ag-grid-search.module.mjs +23 -0
- package/esm2022/lib/error-message/error-message.component.mjs +24 -0
- package/esm2022/lib/error-message/error-message.module.mjs +19 -0
- package/esm2022/lib/input-number/input-number.component.mjs +351 -0
- package/esm2022/lib/input-number/input-number.mjs +3 -0
- package/esm2022/lib/input-number/input-number.module.mjs +65 -0
- package/esm2022/lib/input-number/input-number.service.mjs +68 -0
- package/esm2022/lib/input-text/input-text.component.mjs +345 -0
- package/esm2022/lib/input-text/input-text.mjs +3 -0
- package/esm2022/lib/input-text/input-text.module.mjs +73 -0
- package/esm2022/lib/input-text/input-text.service.mjs +96 -0
- package/esm2022/lib/ng-select-multiple/ng-select-multiple.component.mjs +375 -0
- package/esm2022/lib/ng-select-multiple/ng-select-multiple.mjs +3 -0
- package/esm2022/lib/ng-select-multiple/ng-select-multiple.module.mjs +69 -0
- package/esm2022/lib/ng-select-multiple/ng-select-multiple.service.mjs +96 -0
- package/esm2022/lib/ng-select-simple/ng-select-simple.component.mjs +461 -0
- package/esm2022/lib/ng-select-simple/ng-select-simple.mjs +3 -0
- package/esm2022/lib/ng-select-simple/ng-select-simple.module.mjs +53 -0
- package/esm2022/lib/ng-select-simple/ng-select-simple.service.mjs +138 -0
- package/esm2022/lib/sc-ag-grid/cell-editors/container-shared/container-shared.component.mjs +144 -0
- package/esm2022/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayCustom.component.mjs +27 -0
- package/esm2022/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayDefault.component.mjs +22 -0
- package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-button/sc-cell-render-button.component.mjs +242 -0
- package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-checkbox-list/sc-cell-render-checkbox-list.component.mjs +62 -0
- package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-config.mjs +27 -0
- package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-select/sc-cell-render-select.component.mjs +70 -0
- package/esm2022/lib/sc-ag-grid/cell-render/sc-cell-render-toggle/sc-cell-render-toggle.component.mjs +45 -0
- package/esm2022/lib/sc-ag-grid/directives/scAgGrid.directive.mjs +25 -0
- package/esm2022/lib/sc-ag-grid/index.mjs +14 -0
- package/esm2022/lib/sc-ag-grid/input-search/input-search.component.mjs +20 -0
- package/esm2022/lib/sc-ag-grid/input-search/input-search.module.mjs +31 -0
- package/esm2022/lib/sc-ag-grid/sc-ag-grid-customizable/sc-ag-grid-customizable.component.mjs +564 -0
- package/esm2022/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.component.mjs +80 -0
- package/esm2022/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.module.mjs +31 -0
- package/esm2022/lib/sc-ag-grid/sc-ag-grid.module.mjs +118 -0
- package/esm2022/lib/sc-ag-grid/sc-grid.uitl.mjs +10 -0
- package/esm2022/lib/sc-wizard/sc-wizard.component.mjs +75 -0
- package/esm2022/lib/sc-wizard/sc-wizard.module.mjs +44 -0
- package/esm2022/lib/text-area/text-area.component.mjs +272 -0
- package/esm2022/lib/text-area/text-area.mjs +3 -0
- package/esm2022/lib/text-area/text-area.module.mjs +60 -0
- package/esm2022/lib/text-area/text-area.service.mjs +54 -0
- package/esm2022/lib/tooltip-message/tooltip-message.component.mjs +25 -0
- package/esm2022/lib/tooltip-message/tooltip-message.module.mjs +21 -0
- package/esm2022/lib/utils/DateTimeModel.mjs +56 -0
- package/esm2022/lib/utils/DateTimePickerEditable.mjs +3 -0
- package/esm2022/lib/utils/DateUtil.mjs +196 -0
- package/esm2022/lib/utils/INgSelect.mjs +2 -0
- package/esm2022/lib/utils/IScAgGrid.mjs +7 -0
- package/esm2022/lib/utils/ScWizardBase.mjs +14 -0
- package/esm2022/lib/utils/SharedComponentsUtil.mjs +38 -0
- package/esm2022/lib/utils/ValidateUtil.mjs +18 -0
- package/esm2022/lib/utils/message-util.service.mjs +75 -0
- package/esm2022/ngx-sumax-erp-components.mjs +5 -0
- package/esm2022/public-api.mjs +33 -0
- package/fesm2022/ngx-sumax-erp-components.mjs +7045 -0
- package/fesm2022/ngx-sumax-erp-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/date-picker/CustomDatePickerFormat.d.ts +11 -0
- package/lib/date-picker/CustomDatePickerI18n.d.ts +25 -0
- package/lib/date-picker/date-picker.component.d.ts +108 -0
- package/lib/date-picker/date-picker.d.ts +10 -0
- package/lib/date-picker/date-picker.module.d.ts +18 -0
- package/lib/date-picker/date-picker.service.d.ts +22 -0
- package/lib/date-time-picker/date-time-picker.component.d.ts +96 -0
- package/lib/date-time-picker/date-time-picker.d.ts +9 -0
- package/lib/date-time-picker/date-time-picker.module.d.ts +18 -0
- package/lib/date-time-picker/date-time-picker.service.d.ts +20 -0
- package/lib/date-time-picker-editable/date-time-picker-editable.component.d.ts +118 -0
- package/lib/date-time-picker-editable/date-time-picker-editable.module.d.ts +16 -0
- package/lib/date-time-picker-editable/date-time-picker-editable.service.d.ts +27 -0
- package/lib/dialog-ag-grid-search/dialog-ag-grid-search.component.d.ts +82 -0
- package/lib/dialog-ag-grid-search/dialog-ag-grid-search.module.d.ts +13 -0
- package/lib/error-message/error-message.component.d.ts +13 -0
- package/lib/error-message/error-message.module.d.ts +9 -0
- package/lib/input-number/input-number.component.d.ts +74 -0
- package/lib/input-number/input-number.d.ts +10 -0
- package/lib/input-number/input-number.module.d.ts +17 -0
- package/lib/input-number/input-number.service.d.ts +22 -0
- package/lib/input-text/input-text.component.d.ts +85 -0
- package/lib/input-text/input-text.d.ts +17 -0
- package/lib/input-text/input-text.module.d.ts +18 -0
- package/lib/input-text/input-text.service.d.ts +35 -0
- package/lib/ng-select-multiple/ng-select-multiple.component.d.ts +83 -0
- package/lib/ng-select-multiple/ng-select-multiple.d.ts +14 -0
- package/lib/ng-select-multiple/ng-select-multiple.module.d.ts +17 -0
- package/lib/ng-select-multiple/ng-select-multiple.service.d.ts +30 -0
- package/lib/ng-select-simple/ng-select-simple.component.d.ts +124 -0
- package/lib/ng-select-simple/ng-select-simple.d.ts +20 -0
- package/lib/ng-select-simple/ng-select-simple.module.d.ts +17 -0
- package/lib/ng-select-simple/ng-select-simple.service.d.ts +42 -0
- package/lib/sc-ag-grid/cell-editors/container-shared/container-shared.component.d.ts +61 -0
- package/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayCustom.component.d.ts +10 -0
- package/lib/sc-ag-grid/cell-render/no-rows-overlay/noRowsOverlayDefault.component.d.ts +9 -0
- package/lib/sc-ag-grid/cell-render/sc-cell-render-button/sc-cell-render-button.component.d.ts +49 -0
- package/lib/sc-ag-grid/cell-render/sc-cell-render-checkbox-list/sc-cell-render-checkbox-list.component.d.ts +11 -0
- package/lib/sc-ag-grid/cell-render/sc-cell-render-config.d.ts +20 -0
- package/lib/sc-ag-grid/cell-render/sc-cell-render-select/sc-cell-render-select.component.d.ts +16 -0
- package/lib/sc-ag-grid/cell-render/sc-cell-render-toggle/sc-cell-render-toggle.component.d.ts +16 -0
- package/lib/sc-ag-grid/directives/scAgGrid.directive.d.ts +10 -0
- package/lib/sc-ag-grid/index.d.ts +13 -0
- package/lib/sc-ag-grid/input-search/input-search.component.d.ts +11 -0
- package/lib/sc-ag-grid/input-search/input-search.module.d.ts +9 -0
- package/lib/sc-ag-grid/sc-ag-grid-customizable/sc-ag-grid-customizable.component.d.ts +191 -0
- package/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.component.d.ts +25 -0
- package/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.module.d.ts +9 -0
- package/lib/sc-ag-grid/sc-ag-grid.module.d.ts +32 -0
- package/lib/sc-ag-grid/sc-grid.uitl.d.ts +5 -0
- package/lib/sc-wizard/sc-wizard.component.d.ts +38 -0
- package/lib/sc-wizard/sc-wizard.module.d.ts +13 -0
- package/lib/text-area/text-area.component.d.ts +66 -0
- package/lib/text-area/text-area.d.ts +8 -0
- package/lib/text-area/text-area.module.d.ts +16 -0
- package/lib/text-area/text-area.service.d.ts +18 -0
- package/lib/tooltip-message/tooltip-message.component.d.ts +13 -0
- package/lib/tooltip-message/tooltip-message.module.d.ts +11 -0
- package/lib/utils/DateTimeModel.d.ts +16 -0
- package/lib/utils/DateTimePickerEditable.d.ts +13 -0
- package/lib/utils/DateUtil.d.ts +37 -0
- package/lib/utils/INgSelect.d.ts +6 -0
- package/lib/utils/IScAgGrid.d.ts +65 -0
- package/lib/utils/ScWizardBase.d.ts +9 -0
- package/lib/utils/SharedComponentsUtil.d.ts +6 -0
- package/lib/utils/ValidateUtil.d.ts +4 -0
- package/lib/utils/message-util.service.d.ts +10 -0
- package/package.json +32 -0
- package/public-api.d.ts +29 -0
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { CommonModule } from "@angular/common";
|
|
2
|
+
import { NgModule } from "@angular/core";
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from "@angular/forms";
|
|
4
|
+
import { MatIconModule } from "@angular/material/icon";
|
|
5
|
+
import { MatTooltipModule } from "@angular/material/tooltip";
|
|
6
|
+
import { RouterModule } from "@angular/router";
|
|
7
|
+
import { NgbDatepickerModule } from "@ng-bootstrap/ng-bootstrap";
|
|
8
|
+
import { ErrorMessageModule } from "../error-message/error-message.module";
|
|
9
|
+
import { TooltipMessageModule } from "../tooltip-message/tooltip-message.module";
|
|
10
|
+
import { DatePickerComponent } from "./date-picker.component";
|
|
11
|
+
import { DatePicker } from "./date-picker";
|
|
12
|
+
import { DatePickerService } from "./date-picker.service";
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
export class DatePickerModule {
|
|
15
|
+
static forRoot(datePicker = new DatePicker()) {
|
|
16
|
+
return {
|
|
17
|
+
ngModule: DatePickerModule,
|
|
18
|
+
providers: [
|
|
19
|
+
{ provide: "DATE_PICKER_SHOW_LABEL", useValue: datePicker.showLabel },
|
|
20
|
+
{ provide: "DATE_PICKER_AUTOCOMPLETE", useValue: datePicker.autocomplete },
|
|
21
|
+
{ provide: "DATE_PICKER_NO_AUTO_COMPLETE_NULL", useValue: datePicker.noAutoCompleteNull },
|
|
22
|
+
{ provide: "DATE_PICKER_FOCUS_INITIAL", useValue: datePicker.focusInitial },
|
|
23
|
+
{ provide: "DATE_PICKER_VALIDATOR_MESSAGE", useValue: datePicker.validatorMessage },
|
|
24
|
+
{ provide: "DATE_PICKER_TOOLTIP_MESSAGE", useValue: datePicker.tooltipMessage },
|
|
25
|
+
{ provide: "DATE_PICKER_SUBMITTED", useValue: datePicker.submitted },
|
|
26
|
+
{ provide: "DATE_PICKER_VALIDATOR_ALERT", useValue: datePicker.validatorAlert },
|
|
27
|
+
DatePickerService,
|
|
28
|
+
],
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DatePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
32
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: DatePickerModule, declarations: [DatePickerComponent], imports: [CommonModule,
|
|
33
|
+
RouterModule,
|
|
34
|
+
FormsModule,
|
|
35
|
+
ReactiveFormsModule,
|
|
36
|
+
ErrorMessageModule,
|
|
37
|
+
TooltipMessageModule,
|
|
38
|
+
MatIconModule,
|
|
39
|
+
MatTooltipModule,
|
|
40
|
+
NgbDatepickerModule], exports: [DatePickerComponent] }); }
|
|
41
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DatePickerModule, imports: [CommonModule,
|
|
42
|
+
RouterModule,
|
|
43
|
+
FormsModule,
|
|
44
|
+
ReactiveFormsModule,
|
|
45
|
+
ErrorMessageModule,
|
|
46
|
+
TooltipMessageModule,
|
|
47
|
+
MatIconModule,
|
|
48
|
+
MatTooltipModule,
|
|
49
|
+
NgbDatepickerModule] }); }
|
|
50
|
+
}
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DatePickerModule, decorators: [{
|
|
52
|
+
type: NgModule,
|
|
53
|
+
args: [{
|
|
54
|
+
declarations: [DatePickerComponent],
|
|
55
|
+
imports: [
|
|
56
|
+
CommonModule,
|
|
57
|
+
RouterModule,
|
|
58
|
+
FormsModule,
|
|
59
|
+
ReactiveFormsModule,
|
|
60
|
+
ErrorMessageModule,
|
|
61
|
+
TooltipMessageModule,
|
|
62
|
+
MatIconModule,
|
|
63
|
+
MatTooltipModule,
|
|
64
|
+
NgbDatepickerModule,
|
|
65
|
+
],
|
|
66
|
+
exports: [DatePickerComponent],
|
|
67
|
+
}]
|
|
68
|
+
}] });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN1bWF4LWVycC1jb21wb25lbnQvc3JjL2xpYi9kYXRlLXBpY2tlci9kYXRlLXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBaUIxRCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBeUIsSUFBSSxVQUFVLEVBQUU7UUFDdEQsT0FBTztZQUNMLFFBQVEsRUFBRSxnQkFBZ0I7WUFDMUIsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLFFBQVEsRUFBRSxVQUFVLENBQUMsU0FBUyxFQUFFO2dCQUNyRSxFQUFFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxRQUFRLEVBQUUsVUFBVSxDQUFDLFlBQVksRUFBRTtnQkFDMUUsRUFBRSxPQUFPLEVBQUUsbUNBQW1DLEVBQUUsUUFBUSxFQUFFLFVBQVUsQ0FBQyxrQkFBa0IsRUFBRTtnQkFDekYsRUFBRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsUUFBUSxFQUFFLFVBQVUsQ0FBQyxZQUFZLEVBQUU7Z0JBQzNFLEVBQUUsT0FBTyxFQUFFLCtCQUErQixFQUFFLFFBQVEsRUFBRSxVQUFVLENBQUMsZ0JBQWdCLEVBQUU7Z0JBQ25GLEVBQUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLFFBQVEsRUFBRSxVQUFVLENBQUMsY0FBYyxFQUFFO2dCQUMvRSxFQUFFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxRQUFRLEVBQUUsVUFBVSxDQUFDLFNBQVMsRUFBRTtnQkFDcEUsRUFBRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsUUFBUSxFQUFFLFVBQVUsQ0FBQyxjQUFjLEVBQUU7Z0JBQy9FLGlCQUFpQjthQUNsQjtTQUNGLENBQUM7SUFDSixDQUFDOytHQWhCVSxnQkFBZ0I7Z0hBQWhCLGdCQUFnQixpQkFkWixtQkFBbUIsYUFFaEMsWUFBWTtZQUNaLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGtCQUFrQjtZQUNsQixvQkFBb0I7WUFDcEIsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQixtQkFBbUIsYUFFWCxtQkFBbUI7Z0hBRWxCLGdCQUFnQixZQVp6QixZQUFZO1lBQ1osWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsa0JBQWtCO1lBQ2xCLG9CQUFvQjtZQUNwQixhQUFhO1lBQ2IsZ0JBQWdCO1lBQ2hCLG1CQUFtQjs7NEZBSVYsZ0JBQWdCO2tCQWY1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNuQyxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixrQkFBa0I7d0JBQ2xCLG9CQUFvQjt3QkFDcEIsYUFBYTt3QkFDYixnQkFBZ0I7d0JBQ2hCLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7aUJBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvblwiO1xyXG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXBcIjtcclxuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL3JvdXRlclwiO1xyXG5pbXBvcnQgeyBOZ2JEYXRlcGlja2VyTW9kdWxlIH0gZnJvbSBcIkBuZy1ib290c3RyYXAvbmctYm9vdHN0cmFwXCI7XHJcbmltcG9ydCB7IEVycm9yTWVzc2FnZU1vZHVsZSB9IGZyb20gXCIuLi9lcnJvci1tZXNzYWdlL2Vycm9yLW1lc3NhZ2UubW9kdWxlXCI7XHJcbmltcG9ydCB7IFRvb2x0aXBNZXNzYWdlTW9kdWxlIH0gZnJvbSBcIi4uL3Rvb2x0aXAtbWVzc2FnZS90b29sdGlwLW1lc3NhZ2UubW9kdWxlXCI7XHJcbmltcG9ydCB7IERhdGVQaWNrZXJDb21wb25lbnQgfSBmcm9tIFwiLi9kYXRlLXBpY2tlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgRGF0ZVBpY2tlciB9IGZyb20gXCIuL2RhdGUtcGlja2VyXCI7XHJcbmltcG9ydCB7IERhdGVQaWNrZXJTZXJ2aWNlIH0gZnJvbSBcIi4vZGF0ZS1waWNrZXIuc2VydmljZVwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtEYXRlUGlja2VyQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBSb3V0ZXJNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBFcnJvck1lc3NhZ2VNb2R1bGUsXHJcbiAgICBUb29sdGlwTWVzc2FnZU1vZHVsZSxcclxuICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxyXG4gICAgTmdiRGF0ZXBpY2tlck1vZHVsZSxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtEYXRlUGlja2VyQ29tcG9uZW50XSxcclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGVQaWNrZXJNb2R1bGUge1xyXG4gIHN0YXRpYyBmb3JSb290KGRhdGVQaWNrZXI6IERhdGVQaWNrZXIgPSBuZXcgRGF0ZVBpY2tlcigpKTogTW9kdWxlV2l0aFByb3ZpZGVyczxEYXRlUGlja2VyTW9kdWxlPiB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICBuZ01vZHVsZTogRGF0ZVBpY2tlck1vZHVsZSxcclxuICAgICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgICAgeyBwcm92aWRlOiBcIkRBVEVfUElDS0VSX1NIT1dfTEFCRUxcIiwgdXNlVmFsdWU6IGRhdGVQaWNrZXIuc2hvd0xhYmVsIH0sXHJcbiAgICAgICAgeyBwcm92aWRlOiBcIkRBVEVfUElDS0VSX0FVVE9DT01QTEVURVwiLCB1c2VWYWx1ZTogZGF0ZVBpY2tlci5hdXRvY29tcGxldGUgfSxcclxuICAgICAgICB7IHByb3ZpZGU6IFwiREFURV9QSUNLRVJfTk9fQVVUT19DT01QTEVURV9OVUxMXCIsIHVzZVZhbHVlOiBkYXRlUGlja2VyLm5vQXV0b0NvbXBsZXRlTnVsbCB9LFxyXG4gICAgICAgIHsgcHJvdmlkZTogXCJEQVRFX1BJQ0tFUl9GT0NVU19JTklUSUFMXCIsIHVzZVZhbHVlOiBkYXRlUGlja2VyLmZvY3VzSW5pdGlhbCB9LFxyXG4gICAgICAgIHsgcHJvdmlkZTogXCJEQVRFX1BJQ0tFUl9WQUxJREFUT1JfTUVTU0FHRVwiLCB1c2VWYWx1ZTogZGF0ZVBpY2tlci52YWxpZGF0b3JNZXNzYWdlIH0sXHJcbiAgICAgICAgeyBwcm92aWRlOiBcIkRBVEVfUElDS0VSX1RPT0xUSVBfTUVTU0FHRVwiLCB1c2VWYWx1ZTogZGF0ZVBpY2tlci50b29sdGlwTWVzc2FnZSB9LFxyXG4gICAgICAgIHsgcHJvdmlkZTogXCJEQVRFX1BJQ0tFUl9TVUJNSVRURURcIiwgdXNlVmFsdWU6IGRhdGVQaWNrZXIuc3VibWl0dGVkIH0sXHJcbiAgICAgICAgeyBwcm92aWRlOiBcIkRBVEVfUElDS0VSX1ZBTElEQVRPUl9BTEVSVFwiLCB1c2VWYWx1ZTogZGF0ZVBpY2tlci52YWxpZGF0b3JBbGVydCB9LFxyXG4gICAgICAgIERhdGVQaWNrZXJTZXJ2aWNlLFxyXG4gICAgICBdLFxyXG4gICAgfTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Inject, Injectable } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DatePickerService {
|
|
4
|
+
constructor(showLabel = true, autocomplete = "off", noAutoCompleteNull = true, focusInitial = false, validatorMessage = false, tooltipMessage = true, submitted = true, validatorAlert = false) {
|
|
5
|
+
this.showLabel = showLabel;
|
|
6
|
+
this.autocomplete = autocomplete;
|
|
7
|
+
this.noAutoCompleteNull = noAutoCompleteNull;
|
|
8
|
+
this.focusInitial = focusInitial;
|
|
9
|
+
this.validatorMessage = validatorMessage;
|
|
10
|
+
this.tooltipMessage = tooltipMessage;
|
|
11
|
+
this.submitted = submitted;
|
|
12
|
+
this.validatorAlert = validatorAlert;
|
|
13
|
+
}
|
|
14
|
+
getShowLabel() {
|
|
15
|
+
return this.showLabel;
|
|
16
|
+
}
|
|
17
|
+
getAutocomplete() {
|
|
18
|
+
return this.autocomplete;
|
|
19
|
+
}
|
|
20
|
+
getNoAutoCompleteNull() {
|
|
21
|
+
return this.noAutoCompleteNull;
|
|
22
|
+
}
|
|
23
|
+
getFocusInitial() {
|
|
24
|
+
return this.focusInitial;
|
|
25
|
+
}
|
|
26
|
+
getValidatorMessage() {
|
|
27
|
+
return this.validatorMessage;
|
|
28
|
+
}
|
|
29
|
+
getTooltipMessage() {
|
|
30
|
+
return this.tooltipMessage;
|
|
31
|
+
}
|
|
32
|
+
getSubmitted() {
|
|
33
|
+
return this.submitted;
|
|
34
|
+
}
|
|
35
|
+
getValidatorAlert() {
|
|
36
|
+
return this.validatorAlert;
|
|
37
|
+
}
|
|
38
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DatePickerService, deps: [{ token: 'DATE_PICKER_SHOW_LABEL' }, { token: 'DATE_PICKER_AUTOCOMPLETE' }, { token: 'DATE_PICKER_NO_AUTO_COMPLETE_NULL' }, { token: 'DATE_PICKER_FOCUS_INITIAL' }, { token: 'DATE_PICKER_VALIDATOR_MESSAGE' }, { token: 'DATE_PICKER_TOOLTIP_MESSAGE' }, { token: 'DATE_PICKER_SUBMITTED' }, { token: 'DATE_PICKER_VALIDATOR_ALERT' }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
39
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DatePickerService }); }
|
|
40
|
+
}
|
|
41
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DatePickerService, decorators: [{
|
|
42
|
+
type: Injectable
|
|
43
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
44
|
+
type: Inject,
|
|
45
|
+
args: ['DATE_PICKER_SHOW_LABEL']
|
|
46
|
+
}] }, { type: undefined, decorators: [{
|
|
47
|
+
type: Inject,
|
|
48
|
+
args: ['DATE_PICKER_AUTOCOMPLETE']
|
|
49
|
+
}] }, { type: undefined, decorators: [{
|
|
50
|
+
type: Inject,
|
|
51
|
+
args: ['DATE_PICKER_NO_AUTO_COMPLETE_NULL']
|
|
52
|
+
}] }, { type: undefined, decorators: [{
|
|
53
|
+
type: Inject,
|
|
54
|
+
args: ['DATE_PICKER_FOCUS_INITIAL']
|
|
55
|
+
}] }, { type: undefined, decorators: [{
|
|
56
|
+
type: Inject,
|
|
57
|
+
args: ['DATE_PICKER_VALIDATOR_MESSAGE']
|
|
58
|
+
}] }, { type: undefined, decorators: [{
|
|
59
|
+
type: Inject,
|
|
60
|
+
args: ['DATE_PICKER_TOOLTIP_MESSAGE']
|
|
61
|
+
}] }, { type: undefined, decorators: [{
|
|
62
|
+
type: Inject,
|
|
63
|
+
args: ['DATE_PICKER_SUBMITTED']
|
|
64
|
+
}] }, { type: undefined, decorators: [{
|
|
65
|
+
type: Inject,
|
|
66
|
+
args: ['DATE_PICKER_VALIDATOR_ALERT']
|
|
67
|
+
}] }] });
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zdW1heC1lcnAtY29tcG9uZW50L3NyYy9saWIvZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHbkQsTUFBTSxPQUFPLGlCQUFpQjtJQUU1QixZQUM0QyxZQUFxQixJQUFJLEVBQ3ZCLGVBQXVCLEtBQUssRUFDbkIscUJBQThCLElBQUksRUFDMUMsZUFBd0IsS0FBSyxFQUN6QixtQkFBNEIsS0FBSyxFQUNuQyxpQkFBMEIsSUFBSSxFQUNwQyxZQUFxQixJQUFJLEVBQ25CLGlCQUEwQixLQUFLO1FBUHBDLGNBQVMsR0FBVCxTQUFTLENBQWdCO1FBQ3ZCLGlCQUFZLEdBQVosWUFBWSxDQUFnQjtRQUNuQix1QkFBa0IsR0FBbEIsa0JBQWtCLENBQWdCO1FBQzFDLGlCQUFZLEdBQVosWUFBWSxDQUFpQjtRQUN6QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWlCO1FBQ25DLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUNwQyxjQUFTLEdBQVQsU0FBUyxDQUFnQjtRQUNuQixtQkFBYyxHQUFkLGNBQWMsQ0FBaUI7SUFFaEYsQ0FBQztJQUVNLFlBQVk7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFDTSxlQUFlO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzQixDQUFDO0lBQ00scUJBQXFCO1FBQzFCLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDO0lBQ2pDLENBQUM7SUFDTSxlQUFlO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzQixDQUFDO0lBQ00sbUJBQW1CO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDO0lBQy9CLENBQUM7SUFDTSxpQkFBaUI7UUFDdEIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQzdCLENBQUM7SUFDTSxZQUFZO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBQ00saUJBQWlCO1FBQ3RCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUM3QixDQUFDOytHQXJDVSxpQkFBaUIsa0JBR2xCLHdCQUF3QixhQUN4QiwwQkFBMEIsYUFDMUIsbUNBQW1DLGFBQ25DLDJCQUEyQixhQUMzQiwrQkFBK0IsYUFDL0IsNkJBQTZCLGFBQzdCLHVCQUF1QixhQUN2Qiw2QkFBNkI7bUhBVjVCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFEN0IsVUFBVTs7MEJBSU4sTUFBTTsyQkFBQyx3QkFBd0I7OzBCQUMvQixNQUFNOzJCQUFDLDBCQUEwQjs7MEJBQ2pDLE1BQU07MkJBQUMsbUNBQW1DOzswQkFDMUMsTUFBTTsyQkFBQywyQkFBMkI7OzBCQUNsQyxNQUFNOzJCQUFDLCtCQUErQjs7MEJBQ3RDLE1BQU07MkJBQUMsNkJBQTZCOzswQkFDcEMsTUFBTTsyQkFBQyx1QkFBdUI7OzBCQUM5QixNQUFNOzJCQUFDLDZCQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBEYXRlUGlja2VyU2VydmljZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQEluamVjdCgnREFURV9QSUNLRVJfU0hPV19MQUJFTCcpIHByaXZhdGUgc2hvd0xhYmVsOiBib29sZWFuID0gdHJ1ZSxcclxuICAgIEBJbmplY3QoJ0RBVEVfUElDS0VSX0FVVE9DT01QTEVURScpIHByaXZhdGUgYXV0b2NvbXBsZXRlOiBzdHJpbmcgPSBcIm9mZlwiLFxyXG4gICAgQEluamVjdCgnREFURV9QSUNLRVJfTk9fQVVUT19DT01QTEVURV9OVUxMJykgcHJpdmF0ZSBub0F1dG9Db21wbGV0ZU51bGw6IGJvb2xlYW4gPSB0cnVlLFxyXG4gICAgQEluamVjdCgnREFURV9QSUNLRVJfRk9DVVNfSU5JVElBTCcpIHByaXZhdGUgZm9jdXNJbml0aWFsOiBib29sZWFuID0gZmFsc2UsXHJcbiAgICBASW5qZWN0KCdEQVRFX1BJQ0tFUl9WQUxJREFUT1JfTUVTU0FHRScpIHByaXZhdGUgdmFsaWRhdG9yTWVzc2FnZTogYm9vbGVhbiA9IGZhbHNlLFxyXG4gICAgQEluamVjdCgnREFURV9QSUNLRVJfVE9PTFRJUF9NRVNTQUdFJykgcHJpdmF0ZSB0b29sdGlwTWVzc2FnZTogYm9vbGVhbiA9IHRydWUsXHJcbiAgICBASW5qZWN0KCdEQVRFX1BJQ0tFUl9TVUJNSVRURUQnKSBwcml2YXRlIHN1Ym1pdHRlZDogYm9vbGVhbiA9IHRydWUsXHJcbiAgICBASW5qZWN0KCdEQVRFX1BJQ0tFUl9WQUxJREFUT1JfQUxFUlQnKSBwcml2YXRlIHZhbGlkYXRvckFsZXJ0OiBib29sZWFuID0gZmFsc2VcclxuICApIHtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXRTaG93TGFiZWwoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zaG93TGFiZWw7XHJcbiAgfVxyXG4gIHB1YmxpYyBnZXRBdXRvY29tcGxldGUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmF1dG9jb21wbGV0ZTtcclxuICB9XHJcbiAgcHVibGljIGdldE5vQXV0b0NvbXBsZXRlTnVsbCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLm5vQXV0b0NvbXBsZXRlTnVsbDtcclxuICB9XHJcbiAgcHVibGljIGdldEZvY3VzSW5pdGlhbCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmZvY3VzSW5pdGlhbDtcclxuICB9XHJcbiAgcHVibGljIGdldFZhbGlkYXRvck1lc3NhZ2UoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy52YWxpZGF0b3JNZXNzYWdlO1xyXG4gIH1cclxuICBwdWJsaWMgZ2V0VG9vbHRpcE1lc3NhZ2UoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy50b29sdGlwTWVzc2FnZTtcclxuICB9XHJcbiAgcHVibGljIGdldFN1Ym1pdHRlZCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLnN1Ym1pdHRlZDtcclxuICB9XHJcbiAgcHVibGljIGdldFZhbGlkYXRvckFsZXJ0KCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMudmFsaWRhdG9yQWxlcnQ7XHJcbiAgfVxyXG4gIFxyXG4gIFxyXG59Il19
|
|
@@ -0,0 +1,311 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, forwardRef, } from '@angular/core';
|
|
2
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
|
|
3
|
+
import { NgbDateParserFormatter, NgbDatepickerI18n } from '@ng-bootstrap/ng-bootstrap';
|
|
4
|
+
import { CustomDatepickerI18n, I18n } from '../date-picker/CustomDatePickerI18n';
|
|
5
|
+
import { CustomDatepickerFormat } from '../date-picker/CustomDatePickerFormat';
|
|
6
|
+
import { DateTimeModel } from '../utils/DateTimeModel';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
import * as i3 from "./date-time-picker.service";
|
|
11
|
+
import * as i4 from "@angular/forms";
|
|
12
|
+
import * as i5 from "../error-message/error-message.component";
|
|
13
|
+
import * as i6 from "../tooltip-message/tooltip-message.component";
|
|
14
|
+
import * as i7 from "@angular/material/tooltip";
|
|
15
|
+
export class DateTimePickerComponent {
|
|
16
|
+
constructor(calendar, datePipe, dateTimePickerService, _render) {
|
|
17
|
+
this.calendar = calendar;
|
|
18
|
+
this.datePipe = datePipe;
|
|
19
|
+
this.dateTimePickerService = dateTimePickerService;
|
|
20
|
+
this._render = _render;
|
|
21
|
+
/**
|
|
22
|
+
* @description Formato de la fecha:
|
|
23
|
+
* 'dd/MM/yyyy HH:mm' - 'dd/MM/yyyy HH:mm:ss' - 'M/d/yyyy H:mm:ss'
|
|
24
|
+
* @default 'dd/MM/yyyy HH:mm'
|
|
25
|
+
* @type {string}
|
|
26
|
+
*/
|
|
27
|
+
this.inputDatetimeFormat = 'dd/MM/yyyy HH:mm'; // 'M/d/yyyy H:mm:ss'
|
|
28
|
+
/**
|
|
29
|
+
* @description Texto superion
|
|
30
|
+
* @default null
|
|
31
|
+
* @type any
|
|
32
|
+
*/
|
|
33
|
+
this.label = '';
|
|
34
|
+
/**
|
|
35
|
+
* @description Parametro de la visualización del texto superior
|
|
36
|
+
* @default true
|
|
37
|
+
* @type boolean
|
|
38
|
+
*/
|
|
39
|
+
this.showLabel = true;
|
|
40
|
+
this.readonly = false;
|
|
41
|
+
/**
|
|
42
|
+
* @description Parametro de control requerido
|
|
43
|
+
* @default false
|
|
44
|
+
* @type boolean
|
|
45
|
+
*/
|
|
46
|
+
this.required = false;
|
|
47
|
+
this.validatorMessage = false;
|
|
48
|
+
this.tooltipMessage = true;
|
|
49
|
+
this.submitted = true;
|
|
50
|
+
this.labelInfo = false;
|
|
51
|
+
this.textLabelInfo = '';
|
|
52
|
+
this.openWhenFocus = false;
|
|
53
|
+
this.goNextWhenSelect = false;
|
|
54
|
+
this.onNext = new EventEmitter();
|
|
55
|
+
this.onBack = new EventEmitter();
|
|
56
|
+
this.today = this.calendar.getToday();
|
|
57
|
+
this.date = this.today;
|
|
58
|
+
this.time = {
|
|
59
|
+
hour: new Date().getHours(),
|
|
60
|
+
minute: new Date().getMinutes(),
|
|
61
|
+
second: new Date().getSeconds(),
|
|
62
|
+
};
|
|
63
|
+
this.input = new DateTimeModel(Object.assign(this.date, this.time));
|
|
64
|
+
this.isDisabled = false;
|
|
65
|
+
this._tempValue = null;
|
|
66
|
+
this._initValue = false;
|
|
67
|
+
this.onChange = (_) => { };
|
|
68
|
+
this.onValidationChange = () => { };
|
|
69
|
+
this.onTouch = () => { };
|
|
70
|
+
this.focus = () => {
|
|
71
|
+
this.btnOpen.nativeElement.focus();
|
|
72
|
+
if (!this.readonly && this.openWhenFocus) {
|
|
73
|
+
this.ngbDatepicker.open();
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
this.inputDatetimeFormat =
|
|
77
|
+
this.dateTimePickerService.getInputDatetimeFormat();
|
|
78
|
+
this.showLabel = this.dateTimePickerService.getShowLabel();
|
|
79
|
+
this.openWhenFocus = this.dateTimePickerService.getOpenWhenFocus();
|
|
80
|
+
this.goNextWhenSelect = this.dateTimePickerService.getGoNextWhenSelect();
|
|
81
|
+
this.validatorMessage = this.dateTimePickerService.getValidatorMessage();
|
|
82
|
+
this.tooltipMessage = this.dateTimePickerService.getTooltipMessage();
|
|
83
|
+
this.submitted = this.dateTimePickerService.getSubmitted();
|
|
84
|
+
}
|
|
85
|
+
ngOnChanges(changes) {
|
|
86
|
+
if (changes['submitted']) {
|
|
87
|
+
if (this.controls !== undefined && changes['submitted'].currentValue) {
|
|
88
|
+
this.controls.markAsDirty();
|
|
89
|
+
this.controls.markAsTouched();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
ngOnInit() { }
|
|
94
|
+
// onDateSelect(evt: any) {
|
|
95
|
+
//this.ngbDatepicker.close();
|
|
96
|
+
// if (this.goNextWhenSelect) {
|
|
97
|
+
// this.goNext();
|
|
98
|
+
// }
|
|
99
|
+
//console.log(evt);
|
|
100
|
+
// }
|
|
101
|
+
focusOut(event) {
|
|
102
|
+
if (event.target.ariaLabel == 'Minutes') {
|
|
103
|
+
this.ngbDatepicker.close();
|
|
104
|
+
if (this.goNextWhenSelect) {
|
|
105
|
+
this.goNext();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
onModelDateChange(evt) {
|
|
110
|
+
this.input = new DateTimeModel(Object.assign(this.date, this.time));
|
|
111
|
+
const emitValue = this.datePipe.transform(this.input, 'yyyy-MM-ddTHH:mm');
|
|
112
|
+
this.onTouch();
|
|
113
|
+
this.onChange(emitValue);
|
|
114
|
+
}
|
|
115
|
+
limpiar() {
|
|
116
|
+
this.date = null;
|
|
117
|
+
this.time = { minute: 0, hour: 0, second: 0 };
|
|
118
|
+
this.input = null;
|
|
119
|
+
this.onTouch();
|
|
120
|
+
this.onChange(null);
|
|
121
|
+
}
|
|
122
|
+
writeValue(newModel) {
|
|
123
|
+
// this.input = new DateTimeModel(Object.assign(this.date, this.time));
|
|
124
|
+
if (newModel) {
|
|
125
|
+
// this.input = Object.assign(!this.input, DateTimeModel.fromLocalString(newModel));
|
|
126
|
+
if (!this.input) {
|
|
127
|
+
this.input = DateTimeModel.fromLocalString(newModel);
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
this.input = Object.assign(this.input, DateTimeModel.fromLocalString(newModel));
|
|
131
|
+
}
|
|
132
|
+
this.date = this.input;
|
|
133
|
+
this.time = {
|
|
134
|
+
hour: this.input.hour,
|
|
135
|
+
minute: this.input.minute,
|
|
136
|
+
second: this.input.second,
|
|
137
|
+
};
|
|
138
|
+
this._tempValue = this.datePipe.transform(this.input, 'yyyy-MM-ddTHH:mm');
|
|
139
|
+
// this.onTouch();
|
|
140
|
+
if (this.controls) {
|
|
141
|
+
this._render.setProperty(this.controls, 'value', this._tempValue);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
// Agregue el limpiar para que cargue vacio si se le setea vacio o null
|
|
146
|
+
this.limpiar();
|
|
147
|
+
// this.input = new DateTimeModel();
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
registerOnChange(fn) {
|
|
151
|
+
this.onChange = fn;
|
|
152
|
+
}
|
|
153
|
+
registerOnTouched(fn) {
|
|
154
|
+
this.onTouch = fn;
|
|
155
|
+
}
|
|
156
|
+
setDisabledState(isDisabled) {
|
|
157
|
+
this.isDisabled = isDisabled;
|
|
158
|
+
}
|
|
159
|
+
validate(control) {
|
|
160
|
+
this.controls = control;
|
|
161
|
+
if (!this._initValue) {
|
|
162
|
+
if (this._tempValue) {
|
|
163
|
+
this._render.setProperty(control, 'value', this._tempValue);
|
|
164
|
+
}
|
|
165
|
+
this._initValue = true;
|
|
166
|
+
}
|
|
167
|
+
return null;
|
|
168
|
+
}
|
|
169
|
+
registerOnValidatorChange(fn) {
|
|
170
|
+
this.onValidationChange = fn;
|
|
171
|
+
}
|
|
172
|
+
open(d) {
|
|
173
|
+
if (this.input === null) {
|
|
174
|
+
this.date = this.today;
|
|
175
|
+
this.time = {
|
|
176
|
+
hour: new Date().getHours(),
|
|
177
|
+
minute: new Date().getMinutes(),
|
|
178
|
+
second: new Date().getSeconds(),
|
|
179
|
+
};
|
|
180
|
+
this.input = new DateTimeModel(Object.assign(this.date, this.time));
|
|
181
|
+
const emitValue = this.datePipe.transform(this.input, 'yyyy-MM-ddTHH:mm');
|
|
182
|
+
this.onTouch();
|
|
183
|
+
this.onChange(emitValue);
|
|
184
|
+
}
|
|
185
|
+
//abrir el datetime
|
|
186
|
+
d.open();
|
|
187
|
+
}
|
|
188
|
+
goNext() {
|
|
189
|
+
if (this.next != undefined) {
|
|
190
|
+
if (this.next.disabled || this.next.readonly) {
|
|
191
|
+
if (this.nextIsDisable != undefined) {
|
|
192
|
+
this.nextIsDisable.focus();
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
else {
|
|
196
|
+
this.next.focus();
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
if (this.nextIsDisable != undefined) {
|
|
201
|
+
this.nextIsDisable.focus();
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
this.onNext.emit();
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
goBack() {
|
|
209
|
+
if (this.back != undefined) {
|
|
210
|
+
if (this.back.disabled || this.back.readonly) {
|
|
211
|
+
if (this.backIsDisable != undefined) {
|
|
212
|
+
this.backIsDisable.focus();
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
else {
|
|
216
|
+
this.back.focus();
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
else {
|
|
220
|
+
if (this.backIsDisable != undefined) {
|
|
221
|
+
this.backIsDisable.focus();
|
|
222
|
+
}
|
|
223
|
+
else {
|
|
224
|
+
this.onBack.emit();
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: i1.NgbCalendar }, { token: i2.DatePipe }, { token: i3.DateTimePickerService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
229
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: DateTimePickerComponent, selector: "date-time-picker", inputs: { inputDatetimeFormat: "inputDatetimeFormat", label: "label", showLabel: "showLabel", readonly: "readonly", required: "required", validatorMessage: "validatorMessage", tooltipMessage: "tooltipMessage", submitted: "submitted", next: "next", nextIsDisable: "nextIsDisable", back: "back", backIsDisable: "backIsDisable", labelInfo: "labelInfo", textLabelInfo: "textLabelInfo", openWhenFocus: "openWhenFocus", goNextWhenSelect: "goNextWhenSelect" }, outputs: { onNext: "onNext", onBack: "onBack" }, providers: [
|
|
230
|
+
{
|
|
231
|
+
provide: NG_VALUE_ACCESSOR,
|
|
232
|
+
useExisting: forwardRef(() => DateTimePickerComponent),
|
|
233
|
+
multi: true,
|
|
234
|
+
},
|
|
235
|
+
{
|
|
236
|
+
provide: NG_VALIDATORS,
|
|
237
|
+
useExisting: forwardRef(() => DateTimePickerComponent),
|
|
238
|
+
multi: true,
|
|
239
|
+
},
|
|
240
|
+
I18n,
|
|
241
|
+
{ provide: NgbDatepickerI18n, useClass: CustomDatepickerI18n },
|
|
242
|
+
{ provide: NgbDateParserFormatter, useClass: CustomDatepickerFormat },
|
|
243
|
+
], viewQueries: [{ propertyName: "ngbDatepicker", first: true, predicate: ["d"], descendants: true }, { propertyName: "timePicker", first: true, predicate: ["tp"], descendants: true }, { propertyName: "btnOpen", first: true, predicate: ["btnOpen"], descendants: true }, { propertyName: "btnClean", first: true, predicate: ["btnClean"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<label\r\n *ngIf=\"label != null && label != '' && showLabel\"\r\n class=\"d-flex sumax-label mb-0 p-0\"\r\n ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis;\">{{label}}</span>\r\n\t<span *ngIf=\"required\" class=\"ms-1\"\r\n\t\t[class.text-danger]=\"controls?.errors != null\"> *</span>\r\n\t<span *ngIf=\"labelInfo\">\r\n\t\t<i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n\t</span>\r\n </label\r\n>\r\n<div\r\n [class.input-icon]=\"\r\n controls?.errors != null &&\r\n (controls?.dirty || controls?.touched) &&\r\n submitted\r\n \"\r\n class=\"position-relative\"\r\n [class.right]=\"\r\n controls?.errors != null &&\r\n (controls?.dirty || controls?.touched) &&\r\n submitted\r\n \"\r\n>\r\n <!-- tooltip-message es el icono de error -->\r\n\r\n <tooltip-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [tooltipMessage]=\"tooltipMessage\"\r\n [submitted]=\"submitted\"\r\n ></tooltip-message>\r\n <div class=\"input-group mr-2 \">\r\n <input\r\n name=\"input\"\r\n type=\"text\"\r\n class=\"form-control form-control-sm\"\r\n [disabled]=\"true\"\r\n [ngModel]=\"input | date: inputDatetimeFormat\"\r\n />\r\n <input\r\n class=\"form-control form-control-sm\"\r\n container=\"body\"\r\n [readonly]=\"true\"\r\n placeholder=\"dd/mm/yyyy\"\r\n name=\"dp\"\r\n [(ngModel)]=\"date\"\r\n (ngModelChange)=\"onModelDateChange($event)\"\r\n [autoClose]=\"'outside'\"\r\n ngbDatepicker\r\n [footerTemplate]=\"footerTemplate\"\r\n #d=\"ngbDatepicker\"\r\n />\r\n <!-- (dateSelect)=\"onDateSelect($event)\" -->\r\n <div class=\"input-group-append\">\r\n <button\r\n #btnOpen\r\n class=\"btn btn-info p-0 rounded-0 h-100\"\r\n [disabled]=\"isDisabled || readonly\"\r\n (click)=\"open(d)\"\r\n (keyup.ArrowLeft)=\"goBack()\"\r\n (keyup.ArrowRight)=\"btnClean.focus()\"\r\n type=\"button\"\r\n >\r\n <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Calendario'\" matTooltipClass=\"bg-info\">calendar_today</mat-icon> -->\r\n <i aria-hidden=\"true\" class=\"fa fa-calendar text-light px-1 \"></i>\r\n </button>\r\n <button\r\n #btnClean\r\n class=\"btn btn-danger p-0 rounded-0 limpiar h-100\"\r\n [disabled]=\"isDisabled || readonly\"\r\n (click)=\"limpiar()\"\r\n (keyup.ArrowLeft)=\"btnOpen.focus()\"\r\n (keyup.ArrowRight)=\"goNext()\"\r\n type=\"button\"\r\n >\r\n <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Limpiar'\" matTooltipClass=\"bg-danger\">close</mat-icon> -->\r\n <i aria-hidden=\"true\" class=\"fa fa-times px-1 text-light\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #footerTemplate>\r\n <hr class=\"my-0\" />\r\n <ngb-timepicker\r\n #tp\r\n [(ngModel)]=\"time\"\r\n name=\"timepicker\"\r\n (ngModelChange)=\"onModelDateChange($event)\"\r\n (focusout)=\"focusOut($event)\"\r\n >\r\n </ngb-timepicker>\r\n</ng-template>\r\n<!-- error-message es el mansaje que aparece abajo del componente -->\r\n<error-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [tooltipMessage]=\"tooltipMessage\"\r\n [submitted]=\"submitted\"\r\n></error-message>\r\n", styles: [".sumax-label{color:#646c9a!important}button[disabled]{pointer-events:none}.input-group i{color:#212529}.input-group input:nth-child(1){position:absolute;width:100%}.input-group input:nth-child(2){position:relative;visibility:hidden}.input-group .input-group-append{background-color:#fff;z-index:1;border-left:1px solid #e2e5ec}.form-control[readonly]{background-color:#f7f8fa;opacity:1}.input-icon tooltip-message{color:#ccc;position:absolute;z-index:3;font-size:16px;text-align:center;right:55px;top:50%;transform:translateY(-50%)}.input-icon.right>.form-control{padding-right:33px;padding-left:12px}.was-validated .form-control:invalid:focus,.form-control.is-invalid:focus{border-color:#dc3545;box-shadow:inset 0 1px 1px #00000013,0 0 0 3px #fde6e8!important}.was-validated .form-control:invalid,.form-control.is-invalid{background-image:none;box-shadow:inset 0 1px 1px #00000013,0 0 0 3px #fde6e8!important}.form-control:focus,.form-control:active{border-color:#007eff;box-shadow:inset 0 1px 1px #00000013,0 0 0 3px #007eff1a!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.errorMessageComponent, selector: "error-message", inputs: ["tooltipMessage", "validatorMessage", "controls", "label", "submitted"] }, { kind: "component", type: i6.tooltipMessageComponent, selector: "tooltip-message", inputs: ["tooltipMessage", "validatorMessage", "controls", "label", "submitted"] }, { kind: "directive", type: i1.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "contentTemplate", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "popperOptions", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i1.NgbTimepicker, selector: "ngb-timepicker", inputs: ["meridian", "spinners", "seconds", "hourStep", "minuteStep", "secondStep", "readonlyInputs", "size"], exportAs: ["ngbTimepicker"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
244
|
+
}
|
|
245
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DateTimePickerComponent, decorators: [{
|
|
246
|
+
type: Component,
|
|
247
|
+
args: [{ selector: 'date-time-picker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
248
|
+
{
|
|
249
|
+
provide: NG_VALUE_ACCESSOR,
|
|
250
|
+
useExisting: forwardRef(() => DateTimePickerComponent),
|
|
251
|
+
multi: true,
|
|
252
|
+
},
|
|
253
|
+
{
|
|
254
|
+
provide: NG_VALIDATORS,
|
|
255
|
+
useExisting: forwardRef(() => DateTimePickerComponent),
|
|
256
|
+
multi: true,
|
|
257
|
+
},
|
|
258
|
+
I18n,
|
|
259
|
+
{ provide: NgbDatepickerI18n, useClass: CustomDatepickerI18n },
|
|
260
|
+
{ provide: NgbDateParserFormatter, useClass: CustomDatepickerFormat },
|
|
261
|
+
], template: "<label\r\n *ngIf=\"label != null && label != '' && showLabel\"\r\n class=\"d-flex sumax-label mb-0 p-0\"\r\n ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis;\">{{label}}</span>\r\n\t<span *ngIf=\"required\" class=\"ms-1\"\r\n\t\t[class.text-danger]=\"controls?.errors != null\"> *</span>\r\n\t<span *ngIf=\"labelInfo\">\r\n\t\t<i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n\t</span>\r\n </label\r\n>\r\n<div\r\n [class.input-icon]=\"\r\n controls?.errors != null &&\r\n (controls?.dirty || controls?.touched) &&\r\n submitted\r\n \"\r\n class=\"position-relative\"\r\n [class.right]=\"\r\n controls?.errors != null &&\r\n (controls?.dirty || controls?.touched) &&\r\n submitted\r\n \"\r\n>\r\n <!-- tooltip-message es el icono de error -->\r\n\r\n <tooltip-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [tooltipMessage]=\"tooltipMessage\"\r\n [submitted]=\"submitted\"\r\n ></tooltip-message>\r\n <div class=\"input-group mr-2 \">\r\n <input\r\n name=\"input\"\r\n type=\"text\"\r\n class=\"form-control form-control-sm\"\r\n [disabled]=\"true\"\r\n [ngModel]=\"input | date: inputDatetimeFormat\"\r\n />\r\n <input\r\n class=\"form-control form-control-sm\"\r\n container=\"body\"\r\n [readonly]=\"true\"\r\n placeholder=\"dd/mm/yyyy\"\r\n name=\"dp\"\r\n [(ngModel)]=\"date\"\r\n (ngModelChange)=\"onModelDateChange($event)\"\r\n [autoClose]=\"'outside'\"\r\n ngbDatepicker\r\n [footerTemplate]=\"footerTemplate\"\r\n #d=\"ngbDatepicker\"\r\n />\r\n <!-- (dateSelect)=\"onDateSelect($event)\" -->\r\n <div class=\"input-group-append\">\r\n <button\r\n #btnOpen\r\n class=\"btn btn-info p-0 rounded-0 h-100\"\r\n [disabled]=\"isDisabled || readonly\"\r\n (click)=\"open(d)\"\r\n (keyup.ArrowLeft)=\"goBack()\"\r\n (keyup.ArrowRight)=\"btnClean.focus()\"\r\n type=\"button\"\r\n >\r\n <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Calendario'\" matTooltipClass=\"bg-info\">calendar_today</mat-icon> -->\r\n <i aria-hidden=\"true\" class=\"fa fa-calendar text-light px-1 \"></i>\r\n </button>\r\n <button\r\n #btnClean\r\n class=\"btn btn-danger p-0 rounded-0 limpiar h-100\"\r\n [disabled]=\"isDisabled || readonly\"\r\n (click)=\"limpiar()\"\r\n (keyup.ArrowLeft)=\"btnOpen.focus()\"\r\n (keyup.ArrowRight)=\"goNext()\"\r\n type=\"button\"\r\n >\r\n <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Limpiar'\" matTooltipClass=\"bg-danger\">close</mat-icon> -->\r\n <i aria-hidden=\"true\" class=\"fa fa-times px-1 text-light\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #footerTemplate>\r\n <hr class=\"my-0\" />\r\n <ngb-timepicker\r\n #tp\r\n [(ngModel)]=\"time\"\r\n name=\"timepicker\"\r\n (ngModelChange)=\"onModelDateChange($event)\"\r\n (focusout)=\"focusOut($event)\"\r\n >\r\n </ngb-timepicker>\r\n</ng-template>\r\n<!-- error-message es el mansaje que aparece abajo del componente -->\r\n<error-message\r\n [label]=\"label\"\r\n [controls]=\"controls\"\r\n [validatorMessage]=\"validatorMessage\"\r\n [tooltipMessage]=\"tooltipMessage\"\r\n [submitted]=\"submitted\"\r\n></error-message>\r\n", styles: [".sumax-label{color:#646c9a!important}button[disabled]{pointer-events:none}.input-group i{color:#212529}.input-group input:nth-child(1){position:absolute;width:100%}.input-group input:nth-child(2){position:relative;visibility:hidden}.input-group .input-group-append{background-color:#fff;z-index:1;border-left:1px solid #e2e5ec}.form-control[readonly]{background-color:#f7f8fa;opacity:1}.input-icon tooltip-message{color:#ccc;position:absolute;z-index:3;font-size:16px;text-align:center;right:55px;top:50%;transform:translateY(-50%)}.input-icon.right>.form-control{padding-right:33px;padding-left:12px}.was-validated .form-control:invalid:focus,.form-control.is-invalid:focus{border-color:#dc3545;box-shadow:inset 0 1px 1px #00000013,0 0 0 3px #fde6e8!important}.was-validated .form-control:invalid,.form-control.is-invalid{background-image:none;box-shadow:inset 0 1px 1px #00000013,0 0 0 3px #fde6e8!important}.form-control:focus,.form-control:active{border-color:#007eff;box-shadow:inset 0 1px 1px #00000013,0 0 0 3px #007eff1a!important}\n"] }]
|
|
262
|
+
}], ctorParameters: () => [{ type: i1.NgbCalendar }, { type: i2.DatePipe }, { type: i3.DateTimePickerService }, { type: i0.Renderer2 }], propDecorators: { inputDatetimeFormat: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], label: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], showLabel: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], readonly: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}], required: [{
|
|
271
|
+
type: Input
|
|
272
|
+
}], validatorMessage: [{
|
|
273
|
+
type: Input
|
|
274
|
+
}], tooltipMessage: [{
|
|
275
|
+
type: Input
|
|
276
|
+
}], submitted: [{
|
|
277
|
+
type: Input
|
|
278
|
+
}], next: [{
|
|
279
|
+
type: Input
|
|
280
|
+
}], nextIsDisable: [{
|
|
281
|
+
type: Input
|
|
282
|
+
}], back: [{
|
|
283
|
+
type: Input
|
|
284
|
+
}], backIsDisable: [{
|
|
285
|
+
type: Input
|
|
286
|
+
}], labelInfo: [{
|
|
287
|
+
type: Input
|
|
288
|
+
}], textLabelInfo: [{
|
|
289
|
+
type: Input
|
|
290
|
+
}], openWhenFocus: [{
|
|
291
|
+
type: Input
|
|
292
|
+
}], goNextWhenSelect: [{
|
|
293
|
+
type: Input
|
|
294
|
+
}], onNext: [{
|
|
295
|
+
type: Output
|
|
296
|
+
}], onBack: [{
|
|
297
|
+
type: Output
|
|
298
|
+
}], ngbDatepicker: [{
|
|
299
|
+
type: ViewChild,
|
|
300
|
+
args: ['d']
|
|
301
|
+
}], timePicker: [{
|
|
302
|
+
type: ViewChild,
|
|
303
|
+
args: ['tp']
|
|
304
|
+
}], btnOpen: [{
|
|
305
|
+
type: ViewChild,
|
|
306
|
+
args: ['btnOpen']
|
|
307
|
+
}], btnClean: [{
|
|
308
|
+
type: ViewChild,
|
|
309
|
+
args: ['btnClean']
|
|
310
|
+
}] } });
|
|
311
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sumax-erp-component/src/lib/date-time-picker/date-time-picker.component.ts","../../../../../projects/ngx-sumax-erp-component/src/lib/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  forwardRef,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NG_VALIDATORS,\r\n  NG_VALUE_ACCESSOR,\r\n  ValidationErrors,\r\n} from '@angular/forms';\r\nimport {\r\n  NgbCalendar,\r\n  NgbDateParserFormatter,\r\n  NgbDateStruct,\r\n  NgbDatepickerI18n,\r\n  NgbInputDatepicker,\r\n  NgbTimeStruct,\r\n  NgbTimepicker\r\n} from '@ng-bootstrap/ng-bootstrap';\r\nimport { DateTimePickerService } from './date-time-picker.service';\r\nimport { CustomDatepickerI18n, I18n } from '../date-picker/CustomDatePickerI18n';\r\nimport { CustomDatepickerFormat } from '../date-picker/CustomDatePickerFormat';\r\nimport { DateTimeModel } from '../utils/DateTimeModel';\r\n\r\n@Component({\r\n  selector: 'date-time-picker',\r\n  templateUrl: './date-time-picker.component.html',\r\n  styleUrls: ['./date-time-picker.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => DateTimePickerComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => DateTimePickerComponent),\r\n      multi: true,\r\n    },\r\n    I18n,\r\n    { provide: NgbDatepickerI18n, useClass: CustomDatepickerI18n },\r\n    { provide: NgbDateParserFormatter, useClass: CustomDatepickerFormat },\r\n  ],\r\n})\r\nexport class DateTimePickerComponent\r\n  implements OnInit, OnChanges, ControlValueAccessor\r\n{\r\n    /**\r\n  * @description Formato de la fecha:\r\n  * 'dd/MM/yyyy HH:mm' - 'dd/MM/yyyy HH:mm:ss' - 'M/d/yyyy H:mm:ss'\r\n  * @default 'dd/MM/yyyy HH:mm'\r\n  * @type {string}\r\n  */\r\n  @Input() inputDatetimeFormat: string = 'dd/MM/yyyy HH:mm'; // 'M/d/yyyy H:mm:ss'\r\n    /**\r\n  * @description Texto superion\r\n  * @default null\r\n  * @type any\r\n  */\r\n  @Input() label: string = '';\r\n    /**\r\n  * @description Parametro de la visualización del texto superior\r\n  * @default true\r\n  * @type boolean\r\n  */\r\n  @Input() showLabel: boolean = true;\r\n  @Input() readonly: boolean = false;\r\n    /**\r\n  * @description Parametro de control requerido\r\n  * @default false\r\n  * @type boolean\r\n  */\r\n  @Input() required: boolean = false;\r\n  @Input() validatorMessage: boolean = false;\r\n  @Input() tooltipMessage: boolean = true;\r\n  @Input() submitted: boolean = true;\r\n  /**\r\n  * @description Próximo control a hacer focus\r\n  */\r\n  @Input() next: any;\r\n  /**\r\n  * @description Próximo control a hacer focus en caso el NEXT esté deshabilitado\r\n  */\r\n  @Input() nextIsDisable: any;\r\n    /**\r\n  * @description Anterior control a hacer focus\r\n  */\r\n  @Input() back: any;\r\n    /**\r\n  * @description Anterior control a hacer focus en caso el BACK esté deshabilitado\r\n  */\r\n  @Input() backIsDisable: any;\r\n  @Input() labelInfo: boolean = false;\r\n  @Input() textLabelInfo: string = '';\r\n  @Input() openWhenFocus: boolean = false;\r\n  @Input() goNextWhenSelect: boolean = false;\r\n  @Output() onNext: EventEmitter<any> = new EventEmitter();\r\n  @Output() onBack: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('d') ngbDatepicker!: NgbInputDatepicker;\r\n  @ViewChild('tp') timePicker!: NgbTimepicker;\r\n  @ViewChild('btnOpen') btnOpen!: ElementRef;\r\n  @ViewChild('btnClean') btnClean!: ElementRef;\r\n\r\n  controls?: AbstractControl;\r\n  today = this.calendar.getToday();\r\n  date: NgbDateStruct | any = this.today;\r\n  time: NgbTimeStruct = {\r\n    hour: new Date().getHours(),\r\n    minute: new Date().getMinutes(),\r\n    second: new Date().getSeconds(),\r\n  };\r\n  input: any = new DateTimeModel(Object.assign(this.date, this.time));\r\n  isDisabled = false;\r\n\r\n  _tempValue: string | null = null;\r\n  _initValue = false;\r\n\r\n  constructor(\r\n    private calendar: NgbCalendar,\r\n    private datePipe: DatePipe,\r\n    private dateTimePickerService: DateTimePickerService,\r\n    private _render: Renderer2\r\n  ) {\r\n    this.inputDatetimeFormat =\r\n      this.dateTimePickerService.getInputDatetimeFormat();\r\n    this.showLabel = this.dateTimePickerService.getShowLabel();\r\n    this.openWhenFocus = this.dateTimePickerService.getOpenWhenFocus();\r\n    this.goNextWhenSelect = this.dateTimePickerService.getGoNextWhenSelect();\r\n    this.validatorMessage = this.dateTimePickerService.getValidatorMessage();\r\n    this.tooltipMessage = this.dateTimePickerService.getTooltipMessage();\r\n    this.submitted = this.dateTimePickerService.getSubmitted();\r\n  }\r\n\r\n  onChange = (_: any) => {};\r\n  onValidationChange = () => {};\r\n  onTouch = () => {};\r\n  focus = () => {\r\n    this.btnOpen.nativeElement.focus();\r\n    if (!this.readonly && this.openWhenFocus) {\r\n      this.ngbDatepicker.open();\r\n    }\r\n  };\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['submitted']) {\r\n      if (this.controls !== undefined && changes['submitted'].currentValue) {\r\n        this.controls.markAsDirty();\r\n        this.controls.markAsTouched();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  // onDateSelect(evt: any) {\r\n  //this.ngbDatepicker.close();\r\n  // if (this.goNextWhenSelect) {\r\n  // \tthis.goNext();\r\n  // }\r\n  //console.log(evt);\r\n  // }\r\n\r\n  focusOut(event: any): void {\r\n    if (event.target.ariaLabel == 'Minutes') {\r\n      this.ngbDatepicker.close();\r\n      if (this.goNextWhenSelect) {\r\n        this.goNext();\r\n      }\r\n    }\r\n  }\r\n\r\n  onModelDateChange(evt: NgbDateStruct | NgbTimeStruct): void {\r\n    this.input = new DateTimeModel(Object.assign(this.date, this.time));\r\n    const emitValue = this.datePipe.transform(this.input, 'yyyy-MM-ddTHH:mm');\r\n    this.onTouch();\r\n    this.onChange(emitValue);\r\n  }\r\n\r\n  limpiar(): void {\r\n    this.date = null;\r\n    this.time = { minute: 0, hour: 0, second: 0 };\r\n    this.input = null;\r\n    this.onTouch();\r\n    this.onChange(null);\r\n  }\r\n\r\n  writeValue(newModel: any): void {\r\n    // this.input = new DateTimeModel(Object.assign(this.date, this.time));\r\n    if (newModel) {\r\n      // this.input = Object.assign(!this.input, DateTimeModel.fromLocalString(newModel));\r\n      if (!this.input) {\r\n        this.input = DateTimeModel.fromLocalString(newModel);\r\n      } else {\r\n        this.input = Object.assign(\r\n          this.input,\r\n          DateTimeModel.fromLocalString(newModel)\r\n        );\r\n      }\r\n\r\n      this.date = this.input;\r\n      this.time = {\r\n        hour: this.input.hour,\r\n        minute: this.input.minute,\r\n        second: this.input.second,\r\n      };\r\n\r\n      this._tempValue = this.datePipe.transform(this.input, 'yyyy-MM-ddTHH:mm');\r\n      // this.onTouch();\r\n\r\n      if (this.controls) {\r\n        this._render.setProperty(this.controls, 'value', this._tempValue);\r\n      }\r\n    } else {\r\n      // Agregue el limpiar para que cargue vacio si se le setea vacio o null\r\n      this.limpiar();\r\n      // this.input = new DateTimeModel();\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.isDisabled = isDisabled;\r\n  }\r\n\r\n  validate(control: AbstractControl): ValidationErrors | any {\r\n    this.controls = control;\r\n\r\n    if (!this._initValue) {\r\n      if (this._tempValue) {\r\n        this._render.setProperty(control, 'value', this._tempValue);\r\n      }\r\n      this._initValue = true;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  registerOnValidatorChange?(fn: () => void): void {\r\n    this.onValidationChange = fn;\r\n  }\r\n\r\n  open(d: NgbInputDatepicker): void {\r\n    if (this.input === null) {\r\n      this.date = this.today;\r\n      this.time = {\r\n        hour: new Date().getHours(),\r\n        minute: new Date().getMinutes(),\r\n        second: new Date().getSeconds(),\r\n      };\r\n      this.input = new DateTimeModel(Object.assign(this.date, this.time));\r\n      const emitValue = this.datePipe.transform(this.input, 'yyyy-MM-ddTHH:mm');\r\n      this.onTouch();\r\n      this.onChange(emitValue);\r\n    }\r\n    //abrir el datetime\r\n    d.open();\r\n  }\r\n\r\n  goNext(): void {\r\n    if (this.next != undefined) {\r\n      if (this.next.disabled || this.next.readonly) {\r\n        if (this.nextIsDisable != undefined) {\r\n          this.nextIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.next.focus();\r\n      }\r\n    } else {\r\n      if (this.nextIsDisable != undefined) {\r\n        this.nextIsDisable.focus();\r\n      } else {\r\n        this.onNext.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n  goBack(): void {\r\n    if (this.back != undefined) {\r\n      if (this.back.disabled || this.back.readonly) {\r\n        if (this.backIsDisable != undefined) {\r\n          this.backIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.back.focus();\r\n      }\r\n    } else {\r\n      if (this.backIsDisable != undefined) {\r\n        this.backIsDisable.focus();\r\n      } else {\r\n        this.onBack.emit();\r\n      }\r\n    }\r\n  }\r\n}\r\n","<label\r\n  *ngIf=\"label != null && label != '' && showLabel\"\r\n  class=\"d-flex sumax-label mb-0 p-0\"\r\n  ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis;\">{{label}}</span>\r\n\t<span *ngIf=\"required\" class=\"ms-1\"\r\n\t\t[class.text-danger]=\"controls?.errors != null\"> *</span>\r\n\t<span *ngIf=\"labelInfo\">\r\n\t\t<i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n\t</span>\r\n  </label\r\n>\r\n<div\r\n  [class.input-icon]=\"\r\n    controls?.errors != null &&\r\n    (controls?.dirty || controls?.touched) &&\r\n    submitted\r\n  \"\r\n  class=\"position-relative\"\r\n  [class.right]=\"\r\n    controls?.errors != null &&\r\n    (controls?.dirty || controls?.touched) &&\r\n    submitted\r\n  \"\r\n>\r\n  <!-- tooltip-message es el icono de error -->\r\n\r\n  <tooltip-message\r\n    [label]=\"label\"\r\n    [controls]=\"controls\"\r\n    [validatorMessage]=\"validatorMessage\"\r\n    [tooltipMessage]=\"tooltipMessage\"\r\n    [submitted]=\"submitted\"\r\n  ></tooltip-message>\r\n  <div class=\"input-group mr-2 \">\r\n    <input\r\n      name=\"input\"\r\n      type=\"text\"\r\n      class=\"form-control form-control-sm\"\r\n      [disabled]=\"true\"\r\n      [ngModel]=\"input | date: inputDatetimeFormat\"\r\n    />\r\n    <input\r\n      class=\"form-control form-control-sm\"\r\n      container=\"body\"\r\n      [readonly]=\"true\"\r\n      placeholder=\"dd/mm/yyyy\"\r\n      name=\"dp\"\r\n      [(ngModel)]=\"date\"\r\n      (ngModelChange)=\"onModelDateChange($event)\"\r\n      [autoClose]=\"'outside'\"\r\n      ngbDatepicker\r\n      [footerTemplate]=\"footerTemplate\"\r\n      #d=\"ngbDatepicker\"\r\n    />\r\n    <!-- (dateSelect)=\"onDateSelect($event)\" -->\r\n    <div class=\"input-group-append\">\r\n      <button\r\n        #btnOpen\r\n        class=\"btn btn-info p-0 rounded-0 h-100\"\r\n        [disabled]=\"isDisabled || readonly\"\r\n        (click)=\"open(d)\"\r\n        (keyup.ArrowLeft)=\"goBack()\"\r\n        (keyup.ArrowRight)=\"btnClean.focus()\"\r\n        type=\"button\"\r\n      >\r\n        <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Calendario'\" matTooltipClass=\"bg-info\">calendar_today</mat-icon> -->\r\n        <i aria-hidden=\"true\" class=\"fa fa-calendar text-light px-1 \"></i>\r\n      </button>\r\n      <button\r\n        #btnClean\r\n        class=\"btn btn-danger p-0 rounded-0 limpiar h-100\"\r\n        [disabled]=\"isDisabled || readonly\"\r\n        (click)=\"limpiar()\"\r\n        (keyup.ArrowLeft)=\"btnOpen.focus()\"\r\n        (keyup.ArrowRight)=\"goNext()\"\r\n        type=\"button\"\r\n      >\r\n        <!-- <mat-icon class=\"text-white pt-1\" style=\"font-size: 18px;\" [matTooltip]=\"'Limpiar'\" matTooltipClass=\"bg-danger\">close</mat-icon> -->\r\n        <i aria-hidden=\"true\" class=\"fa fa-times px-1 text-light\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #footerTemplate>\r\n  <hr class=\"my-0\" />\r\n  <ngb-timepicker\r\n    #tp\r\n    [(ngModel)]=\"time\"\r\n    name=\"timepicker\"\r\n    (ngModelChange)=\"onModelDateChange($event)\"\r\n    (focusout)=\"focusOut($event)\"\r\n  >\r\n  </ngb-timepicker>\r\n</ng-template>\r\n<!-- error-message es el mansaje que aparece abajo del componente -->\r\n<error-message\r\n  [label]=\"label\"\r\n  [controls]=\"controls\"\r\n  [validatorMessage]=\"validatorMessage\"\r\n  [tooltipMessage]=\"tooltipMessage\"\r\n  [submitted]=\"submitted\"\r\n></error-message>\r\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export class DateTimePicker {
|
|
2
|
+
}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLXBpY2tlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zdW1heC1lcnAtY29tcG9uZW50L3NyYy9saWIvZGF0ZS10aW1lLXBpY2tlci9kYXRlLXRpbWUtcGlja2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxjQUFjO0NBUTFCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIERhdGVUaW1lUGlja2VyIHtcclxuICBpbnB1dERhdGV0aW1lRm9ybWF0PzpzdHJpbmc7XHJcbiAgc2hvd0xhYmVsPzpib29sZWFuO1xyXG4gIG9wZW5XaGVuRm9jdXM/OmJvb2xlYW47XHJcbiAgZ29OZXh0V2hlblNlbGVjdD86Ym9vbGVhbjtcclxuICB2YWxpZGF0b3JNZXNzYWdlPzogYm9vbGVhbjtcclxuICB0b29sdGlwTWVzc2FnZT86IGJvb2xlYW47XHJcbiAgc3VibWl0dGVkPzogYm9vbGVhbjtcclxufSJdfQ==
|