@dev-tcloud/tcloud-ui 0.0.50 → 0.0.51

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 (28) hide show
  1. package/README.md +10 -0
  2. package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.mjs +302 -0
  3. package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.module.mjs +31 -0
  4. package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.mjs +209 -0
  5. package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.module.mjs +35 -0
  6. package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.mjs +79 -29
  7. package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.mjs +8 -4
  8. package/esm2020/lib/_pipes/datebr.mjs +102 -0
  9. package/esm2020/lib/_pipes/index.mjs +2 -1
  10. package/esm2020/lib/_pipes/tcloud-pipes.module.mjs +14 -8
  11. package/esm2020/lib/tcloud-ui.module.mjs +17 -3
  12. package/esm2020/public-api.mjs +7 -1
  13. package/fesm2015/dev-tcloud-tcloud-ui.mjs +1147 -415
  14. package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
  15. package/fesm2020/dev-tcloud-tcloud-ui.mjs +1139 -413
  16. package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
  17. package/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.d.ts +46 -0
  18. package/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.module.d.ts +9 -0
  19. package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.d.ts +34 -0
  20. package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.module.d.ts +10 -0
  21. package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.d.ts +2 -1
  22. package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.d.ts +2 -1
  23. package/lib/_pipes/datebr.d.ts +11 -0
  24. package/lib/_pipes/index.d.ts +1 -0
  25. package/lib/_pipes/tcloud-pipes.module.d.ts +3 -2
  26. package/lib/tcloud-ui.module.d.ts +5 -3
  27. package/package.json +1 -1
  28. package/public-api.d.ts +4 -0
