info-library 2.16.0-beta → 3.0.0-beta

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.
Files changed (79) hide show
  1. package/controls/autocomplete/autocomplete.component.d.ts +2 -1
  2. package/controls/date/date.component.d.ts +2 -1
  3. package/controls/date-month/date-month.component.d.ts +2 -1
  4. package/controls/grid/grid.component.d.ts +5 -5
  5. package/controls/input/input.component.d.ts +13 -3
  6. package/controls/multi-select/multi-select.component.d.ts +3 -1
  7. package/controls/select/select.component.d.ts +2 -1
  8. package/directives/unmask.directive.d.ts +2 -1
  9. package/esm2022/controls/alert/alert.component.mjs +8 -10
  10. package/esm2022/controls/autocomplete/autocomplete.component.mjs +33 -26
  11. package/esm2022/controls/big-checkbox/big-checkbox.component.mjs +27 -25
  12. package/esm2022/controls/card/card.component.mjs +12 -6
  13. package/esm2022/controls/card-menu/card-menu.component.mjs +14 -16
  14. package/esm2022/controls/checkbox/checkbox.component.mjs +13 -13
  15. package/esm2022/controls/chips/chips.component.mjs +12 -11
  16. package/esm2022/controls/date/date.component.mjs +64 -32
  17. package/esm2022/controls/date-month/date-month.component.mjs +64 -31
  18. package/esm2022/controls/editor/editor.component.mjs +35 -31
  19. package/esm2022/controls/grid/grid.component.mjs +529 -511
  20. package/esm2022/controls/input/input.component.mjs +146 -71
  21. package/esm2022/controls/input-list/input-list.component.mjs +16 -15
  22. package/esm2022/controls/list-checkbox/list-checkbox.component.mjs +16 -12
  23. package/esm2022/controls/message/message.component.mjs +9 -11
  24. package/esm2022/controls/multi-select/multi-select.component.mjs +35 -22
  25. package/esm2022/controls/paginator/paginator.component.mjs +15 -16
  26. package/esm2022/controls/select/select.component.mjs +32 -23
  27. package/esm2022/controls/timeline/timeline.component.mjs +15 -16
  28. package/esm2022/directives/mask.directive.mjs +17 -8
  29. package/esm2022/directives/unmask.directive.mjs +14 -7
  30. package/esm2022/info-library.module.mjs +10 -5
  31. package/esm2022/layouts/dialog/dialog.component.mjs +10 -6
  32. package/esm2022/layouts/filter/filter.component.mjs +179 -0
  33. package/esm2022/layouts/loading/loading.component.mjs +7 -9
  34. package/esm2022/layouts/main/main.component.mjs +101 -54
  35. package/esm2022/layouts/modal/modal.component.mjs +37 -22
  36. package/esm2022/layouts/pagebar/pagebar.component.mjs +125 -97
  37. package/esm2022/layouts/sidebar/sidebar.component.mjs +152 -100
  38. package/esm2022/layouts/topbar/topbar.component.mjs +417 -253
  39. package/esm2022/layouts/topmenu/topmenu.component.mjs +20 -12
  40. package/esm2022/model/app-config.model.mjs +12 -12
  41. package/esm2022/model/data-access.model.mjs +10 -8
  42. package/esm2022/model/dialog-result.model.mjs +3 -2
  43. package/esm2022/model/dialog.model.mjs +13 -14
  44. package/esm2022/model/form-prop.model.mjs +8 -6
  45. package/esm2022/model/grid-button.model.mjs +12 -7
  46. package/esm2022/model/last-search.model.mjs +5 -7
  47. package/esm2022/model/login.model.mjs +4 -2
  48. package/esm2022/model/method-grid-button.model.mjs +4 -2
  49. package/esm2022/model/notification.model.mjs +9 -5
  50. package/esm2022/model/pagebar-buttons.model.mjs +6 -6
  51. package/esm2022/model/permission.model.mjs +4 -1
  52. package/esm2022/model/platform.model.mjs +13 -14
  53. package/esm2022/model/session.model.mjs +25 -6
  54. package/esm2022/pipe/mask.pipe.mjs +10 -6
  55. package/esm2022/pipe/translate.pipe.mjs +4 -3
  56. package/esm2022/public_api.mjs +2 -1
  57. package/esm2022/service/authentication.service.mjs +89 -36
  58. package/esm2022/service/configuration.service.mjs +41 -10
  59. package/esm2022/service/data.service.mjs +38 -21
  60. package/esm2022/service/theme.service.mjs +16 -6
  61. package/esm2022/service/translate.service.mjs +9 -5
  62. package/esm2022/utils/utilities.mjs +52 -5
  63. package/fesm2022/info-library.mjs +2551 -1649
  64. package/fesm2022/info-library.mjs.map +1 -1
  65. package/info-library-3.0.0-beta.tgz +0 -0
  66. package/info-library.module.d.ts +32 -31
  67. package/layouts/filter/filter.component.d.ts +24 -0
  68. package/layouts/main/main.component.d.ts +4 -0
  69. package/layouts/modal/modal.component.d.ts +1 -0
  70. package/layouts/sidebar/sidebar.component.d.ts +1 -1
  71. package/layouts/topbar/topbar.component.d.ts +4 -1
  72. package/model/app-config.model.d.ts +2 -0
  73. package/model/session.model.d.ts +5 -0
  74. package/package.json +1 -1
  75. package/public_api.d.ts +1 -0
  76. package/service/authentication.service.d.ts +4 -2
  77. package/service/configuration.service.d.ts +4 -1
  78. package/service/data.service.d.ts +2 -0
  79. package/utils/utilities.d.ts +11 -0
@@ -6,12 +6,45 @@ import { createTextMaskInputElement } from "text-mask-core/dist/textMaskCore";
6
6
  import { createAutoCorrectedDatePipe } from "text-mask-addons";
7
7
  import moment from "moment";
8
8
  import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/forms";
10
- import * as i2 from "@angular/material/form-field";
11
- import * as i3 from "@angular/material/input";
12
- import * as i4 from "@angular/material/datepicker";
13
- import * as i5 from "../../pipe/translate.pipe";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "@angular/forms";
11
+ import * as i3 from "@angular/material/form-field";
12
+ import * as i4 from "@angular/material/input";
13
+ import * as i5 from "@angular/material/datepicker";
14
+ import * as i6 from "../../pipe/translate.pipe";
14
15
  const _c0 = ["inputDate"];
