@dev-tcloud/tcloud-ui 0.0.79 → 0.0.80
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.mjs +183 -0
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.mjs +81 -75
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.mjs +1 -1
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.mjs +10 -5
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/dev-tcloud-tcloud-ui.mjs +304 -117
- package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/fesm2020/dev-tcloud-tcloud-ui.mjs +303 -117
- package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.d.ts +40 -0
- package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.d.ts +15 -3
- package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.d.ts +3 -0
- package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.d.ts +5 -4
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, forwardRef } from '@angular/core';
|
|
2
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@angular/forms";
|
|
6
|
+
import * as i3 from "../../../tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component";
|
|
7
|
+
const CUSTOM_INPUT_VALIDATORS = {
|
|
8
|
+
provide: NG_VALIDATORS,
|
|
9
|
+
useExisting: forwardRef(() => TCloudUiRangeDateComponent),
|
|
10
|
+
multi: true
|
|
11
|
+
};
|
|
12
|
+
const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
|
|
13
|
+
provide: NG_VALUE_ACCESSOR,
|
|
14
|
+
useExisting: forwardRef(() => TCloudUiRangeDateComponent),
|
|
15
|
+
multi: true
|
|
16
|
+
};
|
|
17
|
+
const noop = () => {
|
|
18
|
+
};
|
|
19
|
+
export class TCloudUiRangeDateComponent {
|
|
20
|
+
constructor() {
|
|
21
|
+
this.result = {};
|
|
22
|
+
this.options_date_time = [];
|
|
23
|
+
this.use_validation_required = false;
|
|
24
|
+
this.onChange = new EventEmitter();
|
|
25
|
+
this.defaultValuePeriodStartStop = '';
|
|
26
|
+
this.descriptionStart = '';
|
|
27
|
+
this.descriptionStop = '';
|
|
28
|
+
this.mode = 'select';
|
|
29
|
+
this.isValid = false;
|
|
30
|
+
//Placeholders for the callbacks which are later providesd
|
|
31
|
+
//by the Control Value Accessor
|
|
32
|
+
this.onTouchedCallback = noop;
|
|
33
|
+
this.onChangeCallback = noop;
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.setOptionsDateTime();
|
|
37
|
+
}
|
|
38
|
+
setOptionsDateTime() {
|
|
39
|
+
this.options_date_time = [
|
|
40
|
+
{ value: '7-days', description: '7 dias' },
|
|
41
|
+
{ value: '15-days', description: '15 dias' },
|
|
42
|
+
{ value: '30-days', description: '30 dias' },
|
|
43
|
+
{ value: 'current-month', description: 'Mês atual' },
|
|
44
|
+
{ value: 'current-year', description: 'Ano atual' }
|
|
45
|
+
];
|
|
46
|
+
setTimeout(() => {
|
|
47
|
+
if (this.defaultValuePeriodStartStop !== '') {
|
|
48
|
+
this.onChangeOptionsDateTime(this.defaultValuePeriodStartStop);
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
onChangeOptionsDateTime(event) {
|
|
53
|
+
this.isValid = false;
|
|
54
|
+
// this.description_options_date_time = '';
|
|
55
|
+
// this.value_options_date_time = '';
|
|
56
|
+
event = (event.value) ? event.value : event;
|
|
57
|
+
let now = new Date();
|
|
58
|
+
let filter_date = undefined;
|
|
59
|
+
if (event === '7-days') {
|
|
60
|
+
filter_date = new Date((new Date(now)).setDate(now.getDate() - 7));
|
|
61
|
+
filter_date = new Date((filter_date).setSeconds(0));
|
|
62
|
+
}
|
|
63
|
+
if (event === '15-days') {
|
|
64
|
+
filter_date = new Date((new Date(now)).setDate(now.getDate() - 15));
|
|
65
|
+
filter_date = new Date((filter_date).setSeconds(0));
|
|
66
|
+
}
|
|
67
|
+
if (event === '30-days') {
|
|
68
|
+
filter_date = new Date((new Date(now)).setDate(now.getDate() - 30));
|
|
69
|
+
filter_date = new Date((filter_date).setSeconds(0));
|
|
70
|
+
}
|
|
71
|
+
if (event === 'current-month') {
|
|
72
|
+
filter_date = new Date(now.getFullYear(), now.getMonth(), 1);
|
|
73
|
+
}
|
|
74
|
+
if (event === 'current-year') {
|
|
75
|
+
filter_date = new Date(now.getFullYear(), 0, 1);
|
|
76
|
+
}
|
|
77
|
+
if (filter_date) {
|
|
78
|
+
this.result = {
|
|
79
|
+
start: filter_date,
|
|
80
|
+
stop: now
|
|
81
|
+
};
|
|
82
|
+
this.onChange.emit(this.result);
|
|
83
|
+
this.isValid = true;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.result = {};
|
|
87
|
+
this.onChange.emit(this.result);
|
|
88
|
+
this.isValid = false;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
onChangeStartDateTime(event) {
|
|
92
|
+
this.isValid = false;
|
|
93
|
+
if (this.result && this.result.start && this.result.stop) {
|
|
94
|
+
this.onChange.emit(this.result);
|
|
95
|
+
this.isValid = true;
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this.result = {};
|
|
99
|
+
this.onChange.emit(this.result);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
onChangeStopDateTime(event) {
|
|
103
|
+
this.isValid = false;
|
|
104
|
+
if (this.result && this.result.start && this.result.stop) {
|
|
105
|
+
this.onChange.emit(this.result);
|
|
106
|
+
this.isValid = true;
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
this.result = {};
|
|
110
|
+
this.onChange.emit(this.result);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
toggle() {
|
|
114
|
+
const mode = (this.mode === 'select') ? 'datepickers' : 'select';
|
|
115
|
+
if (mode === 'select') {
|
|
116
|
+
this.isValid = false;
|
|
117
|
+
this.result = {};
|
|
118
|
+
this.onChange.emit(this.result);
|
|
119
|
+
}
|
|
120
|
+
this.mode = mode;
|
|
121
|
+
}
|
|
122
|
+
//get accessor
|
|
123
|
+
get value() {
|
|
124
|
+
return this.innerValue;
|
|
125
|
+
}
|
|
126
|
+
;
|
|
127
|
+
//set accessor including call the onchange callback
|
|
128
|
+
set value(v) {
|
|
129
|
+
if (v !== this.innerValue) {
|
|
130
|
+
this.innerValue = v;
|
|
131
|
+
this.onChangeCallback(v);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
//Set touched on blur
|
|
135
|
+
onBlur() {
|
|
136
|
+
this.onTouchedCallback();
|
|
137
|
+
}
|
|
138
|
+
//From ControlValueAccessor interface
|
|
139
|
+
writeValue(value) {
|
|
140
|
+
if (value !== this.innerValue) {
|
|
141
|
+
this.innerValue = value;
|
|
142
|
+
//this.toSetDefault(value);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
//From ControlValueAccessor interface
|
|
146
|
+
registerOnChange(fn) {
|
|
147
|
+
this.onChangeCallback = fn;
|
|
148
|
+
}
|
|
149
|
+
//From ControlValueAccessor interface
|
|
150
|
+
registerOnTouched(fn) {
|
|
151
|
+
this.onTouchedCallback = fn;
|
|
152
|
+
}
|
|
153
|
+
validate(c) {
|
|
154
|
+
if (c && (typeof this.required !== 'undefined')) {
|
|
155
|
+
this.use_validation_required = true;
|
|
156
|
+
return (this.check_is_valid()) ? null : 'required';
|
|
157
|
+
}
|
|
158
|
+
return null;
|
|
159
|
+
}
|
|
160
|
+
check_is_valid() {
|
|
161
|
+
if (this.result && this.result.start && this.result.stop) {
|
|
162
|
+
return true;
|
|
163
|
+
}
|
|
164
|
+
return false;
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
TCloudUiRangeDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiRangeDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
168
|
+
TCloudUiRangeDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiRangeDateComponent, selector: "range-date", inputs: { defaultValuePeriodStartStop: "defaultValuePeriodStartStop", required: "required", descriptionStart: "descriptionStart", descriptionStop: "descriptionStop" }, outputs: { onChange: "onChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS], ngImport: i0, template: "<table class=\"area-range-date\">\n <tr>\n\n <td>\n <div *ngIf=\"mode === 'select'\">\n <div class=\"description-period\">Per\u00EDodo</div>\n <select name=\"periodo\" class=\"form-control tc-form-control\" (change)=\"onChangeOptionsDateTime($event.target)\" [(ngModel)]=\"defaultValuePeriodStartStop\" >\n <option value=\"\"></option> \n <ng-container *ngFor=\"let item of options_date_time\">\n <option [value]=\"item.value\">{{ item.description }}</option>\n </ng-container>\n </select>\n </div>\n <div *ngIf=\"mode === 'datepickers'\">\n\n <table class=\"area-range-datepickers\">\n <tr>\n <td>\n <div class=\"description-start\">{{ descriptionStart }}</div>\n <tcloud-ui-datepicker-time \n #_input_start \n [(ngModel)]=\"result.start\" \n name=\"input_start\" \n (eventChange)=\"onChangeStartDateTime(_input_start)\">\n </tcloud-ui-datepicker-time>\n </td>\n <td>\n <div class=\"description-stop\">{{ descriptionStop }}</div>\n <tcloud-ui-datepicker-time \n #_input_stop\n [(ngModel)]=\"result.stop\" \n name=\"input_stop\" \n (eventChange)=\"onChangeStopDateTime(_input_stop)\">\n </tcloud-ui-datepicker-time>\n </td>\n </tr>\n </table>\n\n </div>\n </td>\n\n <td>\n <button class=\"btn-mode-range-date\" [class.active]=\"mode === 'select'\" (click)=\"toggle()\" type=\"button\">\n\n <i *ngIf=\"mode === 'select'\" class=\"far fa-calendar-alt\" title=\"Alterar para calend\u00E1rio\"></i>\n <i *ngIf=\"mode !== 'select'\" class=\"fas fa-calendar-week\" title=\"Selecionar per\u00EDodo\"></i>\n\n <!-- <div *ngIf=\"mode === 'select'\">Exibir<br>Calend\u00E1rio</div> -->\n <!-- <div *ngIf=\"mode !== 'select'\">Exibir<br>Per\u00EDodo</div> -->\n </button>\n </td>\n\n </tr>\n</table>", styles: [".area-range-date{width:100%}.area-range-date tr td:first-child{width:calc(100% - 35px)}.area-range-date tr td:first-child select{color:#535353;border-radius:3px 0 0 3px!important}.area-range-date tr td:first-child .area-range-datepickers{width:100%}.area-range-date tr td:first-child .area-range-datepickers td{width:50%!important}.area-range-date tr td:last-child{width:35px}.area-range-date tr td:last-child .btn-mode-range-date{width:100%;text-align:center;border:1px solid #ccc;background-color:#fff;font-size:17px;line-height:1;cursor:pointer;color:#6c6c6c;height:40px;border-radius:0 3px 3px 0}.area-range-date tr td:last-child .btn-mode-range-date:focus{color:#403d3d}.active{background-color:#eee!important}.description-period,.description-start{position:relative;left:17px;top:-15px;line-height:0}.description-stop{position:relative;top:-15px;line-height:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.TCloudUiDatepickerTimeComponent, selector: "tcloud-ui-datepicker-time", inputs: ["UTC", "ngModel", "useOptionsDateTime"], outputs: ["ngModelChange", "onChange", "eventChange"] }] });
|
|
169
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiRangeDateComponent, decorators: [{
|
|
170
|
+
type: Component,
|
|
171
|
+
args: [{ selector: 'range-date', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS], template: "<table class=\"area-range-date\">\n <tr>\n\n <td>\n <div *ngIf=\"mode === 'select'\">\n <div class=\"description-period\">Per\u00EDodo</div>\n <select name=\"periodo\" class=\"form-control tc-form-control\" (change)=\"onChangeOptionsDateTime($event.target)\" [(ngModel)]=\"defaultValuePeriodStartStop\" >\n <option value=\"\"></option> \n <ng-container *ngFor=\"let item of options_date_time\">\n <option [value]=\"item.value\">{{ item.description }}</option>\n </ng-container>\n </select>\n </div>\n <div *ngIf=\"mode === 'datepickers'\">\n\n <table class=\"area-range-datepickers\">\n <tr>\n <td>\n <div class=\"description-start\">{{ descriptionStart }}</div>\n <tcloud-ui-datepicker-time \n #_input_start \n [(ngModel)]=\"result.start\" \n name=\"input_start\" \n (eventChange)=\"onChangeStartDateTime(_input_start)\">\n </tcloud-ui-datepicker-time>\n </td>\n <td>\n <div class=\"description-stop\">{{ descriptionStop }}</div>\n <tcloud-ui-datepicker-time \n #_input_stop\n [(ngModel)]=\"result.stop\" \n name=\"input_stop\" \n (eventChange)=\"onChangeStopDateTime(_input_stop)\">\n </tcloud-ui-datepicker-time>\n </td>\n </tr>\n </table>\n\n </div>\n </td>\n\n <td>\n <button class=\"btn-mode-range-date\" [class.active]=\"mode === 'select'\" (click)=\"toggle()\" type=\"button\">\n\n <i *ngIf=\"mode === 'select'\" class=\"far fa-calendar-alt\" title=\"Alterar para calend\u00E1rio\"></i>\n <i *ngIf=\"mode !== 'select'\" class=\"fas fa-calendar-week\" title=\"Selecionar per\u00EDodo\"></i>\n\n <!-- <div *ngIf=\"mode === 'select'\">Exibir<br>Calend\u00E1rio</div> -->\n <!-- <div *ngIf=\"mode !== 'select'\">Exibir<br>Per\u00EDodo</div> -->\n </button>\n </td>\n\n </tr>\n</table>", styles: [".area-range-date{width:100%}.area-range-date tr td:first-child{width:calc(100% - 35px)}.area-range-date tr td:first-child select{color:#535353;border-radius:3px 0 0 3px!important}.area-range-date tr td:first-child .area-range-datepickers{width:100%}.area-range-date tr td:first-child .area-range-datepickers td{width:50%!important}.area-range-date tr td:last-child{width:35px}.area-range-date tr td:last-child .btn-mode-range-date{width:100%;text-align:center;border:1px solid #ccc;background-color:#fff;font-size:17px;line-height:1;cursor:pointer;color:#6c6c6c;height:40px;border-radius:0 3px 3px 0}.area-range-date tr td:last-child .btn-mode-range-date:focus{color:#403d3d}.active{background-color:#eee!important}.description-period,.description-start{position:relative;left:17px;top:-15px;line-height:0}.description-stop{position:relative;top:-15px;line-height:0}\n"] }]
|
|
172
|
+
}], ctorParameters: function () { return []; }, propDecorators: { onChange: [{
|
|
173
|
+
type: Output
|
|
174
|
+
}], defaultValuePeriodStartStop: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], required: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], descriptionStart: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], descriptionStop: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}] } });
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-date.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.ts","../../../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, Output, EventEmitter, forwardRef } from '@angular/core';\nimport { FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nconst  CUSTOM_INPUT_VALIDATORS: any = { \n  provide: NG_VALIDATORS, \n  useExisting: forwardRef(() => TCloudUiRangeDateComponent),\n  multi: true\n}\n\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => TCloudUiRangeDateComponent),\n  multi: true\n};\n\nconst noop = () => {\n};\n\n\ninterface IResultDateTime{\n  start: any;\n  stop: any;\n}\n\n@Component({\n  selector: 'range-date',\n  templateUrl: './range-date.component.html',\n  styleUrls: ['./range-date.component.scss'],\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS]\n})\nexport class TCloudUiRangeDateComponent implements OnInit {\n\n  result = {} as IResultDateTime;\n\n  options_date_time: any = [];\n  use_validation_required: boolean = false;\n\n  @Output() onChange = new EventEmitter<IResultDateTime>();\n\n  @Input() defaultValuePeriodStartStop: string = '';\n  @Input() required: string | undefined;\n\n  @Input() descriptionStart: string = '';\n  @Input() descriptionStop: string = '';\n\n  mode: string = 'select';\n\n  isValid = false;\n\n  constructor() { }\n\n  ngOnInit(): void {\n    this.setOptionsDateTime();\n  }\n\n  setOptionsDateTime(){\n    this.options_date_time = [\n      {value:'7-days', description: '7 dias'},\n      {value:'15-days', description: '15 dias'},\n      {value:'30-days', description: '30 dias'},\n      {value:'current-month', description: 'Mês atual'},\n      {value:'current-year', description: 'Ano atual'}\n    ]\n    setTimeout(() => {\n      if( this.defaultValuePeriodStartStop !== '' ){\n        this.onChangeOptionsDateTime( this.defaultValuePeriodStartStop );\n      }\n    });\n    \n  }\n\n  onChangeOptionsDateTime(event: any){\n    this.isValid = false;\n    // this.description_options_date_time = '';\n    // this.value_options_date_time = '';\n    event = (event.value) ? event.value : event;\n\n    let now = new Date();\n    let filter_date: any = undefined;\n    if( event === '7-days' ){\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 7 ) );  \n      filter_date = new Date( (filter_date).setSeconds(0) );      \n    }\n\n    if( event === '15-days' ){\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 15 ) );\n      filter_date = new Date( (filter_date).setSeconds(0) );\n    }\n\n    if( event === '30-days' ){\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 30 ) );\n      filter_date = new Date( (filter_date).setSeconds(0) );\n    }\n\n    if( event === 'current-month' ){\n      filter_date = new Date(now.getFullYear(), now.getMonth(), 1);\n    }\n\n    if( event === 'current-year' ){\n      filter_date = new Date(now.getFullYear(), 0, 1);\n    }\n\n    if(filter_date){   \n      \n      this.result = {\n        start: filter_date,\n        stop: now\n      } as IResultDateTime;\n      this.onChange.emit(this.result);\n      this.isValid = true;\n    }else{\n      this.result = {} as IResultDateTime;\n      this.onChange.emit(this.result);\n      this.isValid = false;\n    }\n\n  }\n\n  onChangeStartDateTime(event: any){\n    this.isValid = false;\n    if( this.result && this.result.start && this.result.stop ){\n      this.onChange.emit(this.result);\n      this.isValid = true;\n    }else{\n      this.result = {} as IResultDateTime;\n      this.onChange.emit(this.result);\n    }\n  }\n\n  onChangeStopDateTime(event: any){\n    this.isValid = false;\n    if( this.result && this.result.start && this.result.stop ){\n      this.onChange.emit(this.result);\n      this.isValid = true;\n    }else{\n      this.result = {} as IResultDateTime;\n      this.onChange.emit(this.result);\n    }\n  }\n\n  toggle(){\n    const mode = (this.mode === 'select') ? 'datepickers' : 'select';\n    if( mode === 'select' ){\n      this.isValid = false;\n      this.result = {} as IResultDateTime;\n      this.onChange.emit(this.result);\n    }\n    this.mode = mode;\n  }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n  innerValue: any | undefined;\n  //Placeholders for the callbacks which are later providesd\n  //by the Control Value Accessor\n  private onTouchedCallback: () => void = noop;\n  private onChangeCallback: (_: any) => void = noop;\n\n  //get accessor\n  get value(): any {\n      return this.innerValue;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.innerValue) {\n      this.innerValue = v;      \n      this.onChangeCallback(v);\n    }\n  }\n\n  //Set touched on blur\n  onBlur() {\n    this.onTouchedCallback();\n  }\n\n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    if (value !== this.innerValue) {\n      this.innerValue = value;\n      //this.toSetDefault(value);\n    }\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeCallback = fn;\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedCallback = fn;\n  }\n\n  public validate(c: FormControl): any {\n    if( c && ( typeof this.required !== 'undefined' ) ){\n      this.use_validation_required = true;\n      return (this.check_is_valid()) ? null : 'required';\n    }\n    return null;\n  }\n\n  check_is_valid(): boolean{\n    if( this.result && this.result.start && this.result.stop ){\n      return true;\n    }\n    return false;\n  }\n\n}\n","<table class=\"area-range-date\">\n    <tr>\n\n        <td>\n            <div *ngIf=\"mode === 'select'\">\n                <div class=\"description-period\">Período</div>\n                <select name=\"periodo\" class=\"form-control tc-form-control\" (change)=\"onChangeOptionsDateTime($event.target)\" [(ngModel)]=\"defaultValuePeriodStartStop\"  >\n                    <option value=\"\"></option> \n                    <ng-container *ngFor=\"let item of options_date_time\">\n                        <option [value]=\"item.value\">{{ item.description }}</option>\n                    </ng-container>\n                </select>\n            </div>\n            <div *ngIf=\"mode === 'datepickers'\">\n\n                <table class=\"area-range-datepickers\">\n                    <tr>\n                        <td>\n                            <div class=\"description-start\">{{ descriptionStart }}</div>\n                            <tcloud-ui-datepicker-time \n                                #_input_start \n                                [(ngModel)]=\"result.start\" \n                                name=\"input_start\" \n                                (eventChange)=\"onChangeStartDateTime(_input_start)\">\n                            </tcloud-ui-datepicker-time>\n                        </td>\n                        <td>\n                            <div class=\"description-stop\">{{ descriptionStop }}</div>\n                            <tcloud-ui-datepicker-time \n                                #_input_stop\n                                [(ngModel)]=\"result.stop\" \n                                name=\"input_stop\" \n                                (eventChange)=\"onChangeStopDateTime(_input_stop)\">\n                            </tcloud-ui-datepicker-time>\n                        </td>\n                    </tr>\n                </table>\n\n            </div>\n        </td>\n\n        <td>\n            <button class=\"btn-mode-range-date\" [class.active]=\"mode === 'select'\" (click)=\"toggle()\" type=\"button\">\n\n                <i *ngIf=\"mode === 'select'\" class=\"far fa-calendar-alt\" title=\"Alterar para calendário\"></i>\n                <i *ngIf=\"mode !== 'select'\" class=\"fas fa-calendar-week\" title=\"Selecionar período\"></i>\n\n                <!-- <div *ngIf=\"mode === 'select'\">Exibir<br>Calendário</div> -->\n                <!-- <div *ngIf=\"mode !== 'select'\">Exibir<br>Período</div> -->\n            </button>\n        </td>\n\n    </tr>\n</table>"]}
|