@@ -0,0 +1,209 @@
1
+ import { Component, forwardRef, EventEmitter, Output, Input, ViewChild } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../tcloud-ui-datepicker/tcloud-ui-datepicker.component";
5
+ import * as i2 from "@angular/forms";
6
+ const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
7
+ provide: NG_VALUE_ACCESSOR,
8
+ useExisting: forwardRef(() => TCloudUiDatepickerTimeComponent),
9
+ multi: true
10
+ };
11
+ const noop = () => {
12
+ };
13
+ export class TCloudUiDatepickerTimeComponent {
14
+ constructor() {
15
+ this.ngModelChange = new EventEmitter();
16
+ this.onChange = new EventEmitter();
17
+ this.eventChange = new EventEmitter();
18
+ this.DD_MM_YYYY = '';
19
+ this.HH = '';
20
+ this.MM = '';
21
+ this.ID = '';
22
+ //Placeholders for the callbacks which are later providesd
23
+ //by the Control Value Accessor
24
+ this.onTouchedCallback = noop;
25
+ this.onChangeCallback = noop;
26
+ }
27
+ set ngModel(v) {
28
+ if (v && v !== this.innerValue) {
29
+ this.innerValue = v;
30
+ }
31
+ }
32
+ ngOnInit() {
33
+ this.ID = this.generateID();
34
+ }
35
+ generateID() {
36
+ return `tcloud-ui-datepicker-time-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;
37
+ }
38
+ toSetDate(date) {
39
+ console.log('toSetDate', date);
40
+ this.set_date_by_datepicker(date);
41
+ }
42
+ toSetTime() {
43
+ if (this.DD_MM_YYYY && ((this.DD_MM_YYYY).trim()).length === 10) {
44
+ const date = (this.DD_MM_YYYY).replace(/-/g, '/');
45
+ let date_part = (date).split('/');
46
+ let dd = date_part[0];
47
+ let mm = date_part[1];
48
+ let yy = date_part[2];
49
+ const datetime = new Date(`${yy}-${mm}-${dd}`);
50
+ if (this.checkIsDate(datetime)) {
51
+ this.set_date_by_datepicker(date);
52
+ }
53
+ }
54
+ }
55
+ set_date_by_datepicker(date) {
56
+ if (date) {
57
+ date = (date).replace(/-/g, '/');
58
+ let date_part = (date).split('/');
59
+ let dia = date_part[0];
60
+ let mes = date_part[1];
61
+ let ano = date_part[2];
62
+ let hh = this.HH;
63
+ if (!hh) {
64
+ hh = '00';
65
+ }
66
+ else {
67
+ if ((+(hh) >= 0 && +(hh) < 24)) {
68
+ hh = (+(hh) < 10) ? `0${+(hh)}` : `${+(hh)}`;
69
+ }
70
+ else {
71
+ hh = '00';
72
+ }
73
+ }
74
+ let mm = this.MM;
75
+ if (!mm) {
76
+ mm = '00';
77
+ }
78
+ else {
79
+ if ((+(mm) >= 0 && +(mm) < 60)) {
80
+ mm = (+(mm) < 10) ? `0${+(mm)}` : `${+(mm)}`;
81
+ }
82
+ else {
83
+ mm = '00';
84
+ }
85
+ }
86
+ if (hh === '00') {
87
+ this.HH = hh;
88
+ }
89
+ if (mm === '00') {
90
+ this.MM = mm;
91
+ }
92
+ const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:00`;
93
+ const datetime = new Date(str_date);
94
+ if (this.checkIsDate(datetime)) {
95
+ this.innerValue = datetime;
96
+ }
97
+ else {
98
+ this.innerValue = undefined;
99
+ }
100
+ this.ngModelChange.emit(this.innerValue);
101
+ this.onChange.emit(this.innerValue);
102
+ this.eventChange.emit(this.datepickertime?.nativeElement);
103
+ console.log('str_date', str_date);
104
+ }
105
+ else {
106
+ this.innerValue = undefined;
107
+ this.ngModelChange.emit(this.innerValue);
108
+ this.onChange.emit(this.innerValue);
109
+ this.eventChange.emit(this.datepickertime?.nativeElement);
110
+ }
111
+ }
112
+ // Distribuir os valores da data por pedaços: data - hora - min
113
+ to_date_hh_mm(d) {
114
+ let dia = `${(d).getDate()}`;
115
+ dia = (+(dia) < 10) ? `0${+dia}` : dia;
116
+ let mes = `${(d).getMonth() + 1}`;
117
+ mes = (+(mes) < 10) ? `0${+mes}` : mes;
118
+ let ano = `${(d).getFullYear()}`;
119
+ let hh = `${(d).getHours()}`;
120
+ let mm = `${(d).getMinutes()}`;
121
+ if (hh && (+(hh) < 0 || +(hh) > 23)) {
122
+ hh = '00';
123
+ }
124
+ hh = (hh) ? ((+(hh) < 10) ? `0${hh}` : hh) : '00';
125
+ if (mm && (+(mm) < 0 || +(mm) > 59)) {
126
+ mm = '00';
127
+ }
128
+ mm = (mm) ? ((+(mm) < 10) ? `0${mm}` : mm) : '00';
129
+ this.MM = mm;
130
+ this.HH = hh;
131
+ this.DD_MM_YYYY = `${dia}/${mes}/${ano}`;
132
+ }
133
+ checkIsDate(d) {
134
+ if (Object.prototype.toString.call(d) === "[object Date]") {
135
+ if (isNaN(d)) {
136
+ return false;
137
+ }
138
+ else {
139
+ return true;
140
+ }
141
+ }
142
+ return false;
143
+ }
144
+ clean() {
145
+ this.DD_MM_YYYY = '';
146
+ this.HH = '';
147
+ this.MM = '';
148
+ }
149
+ toClickIn(id) {
150
+ document.getElementById(id)?.focus();
151
+ }
152
+ //get accessor
153
+ get value() {
154
+ return this.innerValue;
155
+ }
156
+ ;
157
+ //set accessor including call the onchange callback
158
+ set value(v) {
159
+ //console.log('set value', v);
160
+ if (v !== this.innerValue) {
161
+ //console.log('set value this.innerValue', this.innerValue);
162
+ this.innerValue = v;
163
+ this.onChangeCallback(v);
164
+ }
165
+ }
166
+ //Set touched on blur
167
+ onBlur() {
168
+ this.onTouchedCallback();
169
+ }
170
+ //From ControlValueAccessor interface
171
+ writeValue(value) {
172
+ if (value !== this.innerValue) {
173
+ this.innerValue = value;
174
+ console.log('writeValue this.innerValue', this.innerValue);
175
+ if (this.checkIsDate(value)) {
176
+ this.to_date_hh_mm(value);
177
+ }
178
+ else {
179
+ this.clean();
180
+ }
181
+ }
182
+ }
183
+ //From ControlValueAccessor interface
184
+ registerOnChange(fn) {
185
+ this.onChangeCallback = fn;
186
+ }
187
+ //From ControlValueAccessor interface
188
+ registerOnTouched(fn) {
189
+ this.onTouchedCallback = fn;
190
+ }
191
+ }
192
+ TCloudUiDatepickerTimeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
193
+ TCloudUiDatepickerTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiDatepickerTimeComponent, selector: "tcloud-ui-datepicker-time", inputs: { ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange", onChange: "onChange", eventChange: "eventChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "datepickertime", first: true, predicate: ["_datepickertime"], descendants: true }], ngImport: i0, template: "<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n <div class=\"input-control-time\">\r\n <div class=\"form-control-time\">\r\n <table class=\"form-time\">\r\n <tr>\r\n <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n <td class=\"area-input-hour\"><input type=\"text\" placeholder=\"HH\" (keyup)=\"toSetTime()\" [(ngModel)]=\"HH\" maxlength=\"2\" name=\"hh\" pattern=\"[0][0-9]|[1][0-9]|2[0-3]\"></td>\r\n <td class=\"area-delimiter\"><div class=\"delimiter-time\">:</div></td>\r\n <td class=\"area-input-minute\"><input type=\"text\" placeholder=\"MM\" (keyup)=\"toSetTime()\" [(ngModel)]=\"MM\" maxlength=\"2\" name=\"mm\" pattern=\"[012345][0-9]\"></td>\r\n <td class=\"area-clean\"></td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n</form>", styles: [".input-control-time{border:1px solid #ccc;border-radius:3px;width:100%}.form-control-time{max-width:220px;border:none}.form-control-time input{text-align:center}.form-time{width:100%}.delimiter-time{width:100%;text-align:center}.delimiter-time-icon{border:none;height:35px;width:10px;padding:4px;font-size:17px;text-align:center;opacity:.6}.area-icon{width:25px}.area-input-date{width:105px}.area-delimiter{width:2px;text-align:center}.area-input-hour,.area-input-minute{text-align:center;width:28px}.area-input-hour input,.area-input-minute input{height:35px;width:28px;text-align:center;color:#999;font-weight:600;font-style:italic}.area-input-hour input:focus,.area-input-minute input:focus{outline:none}.area-clean{width:15px}input,.datepicker-input{border:none!important}\n"], dependencies: [{ kind: "component", type: i1.TCloudUiDatepickerComponent, selector: "tcloud-ui-datepicker", inputs: ["multiple", "maxNumberOfDates", "daysOfWeekDisabled", "minDate", "maxDate", "datesDisabled", "modeInput", "useBorder", "ngModel", "code"], outputs: ["onChange", "ngModelChange"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
194
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeComponent, decorators: [{
195
+ type: Component,
196
+ args: [{ selector: 'tcloud-ui-datepicker-time', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n <div class=\"input-control-time\">\r\n <div class=\"form-control-time\">\r\n <table class=\"form-time\">\r\n <tr>\r\n <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n <td class=\"area-input-hour\"><input type=\"text\" placeholder=\"HH\" (keyup)=\"toSetTime()\" [(ngModel)]=\"HH\" maxlength=\"2\" name=\"hh\" pattern=\"[0][0-9]|[1][0-9]|2[0-3]\"></td>\r\n <td class=\"area-delimiter\"><div class=\"delimiter-time\">:</div></td>\r\n <td class=\"area-input-minute\"><input type=\"text\" placeholder=\"MM\" (keyup)=\"toSetTime()\" [(ngModel)]=\"MM\" maxlength=\"2\" name=\"mm\" pattern=\"[012345][0-9]\"></td>\r\n <td class=\"area-clean\"></td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n</form>", styles: [".input-control-time{border:1px solid #ccc;border-radius:3px;width:100%}.form-control-time{max-width:220px;border:none}.form-control-time input{text-align:center}.form-time{width:100%}.delimiter-time{width:100%;text-align:center}.delimiter-time-icon{border:none;height:35px;width:10px;padding:4px;font-size:17px;text-align:center;opacity:.6}.area-icon{width:25px}.area-input-date{width:105px}.area-delimiter{width:2px;text-align:center}.area-input-hour,.area-input-minute{text-align:center;width:28px}.area-input-hour input,.area-input-minute input{height:35px;width:28px;text-align:center;color:#999;font-weight:600;font-style:italic}.area-input-hour input:focus,.area-input-minute input:focus{outline:none}.area-clean{width:15px}input,.datepicker-input{border:none!important}\n"] }]
197
+ }], propDecorators: { ngModel: [{
198
+ type: Input
199
+ }], ngModelChange: [{
200
+ type: Output
201
+ }], onChange: [{
202
+ type: Output
203
+ }], eventChange: [{
204
+ type: Output
205
+ }], datepickertime: [{
206
+ type: ViewChild,
207
+ args: ['_datepickertime', { static: false }]
208
+ }] } });
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-datepicker-time.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit, EventEmitter, Output, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDatepickerTimeComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-datepicker-time',\r\n  templateUrl: './tcloud-ui-datepicker-time.component.html',\r\n  styleUrls: ['./tcloud-ui-datepicker-time.component.scss'],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]\r\n})\r\nexport class TCloudUiDatepickerTimeComponent implements OnInit {\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n    if( v && v !== this.innerValue ){\r\n      this.innerValue = v; \r\n    } \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<Date>();\r\n\r\n  @Output() onChange = new EventEmitter<Date>();\r\n  @Output() eventChange = new EventEmitter<any>();\r\n\r\n  DD_MM_YYYY: string = '';\r\n  HH: string = '';\r\n  MM: string = '';\r\n\r\n  ID: string = '';\r\n\r\n  @ViewChild('_datepickertime', {static: false}) datepickertime: ElementRef<HTMLElement> | undefined;\r\n\r\n  ngOnInit(): void {\r\n    this.ID = this.generateID();\r\n  }\r\n\r\n  generateID(): string{\r\n    return `tcloud-ui-datepicker-time-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  toSetDate(date: string){\r\n    console.log('toSetDate', date);\r\n\r\n    this.set_date_by_datepicker(date);\r\n  }\r\n\r\n  toSetTime(){\r\n    if( this.DD_MM_YYYY && ((this.DD_MM_YYYY).trim()).length === 10){\r\n      const date = (this.DD_MM_YYYY).replace(/-/g, '/');\r\n      let date_part = (date).split('/');\r\n      let dd = date_part[0];\r\n      let mm = date_part[1];\r\n      let yy = date_part[2];\r\n      const datetime = new Date(`${yy}-${mm}-${dd}`);\r\n      if( this.checkIsDate(datetime) ){\r\n        this.set_date_by_datepicker(date);\r\n      }\r\n    }\r\n  }\r\n\r\n  set_date_by_datepicker(date: string){\r\n\r\n    if( date ){\r\n      date = (date).replace(/-/g, '/');\r\n      let date_part = (date).split('/');\r\n      let dia = date_part[0];\r\n      let mes = date_part[1];\r\n      let ano = date_part[2];\r\n\r\n      let hh = this.HH;\r\n      if( !hh ){\r\n        hh = '00';\r\n      }else{\r\n        if( ( +(hh) >= 0 && +(hh) < 24 ) ){\r\n          hh = (+(hh) < 10 ) ? `0${+(hh)}` : `${+(hh)}`;\r\n        }else{\r\n          hh = '00';\r\n        }\r\n      }\r\n\r\n      let mm = this.MM;\r\n      if( !mm ){\r\n        mm = '00';\r\n      }else{\r\n        if( ( +(mm) >= 0 && +(mm) < 60 ) ){\r\n          mm = (+(mm) < 10 ) ? `0${+(mm)}` : `${+(mm)}`;\r\n        }else{\r\n          mm = '00';\r\n        }\r\n      }\r\n\r\n      if( hh === '00' ){ this.HH = hh; }\r\n      if( mm === '00' ){ this.MM = mm; }\r\n\r\n      const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:00`;\r\n      const datetime = new Date( str_date );\r\n      if( this.checkIsDate(datetime) ){\r\n        this.innerValue = datetime;\r\n        \r\n      }else{\r\n        this.innerValue = undefined;\r\n      }\r\n\r\n      this.ngModelChange.emit( this.innerValue );\r\n      this.onChange.emit( this.innerValue );\r\n      this.eventChange.emit( this.datepickertime?.nativeElement );\r\n\r\n      console.log('str_date', str_date);\r\n    }else{\r\n      this.innerValue = undefined;\r\n      this.ngModelChange.emit( this.innerValue );\r\n      this.onChange.emit( this.innerValue );\r\n      this.eventChange.emit( this.datepickertime?.nativeElement );\r\n    }\r\n\r\n  }\r\n\r\n  // Distribuir os valores da data por pedaços: data - hora - min\r\n  to_date_hh_mm(d: Date){\r\n    let dia = `${(d).getDate()}`;\r\n    dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n    let mes = `${(d).getMonth()+1}`;\r\n    mes = (+(mes) < 10 ) ? `0${+mes}` : mes;  \r\n\r\n    let ano = `${(d).getFullYear()}`;\r\n    let hh  = `${(d).getHours()}`;\r\n    let mm  = `${(d).getMinutes()}`;\r\n\r\n    if( hh && ( +(hh) < 0 || +(hh) > 23 ) ){ hh = '00'; }\r\n    hh = (hh) ? ( (+(hh) < 10 ) ? `0${hh}` : hh ) : '00';\r\n\r\n    if( mm && ( +(mm) < 0 || +(mm) > 59 ) ){ mm = '00'; }\r\n    mm = (mm) ? ( (+(mm) < 10 ) ? `0${mm}` : mm ) : '00';\r\n\r\n    this.MM = mm;\r\n    this.HH = hh;\r\n\r\n    this.DD_MM_YYYY = `${dia}/${mes}/${ano}`;\r\n  }\r\n\r\n  checkIsDate(d: any): boolean{\r\n    if(Object.prototype.toString.call(d) === \"[object Date]\") {\r\n      if(isNaN(d)) { return false; } else { return true; }\r\n    } \r\n    return false;\r\n  }\r\n\r\n\r\n  clean(){\r\n    this.DD_MM_YYYY = '';\r\n    this.HH = '';\r\n    this.MM = '';\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    document.getElementById(id)?.focus();\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  \r\n  innerValue: any | undefined;\r\n  //Placeholders for the callbacks which are later providesd\r\n  //by the Control Value Accessor\r\n  private onTouchedCallback: () => void = noop;\r\n  private onChangeCallback: (_: any) => void = noop;\r\n\r\n  //get accessor\r\n  get value(): any {\r\n      return this.innerValue;\r\n  };\r\n\r\n  //set accessor including call the onchange callback\r\n  set value(v: any) {\r\n    //console.log('set value', v);\r\n    if (v !== this.innerValue) {\r\n      //console.log('set value this.innerValue', this.innerValue);\r\n      this.innerValue = v;      \r\n      this.onChangeCallback(v);\r\n    }\r\n  }\r\n\r\n  //Set touched on blur\r\n  onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  writeValue(value: any) {\r\n    if (value !== this.innerValue) {\r\n      this.innerValue = value;\r\n      console.log('writeValue this.innerValue', this.innerValue);\r\n      if( this.checkIsDate(value) ){\r\n        this.to_date_hh_mm(value);\r\n      }else{\r\n        this.clean()\r\n      }\r\n    }\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  registerOnChange(fn: any) {\r\n    this.onChangeCallback = fn;\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  registerOnTouched(fn: any) {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n}\r\n","<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n  <div class=\"input-control-time\">\r\n    <div class=\"form-control-time\">\r\n      <table class=\"form-time\">\r\n        <tr>\r\n          <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n          <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n          <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n          <td class=\"area-input-hour\"><input type=\"text\" placeholder=\"HH\" (keyup)=\"toSetTime()\" [(ngModel)]=\"HH\" maxlength=\"2\" name=\"hh\" pattern=\"[0][0-9]|[1][0-9]|2[0-3]\"></td>\r\n          <td class=\"area-delimiter\"><div class=\"delimiter-time\">:</div></td>\r\n          <td class=\"area-input-minute\"><input type=\"text\" placeholder=\"MM\" (keyup)=\"toSetTime()\" [(ngModel)]=\"MM\" maxlength=\"2\" name=\"mm\" pattern=\"[012345][0-9]\"></td>\r\n          <td class=\"area-clean\"></td>\r\n        </tr>\r\n      </table>\r\n    </div>\r\n  </div>\r\n</form>"]}
@@ -0,0 +1,35 @@
1
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
2
+ import { NgModule } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { TCloudUiDatepickerTimeComponent } from './tcloud-ui-datepicker-time.component';
5
+ import { TCloudUiDatepickerModule } from './../tcloud-ui-datepicker/tcloud-ui-datepicker.module';
6
+ import * as i0 from "@angular/core";
7
+ export class TCloudUiDatepickerTimeModule {
8
+ }
9
+ TCloudUiDatepickerTimeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
10
+ TCloudUiDatepickerTimeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeModule, declarations: [TCloudUiDatepickerTimeComponent], imports: [CommonModule,
11
+ TCloudUiDatepickerModule,
12
+ FormsModule,
13
+ ReactiveFormsModule], exports: [TCloudUiDatepickerTimeComponent] });
14
+ TCloudUiDatepickerTimeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeModule, imports: [CommonModule,
15
+ TCloudUiDatepickerModule,
16
+ FormsModule,
17
+ ReactiveFormsModule] });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeModule, decorators: [{
19
+ type: NgModule,
20
+ args: [{
21
+ declarations: [
22
+ TCloudUiDatepickerTimeComponent
23
+ ],
24
+ exports: [
25
+ TCloudUiDatepickerTimeComponent
26
+ ],
27
+ imports: [
28
+ CommonModule,
29
+ TCloudUiDatepickerModule,
30
+ FormsModule,
31
+ ReactiveFormsModule,
32
+ ]
33
+ }]
34
+ }] });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGNsb3VkLXVpLWRhdGVwaWNrZXItdGltZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Y2xvdWQtdWkvc3JjL2xpYi9fbW9kdWxlcy90Y2xvdWQtdWktZGF0ZXBpY2tlci10aW1lL3RjbG91ZC11aS1kYXRlcGlja2VyLXRpbWUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUN4RixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQzs7QUFpQmpHLE1BQU0sT0FBTyw0QkFBNEI7OzBIQUE1Qiw0QkFBNEI7MkhBQTVCLDRCQUE0QixpQkFickMsK0JBQStCLGFBTS9CLFlBQVk7UUFDWix3QkFBd0I7UUFDeEIsV0FBVztRQUNYLG1CQUFtQixhQU5uQiwrQkFBK0I7MkhBVXRCLDRCQUE0QixZQVByQyxZQUFZO1FBQ1osd0JBQXdCO1FBQ3hCLFdBQVc7UUFDWCxtQkFBbUI7NEZBSVYsNEJBQTRCO2tCQWZ4QyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWiwrQkFBK0I7cUJBQ2hDO29CQUNELE9BQU8sRUFBRTt3QkFDUCwrQkFBK0I7cUJBQ2hDO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLHdCQUF3Qjt3QkFDeEIsV0FBVzt3QkFDWCxtQkFBbUI7cUJBRXBCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFRDbG91ZFVpRGF0ZXBpY2tlclRpbWVDb21wb25lbnQgfSBmcm9tICcuL3RjbG91ZC11aS1kYXRlcGlja2VyLXRpbWUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVENsb3VkVWlEYXRlcGlja2VyTW9kdWxlIH0gZnJvbSAnLi8uLi90Y2xvdWQtdWktZGF0ZXBpY2tlci90Y2xvdWQtdWktZGF0ZXBpY2tlci5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFRDbG91ZFVpRGF0ZXBpY2tlclRpbWVDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFRDbG91ZFVpRGF0ZXBpY2tlclRpbWVDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFRDbG91ZFVpRGF0ZXBpY2tlck1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFRDbG91ZFVpRGF0ZXBpY2tlclRpbWVNb2R1bGUgeyB9XHJcbiJdfQ==