16
+ function InfoDateComponent_mat_form_field_0_Template(rf, ctx) { if (rf & 1) {
17
+ const _r5 = i0.ɵɵgetCurrentView();
18
+ i0.ɵɵelementStart(0, "mat-form-field")(1, "input", 1, 2);
19
+ i0.ɵɵlistener("ngModelChange", function InfoDateComponent_mat_form_field_0_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.dateValue = $event); })("dateChange", function InfoDateComponent_mat_form_field_0_Template_input_dateChange_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.onChangeValue()); })("input", function InfoDateComponent_mat_form_field_0_Template_input_input_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.onInputDate($event.target.value)); })("keypress", function InfoDateComponent_mat_form_field_0_Template_input_keypress_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onKeyPress($event)); })("blur", function InfoDateComponent_mat_form_field_0_Template_input_blur_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.onChangeValue()); });
20
+ i0.ɵɵpipe(3, "translate");
21
+ i0.ɵɵelementEnd();
22
+ i0.ɵɵelement(4, "mat-datepicker-toggle", 3)(5, "mat-datepicker", 4, 5);
23
+ i0.ɵɵelementEnd();
24
+ } if (rf & 2) {
25
+ const _r3 = i0.ɵɵreference(6);
26
+ const ctx_r0 = i0.ɵɵnextContext();
27
+ i0.ɵɵadvance(1);
28
+ i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(3, 10, ctx_r0.placeholder))("ngModel", ctx_r0.dateValue)("disabled", ctx_r0.disabled)("required", ctx_r0.required)("min", ctx_r0.minDate)("max", ctx_r0.maxDate)("matDatepicker", _r3)("matDatepickerFilter", ctx_r0.datefilter);
29
+ i0.ɵɵadvance(3);
30
+ i0.ɵɵproperty("for", _r3);
31
+ i0.ɵɵadvance(1);
32
+ i0.ɵɵproperty("dateClass", ctx_r0.dateclass);
33
+ } }
34
+ function InfoDateComponent_ng_container_1_Template(rf, ctx) { if (rf & 1) {
35
+ const _r13 = i0.ɵɵgetCurrentView();
36
+ i0.ɵɵelementContainerStart(0);
37
+ i0.ɵɵelementStart(1, "input", 6, 2);
38
+ i0.ɵɵlistener("click", function InfoDateComponent_ng_container_1_Template_input_click_1_listener() { i0.ɵɵrestoreView(_r13); const _r11 = i0.ɵɵreference(4); return i0.ɵɵresetView(_r11.open()); })("ngModelChange", function InfoDateComponent_ng_container_1_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r14 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r14.dateValue = $event); })("dateChange", function InfoDateComponent_ng_container_1_Template_input_dateChange_1_listener() { i0.ɵɵrestoreView(_r13); const ctx_r15 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r15.onChangeValue()); });
39
+ i0.ɵɵelementEnd();
40
+ i0.ɵɵelement(3, "mat-datepicker", null, 5);
41
+ i0.ɵɵelementContainerEnd();
42
+ } if (rf & 2) {
43
+ const _r11 = i0.ɵɵreference(4);
44
+ const ctx_r1 = i0.ɵɵnextContext();
45
+ i0.ɵɵadvance(1);
46
+ i0.ɵɵproperty("ngModel", ctx_r1.dateValue)("disabled", ctx_r1.disabled)("required", ctx_r1.required)("min", ctx_r1.minDate)("max", ctx_r1.maxDate)("matDatepicker", _r11)("matDatepickerFilter", ctx_r1.datefilter);
47
+ } }
15
48
  export const PT_BR_DATE_FORMATS = {
16
49
  parse: {
17
50
  dateInput: 'DD/MM/YYYY',
@@ -24,14 +57,19 @@ export const PT_BR_DATE_FORMATS = {
24
57
  },
25
58
  };
26
59
  export class InfoDateComponent {
27
- constructor() {
28
- this.disabled = false;
29
- this.required = false;
30
- this.minDate = new Date(1800, 0, 1);
31
- this.maxDate = null;
32
- this.datefilter = null; //Metodo que recebe uma data(moment) e retorna boolean
33
- this.dateclass = null; //Metodo que recebe uma data(moment) e retorna string
34
- }
60
+ placeholder;
61
+ disabled = false;
62
+ required = false;
63
+ minDate = new Date(1800, 0, 1);
64
+ maxDate = null;
65
+ button = false;
66
+ datefilter = null; //Metodo que recebe uma data(moment) e retorna boolean
67
+ dateclass = null; //Metodo que recebe uma data(moment) e retorna string
68
+ input;
69
+ dateValue;
70
+ dateMask;
71
+ onChange;
72
+ onTouched;
35
73
  ngAfterViewInit() {
36
74
  let config = {
37
75
  mask: [/\d/, /\d/, '/', /\d/, /\d/, '/', /\d/, /\d/, /\d/, /\d/],
@@ -78,13 +116,13 @@ export class InfoDateComponent {
78
116
  if (e.keyCode == 13)
79
117
  this.onChangeValue();
80
118
  }
81
- /** @nocollapse */ static { this.ɵfac = function InfoDateComponent_Factory(t) { return new (t || InfoDateComponent)(); }; }
82
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoDateComponent, selectors: [["info-date"]], viewQuery: function InfoDateComponent_Query(rf, ctx) { if (rf & 1) {
119
+ /** @nocollapse */ static ɵfac = function InfoDateComponent_Factory(t) { return new (t || InfoDateComponent)(); };
120
+ /** @nocollapse */ static ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoDateComponent, selectors: [["info-date"]], viewQuery: function InfoDateComponent_Query(rf, ctx) { if (rf & 1) {
83
121
  i0.ɵɵviewQuery(_c0, 5);
84
122
  } if (rf & 2) {
85
123
  let _t;
86
124
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.input = _t.first);
87
- } }, inputs: { placeholder: "placeholder", disabled: "disabled", required: "required", minDate: "minDate", maxDate: "maxDate", datefilter: "datefilter", dateclass: "dateclass" }, features: [i0.ɵɵProvidersFeature([{
125
+ } }, inputs: { placeholder: "placeholder", disabled: "disabled", required: "required", minDate: "minDate", maxDate: "maxDate", button: "button", datefilter: "datefilter", dateclass: "dateclass" }, features: [i0.ɵɵProvidersFeature([{
88
126
  provide: NG_VALUE_ACCESSOR,
89
127
  useExisting: forwardRef((() => InfoDateComponent)),
90
128
  multi: true
@@ -92,22 +130,14 @@ export class InfoDateComponent {
92
130
  { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },
93
131
  { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },
94
132
  { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_FORMATS },
95
- { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }])], decls: 7, vars: 12, consts: [["matInput", "", 3, "placeholder", "ngModel", "disabled", "required", "min", "max", "matDatepicker", "matDatepickerFilter", "ngModelChange", "dateChange", "input", "keypress", "blur"], ["inputDate", ""], ["matSuffix", "", 3, "for"], [3, "dateClass"], ["datepicker", ""]], template: function InfoDateComponent_Template(rf, ctx) { if (rf & 1) {
96
- i0.ɵɵelementStart(0, "mat-form-field")(1, "input", 0, 1);
97
- i0.ɵɵlistener("ngModelChange", function InfoDateComponent_Template_input_ngModelChange_1_listener($event) { return ctx.dateValue = $event; })("dateChange", function InfoDateComponent_Template_input_dateChange_1_listener() { return ctx.onChangeValue(); })("input", function InfoDateComponent_Template_input_input_1_listener($event) { return ctx.onInputDate($event.target.value); })("keypress", function InfoDateComponent_Template_input_keypress_1_listener($event) { return ctx.onKeyPress($event); })("blur", function InfoDateComponent_Template_input_blur_1_listener() { return ctx.onChangeValue(); });
98
- i0.ɵɵpipe(3, "translate");
99
- i0.ɵɵelementEnd();
100
- i0.ɵɵelement(4, "mat-datepicker-toggle", 2)(5, "mat-datepicker", 3, 4);
101
- i0.ɵɵelementEnd();
133
+ { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }])], decls: 2, vars: 2, consts: [[4, "ngIf"], ["matInput", "", 3, "placeholder", "ngModel", "disabled", "required", "min", "max", "matDatepicker", "matDatepickerFilter", "ngModelChange", "dateChange", "input", "keypress", "blur"], ["inputDate", ""], ["matSuffix", "", 3, "for"], [3, "dateClass"], ["datepicker", ""], ["type", "button", 1, "mat-button", 3, "ngModel", "disabled", "required", "min", "max", "matDatepicker", "matDatepickerFilter", "click", "ngModelChange", "dateChange"]], template: function InfoDateComponent_Template(rf, ctx) { if (rf & 1) {
134
+ i0.ɵɵtemplate(0, InfoDateComponent_mat_form_field_0_Template, 7, 12, "mat-form-field", 0);
135
+ i0.ɵɵtemplate(1, InfoDateComponent_ng_container_1_Template, 5, 7, "ng-container", 0);
102
136
  } if (rf & 2) {
103
- const _r1 = i0.ɵɵreference(6);
104
- i0.ɵɵadvance(1);
105
- i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(3, 10, ctx.placeholder))("ngModel", ctx.dateValue)("disabled", ctx.disabled)("required", ctx.required)("min", ctx.minDate)("max", ctx.maxDate)("matDatepicker", _r1)("matDatepickerFilter", ctx.datefilter);
106
- i0.ɵɵadvance(3);
107
- i0.ɵɵproperty("for", _r1);
137
+ i0.ɵɵproperty("ngIf", !ctx.button);
108
138
  i0.ɵɵadvance(1);
109
- i0.ɵɵproperty("dateClass", ctx.dateclass);
110
- } }, dependencies: [i1.DefaultValueAccessor, i1.NgControlStatus, i1.RequiredValidator, i1.NgModel, i2.MatFormField, i2.MatSuffix, i3.MatInput, i4.MatDatepicker, i4.MatDatepickerInput, i4.MatDatepickerToggle, i5.InfoTranslatePipe], encapsulation: 2 }); }
139
+ i0.ɵɵproperty("ngIf", ctx.button);
140
+ } }, dependencies: [i1.NgIf, i2.DefaultValueAccessor, i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, i3.MatFormField, i3.MatSuffix, i4.MatInput, i5.MatDatepicker, i5.MatDatepickerInput, i5.MatDatepickerToggle, i6.InfoTranslatePipe], encapsulation: 2 });
111
141
  }
