@dev-tcloud/tcloud-ui 0.0.79 → 0.0.81

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.
@@ -0,0 +1,186 @@
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.UTC = false;
29
+ this.mode = 'select';
30
+ this.isValid = false;
31
+ //Placeholders for the callbacks which are later providesd
32
+ //by the Control Value Accessor
33
+ this.onTouchedCallback = noop;
34
+ this.onChangeCallback = noop;
35
+ }
36
+ ngOnInit() {
37
+ this.setOptionsDateTime();
38
+ }
39
+ setOptionsDateTime() {
40
+ this.options_date_time = [
41
+ { value: '7-days', description: '7 dias' },
42
+ { value: '15-days', description: '15 dias' },
43
+ { value: '30-days', description: '30 dias' },
44
+ { value: 'current-month', description: 'Mês atual' },
45
+ { value: 'current-year', description: 'Ano atual' }
46
+ ];
47
+ setTimeout(() => {
48
+ if (this.defaultValuePeriodStartStop !== '') {
49
+ this.onChangeOptionsDateTime(this.defaultValuePeriodStartStop);
50
+ }
51
+ });
52
+ }
53
+ onChangeOptionsDateTime(event) {
54
+ this.isValid = false;
55
+ // this.description_options_date_time = '';
56
+ // this.value_options_date_time = '';
57
+ event = (event.value) ? event.value : event;
58
+ let now = new Date();
59
+ let filter_date = undefined;
60
+ if (event === '7-days') {
61
+ filter_date = new Date((new Date(now)).setDate(now.getDate() - 7));
62
+ filter_date = new Date((filter_date).setSeconds(0));
63
+ }
64
+ if (event === '15-days') {
65
+ filter_date = new Date((new Date(now)).setDate(now.getDate() - 15));
66
+ filter_date = new Date((filter_date).setSeconds(0));
67
+ }
68
+ if (event === '30-days') {
69
+ filter_date = new Date((new Date(now)).setDate(now.getDate() - 30));
70
+ filter_date = new Date((filter_date).setSeconds(0));
71
+ }
72
+ if (event === 'current-month') {
73
+ filter_date = new Date(now.getFullYear(), now.getMonth(), 1);
74
+ }
75
+ if (event === 'current-year') {
76
+ filter_date = new Date(now.getFullYear(), 0, 1);
77
+ }
78
+ if (filter_date) {
79
+ this.result = {
80
+ start: filter_date,
81
+ stop: now
82
+ };
83
+ this.onChange.emit(this.result);
84
+ this.isValid = true;
85
+ }
86
+ else {
87
+ this.result = {};
88
+ this.onChange.emit(this.result);
89
+ this.isValid = false;
90
+ }
91
+ }
92
+ onChangeStartDateTime(event) {
93
+ this.isValid = false;
94
+ if (this.result && this.result.start && this.result.stop) {
95
+ this.onChange.emit(this.result);
96
+ this.isValid = true;
97
+ }
98
+ else {
99
+ this.result = {};
100
+ this.onChange.emit(this.result);
101
+ }
102
+ }
103
+ onChangeStopDateTime(event) {
104
+ this.isValid = false;
105
+ if (this.result && this.result.start && this.result.stop) {
106
+ this.onChange.emit(this.result);
107
+ this.isValid = true;
108
+ }
109
+ else {
110
+ this.result = {};
111
+ this.onChange.emit(this.result);
112
+ }
113
+ }
114
+ toggle() {
115
+ const mode = (this.mode === 'select') ? 'datepickers' : 'select';
116
+ if (mode === 'select') {
117
+ this.isValid = false;
118
+ this.result = {};
119
+ this.onChange.emit(this.result);
120
+ }
121
+ this.mode = mode;
122
+ }
123
+ //get accessor
124
+ get value() {
125
+ return this.innerValue;
126
+ }
127
+ ;
128
+ //set accessor including call the onchange callback
129
+ set value(v) {
130
+ if (v !== this.innerValue) {
131
+ this.innerValue = v;
132
+ this.onChangeCallback(v);
133
+ }
134
+ }
135
+ //Set touched on blur
136
+ onBlur() {
137
+ this.onTouchedCallback();
138
+ }
139
+ //From ControlValueAccessor interface
140
+ writeValue(value) {
141
+ if (value !== this.innerValue) {
142
+ this.innerValue = value;
143
+ //this.toSetDefault(value);
144
+ }
145
+ }
146
+ //From ControlValueAccessor interface
147
+ registerOnChange(fn) {
148
+ this.onChangeCallback = fn;
149
+ }
150
+ //From ControlValueAccessor interface
151
+ registerOnTouched(fn) {
152
+ this.onTouchedCallback = fn;
153
+ }
154
+ validate(c) {
155
+ if (c && (typeof this.required !== 'undefined')) {
156
+ this.use_validation_required = true;
157
+ return (this.check_is_valid()) ? null : 'required';
158
+ }
159
+ return null;
160
+ }
161
+ check_is_valid() {
162
+ if (this.result && this.result.start && this.result.stop) {
163
+ return true;
164
+ }
165
+ return false;
166
+ }
167
+ }
168
+ TCloudUiRangeDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiRangeDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
169
+ 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", UTC: "UTC" }, 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 [UTC]=\"UTC\"\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 [UTC]=\"UTC\"\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"] }] });
170
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiRangeDateComponent, decorators: [{
171
+ type: Component,
172
+ 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 [UTC]=\"UTC\"\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 [UTC]=\"UTC\"\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"] }]
173
+ }], ctorParameters: function () { return []; }, propDecorators: { onChange: [{
174
+ type: Output
175
+ }], defaultValuePeriodStartStop: [{
176
+ type: Input
177
+ }], required: [{
178
+ type: Input
179
+ }], descriptionStart: [{
180
+ type: Input
181
+ }], descriptionStop: [{
182
+ type: Input
183
+ }], UTC: [{
184
+ type: Input
185
+ }] } });
186
+ //# 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  @Input() UTC: boolean = false;\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                                [UTC]=\"UTC\"\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                                [UTC]=\"UTC\"\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>"]}