@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.
@@ -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>"]}