112
142
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoDateComponent, [{
113
143
  type: Component,
@@ -119,7 +149,7 @@ export class InfoDateComponent {
119
149
  { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },
120
150
  { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },
121
151
  { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_FORMATS },
122
- { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }], template: "<mat-form-field>\r\n <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\" [max]=\"maxDate\"\r\n (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"datefilter\" #inputDate >\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker [dateClass]=\"dateclass\" #datepicker></mat-datepicker>\r\n</mat-form-field>" }]
152
+ { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }], template: "<mat-form-field *ngIf=\"!button\">\r\n <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\" [max]=\"maxDate\"\r\n (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"datefilter\" #inputDate>\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker [dateClass]=\"dateclass\" #datepicker></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-container *ngIf=\"button\">\r\n <input class=\"mat-button\" type=\"button\" (click)=\"datepicker.open()\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\" [max]=\"maxDate\"\r\n (dateChange)=\"onChangeValue()\" [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"datefilter\" #inputDate>\r\n\r\n <mat-datepicker #datepicker></mat-datepicker>\r\n</ng-container>" }]
123
153
  }], null, { placeholder: [{
124
154
  type: Input
125
155
  }], disabled: [{
@@ -130,6 +160,8 @@ export class InfoDateComponent {
130
160
  type: Input
131
161
  }], maxDate: [{
132
162
  type: Input
163
+ }], button: [{
164
+ type: Input
133
165
  }], datefilter: [{
134
166
  type: Input
135
167
  }], dateclass: [{
@@ -138,4 +170,4 @@ export class InfoDateComponent {
138
170
  type: ViewChild,
139
171
  args: ['inputDate', { static: false }]
140
172
  }] }); })();
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/date/date.component.ts","../../../../../projects/info-library/src/controls/date/date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, ViewChild } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\r\nimport { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS } from \"@angular/material-moment-adapter\";\r\nimport { createTextMaskInputElement } from \"text-mask-core/dist/textMaskCore\";\r\nimport { createAutoCorrectedDatePipe } from \"text-mask-addons\";\r\nimport moment from \"moment\";\r\n\r\nexport const PT_BR_DATE_FORMATS = {\r\n    parse: {\r\n        dateInput: 'DD/MM/YYYY',\r\n    },\r\n    display: {\r\n        dateInput: 'DD/MM/YYYY',\r\n        monthYearLabel: 'MMM Y',\r\n        dateA11yLabel: 'LL',\r\n        monthYearA11yLabel: 'MMMM Y',\r\n    },\r\n};\r\n\r\n@Component({\r\n    selector: 'info-date',\r\n    templateUrl: './date.component.html',\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoDateComponent),\r\n        multi: true\r\n    },\r\n    { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },\r\n    { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },\r\n    { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_FORMATS },\r\n    { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }]\r\n})\r\nexport class InfoDateComponent implements ControlValueAccessor {\r\n\r\n    @Input() placeholder: string;\r\n    @Input() disabled: boolean = false;\r\n    @Input() required: boolean = false;\r\n    @Input() minDate: Date = new Date(1800, 0, 1);\r\n    @Input() maxDate: Date = null;\r\n\r\n    @Input() datefilter: any = null; //Metodo que recebe uma data(moment) e retorna boolean\r\n    @Input() dateclass: any = null; //Metodo que recebe uma data(moment) e retorna string\r\n\r\n    @ViewChild('inputDate', { static: false }) input;\r\n\r\n    dateValue: any;\r\n    dateMask: any;\r\n    onChange;\r\n    onTouched;\r\n\r\n    ngAfterViewInit() {\r\n\r\n        let config = {\r\n            mask: [/\\d/, /\\d/, '/', /\\d/, /\\d/, '/', /\\d/, /\\d/, /\\d/, /\\d/],\r\n            guide: true,\r\n            placeholderChar: '_',\r\n            pipe: createAutoCorrectedDatePipe(PT_BR_DATE_FORMATS.parse.dateInput.toLowerCase()),\r\n            modelClean: true,\r\n            keepCharPositions: false,\r\n        };\r\n\r\n        this.dateMask = createTextMaskInputElement(\r\n            Object.assign({ inputElement: this.input.nativeElement }, config)\r\n        );\r\n    }\r\n\r\n    onInputDate(value) {\r\n        this.dateMask.update(value);\r\n    }\r\n\r\n    onChangeValue() {\r\n        if (this.dateValue != null) {\r\n            if (moment(this.dateValue).isBefore(moment(this.minDate)))\r\n               this.dateValue = this.minDate;\r\n                \r\n            if (this.maxDate != null && moment(this.dateValue).isAfter(moment(this.maxDate)))\r\n                this.dateValue = this.maxDate;\r\n        }\r\n\r\n        if (this.onChange != null)\r\n            this.onChange(this.dateValue);\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (value != null) {\r\n            value = new Date(value);\r\n            value.setMinutes(value.getMinutes() + value.getTimezoneOffset());\r\n            value = new Date(value.getFullYear(), value.getMonth(), value.getDate());\r\n        }\r\n\r\n        this.dateValue = value;\r\n        this.onChangeValue();\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.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    onKeyPress(e){\r\n        if (e.keyCode == 13)\r\n            this.onChangeValue();\r\n    }\r\n}","<mat-form-field>\r\n    <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\" [max]=\"maxDate\"\r\n           (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\"\r\n           [matDatepickerFilter]=\"datefilter\" #inputDate >\r\n\r\n    <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n    <mat-datepicker [dateClass]=\"dateclass\" #datepicker></mat-datepicker>\r\n</mat-form-field>"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/date/date.component.ts","../../../../../projects/info-library/src/controls/date/date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, ViewChild } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\r\nimport { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS } from \"@angular/material-moment-adapter\";\r\nimport { createTextMaskInputElement } from \"text-mask-core/dist/textMaskCore\";\r\nimport { createAutoCorrectedDatePipe } from \"text-mask-addons\";\r\nimport moment from \"moment\";\r\n\r\nexport const PT_BR_DATE_FORMATS = {\r\n    parse: {\r\n        dateInput: 'DD/MM/YYYY',\r\n    },\r\n    display: {\r\n        dateInput: 'DD/MM/YYYY',\r\n        monthYearLabel: 'MMM Y',\r\n        dateA11yLabel: 'LL',\r\n        monthYearA11yLabel: 'MMMM Y',\r\n    },\r\n};\r\n\r\n@Component({\r\n    selector: 'info-date',\r\n    templateUrl: './date.component.html',\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoDateComponent),\r\n        multi: true\r\n    },\r\n    { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },\r\n    { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },\r\n    { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_FORMATS },\r\n    { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }]\r\n})\r\nexport class InfoDateComponent implements ControlValueAccessor {\r\n\r\n    @Input() placeholder: string;\r\n    @Input() disabled: boolean = false;\r\n    @Input() required: boolean = false;\r\n    @Input() minDate: Date = new Date(1800, 0, 1);\r\n    @Input() maxDate: Date = null;\r\n    @Input() button: boolean = false;\r\n\r\n    @Input() datefilter: any = null; //Metodo que recebe uma data(moment) e retorna boolean\r\n    @Input() dateclass: any = null; //Metodo que recebe uma data(moment) e retorna string\r\n\r\n    @ViewChild('inputDate', { static: false }) input;\r\n\r\n    dateValue: any;\r\n    dateMask: any;\r\n    onChange;\r\n    onTouched;\r\n\r\n    ngAfterViewInit() {\r\n\r\n        let config = {\r\n            mask: [/\\d/, /\\d/, '/', /\\d/, /\\d/, '/', /\\d/, /\\d/, /\\d/, /\\d/],\r\n            guide: true,\r\n            placeholderChar: '_',\r\n            pipe: createAutoCorrectedDatePipe(PT_BR_DATE_FORMATS.parse.dateInput.toLowerCase()),\r\n            modelClean: true,\r\n            keepCharPositions: false,\r\n        };\r\n\r\n        this.dateMask = createTextMaskInputElement(\r\n            Object.assign({ inputElement: this.input.nativeElement }, config)\r\n        );\r\n    }\r\n\r\n    onInputDate(value) {\r\n        this.dateMask.update(value);\r\n    }\r\n\r\n    onChangeValue() {\r\n        if (this.dateValue != null) {\r\n            if (moment(this.dateValue).isBefore(moment(this.minDate)))\r\n               this.dateValue = this.minDate;\r\n                \r\n            if (this.maxDate != null && moment(this.dateValue).isAfter(moment(this.maxDate)))\r\n                this.dateValue = this.maxDate;\r\n        }\r\n\r\n        if (this.onChange != null)\r\n            this.onChange(this.dateValue);\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (value != null) {\r\n            value = new Date(value);\r\n            value.setMinutes(value.getMinutes() + value.getTimezoneOffset());\r\n            value = new Date(value.getFullYear(), value.getMonth(), value.getDate());\r\n        }\r\n\r\n        this.dateValue = value;\r\n        this.onChangeValue();\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.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    onKeyPress(e){\r\n        if (e.keyCode == 13)\r\n            this.onChangeValue();\r\n    }\r\n}","<mat-form-field *ngIf=\"!button\">\r\n    <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\" [max]=\"maxDate\"\r\n           (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\"\r\n           [matDatepickerFilter]=\"datefilter\" #inputDate>\r\n\r\n    <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n    <mat-datepicker [dateClass]=\"dateclass\" #datepicker></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-container *ngIf=\"button\">\r\n    <input class=\"mat-button\" type=\"button\" (click)=\"datepicker.open()\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\" [max]=\"maxDate\"\r\n           (dateChange)=\"onChangeValue()\" [matDatepicker]=\"datepicker\"\r\n           [matDatepickerFilter]=\"datefilter\" #inputDate>\r\n\r\n    <mat-datepicker #datepicker></mat-datepicker>\r\n</ng-container>"]}
@@ -6,12 +6,47 @@ import { createTextMaskInputElement } from "text-mask-core/dist/textMaskCore";
6
6
  import { createAutoCorrectedDatePipe } from "text-mask-addons";
7
7
  import moment from "moment";
8
8
  import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/forms";
10
- import * as i2 from "@angular/material/form-field";
11
- import * as i3 from "@angular/material/input";
12
- import * as i4 from "@angular/material/datepicker";
13
- import * as i5 from "../../pipe/translate.pipe";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "@angular/forms";
11
+ import * as i3 from "@angular/material/form-field";
12
+ import * as i4 from "@angular/material/input";
13
+ import * as i5 from "@angular/material/datepicker";
14
+ import * as i6 from "../../pipe/translate.pipe";
14
15
  const _c0 = ["inputDate"];
16
+ function InfoDateMonthComponent_mat_form_field_0_Template(rf, ctx) { if (rf & 1) {
17
+ const _r5 = i0.ɵɵgetCurrentView();
18
+ i0.ɵɵelementStart(0, "mat-form-field")(1, "input", 1, 2);
19
+ i0.ɵɵlistener("ngModelChange", function InfoDateMonthComponent_mat_form_field_0_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.dateValue = $event); })("dateChange", function InfoDateMonthComponent_mat_form_field_0_Template_input_dateChange_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.onChangeValue()); })("input", function InfoDateMonthComponent_mat_form_field_0_Template_input_input_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.onInputDate($event.target.value)); })("keypress", function InfoDateMonthComponent_mat_form_field_0_Template_input_keypress_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onKeyPress($event)); })("blur", function InfoDateMonthComponent_mat_form_field_0_Template_input_blur_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.onChangeValue()); });
20
+ i0.ɵɵpipe(3, "translate");
21
+ i0.ɵɵelementEnd();
22
+ i0.ɵɵelement(4, "mat-datepicker-toggle", 3);
23
+ i0.ɵɵelementStart(5, "mat-datepicker", 4, 5);
24
+ i0.ɵɵlistener("yearSelected", function InfoDateMonthComponent_mat_form_field_0_Template_mat_datepicker_yearSelected_5_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.chosenYearHandler($event)); })("monthSelected", function InfoDateMonthComponent_mat_form_field_0_Template_mat_datepicker_monthSelected_5_listener($event) { i0.ɵɵrestoreView(_r5); const _r3 = i0.ɵɵreference(6); const ctx_r11 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r11.chosenMonthHandler($event, _r3)); });
25
+ i0.ɵɵelementEnd()();
26
+ } if (rf & 2) {
27
+ const _r3 = i0.ɵɵreference(6);
28
+ const ctx_r0 = i0.ɵɵnextContext();
29
+ i0.ɵɵadvance(1);
30
+ i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(3, 7, ctx_r0.placeholder))("ngModel", ctx_r0.dateValue)("disabled", ctx_r0.disabled)("required", ctx_r0.required)("min", ctx_r0.minDate)("matDatepicker", _r3);
31
+ i0.ɵɵadvance(3);
32
+ i0.ɵɵproperty("for", _r3);
33
+ } }
34
+ function InfoDateMonthComponent_ng_container_1_Template(rf, ctx) { if (rf & 1) {
35
+ const _r15 = i0.ɵɵgetCurrentView();
36
+ i0.ɵɵelementContainerStart(0);
37
+ i0.ɵɵelementStart(1, "input", 6, 2);
38
+ i0.ɵɵlistener("click", function InfoDateMonthComponent_ng_container_1_Template_input_click_1_listener() { i0.ɵɵrestoreView(_r15); const _r13 = i0.ɵɵreference(4); return i0.ɵɵresetView(_r13.open()); })("ngModelChange", function InfoDateMonthComponent_ng_container_1_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r16 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r16.dateValue = $event); })("dateChange", function InfoDateMonthComponent_ng_container_1_Template_input_dateChange_1_listener() { i0.ɵɵrestoreView(_r15); const ctx_r17 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r17.onChangeValue()); })("input", function InfoDateMonthComponent_ng_container_1_Template_input_input_1_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r18 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r18.onInputDate($event.target.value)); });
39
+ i0.ɵɵelementEnd();
40
+ i0.ɵɵelementStart(3, "mat-datepicker", 4, 5);
41
+ i0.ɵɵlistener("yearSelected", function InfoDateMonthComponent_ng_container_1_Template_mat_datepicker_yearSelected_3_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r19 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r19.chosenYearHandler($event)); })("monthSelected", function InfoDateMonthComponent_ng_container_1_Template_mat_datepicker_monthSelected_3_listener($event) { i0.ɵɵrestoreView(_r15); const _r13 = i0.ɵɵreference(4); const ctx_r20 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r20.chosenMonthHandler($event, _r13)); });
42
+ i0.ɵɵelementEnd();
43
+ i0.ɵɵelementContainerEnd();
44
+ } if (rf & 2) {
45
+ const _r13 = i0.ɵɵreference(4);
46
+ const ctx_r1 = i0.ɵɵnextContext();
47
+ i0.ɵɵadvance(1);
48
+ i0.ɵɵproperty("ngModel", ctx_r1.dateValue)("disabled", ctx_r1.disabled)("required", ctx_r1.required)("min", ctx_r1.minDate)("matDatepicker", _r13);
49
+ } }
15
50
  export const PT_BR_DATE_MONTH_FORMATS = {
16
51
  parse: {
17
52
  dateInput: 'MM/YYYY',
@@ -24,12 +59,17 @@ export const PT_BR_DATE_MONTH_FORMATS = {
24
59
  },
25
60
  };
26
61
  export class InfoDateMonthComponent {
27
- constructor() {
28
- this.disabled = false;
29
- this.required = false;
30
- this.changeonlyonmonth = false;
31
- this.minDate = new Date(1800, 0, 1);
32
- }
62
+ placeholder;
63
+ disabled = false;
64
+ required = false;
65
+ changeonlyonmonth = false;
66
+ minDate = new Date(1800, 0, 1);
67
+ button = false;
68
+ input;
69
+ dateValue;
70
+ dateMask;
71
+ onChange;
72
+ onTouched;
33
73
  ngAfterViewInit() {
34
74
  let config = {
35
75
  mask: [/\d/, /\d/, '/', /\d/, /\d/, /\d/, /\d/],
@@ -88,13 +128,13 @@ export class InfoDateMonthComponent {
88
128
  if (e.keyCode == 13)
89
129
  this.onChangeValue();
90
130
  }
91
- /** @nocollapse */ static { this.ɵfac = function InfoDateMonthComponent_Factory(t) { return new (t || InfoDateMonthComponent)(); }; }
92
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoDateMonthComponent, selectors: [["info-date-month"]], viewQuery: function InfoDateMonthComponent_Query(rf, ctx) { if (rf & 1) {
131
+ /** @nocollapse */ static ɵfac = function InfoDateMonthComponent_Factory(t) { return new (t || InfoDateMonthComponent)(); };
132
+ /** @nocollapse */ static ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoDateMonthComponent, selectors: [["info-date-month"]], viewQuery: function InfoDateMonthComponent_Query(rf, ctx) { if (rf & 1) {
93
133
  i0.ɵɵviewQuery(_c0, 5);
94
134
  } if (rf & 2) {
95
135
  let _t;
96
136
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.input = _t.first);
97
- } }, inputs: { placeholder: "placeholder", disabled: "disabled", required: "required", changeonlyonmonth: "changeonlyonmonth", minDate: "minDate" }, features: [i0.ɵɵProvidersFeature([{
137
+ } }, inputs: { placeholder: "placeholder", disabled: "disabled", required: "required", changeonlyonmonth: "changeonlyonmonth", minDate: "minDate", button: "button" }, features: [i0.ɵɵProvidersFeature([{
98
138
  provide: NG_VALUE_ACCESSOR,
99
139
  useExisting: forwardRef((() => InfoDateMonthComponent)),
100
140
  multi: true
@@ -102,23 +142,14 @@ export class InfoDateMonthComponent {
102
142
  { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },
103
143
  { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },
104
144
  { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_MONTH_FORMATS },
105
- { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }])], decls: 7, vars: 9, consts: [["matInput", "", 3, "placeholder", "ngModel", "disabled", "required", "min", "matDatepicker", "ngModelChange", "dateChange", "input", "keypress", "blur"], ["inputDate", ""], ["matSuffix", "", 3, "for"], ["startView", "multi-year", 3, "yearSelected", "monthSelected"], ["datepicker", ""]], template: function InfoDateMonthComponent_Template(rf, ctx) { if (rf & 1) {
106
- const _r2 = i0.ɵɵgetCurrentView();
107
- i0.ɵɵelementStart(0, "mat-form-field")(1, "input", 0, 1);
108
- i0.ɵɵlistener("ngModelChange", function InfoDateMonthComponent_Template_input_ngModelChange_1_listener($event) { return ctx.dateValue = $event; })("dateChange", function InfoDateMonthComponent_Template_input_dateChange_1_listener() { return ctx.onChangeValue(); })("input", function InfoDateMonthComponent_Template_input_input_1_listener($event) { return ctx.onInputDate($event.target.value); })("keypress", function InfoDateMonthComponent_Template_input_keypress_1_listener($event) { return ctx.onKeyPress($event); })("blur", function InfoDateMonthComponent_Template_input_blur_1_listener() { return ctx.onChangeValue(); });
109
- i0.ɵɵpipe(3, "translate");
110
- i0.ɵɵelementEnd();
111
- i0.ɵɵelement(4, "mat-datepicker-toggle", 2);
112
- i0.ɵɵelementStart(5, "mat-datepicker", 3, 4);
113
- i0.ɵɵlistener("yearSelected", function InfoDateMonthComponent_Template_mat_datepicker_yearSelected_5_listener($event) { return ctx.chosenYearHandler($event); })("monthSelected", function InfoDateMonthComponent_Template_mat_datepicker_monthSelected_5_listener($event) { i0.ɵɵrestoreView(_r2); const _r1 = i0.ɵɵreference(6); return i0.ɵɵresetView(ctx.chosenMonthHandler($event, _r1)); });
114
- i0.ɵɵelementEnd()();
145
+ { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }])], decls: 2, vars: 2, consts: [[4, "ngIf"], ["matInput", "", 3, "placeholder", "ngModel", "disabled", "required", "min", "matDatepicker", "ngModelChange", "dateChange", "input", "keypress", "blur"], ["inputDate", ""], ["matSuffix", "", 3, "for"], ["startView", "multi-year", 3, "yearSelected", "monthSelected"], ["datepicker", ""], ["type", "button", 1, "mat-button", 3, "ngModel", "disabled", "required", "min", "matDatepicker", "click", "ngModelChange", "dateChange", "input"]], template: function InfoDateMonthComponent_Template(rf, ctx) { if (rf & 1) {
146
+ i0.ɵɵtemplate(0, InfoDateMonthComponent_mat_form_field_0_Template, 7, 9, "mat-form-field", 0);
147
+ i0.ɵɵtemplate(1, InfoDateMonthComponent_ng_container_1_Template, 5, 5, "ng-container", 0);
115
148
  } if (rf & 2) {
116
- const _r1 = i0.ɵɵreference(6);
149
+ i0.ɵɵproperty("ngIf", !ctx.button);
117
150
  i0.ɵɵadvance(1);
118
- i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(3, 7, ctx.placeholder))("ngModel", ctx.dateValue)("disabled", ctx.disabled)("required", ctx.required)("min", ctx.minDate)("matDatepicker", _r1);
119
- i0.ɵɵadvance(3);
120
- i0.ɵɵproperty("for", _r1);
121
- } }, dependencies: [i1.DefaultValueAccessor, i1.NgControlStatus, i1.RequiredValidator, i1.NgModel, i2.MatFormField, i2.MatSuffix, i3.MatInput, i4.MatDatepicker, i4.MatDatepickerInput, i4.MatDatepickerToggle, i5.InfoTranslatePipe], encapsulation: 2 }); }
151
+ i0.ɵɵproperty("ngIf", ctx.button);
152
+ } }, dependencies: [i1.NgIf, i2.DefaultValueAccessor, i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, i3.MatFormField, i3.MatSuffix, i4.MatInput, i5.MatDatepicker, i5.MatDatepickerInput, i5.MatDatepickerToggle, i6.InfoTranslatePipe], encapsulation: 2 });
122
153
  }
123
154
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoDateMonthComponent, [{
124
155
  type: Component,
@@ -130,7 +161,7 @@ export class InfoDateMonthComponent {
130
161
  { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },
131
162
  { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },
132
163
  { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_MONTH_FORMATS },
133
- { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }], template: "<mat-form-field>\r\n <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\"\r\n (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\" #inputDate >\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker #datepicker startView=\"multi-year\" (yearSelected)=\"chosenYearHandler($event)\" (monthSelected)=\"chosenMonthHandler($event, datepicker)\"></mat-datepicker>\r\n</mat-form-field> " }]
164
+ { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }], template: "<mat-form-field *ngIf=\"!button\">\r\n <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\"\r\n (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\" #inputDate >\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker #datepicker startView=\"multi-year\" (yearSelected)=\"chosenYearHandler($event)\" (monthSelected)=\"chosenMonthHandler($event, datepicker)\"></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-container *ngIf=\"button\">\r\n <input class=\"mat-button\" type=\"button\" (click)=\"datepicker.open()\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\"\r\n (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" [matDatepicker]=\"datepicker\" #inputDate>\r\n\r\n <mat-datepicker #datepicker startView=\"multi-year\" (yearSelected)=\"chosenYearHandler($event)\" (monthSelected)=\"chosenMonthHandler($event, datepicker)\"></mat-datepicker>\r\n</ng-container>" }]
134
165
  }], null, { placeholder: [{
135
166
  type: Input
136
167
  }], disabled: [{
@@ -141,8 +172,10 @@ export class InfoDateMonthComponent {
141
172
  type: Input
142
173
  }], minDate: [{
143
174
  type: Input
175
+ }], button: [{
176
+ type: Input
144
177
  }], input: [{
145
178
  type: ViewChild,
146
179
  args: ['inputDate', { static: false }]
147
180
  }] }); })();
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-month.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/date-month/date-month.component.ts","../../../../../projects/info-library/src/controls/date-month/date-month.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnInit, ViewChild } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { MAT_DATE_LOCALE, DateAdapter, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\nimport { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS } from \"@angular/material-moment-adapter\";\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\nimport { createTextMaskInputElement } from \"text-mask-core/dist/textMaskCore\";\r\nimport { createAutoCorrectedDatePipe } from \"text-mask-addons\";\r\nimport { Moment } from \"moment\";\r\nimport moment from \"moment\";\r\n\r\nexport const PT_BR_DATE_MONTH_FORMATS = {\r\n    parse: {\r\n        dateInput: 'MM/YYYY',\r\n    },\r\n    display: {\r\n        dateInput: 'MM/YYYY',\r\n        monthYearLabel: 'MMM YYYY',\r\n        dateA11yLabel: 'LL',\r\n        monthYearA11yLabel: 'MMMM YYYY',\r\n    },\r\n};\r\n\r\n@Component({\r\n    selector: 'info-date-month',\r\n    templateUrl: './date-month.component.html',\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoDateMonthComponent),\r\n        multi: true\r\n    },\r\n    { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },\r\n    { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },\r\n    { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_MONTH_FORMATS },\r\n    { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }]\r\n})\r\nexport class InfoDateMonthComponent implements ControlValueAccessor {\r\n\r\n    @Input() placeholder: string;\r\n    @Input() disabled: boolean = false;\r\n    @Input() required: boolean = false;\r\n    @Input() changeonlyonmonth: boolean = false;\r\n    @Input() minDate: Date = new Date(1800, 0, 1);\r\n    \r\n    @ViewChild('inputDate', { static: false }) input;\r\n\r\n    dateValue: any;\r\n    dateMask: any;\r\n    onChange;\r\n    onTouched;\r\n\r\n    ngAfterViewInit() {\r\n\r\n        let config = {\r\n            mask: [/\\d/, /\\d/, '/', /\\d/, /\\d/, /\\d/, /\\d/],\r\n            guide: true,\r\n            placeholderChar: '_',\r\n            pipe: createAutoCorrectedDatePipe(PT_BR_DATE_MONTH_FORMATS.parse.dateInput.toLowerCase()),\r\n            modelClean: true,\r\n            keepCharPositions: false,\r\n        };\r\n\r\n        this.dateMask = createTextMaskInputElement(\r\n            Object.assign({ inputElement: this.input.nativeElement }, config)\r\n        );\r\n    }\r\n\r\n    onInputDate(value) {\r\n        this.dateMask.update(value);\r\n    }\r\n\r\n    onChangeValue() {\r\n        if (this.onChange != null) {\r\n            if (moment(this.dateValue).isBefore(moment(this.minDate)))\r\n               this.dateValue = this.minDate;\r\n\r\n            this.onChange(this.dateValue);\r\n        }\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (value == null || value == undefined)\r\n            this.dateValue = null;\r\n        else {\r\n            value = new Date(value);\r\n            value.setMinutes(value.getMinutes() + value.getTimezoneOffset());\r\n            value = new Date(value.getFullYear(), value.getMonth(), 1);\r\n            this.dateValue = value;\r\n        }\r\n        \r\n        this.onChangeValue();\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.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    chosenYearHandler(value: Moment) {\r\n        if (this.changeonlyonmonth)\r\n            return;\r\n        let aux = new Date(value.year(), new Date(this.dateValue).getMonth(), 1);\r\n        this.dateValue = aux;\r\n        this.onChangeValue();\r\n    }\r\n\r\n    chosenMonthHandler(value: Moment, datepicker: MatDatepicker<Moment>) {\r\n        let aux = new Date(value.year(), value.month(), 1);\r\n        this.dateValue = aux;\r\n        this.onChangeValue();\r\n        datepicker.close();\r\n    }\r\n    \r\n    onKeyPress(e){\r\n        if (e.keyCode == 13)\r\n            this.onChangeValue();\r\n    }\r\n}","<mat-form-field>\r\n    <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\"\r\n           (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\" #inputDate >\r\n\r\n    <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n    <mat-datepicker #datepicker startView=\"multi-year\" (yearSelected)=\"chosenYearHandler($event)\" (monthSelected)=\"chosenMonthHandler($event, datepicker)\"></mat-datepicker>\r\n</mat-form-field>   "]}
181
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-month.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/date-month/date-month.component.ts","../../../../../projects/info-library/src/controls/date-month/date-month.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnInit, ViewChild } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { MAT_DATE_LOCALE, DateAdapter, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\nimport { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS } from \"@angular/material-moment-adapter\";\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\nimport { createTextMaskInputElement } from \"text-mask-core/dist/textMaskCore\";\r\nimport { createAutoCorrectedDatePipe } from \"text-mask-addons\";\r\nimport { Moment } from \"moment\";\r\nimport moment from \"moment\";\r\n\r\nexport const PT_BR_DATE_MONTH_FORMATS = {\r\n    parse: {\r\n        dateInput: 'MM/YYYY',\r\n    },\r\n    display: {\r\n        dateInput: 'MM/YYYY',\r\n        monthYearLabel: 'MMM YYYY',\r\n        dateA11yLabel: 'LL',\r\n        monthYearA11yLabel: 'MMMM YYYY',\r\n    },\r\n};\r\n\r\n@Component({\r\n    selector: 'info-date-month',\r\n    templateUrl: './date-month.component.html',\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoDateMonthComponent),\r\n        multi: true\r\n    },\r\n    { provide: MAT_DATE_LOCALE, useValue: 'pt-BR' },\r\n    { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },\r\n    { provide: MAT_DATE_FORMATS, useValue: PT_BR_DATE_MONTH_FORMATS },\r\n    { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true } }]\r\n})\r\nexport class InfoDateMonthComponent implements ControlValueAccessor {\r\n\r\n    @Input() placeholder: string;\r\n    @Input() disabled: boolean = false;\r\n    @Input() required: boolean = false;\r\n    @Input() changeonlyonmonth: boolean = false;\r\n    @Input() minDate: Date = new Date(1800, 0, 1);\r\n    @Input() button: boolean = false;\r\n\r\n    @ViewChild('inputDate', { static: false }) input;\r\n\r\n    dateValue: any;\r\n    dateMask: any;\r\n    onChange;\r\n    onTouched;\r\n\r\n    ngAfterViewInit() {\r\n\r\n        let config = {\r\n            mask: [/\\d/, /\\d/, '/', /\\d/, /\\d/, /\\d/, /\\d/],\r\n            guide: true,\r\n            placeholderChar: '_',\r\n            pipe: createAutoCorrectedDatePipe(PT_BR_DATE_MONTH_FORMATS.parse.dateInput.toLowerCase()),\r\n            modelClean: true,\r\n            keepCharPositions: false,\r\n        };\r\n\r\n        this.dateMask = createTextMaskInputElement(\r\n            Object.assign({ inputElement: this.input.nativeElement }, config)\r\n        );\r\n    }\r\n\r\n    onInputDate(value) {\r\n        this.dateMask.update(value);\r\n    }\r\n\r\n    onChangeValue() {\r\n        if (this.onChange != null) {\r\n            if (moment(this.dateValue).isBefore(moment(this.minDate)))\r\n               this.dateValue = this.minDate;\r\n\r\n            this.onChange(this.dateValue);\r\n        }\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (value == null || value == undefined)\r\n            this.dateValue = null;\r\n        else {\r\n            value = new Date(value);\r\n            value.setMinutes(value.getMinutes() + value.getTimezoneOffset());\r\n            value = new Date(value.getFullYear(), value.getMonth(), 1);\r\n            this.dateValue = value;\r\n        }\r\n        \r\n        this.onChangeValue();\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.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.disabled = isDisabled;\r\n    }\r\n\r\n    chosenYearHandler(value: Moment) {\r\n        if (this.changeonlyonmonth)\r\n            return;\r\n        let aux = new Date(value.year(), new Date(this.dateValue).getMonth(), 1);\r\n        this.dateValue = aux;\r\n        this.onChangeValue();\r\n    }\r\n\r\n    chosenMonthHandler(value: Moment, datepicker: MatDatepicker<Moment>) {\r\n        let aux = new Date(value.year(), value.month(), 1);\r\n        this.dateValue = aux;\r\n        this.onChangeValue();\r\n        datepicker.close();\r\n    }\r\n    \r\n    onKeyPress(e){\r\n        if (e.keyCode == 13)\r\n            this.onChangeValue();\r\n    }\r\n}","<mat-form-field *ngIf=\"!button\">\r\n    <input matInput [placeholder]=\"placeholder | translate\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\"\r\n           (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" (keypress)=\"onKeyPress($event)\" (blur)=\"onChangeValue()\" [matDatepicker]=\"datepicker\" #inputDate >\r\n\r\n    <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n    <mat-datepicker #datepicker startView=\"multi-year\" (yearSelected)=\"chosenYearHandler($event)\" (monthSelected)=\"chosenMonthHandler($event, datepicker)\"></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-container *ngIf=\"button\">\r\n    <input class=\"mat-button\" type=\"button\" (click)=\"datepicker.open()\" [(ngModel)]=\"dateValue\" [disabled]=\"disabled\" [required]=\"required\" [min]=\"minDate\"\r\n           (dateChange)=\"onChangeValue()\" (input)=\"onInputDate($event.target.value)\" [matDatepicker]=\"datepicker\" #inputDate>\r\n\r\n    <mat-datepicker #datepicker startView=\"multi-year\" (yearSelected)=\"chosenYearHandler($event)\" (monthSelected)=\"chosenMonthHandler($event, datepicker)\"></mat-datepicker>\r\n</ng-container>"]}
@@ -8,6 +8,11 @@ import * as i2 from "@angular/forms";
8
8
  import * as i3 from "@kolkov/angular-editor";
9
9
  const _c0 = ["editor"];
10
10
  export class InfoEditorComponent {
11
+ _sanitizer;
12
+ editor;
13
+ required = false;
14
+ enabledhtmlmode = false;
15
+ sanitize = true;
11
16
  get disabled() { return !(this.editorConfig || {}).editable; }
12
17
  set disabled(value) { this.editorConfig.editable = !value; }
13
18
  get height() { return (this.editorConfig || {}).height; }
@@ -20,35 +25,34 @@ export class InfoEditorComponent {
20
25
  set width(value) { this.editorConfig.width = value || 'auto'; }
21
26
  get minwidth() { return (this.editorConfig || {}).minWidth; }
22
27
  set minwidth(value) { this.editorConfig.minWidth = value || '0'; }
28
+ value = '';
29
+ onChange;
30
+ onTouched;
31
+ focused = false;
32
+ id = null;
33
+ editorConfig = {
34
+ editable: true,
35
+ spellcheck: true,
36
+ height: 'auto',
37
+ minHeight: '0',
38
+ maxHeight: 'auto',
39
+ width: 'auto',
40
+ minWidth: '0',
41
+ translate: 'yes',
42
+ enableToolbar: true,
43
+ showToolbar: true,
44
+ defaultParagraphSeparator: '',
45
+ toolbarPosition: 'top',
46
+ sanitize: false,
47
+ fonts: [
48
+ { class: 'arial', name: 'Arial' },
49
+ { class: 'times-new-roman', name: 'Times New Roman' },
50
+ { class: 'calibri', name: 'Calibri' },
51
+ { class: 'comic-sans-ms', name: 'Comic Sans MS' }
52
+ ],
53
+ };
23
54
  constructor(_sanitizer) {
24
55
  this._sanitizer = _sanitizer;
25
- this.required = false;
26
- this.enabledhtmlmode = false;
27
- this.sanitize = true;
28
- this.value = '';
29
- this.focused = false;
30
- this.id = null;
31
- this.editorConfig = {
32
- editable: true,
33
- spellcheck: true,
34
- height: 'auto',
35
- minHeight: '0',
36
- maxHeight: 'auto',
37
- width: 'auto',
38
- minWidth: '0',
39
- translate: 'yes',
40
- enableToolbar: true,
41
- showToolbar: true,
42
- defaultParagraphSeparator: '',
43
- toolbarPosition: 'top',
44
- sanitize: false,
45
- fonts: [
46
- { class: 'arial', name: 'Arial' },
47
- { class: 'times-new-roman', name: 'Times New Roman' },
48
- { class: 'calibri', name: 'Calibri' },
49
- { class: 'comic-sans-ms', name: 'Comic Sans MS' }
50
- ],
51
- };
52
56
  }
53
57
  ngOnInit() {
54
58
  this.id = `editor-${this.getGuid()}`;
@@ -84,8 +88,8 @@ export class InfoEditorComponent {
84
88
  setDisabledState(isDisabled) {
85
89
  this.disabled = isDisabled;
86
90
  }
87
- /** @nocollapse */ static { this.ɵfac = function InfoEditorComponent_Factory(t) { return new (t || InfoEditorComponent)(i0.ɵɵdirectiveInject(i1.DomSanitizer)); }; }
88
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoEditorComponent, selectors: [["info-editor"]], viewQuery: function InfoEditorComponent_Query(rf, ctx) { if (rf & 1) {
91
+ /** @nocollapse */ static ɵfac = function InfoEditorComponent_Factory(t) { return new (t || InfoEditorComponent)(i0.ɵɵdirectiveInject(i1.DomSanitizer)); };
92
+ /** @nocollapse */ static ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoEditorComponent, selectors: [["info-editor"]], viewQuery: function InfoEditorComponent_Query(rf, ctx) { if (rf & 1) {
89
93
  i0.ɵɵviewQuery(_c0, 5);
90
94
  } if (rf & 2) {
91
95
  let _t;
@@ -101,7 +105,7 @@ export class InfoEditorComponent {
101
105
  } if (rf & 2) {
102
106
  i0.ɵɵproperty("ngModel", ctx.value)("config", ctx.editorConfig)("required", ctx.required);
103
107
  i0.ɵɵattribute("id", ctx.id)("focused", ctx.focused)("htmlmode", ctx.enabledhtmlmode);
104
- } }, dependencies: [i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, i3.AngularEditorComponent], styles: ["[_nghost-%COMP%] [htmlmode=false] .angular-editor-toolbar-set #toggleEditorMode-{display:none}[_nghost-%COMP%] .angular-editor-toolbar-set #insertVideo-{display:none}[_nghost-%COMP%] .angular-editor-textarea{outline:none;border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:solid 1px!important}[_nghost-%COMP%] .angular-editor-textarea[contenteditable=false]{border-bottom:dotted 1.5px lightgray!important}[_nghost-%COMP%] .angular-editor-wrapper:after{content:\"\";position:absolute;left:0;width:100%;height:2px;bottom:0;transform-origin:50%;transform:scaleX(.5);opacity:0;background-color:#000;transition:background-color .3s cubic-bezier(.55,0,.55,.2)}[_nghost-%COMP%] [focused=true] .angular-editor-wrapper:after{opacity:1;transform:scaleX(1);transition:transform .3s cubic-bezier(.25,.8,.25,1),opacity .1s cubic-bezier(.25,.8,.25,1),background-color .3s cubic-bezier(.25,.8,.25,1)}[_nghost-%COMP%] .ng-touched.ng-invalid .angular-editor-wrapper:after{background-color:#f44336!important}[_nghost-%COMP%] .ng-touched.ng-invalid .angular-editor-textarea[contenteditable=true]{border-bottom-color:#f44336!important}"] }); }
108
+ } }, dependencies: [i2.NgControlStatus, i2.RequiredValidator, i2.NgModel, i3.AngularEditorComponent], styles: ["[_nghost-%COMP%] [htmlmode=false] .angular-editor-toolbar-set #toggleEditorMode-{display:none}[_nghost-%COMP%] .angular-editor-toolbar-set #insertVideo-{display:none}[_nghost-%COMP%] .angular-editor-textarea{outline:none;border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:solid 1px!important}[_nghost-%COMP%] .angular-editor-textarea[contenteditable=false]{border-bottom:dotted 1.5px lightgray!important}[_nghost-%COMP%] .angular-editor-wrapper:after{content:\"\";position:absolute;left:0;width:100%;height:2px;bottom:0;transform-origin:50%;transform:scaleX(.5);opacity:0;background-color:#000;transition:background-color .3s cubic-bezier(.55,0,.55,.2)}[_nghost-%COMP%] [focused=true] .angular-editor-wrapper:after{opacity:1;transform:scaleX(1);transition:transform .3s cubic-bezier(.25,.8,.25,1),opacity .1s cubic-bezier(.25,.8,.25,1),background-color .3s cubic-bezier(.25,.8,.25,1)}[_nghost-%COMP%] .ng-touched.ng-invalid .angular-editor-wrapper:after{background-color:#f44336!important}[_nghost-%COMP%] .ng-touched.ng-invalid .angular-editor-textarea[contenteditable=true]{border-bottom-color:#f44336!important}"] });
105
109
  }
106
110
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoEditorComponent, [{
107
111
  type: Component,
@@ -132,4 +136,4 @@ export class InfoEditorComponent {
132
136
  }], minwidth: [{
133
137
  type: Input
134
138
  }] }); })();
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/editor/editor.component.ts","../../../../../projects/info-library/src/controls/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, SecurityContext, ViewChild } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { AngularEditorComponent, AngularEditorConfig, AngularEditorService } from '@kolkov/angular-editor';\r\n \r\n@Component({\r\n  selector: 'info-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.scss'],\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => InfoEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class InfoEditorComponent implements ControlValueAccessor {\r\n\r\n  @ViewChild('editor') editor: AngularEditorComponent;\r\n\r\n  @Input() required: boolean = false;\r\n  @Input() enabledhtmlmode: boolean = false;\r\n  @Input() sanitize: boolean = true;\r\n\r\n  @Input()\r\n  get disabled() { return !(this.editorConfig || {}).editable; }\r\n  set disabled(value) { this.editorConfig.editable = !value; }\r\n\r\n  @Input()\r\n  get height() { return (this.editorConfig || {}).height; }\r\n  set height(value) { this.editorConfig.height = value || 'auto'; }\r\n\r\n  @Input()\r\n  get minheight() { return (this.editorConfig || {}).minHeight; }\r\n  set minheight(value) { this.editorConfig.minHeight = value || '0'; }\r\n\r\n  @Input()\r\n  get maxheight() { return (this.editorConfig || {}).maxHeight; }\r\n  set maxheight(value) { this.editorConfig.maxHeight = value || 'auto'; }\r\n\r\n  @Input()\r\n  get width() { return (this.editorConfig || {}).width; }\r\n  set width(value) { this.editorConfig.width = value || 'auto'; }\r\n\r\n  @Input()\r\n  get minwidth() { return (this.editorConfig || {}).minWidth; }\r\n  set minwidth(value) { this.editorConfig.minWidth = value || '0'; }\r\n\r\n  value: any = '';\r\n  \r\n  onChange: any;\r\n  onTouched: any;\r\n  focused = false;\r\n  id = null;\r\n\r\n  editorConfig: AngularEditorConfig = {\r\n    editable: true,\r\n    spellcheck: true,\r\n    height: 'auto',\r\n    minHeight: '0',\r\n    maxHeight: 'auto',\r\n    width: 'auto',\r\n    minWidth: '0',\r\n    translate: 'yes',\r\n    enableToolbar: true,\r\n    showToolbar: true,\r\n    defaultParagraphSeparator: '',\r\n    toolbarPosition: 'top',\r\n    sanitize: false,\r\n    fonts: [\r\n      {class: 'arial', name: 'Arial'},\r\n      {class: 'times-new-roman', name: 'Times New Roman'},\r\n      {class: 'calibri', name: 'Calibri'},\r\n      {class: 'comic-sans-ms', name: 'Comic Sans MS'}\r\n    ],\r\n  };\r\n\r\n  constructor(private _sanitizer: DomSanitizer) {}\r\n\r\n  ngOnInit() {\r\n    this.id = `editor-${this.getGuid()}`;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    var _this = this;\r\n    document.querySelector(`#${this.id} .angular-editor-textarea`).addEventListener('focus', () => _this.focused = true);\r\n    document.querySelector(`#${this.id} .angular-editor-textarea`).addEventListener('blur', () => _this.focused = false);\r\n    document.querySelector(`#${this.id} .angular-editor-textarea`).addEventListener('mouseout', () => _this.editor.editorToolbar['editorService'].saveSelection());\r\n  }\r\n\r\n  private getGuid() : string {\r\n    return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {\r\n        const r = Math.random() * 16 | 0, v = c === 'x' ? r : ( r & 0x3 | 0x8 );\r\n        return v.toString(16);\r\n    });\r\n  }\r\n\r\n  onChangeValue() {\r\n    if (this.sanitize)\r\n      this.value = this._sanitizer.sanitize(SecurityContext.HTML, this.value);\r\n    if (this.onChange != null)\r\n        this.onChange(this.value);\r\n  }\r\n\r\n  writeValue(modelValue: any): void {\r\n    this.value = this.sanitize ? this._sanitizer.sanitize(SecurityContext.HTML, modelValue) : modelValue;\r\n    this.onChangeValue();\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.onTouched = fn;\r\n  }\r\n  \r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n  \r\n}","<angular-editor [attr.id]=\"id\" [attr.focused]=\"focused\" [attr.htmlmode]=\"enabledhtmlmode\" [(ngModel)]=\"value\" name=\"editor\" [config]=\"editorConfig\" (ngModelChange)=\"onChangeValue()\" [required]=\"required\" #editor></angular-editor>\r\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/editor/editor.component.ts","../../../../../projects/info-library/src/controls/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, SecurityContext, ViewChild } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { AngularEditorComponent, AngularEditorConfig, AngularEditorService } from '@kolkov/angular-editor';\r\n \r\n@Component({\r\n  selector: 'info-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.scss'],\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => InfoEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class InfoEditorComponent implements ControlValueAccessor {\r\n\r\n  @ViewChild('editor') editor: AngularEditorComponent;\r\n\r\n  @Input() required: boolean = false;\r\n  @Input() enabledhtmlmode: boolean = false;\r\n  @Input() sanitize: boolean = true;\r\n\r\n  @Input()\r\n  get disabled() { return !(this.editorConfig || {}).editable; }\r\n  set disabled(value) { this.editorConfig.editable = !value; }\r\n\r\n  @Input()\r\n  get height() { return (this.editorConfig || {}).height; }\r\n  set height(value) { this.editorConfig.height = value || 'auto'; }\r\n\r\n  @Input()\r\n  get minheight() { return (this.editorConfig || {}).minHeight; }\r\n  set minheight(value) { this.editorConfig.minHeight = value || '0'; }\r\n\r\n  @Input()\r\n  get maxheight() { return (this.editorConfig || {}).maxHeight; }\r\n  set maxheight(value) { this.editorConfig.maxHeight = value || 'auto'; }\r\n\r\n  @Input()\r\n  get width() { return (this.editorConfig || {}).width; }\r\n  set width(value) { this.editorConfig.width = value || 'auto'; }\r\n\r\n  @Input()\r\n  get minwidth() { return (this.editorConfig || {}).minWidth; }\r\n  set minwidth(value) { this.editorConfig.minWidth = value || '0'; }\r\n\r\n  value: any = '';\r\n  \r\n  onChange: any;\r\n  onTouched: any;\r\n  focused = false;\r\n  id = null;\r\n\r\n  editorConfig: AngularEditorConfig = {\r\n    editable: true,\r\n    spellcheck: true,\r\n    height: 'auto',\r\n    minHeight: '0',\r\n    maxHeight: 'auto',\r\n    width: 'auto',\r\n    minWidth: '0',\r\n    translate: 'yes',\r\n    enableToolbar: true,\r\n    showToolbar: true,\r\n    defaultParagraphSeparator: '',\r\n    toolbarPosition: 'top',\r\n    sanitize: false,\r\n    fonts: [\r\n      {class: 'arial', name: 'Arial'},\r\n      {class: 'times-new-roman', name: 'Times New Roman'},\r\n      {class: 'calibri', name: 'Calibri'},\r\n      {class: 'comic-sans-ms', name: 'Comic Sans MS'}\r\n    ],\r\n  };\r\n\r\n  constructor(private _sanitizer: DomSanitizer) {}\r\n\r\n  ngOnInit() {\r\n    this.id = `editor-${this.getGuid()}`;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    var _this = this;\r\n    document.querySelector(`#${this.id} .angular-editor-textarea`).addEventListener('focus', () => _this.focused = true);\r\n    document.querySelector(`#${this.id} .angular-editor-textarea`).addEventListener('blur', () => _this.focused = false);\r\n    document.querySelector(`#${this.id} .angular-editor-textarea`).addEventListener('mouseout', () => _this.editor.editorToolbar['editorService'].saveSelection());\r\n  }\r\n\r\n  private getGuid() : string {\r\n    return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {\r\n        const r = Math.random() * 16 | 0, v = c === 'x' ? r : ( r & 0x3 | 0x8 );\r\n        return v.toString(16);\r\n    });\r\n  }\r\n\r\n  onChangeValue() {\r\n    if (this.sanitize)\r\n      this.value = this._sanitizer.sanitize(SecurityContext.HTML, this.value);\r\n    if (this.onChange != null)\r\n        this.onChange(this.value);\r\n  }\r\n\r\n  writeValue(modelValue: any): void {\r\n    this.value = this.sanitize ? this._sanitizer.sanitize(SecurityContext.HTML, modelValue) : modelValue;\r\n    this.onChangeValue();\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.onTouched = fn;\r\n  }\r\n  \r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n  \r\n}","<angular-editor [attr.id]=\"id\" [attr.focused]=\"focused\" [attr.htmlmode]=\"enabledhtmlmode\" [(ngModel)]=\"value\" name=\"editor\" [config]=\"editorConfig\" (ngModelChange)=\"onChangeValue()\" [required]=\"required\" #editor></angular-editor>\r\n"]}