@dev-tcloud/tcloud-ui 0.1.9 → 0.1.10
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-datepicker-time/tcloud-ui-datepicker-time.component.mjs +2 -2
- package/esm2020/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.mjs +11 -8
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.mjs +10 -2
- package/fesm2015/dev-tcloud-tcloud-ui.mjs +20 -9
- package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/fesm2020/dev-tcloud-tcloud-ui.mjs +20 -9
- package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.d.ts +1 -1
- package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.d.ts +1 -0
- package/package.json +1 -1
package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.mjs
CHANGED
|
@@ -120,7 +120,7 @@ export class TCloudUiDatepickerTimeComponent {
|
|
|
120
120
|
if (mm === '00') {
|
|
121
121
|
this.MM = mm;
|
|
122
122
|
}
|
|
123
|
-
const notation = '
|
|
123
|
+
const notation = '00';
|
|
124
124
|
const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:${notation}`;
|
|
125
125
|
const datetime = new Date(str_date);
|
|
126
126
|
if (this.checkIsDate(datetime)) {
|
|
@@ -309,4 +309,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
309
309
|
type: ViewChild,
|
|
310
310
|
args: ['_datepickertime', { static: false }]
|
|
311
311
|
}] } });
|
|
312
|
-
//# 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\nimport { ISelectOptions } from '../tcloud-ui-data-list/tcloud-ui-data-list';\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  show_date_picker: boolean = true;\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  @Input() useOptionsDateTime = false;\r\n\r\n  DD_MM_YYYY: string = '';\r\n  HH: string = '00';\r\n  MM: string = '00';\r\n\r\n  ID: string = '';\r\n\r\n  option_HH: string[] | undefined;\r\n  option_MM: string[] | undefined;\r\n\r\n  @ViewChild('_datepickertime', {static: false}) datepickertime: ElementRef<HTMLElement> | undefined;\r\n\r\n  options_date_time : ISelectOptions[] = [];\r\n  open_options_date_time: boolean = false;\r\n\r\n  last_options_date_time: any;\r\n  description_options_date_time: any = '';\r\n  value_options_date_time: any = '';\r\n\r\n  ngOnInit(): void {\r\n\r\n\r\n    this.setOptionsDateTime();\r\n\r\n    this.ID = this.generateID();\r\n    this.option_HH = this.getListTIME(23);\r\n    this.option_MM = this.getListTIME(59);\r\n  }\r\n\r\n  setOptionsDateTime(){\r\n    this.options_date_time = [\r\n      {value:'7-days', description: '7 dias'},\r\n      {value:'15-days', description: '15 dias'},\r\n      {value:'30-days', description: '30 dias'},\r\n      {value:'current-month', description: 'Mês atual até agora'},\r\n      {value:'current-year', description: 'Ano atual até agora'}\r\n    ]\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  getListTIME(v: number){\r\n    let mm = [];\r\n    for(let i = 0; i <= v; i++ ){\r\n      if( i < 10 ){\r\n        (mm).push(`0${i}`);\r\n      }else{\r\n        (mm).push(`${i}`);\r\n      }\r\n    }\r\n    return mm;\r\n  }\r\n\r\n  toSetDate(date: string){    \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 notation = '00Z';\r\n\r\n      const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:${notation}`;\r\n      const datetime = new Date( str_date );\r\n      \r\n      if( this.checkIsDate(datetime) ){\r\n        this.innerValue = datetime;\r\n      }else{\r\n        this.innerValue = undefined;\r\n      }\r\n\r\n      // console.log('this.datepickertime?.nativeElement', this.datepickertime?.nativeElement);\r\n\r\n      // if(this.datepickertime && this.datepickertime.nativeElement){\r\n      //   const elem = <any> this.datepickertime.nativeElement;\r\n      //   elem.value = this.innerValue;\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    }else{\r\n\r\n      this.description_options_date_time = '';\r\n      this.value_options_date_time = '';\r\n\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    if( `${this.last_options_date_time}` !== `${this.innerValue}` ){\r\n      // this.description_options_date_time = '';\r\n      // this.value_options_date_time = '';\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\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 = '00';\r\n    this.MM = '00';\r\n    this.description_options_date_time = '';\r\n    this.value_options_date_time = '';\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    document.getElementById(id)?.focus();\r\n  }\r\n\r\n  onClosedOptionsDateTime(){\r\n    this.open_options_date_time = false\r\n  }\r\n\r\n  \r\n  onChangeOptionsDateTime(event: any){\r\n    // this.description_options_date_time = '';\r\n    // this.value_options_date_time = '';\r\n    this.show_date_picker = false;\r\n\r\n    let now = new Date();\r\n    let filter_date: any = undefined;\r\n    if( event === '7-days' ){\r\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 7 ) );  \r\n      filter_date = new Date( (filter_date).setSeconds(0) );      \r\n    }\r\n\r\n    if( event === '15-days' ){\r\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 15 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === '30-days' ){\r\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 30 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === 'current-month' ){\r\n      filter_date = new Date(now.getFullYear(), now.getMonth(), 1);\r\n    }\r\n\r\n    if( event === 'current-year' ){\r\n      filter_date = new Date(now.getFullYear(), 0, 1);\r\n    }\r\n\r\n    if(filter_date){      \r\n      this.innerValue = filter_date;\r\n      if( this.checkIsDate(filter_date) ){              \r\n        setTimeout(() => {\r\n          this.to_date_hh_mm(filter_date);\r\n          this.toSetDate(this.DD_MM_YYYY);  \r\n          this.show_date_picker = true;\r\n          this.value_options_date_time = event;\r\n          this.last_options_date_time = filter_date as any;\r\n          this.description_options_date_time = this.get_description_options_date_time(event);\r\n        });       \r\n      }\r\n    }\r\n\r\n  }\r\n\r\n\r\n  get_description_options_date_time(value: string){\r\n    if( this.options_date_time && (this.options_date_time).length > 0 ){\r\n      for( let i = 0; i < (this.options_date_time).length; i++ ){\r\n        const item = this.options_date_time[i];\r\n        if( item.value === value ){\r\n          return item.description;\r\n        }\r\n      }\r\n    }\r\n    return '';\r\n  }\r\n\r\n\r\n  closedTimeDescription(){\r\n    this.value_options_date_time = '';\r\n    this.description_options_date_time = ''; \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    if (v !== 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\r\n      try {\r\n        value = new Date( `${value}` );\r\n      } catch (error) {}\r\n\r\n      this.innerValue = value;\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","<div class=\"tcloud-ui-datepicker-time\">\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\r\n        <table style=\"width: 100%;\">\r\n          <tr>\r\n            <td>\r\n\r\n              <div class=\"input-options-date\">\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\">\r\n                    <ng-container *ngIf=\"show_date_picker\">\r\n                      <tcloud-ui-datepicker #_tclouddatepickertime [childInputDateTime]=\"true\" [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker>\r\n                    </ng-container>\r\n                  </td>\r\n                  \r\n                  <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n                  <td class=\"area-input-hour\">\r\n                    <!--<input type=\"text\" placeholder=\"HH\" (keyup)=\"toSetTime()\" [(ngModel)]=\"HH\" maxlength=\"2\" name=\"hh\" pattern=\"[0][0-9]|[1][0-9]|2[0-3]\">-->\r\n                    <select class=\"select-time-date\" (change)=\"toSetTime()\" [(ngModel)]=\"HH\" name=\"hh\">\r\n                      <ng-container *ngFor=\"let hh of option_HH\">\r\n                        <option [ngValue]=\"hh\">{{ hh }}</option>\r\n                      </ng-container>\r\n                    </select>\r\n                  </td>\r\n                  <td class=\"area-delimiter\"><div class=\"delimiter-time\">:</div></td>\r\n                  <td class=\"area-input-minute\">\r\n                    <!--<input type=\"text\" placeholder=\"MM\" (keyup)=\"toSetTime()\" [(ngModel)]=\"MM\" maxlength=\"2\" name=\"mm\" pattern=\"[012345][0-9]\">-->\r\n                    <select class=\"select-time-date\" (change)=\"toSetTime()\" [(ngModel)]=\"MM\" name=\"mm\">\r\n                      <ng-container *ngFor=\"let mm of option_MM\">\r\n                        <option [value]=\"mm\">{{ mm }}</option>\r\n                      </ng-container>\r\n                    </select>\r\n                  </td>\r\n                  <td class=\"area-clean\"></td>\r\n                </tr>\r\n              </table>\r\n\r\n              <div class=\"description-options-date\" *ngIf=\"value_options_date_time !== ''\">\r\n                <strong>{{ description_options_date_time }}</strong>\r\n\r\n                  <!-- <div class=\"area-action-date-time-selected\">\r\n                    <button class=\"btn-icon\" type=\"button\" (click)=\"closedTimeDescription()\" >\r\n                      <i class=\"fas fa-times\"></i>\r\n                    </button>                  \r\n                  </div> -->\r\n              </div>\r\n\r\n\r\n            </div>\r\n\r\n            </td>\r\n            <td *ngIf=\"useOptionsDateTime && options_date_time && (options_date_time).length > 0\" style=\"width: 20px\">\r\n              <button type=\"button\" class=\"icon-short-time\" (click)=\"open_options_date_time = !open_options_date_time\" [title]=\"description_options_date_time\" >\r\n                <i *ngIf=\"!open_options_date_time\" class=\"fas fa-caret-down\"></i>\r\n                <i *ngIf=\"open_options_date_time\" class=\"fas fa-caret-up\"></i>\r\n              </button>\r\n\r\n              <ng-container *ngIf=\"value_options_date_time !== ''\">\r\n                <button class=\"btn-icon-close\" type=\"button\" (click)=\"closedTimeDescription()\" >\r\n                  <i class=\"fas fa-times\"></i>\r\n                </button> \r\n              </ng-container>\r\n\r\n            </td>\r\n          </tr>\r\n          <tr *ngIf=\"useOptionsDateTime && options_date_time && (options_date_time).length > 0 && open_options_date_time\">\r\n            <td colspan=\"2\">\r\n                <tcloud-ui-data-list \r\n                  name=\"value_options_date_time\"\r\n                  [showInput]=\"false\" \r\n                  [search]=\"false\" \r\n                  [open]=\"true\" \r\n                  [listItems]=\"options_date_time\" \r\n                  (onClosed)=\"onClosedOptionsDateTime()\"\r\n                  [ngModel]=\"value_options_date_time\"\r\n                  (ngModelChange)=\"onChangeOptionsDateTime($event)\"\r\n                  >\r\n                </tcloud-ui-data-list>\r\n\r\n                \r\n\r\n\r\n              \r\n            </td>\r\n          </tr>\r\n        </table>\r\n\r\n        \r\n      </div>\r\n    </div>\r\n  </form>\r\n</div>"]}
|
|
312
|
+
//# 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\nimport { ISelectOptions } from '../tcloud-ui-data-list/tcloud-ui-data-list';\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  show_date_picker: boolean = true;\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  @Input() useOptionsDateTime = false;\r\n\r\n  DD_MM_YYYY: string = '';\r\n  HH: string = '00';\r\n  MM: string = '00';\r\n\r\n  ID: string = '';\r\n\r\n  option_HH: string[] | undefined;\r\n  option_MM: string[] | undefined;\r\n\r\n  @ViewChild('_datepickertime', {static: false}) datepickertime: ElementRef<HTMLElement> | undefined;\r\n\r\n  options_date_time : ISelectOptions[] = [];\r\n  open_options_date_time: boolean = false;\r\n\r\n  last_options_date_time: any;\r\n  description_options_date_time: any = '';\r\n  value_options_date_time: any = '';\r\n\r\n  ngOnInit(): void {\r\n\r\n\r\n    this.setOptionsDateTime();\r\n\r\n    this.ID = this.generateID();\r\n    this.option_HH = this.getListTIME(23);\r\n    this.option_MM = this.getListTIME(59);\r\n  }\r\n\r\n  setOptionsDateTime(){\r\n    this.options_date_time = [\r\n      {value:'7-days', description: '7 dias'},\r\n      {value:'15-days', description: '15 dias'},\r\n      {value:'30-days', description: '30 dias'},\r\n      {value:'current-month', description: 'Mês atual até agora'},\r\n      {value:'current-year', description: 'Ano atual até agora'}\r\n    ]\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  getListTIME(v: number){\r\n    let mm = [];\r\n    for(let i = 0; i <= v; i++ ){\r\n      if( i < 10 ){\r\n        (mm).push(`0${i}`);\r\n      }else{\r\n        (mm).push(`${i}`);\r\n      }\r\n    }\r\n    return mm;\r\n  }\r\n\r\n  toSetDate(date: string){    \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 notation = '00';\r\n\r\n      const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:${notation}`;\r\n      const datetime = new Date( str_date );\r\n      \r\n      if( this.checkIsDate(datetime) ){\r\n        this.innerValue = datetime;\r\n      }else{\r\n        this.innerValue = undefined;\r\n      }\r\n\r\n      // console.log('this.datepickertime?.nativeElement', this.datepickertime?.nativeElement);\r\n\r\n      // if(this.datepickertime && this.datepickertime.nativeElement){\r\n      //   const elem = <any> this.datepickertime.nativeElement;\r\n      //   elem.value = this.innerValue;\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    }else{\r\n\r\n      this.description_options_date_time = '';\r\n      this.value_options_date_time = '';\r\n\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    if( `${this.last_options_date_time}` !== `${this.innerValue}` ){\r\n      // this.description_options_date_time = '';\r\n      // this.value_options_date_time = '';\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\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 = '00';\r\n    this.MM = '00';\r\n    this.description_options_date_time = '';\r\n    this.value_options_date_time = '';\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    document.getElementById(id)?.focus();\r\n  }\r\n\r\n  onClosedOptionsDateTime(){\r\n    this.open_options_date_time = false\r\n  }\r\n\r\n  \r\n  onChangeOptionsDateTime(event: any){\r\n    // this.description_options_date_time = '';\r\n    // this.value_options_date_time = '';\r\n    this.show_date_picker = false;\r\n\r\n    let now = new Date();\r\n    let filter_date: any = undefined;\r\n    if( event === '7-days' ){\r\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 7 ) );  \r\n      filter_date = new Date( (filter_date).setSeconds(0) );      \r\n    }\r\n\r\n    if( event === '15-days' ){\r\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 15 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === '30-days' ){\r\n      filter_date = new Date( (new Date(now)).setDate( now.getDate() - 30 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === 'current-month' ){\r\n      filter_date = new Date(now.getFullYear(), now.getMonth(), 1);\r\n    }\r\n\r\n    if( event === 'current-year' ){\r\n      filter_date = new Date(now.getFullYear(), 0, 1);\r\n    }\r\n\r\n    if(filter_date){      \r\n      this.innerValue = filter_date;\r\n      if( this.checkIsDate(filter_date) ){              \r\n        setTimeout(() => {\r\n          this.to_date_hh_mm(filter_date);\r\n          this.toSetDate(this.DD_MM_YYYY);  \r\n          this.show_date_picker = true;\r\n          this.value_options_date_time = event;\r\n          this.last_options_date_time = filter_date as any;\r\n          this.description_options_date_time = this.get_description_options_date_time(event);\r\n        });       \r\n      }\r\n    }\r\n\r\n  }\r\n\r\n\r\n  get_description_options_date_time(value: string){\r\n    if( this.options_date_time && (this.options_date_time).length > 0 ){\r\n      for( let i = 0; i < (this.options_date_time).length; i++ ){\r\n        const item = this.options_date_time[i];\r\n        if( item.value === value ){\r\n          return item.description;\r\n        }\r\n      }\r\n    }\r\n    return '';\r\n  }\r\n\r\n\r\n  closedTimeDescription(){\r\n    this.value_options_date_time = '';\r\n    this.description_options_date_time = ''; \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    if (v !== 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\r\n      try {\r\n        value = new Date( `${value}` );\r\n      } catch (error) {}\r\n\r\n      this.innerValue = value;\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","<div class=\"tcloud-ui-datepicker-time\">\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\r\n        <table style=\"width: 100%;\">\r\n          <tr>\r\n            <td>\r\n\r\n              <div class=\"input-options-date\">\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\">\r\n                    <ng-container *ngIf=\"show_date_picker\">\r\n                      <tcloud-ui-datepicker #_tclouddatepickertime [childInputDateTime]=\"true\" [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker>\r\n                    </ng-container>\r\n                  </td>\r\n                  \r\n                  <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n                  <td class=\"area-input-hour\">\r\n                    <!--<input type=\"text\" placeholder=\"HH\" (keyup)=\"toSetTime()\" [(ngModel)]=\"HH\" maxlength=\"2\" name=\"hh\" pattern=\"[0][0-9]|[1][0-9]|2[0-3]\">-->\r\n                    <select class=\"select-time-date\" (change)=\"toSetTime()\" [(ngModel)]=\"HH\" name=\"hh\">\r\n                      <ng-container *ngFor=\"let hh of option_HH\">\r\n                        <option [ngValue]=\"hh\">{{ hh }}</option>\r\n                      </ng-container>\r\n                    </select>\r\n                  </td>\r\n                  <td class=\"area-delimiter\"><div class=\"delimiter-time\">:</div></td>\r\n                  <td class=\"area-input-minute\">\r\n                    <!--<input type=\"text\" placeholder=\"MM\" (keyup)=\"toSetTime()\" [(ngModel)]=\"MM\" maxlength=\"2\" name=\"mm\" pattern=\"[012345][0-9]\">-->\r\n                    <select class=\"select-time-date\" (change)=\"toSetTime()\" [(ngModel)]=\"MM\" name=\"mm\">\r\n                      <ng-container *ngFor=\"let mm of option_MM\">\r\n                        <option [value]=\"mm\">{{ mm }}</option>\r\n                      </ng-container>\r\n                    </select>\r\n                  </td>\r\n                  <td class=\"area-clean\"></td>\r\n                </tr>\r\n              </table>\r\n\r\n              <div class=\"description-options-date\" *ngIf=\"value_options_date_time !== ''\">\r\n                <strong>{{ description_options_date_time }}</strong>\r\n\r\n                  <!-- <div class=\"area-action-date-time-selected\">\r\n                    <button class=\"btn-icon\" type=\"button\" (click)=\"closedTimeDescription()\" >\r\n                      <i class=\"fas fa-times\"></i>\r\n                    </button>                  \r\n                  </div> -->\r\n              </div>\r\n\r\n\r\n            </div>\r\n\r\n            </td>\r\n            <td *ngIf=\"useOptionsDateTime && options_date_time && (options_date_time).length > 0\" style=\"width: 20px\">\r\n              <button type=\"button\" class=\"icon-short-time\" (click)=\"open_options_date_time = !open_options_date_time\" [title]=\"description_options_date_time\" >\r\n                <i *ngIf=\"!open_options_date_time\" class=\"fas fa-caret-down\"></i>\r\n                <i *ngIf=\"open_options_date_time\" class=\"fas fa-caret-up\"></i>\r\n              </button>\r\n\r\n              <ng-container *ngIf=\"value_options_date_time !== ''\">\r\n                <button class=\"btn-icon-close\" type=\"button\" (click)=\"closedTimeDescription()\" >\r\n                  <i class=\"fas fa-times\"></i>\r\n                </button> \r\n              </ng-container>\r\n\r\n            </td>\r\n          </tr>\r\n          <tr *ngIf=\"useOptionsDateTime && options_date_time && (options_date_time).length > 0 && open_options_date_time\">\r\n            <td colspan=\"2\">\r\n                <tcloud-ui-data-list \r\n                  name=\"value_options_date_time\"\r\n                  [showInput]=\"false\" \r\n                  [search]=\"false\" \r\n                  [open]=\"true\" \r\n                  [listItems]=\"options_date_time\" \r\n                  (onClosed)=\"onClosedOptionsDateTime()\"\r\n                  [ngModel]=\"value_options_date_time\"\r\n                  (ngModelChange)=\"onChangeOptionsDateTime($event)\"\r\n                  >\r\n                </tcloud-ui-data-list>\r\n\r\n                \r\n\r\n\r\n              \r\n            </td>\r\n          </tr>\r\n        </table>\r\n\r\n        \r\n      </div>\r\n    </div>\r\n  </form>\r\n</div>"]}
|
package/esm2020/lib/_modules/tcloud-ui-filters/components/range-date/range-date.component.mjs
CHANGED
|
@@ -89,8 +89,8 @@ export class TCloudUiRangeDateComponent {
|
|
|
89
89
|
}
|
|
90
90
|
if (filter_date) {
|
|
91
91
|
this.result = {
|
|
92
|
-
start: this.
|
|
93
|
-
stop: this.
|
|
92
|
+
start: this.getTransformDate(filter_date),
|
|
93
|
+
stop: this.getTransformDate(now)
|
|
94
94
|
};
|
|
95
95
|
this.onChange.emit(this.result);
|
|
96
96
|
this.isValid = true;
|
|
@@ -101,19 +101,22 @@ export class TCloudUiRangeDateComponent {
|
|
|
101
101
|
this.isValid = false;
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
|
-
|
|
104
|
+
getTransformDate(dt) {
|
|
105
|
+
//return (dt).toLocaleString('pt-BR');
|
|
106
|
+
return dt;
|
|
107
|
+
/*
|
|
105
108
|
const ano = dt.getFullYear();
|
|
106
109
|
const mes = dt.getMonth();
|
|
107
110
|
const dia = dt.getDate();
|
|
108
111
|
const horas = dt.getHours();
|
|
109
112
|
const minutos = dt.getMinutes();
|
|
110
|
-
|
|
111
|
-
|
|
113
|
+
return new Date(Date.UTC(ano, mes, dia, horas, minutos));
|
|
114
|
+
*/
|
|
112
115
|
}
|
|
113
116
|
onChangeStartDateTime(event) {
|
|
114
117
|
this.isValid = false;
|
|
115
118
|
if (this.result && this.result.start) {
|
|
116
|
-
this.result.start = event.value;
|
|
119
|
+
this.result.start = event.value = this.getTransformDate(event.value);
|
|
117
120
|
this.onChange.emit(this.result);
|
|
118
121
|
this.isValid = true;
|
|
119
122
|
}
|
|
@@ -125,7 +128,7 @@ export class TCloudUiRangeDateComponent {
|
|
|
125
128
|
onChangeStopDateTime(event) {
|
|
126
129
|
this.isValid = false;
|
|
127
130
|
if (this.result && this.result.stop) {
|
|
128
|
-
this.result.
|
|
131
|
+
this.result.stop = event.value = this.getTransformDate(event.value);
|
|
129
132
|
this.onChange.emit(this.result);
|
|
130
133
|
this.isValid = true;
|
|
131
134
|
}
|
|
@@ -203,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
203
206
|
}], descriptionStop: [{
|
|
204
207
|
type: Input
|
|
205
208
|
}] } });
|
|
206
|
-
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAe,aAAa,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;;AAE/E,MAAO,uBAAuB,GAAQ;IACpC,OAAO,EAAE,aAAa;IACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;IACzD,KAAK,EAAE,IAAI;CACZ,CAAA;AAED,MAAM,mCAAmC,GAAQ;IAC/C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;IACzD,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF,MAAM,IAAI,GAAG,GAAG,EAAE;AAClB,CAAC,CAAC;AAcF,MAAM,OAAO,0BAA0B;IAmBrC;QAjBA,WAAM,GAAG,EAAqB,CAAC;QAE/B,sBAAiB,GAAQ,EAAE,CAAC;QAC5B,4BAAuB,GAAY,KAAK,CAAC;QAE/B,aAAQ,GAAG,IAAI,YAAY,EAAmB,CAAC;QAEhD,gCAA2B,GAAW,EAAE,CAAC;QAGzC,qBAAgB,GAAW,EAAE,CAAC;QAC9B,oBAAe,GAAW,EAAE,CAAC;QAEtC,SAAI,GAAW,QAAQ,CAAC;QAExB,YAAO,GAAG,KAAK,CAAC;QA2KhB,0DAA0D;QAC1D,+BAA+B;QACvB,sBAAiB,GAAe,IAAI,CAAC;QACrC,qBAAgB,GAAqB,IAAI,CAAC;IA5KlC,CAAC;IAEjB,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,iBAAiB,GAAG;YACvB,EAAC,KAAK,EAAC,aAAa,EAAE,WAAW,EAAE,eAAe,EAAC;YACnD,EAAC,KAAK,EAAC,aAAa,EAAE,WAAW,EAAE,iBAAiB,EAAC;YACrD,EAAC,KAAK,EAAC,cAAc,EAAE,WAAW,EAAE,kBAAkB,EAAC;YAEvD,EAAC,KAAK,EAAC,QAAQ,EAAE,WAAW,EAAE,gBAAgB,EAAC;YAC/C,EAAC,KAAK,EAAC,SAAS,EAAE,WAAW,EAAE,iBAAiB,EAAC;YACjD,EAAC,KAAK,EAAC,SAAS,EAAE,WAAW,EAAE,iBAAiB,EAAC;YACjD,EAAC,KAAK,EAAC,eAAe,EAAE,WAAW,EAAE,WAAW,EAAC;YACjD,EAAC,KAAK,EAAC,cAAc,EAAE,WAAW,EAAE,WAAW,EAAC;SACjD,CAAA;QACD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,2BAA2B,KAAK,EAAE,EAAE;gBAC3C,IAAI,CAAC,uBAAuB,CAAE,IAAI,CAAC,2BAA2B,CAAE,CAAC;aAClE;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,uBAAuB,CAAC,KAAU;QAChC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,2CAA2C;QAC3C,qCAAqC;QACrC,KAAK,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAE5C,IAAI,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACrB,IAAI,YAAY,GAAG,IAAI,IAAI,EAAE,CAAC;QAC9B,IAAI,WAAW,GAAQ,SAAS,CAAC;QAGjC,IAAI,KAAK,KAAK,aAAa,EAAE;YAC3B,WAAW,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;SACrE;QAED,IAAI,KAAK,KAAK,aAAa,EAAE;YAC3B,WAAW,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;SACrE;QAED,IAAI,KAAK,KAAK,cAAc,EAAE;YAC5B,WAAW,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;SACtE;QAED,IAAI,KAAK,KAAK,QAAQ,EAAE;YACtB,WAAW,GAAG,IAAI,IAAI,CAAE,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAE,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,CAAE,CAAE,CAAC;YAChF,WAAW,GAAG,IAAI,IAAI,CAAE,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAE,CAAC;SACvD;QAED,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,WAAW,GAAG,IAAI,IAAI,CAAE,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAE,GAAG,CAAC,OAAO,EAAE,GAAG,EAAE,CAAE,CAAE,CAAC;YACjF,WAAW,GAAG,IAAI,IAAI,CAAE,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAE,CAAC;SACvD;QAED,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,WAAW,GAAG,IAAI,IAAI,CAAE,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAE,GAAG,CAAC,OAAO,EAAE,GAAG,EAAE,CAAE,CAAE,CAAC;YACjF,WAAW,GAAG,IAAI,IAAI,CAAE,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAE,CAAC;SACvD;QAED,IAAI,KAAK,KAAK,eAAe,EAAE;YAC7B,WAAW,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;SAC9D;QAED,IAAI,KAAK,KAAK,cAAc,EAAE;YAC5B,WAAW,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;SACjD;QAED,IAAG,WAAW,EAAC;YACb,IAAI,CAAC,MAAM,GAAG;gBACZ,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;gBACnC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;aACR,CAAC;YAErB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;aAAI;YAEH,IAAI,CAAC,MAAM,GAAG,EAAqB,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAChC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SAEtB;IAEH,CAAC;IAED,UAAU,CAAC,EAAO;QAChB,MAAM,GAAG,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;QAC7B,MAAM,GAAG,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC;QAC1B,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC;QACzB,MAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC;QAC5B,MAAM,OAAO,GAAG,EAAE,CAAC,UAAU,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,EAAE,CAAC,UAAU,EAAE,CAAC;QACjC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,EAAC;YACnC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;aAAI;YACH,IAAI,CAAC,MAAM,GAAG,EAAqB,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACjC;IACH,CAAC;IAED,oBAAoB,CAAC,KAAU;QAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YACnC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;aAAI;YACH,IAAI,CAAC,MAAM,GAAG,EAAqB,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACjC;IACH,CAAC;IAED,MAAM;QACJ,MAAM,IAAI,GAAG,CAAE,GAAG,IAAI,CAAC,IAAI,EAAE,KAAK,QAAQ,CAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC;QACxE,IAAI,CAAC,2BAA2B,GAAG,EAAE,CAAC;QACtC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,EAAqB,CAAC;QACpC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IA2CD,cAAc;IACd,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAAA,CAAC;IAEF,mDAAmD;IACnD,IAAI,KAAK,CAAC,CAAM;QACd,IAAI,CAAC,KAAK,IAAI,CAAC,UAAU,EAAE;YACzB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACpB,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;SAC1B;IACH,CAAC;IAED,qBAAqB;IACrB,MAAM;QACJ,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,qCAAqC;IACrC,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,EAAE;YAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,2BAA2B;SAC5B;IACH,CAAC;IAED,qCAAqC;IACrC,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,qCAAqC;IACrC,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAEM,QAAQ,CAAC,CAAc;QAC5B,IAAI,CAAC,IAAI,CAAE,OAAO,IAAI,CAAC,QAAQ,KAAK,WAAW,CAAE,EAAE;YACjD,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC;YACpC,OAAO,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC;SACpD;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YACxD,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;;wHAlPU,0BAA0B;4GAA1B,0BAA0B,gPAF1B,CAAC,mCAAmC,EAAE,uBAAuB,CAAC,0BC5B3E,ynFAqDQ;4FDvBK,0BAA0B;kBANtC,SAAS;+BACE,YAAY,aAGX,CAAC,mCAAmC,EAAE,uBAAuB,CAAC;0EAS/D,QAAQ;sBAAjB,MAAM;gBAEE,2BAA2B;sBAAnC,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACG,eAAe;sBAAvB,KAAK","sourcesContent":["import { Component, Input, OnInit, Output, EventEmitter, forwardRef } from '@angular/core';\r\nimport { FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nconst  CUSTOM_INPUT_VALIDATORS: any = { \r\n  provide: NG_VALIDATORS, \r\n  useExisting: forwardRef(() => TCloudUiRangeDateComponent),\r\n  multi: true\r\n}\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiRangeDateComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n\r\ninterface IResultDateTime{\r\n  start: any;\r\n  stop: any;\r\n}\r\n\r\n@Component({\r\n  selector: 'range-date',\r\n  templateUrl: './range-date.component.html',\r\n  styleUrls: ['./range-date.component.scss'],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS]\r\n})\r\nexport class TCloudUiRangeDateComponent implements OnInit {\r\n\r\n  result = {} as IResultDateTime;\r\n\r\n  options_date_time: any = [];\r\n  use_validation_required: boolean = false;\r\n\r\n  @Output() onChange = new EventEmitter<IResultDateTime>();\r\n\r\n  @Input() defaultValuePeriodStartStop: string = '';\r\n  @Input() required: string | undefined;\r\n\r\n  @Input() descriptionStart: string = '';\r\n  @Input() descriptionStop: string = '';\r\n\r\n  mode: string = 'select';\r\n\r\n  isValid = false;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.setOptionsDateTime();\r\n  }\r\n\r\n  setOptionsDateTime(){\r\n    this.options_date_time = [\r\n      {value:'1-last-time', description: 'Última 1 hora'},\r\n      {value:'3-last-time', description: 'Últimas 3 horas'},\r\n      {value:'24-last-time', description: 'Últimas 24 horas'},\r\n\r\n      {value:'7-days', description: 'Últimos 7 dias'},\r\n      {value:'15-days', description: 'Últimos 15 dias'},\r\n      {value:'30-days', description: 'Últimos 30 dias'},\r\n      {value:'current-month', description: 'Mês atual'},\r\n      {value:'current-year', description: 'Ano atual'}\r\n    ]\r\n    setTimeout(() => {\r\n      if( this.defaultValuePeriodStartStop !== '' ){\r\n        this.onChangeOptionsDateTime( this.defaultValuePeriodStartStop );\r\n      }\r\n    });\r\n    \r\n  }\r\n\r\n  onChangeOptionsDateTime(event: any){\r\n    this.isValid = false;\r\n    // this.description_options_date_time = '';\r\n    // this.value_options_date_time = '';\r\n    event = (event.value) ? event.value : event;\r\n\r\n    let now = new Date();\r\n    let current_date = new Date();\r\n    let filter_date: any = undefined;\r\n\r\n\r\n    if( event === '1-last-time' ){\r\n      filter_date = new Date(current_date.getTime() - 1 * 60 * 60 * 1000);\r\n    }\r\n\r\n    if( event === '3-last-time' ){\r\n      filter_date = new Date(current_date.getTime() - 3 * 60 * 60 * 1000);\r\n    }\r\n\r\n    if( event === '24-last-time' ){\r\n      filter_date = new Date(current_date.getTime() - 24 * 60 * 60 * 1000);\r\n    }\r\n\r\n    if( event === '7-days' ){\r\n      filter_date = new Date( (new Date(current_date)).setDate( now.getDate() - 7 ) );  \r\n      filter_date = new Date( (filter_date).setSeconds(0) );      \r\n    }\r\n\r\n    if( event === '15-days' ){\r\n      filter_date = new Date( (new Date(current_date)).setDate( now.getDate() - 15 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === '30-days' ){\r\n      filter_date = new Date( (new Date(current_date)).setDate( now.getDate() - 30 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === 'current-month' ){\r\n      filter_date = new Date(now.getFullYear(), now.getMonth(), 1);\r\n    }\r\n\r\n    if( event === 'current-year' ){\r\n      filter_date = new Date(now.getFullYear(), 0, 1);\r\n    }\r\n\r\n    if(filter_date){        \r\n      this.result = {\r\n        start: this.getDateUTC(filter_date),\r\n        stop: this.getDateUTC(now)\r\n      } as IResultDateTime;\r\n\r\n      this.onChange.emit(this.result);\r\n      this.isValid = true;\r\n    }else{\r\n       \r\n      this.result = {} as IResultDateTime;\r\n      this.onChange.emit(this.result);\r\n      this.isValid = false;\r\n      \r\n    }\r\n\r\n  }\r\n\r\n  getDateUTC(dt: any){\r\n    const ano = dt.getFullYear();\r\n    const mes = dt.getMonth();\r\n    const dia = dt.getDate();\r\n    const horas = dt.getHours();\r\n    const minutos = dt.getMinutes();\r\n    const segundos = dt.getSeconds();\r\n    return new Date(Date.UTC(ano, mes, dia, horas, minutos, segundos));\r\n  }\r\n\r\n  onChangeStartDateTime(event: any){\r\n    this.isValid = false;\r\n    if( this.result && this.result.start){\r\n      this.result.start = event.value;\r\n      this.onChange.emit(this.result);\r\n      this.isValid = true;\r\n    }else{\r\n      this.result = {} as IResultDateTime;\r\n      this.onChange.emit(this.result);\r\n    }\r\n  }\r\n\r\n  onChangeStopDateTime(event: any){\r\n    this.isValid = false;\r\n    if( this.result && this.result.stop ){\r\n      this.result.start = event.value;\r\n      this.onChange.emit(this.result);\r\n      this.isValid = true;\r\n    }else{\r\n      this.result = {} as IResultDateTime;\r\n      this.onChange.emit(this.result);\r\n    }\r\n  }\r\n\r\n  toggle(){\r\n    const mode = ( `${this.mode}` === 'select' ) ? 'datepickers' : 'select';\r\n    this.defaultValuePeriodStartStop = '';\r\n    this.isValid = false;\r\n    this.result = {} as IResultDateTime;\r\n    this.mode = mode;\r\n    this.onChange.emit(this.result);\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\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    if (v !== 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      //this.toSetDefault(value);\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  public validate(c: FormControl): any {\r\n    if( c && ( typeof this.required !== 'undefined' ) ){\r\n      this.use_validation_required = true;\r\n      return (this.check_is_valid()) ? null : 'required';\r\n    }\r\n    return null;\r\n  }\r\n\r\n  check_is_valid(): boolean{\r\n    if( this.result && this.result.start && this.result.stop ){\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n}\r\n","<table class=\"tcloud-ui-filters-range-date area-range-date\">\r\n    <tr>\r\n\r\n        <td>\r\n            <div *ngIf=\"mode === 'select'\">\r\n                <div class=\"description-period\">Período</div>\r\n                <select name=\"periodo\" class=\"form-control tc-form-control\" (change)=\"onChangeOptionsDateTime($event.target)\" [(ngModel)]=\"defaultValuePeriodStartStop\"  >\r\n                    <option value=\"\"></option> \r\n                    <ng-container *ngFor=\"let item of options_date_time\">\r\n                        <option [value]=\"item.value\">{{ item.description }}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div *ngIf=\"mode === 'datepickers'\">\r\n\r\n                <table class=\"area-range-datepickers\">\r\n                    <tr>\r\n                        <td>\r\n                            <div class=\"description-start\">{{ descriptionStart }}</div>\r\n                            <tcloud-ui-datepicker-time \r\n                                #_input_start \r\n                                [(ngModel)]=\"result.start\" \r\n                                name=\"input_start\" \r\n                                (eventChange)=\"onChangeStartDateTime(_input_start)\">\r\n                            </tcloud-ui-datepicker-time>\r\n                        </td>\r\n                        <td>\r\n                            <div class=\"description-stop\">{{ descriptionStop }}</div>\r\n                            <tcloud-ui-datepicker-time \r\n                                #_input_stop\r\n                                [(ngModel)]=\"result.stop\" \r\n                                name=\"input_stop\" \r\n                                (eventChange)=\"onChangeStopDateTime(_input_stop)\">\r\n                            </tcloud-ui-datepicker-time>\r\n                        </td>\r\n                    </tr>\r\n                </table>\r\n\r\n            </div>\r\n        </td>\r\n\r\n        <td>\r\n            <button class=\"btn-mode-range-date\" [class.active]=\"mode === 'select'\" (click)=\"toggle()\" type=\"button\">\r\n\r\n                <i *ngIf=\"mode === 'select'\" class=\"far fa-calendar-alt\" title=\"Alterar para calendário\"></i>\r\n                <i *ngIf=\"mode !== 'select'\" class=\"fas fa-calendar-week\" title=\"Selecionar período\"></i>\r\n\r\n                <!-- <div *ngIf=\"mode === 'select'\">Exibir<br>Calendário</div> -->\r\n                <!-- <div *ngIf=\"mode !== 'select'\">Exibir<br>Período</div> -->\r\n            </button>\r\n        </td>\r\n\r\n    </tr>\r\n</table>"]}
|
|
209
|
+
//# 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';\r\nimport { FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nconst  CUSTOM_INPUT_VALIDATORS: any = { \r\n  provide: NG_VALIDATORS, \r\n  useExisting: forwardRef(() => TCloudUiRangeDateComponent),\r\n  multi: true\r\n}\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiRangeDateComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n\r\ninterface IResultDateTime{\r\n  start: any;\r\n  stop: any;\r\n}\r\n\r\n@Component({\r\n  selector: 'range-date',\r\n  templateUrl: './range-date.component.html',\r\n  styleUrls: ['./range-date.component.scss'],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS]\r\n})\r\nexport class TCloudUiRangeDateComponent implements OnInit {\r\n\r\n  result = {} as IResultDateTime;\r\n\r\n  options_date_time: any = [];\r\n  use_validation_required: boolean = false;\r\n\r\n  @Output() onChange = new EventEmitter<IResultDateTime>();\r\n\r\n  @Input() defaultValuePeriodStartStop: string = '';\r\n  @Input() required: string | undefined;\r\n\r\n  @Input() descriptionStart: string = '';\r\n  @Input() descriptionStop: string = '';\r\n\r\n  mode: string = 'select';\r\n\r\n  isValid = false;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.setOptionsDateTime();\r\n  }\r\n\r\n  setOptionsDateTime(){\r\n    this.options_date_time = [\r\n      {value:'1-last-time', description: 'Última 1 hora'},\r\n      {value:'3-last-time', description: 'Últimas 3 horas'},\r\n      {value:'24-last-time', description: 'Últimas 24 horas'},\r\n\r\n      {value:'7-days', description: 'Últimos 7 dias'},\r\n      {value:'15-days', description: 'Últimos 15 dias'},\r\n      {value:'30-days', description: 'Últimos 30 dias'},\r\n      {value:'current-month', description: 'Mês atual'},\r\n      {value:'current-year', description: 'Ano atual'}\r\n    ]\r\n    setTimeout(() => {\r\n      if( this.defaultValuePeriodStartStop !== '' ){\r\n        this.onChangeOptionsDateTime( this.defaultValuePeriodStartStop );\r\n      }\r\n    });\r\n    \r\n  }\r\n\r\n  onChangeOptionsDateTime(event: any){\r\n    this.isValid = false;\r\n    // this.description_options_date_time = '';\r\n    // this.value_options_date_time = '';\r\n    event = (event.value) ? event.value : event;\r\n\r\n    let now = new Date();\r\n    let current_date = new Date();\r\n    let filter_date: any = undefined;\r\n\r\n\r\n    if( event === '1-last-time' ){\r\n      filter_date = new Date(current_date.getTime() - 1 * 60 * 60 * 1000);\r\n    }\r\n\r\n    if( event === '3-last-time' ){\r\n      filter_date = new Date(current_date.getTime() - 3 * 60 * 60 * 1000);\r\n    }\r\n\r\n    if( event === '24-last-time' ){\r\n      filter_date = new Date(current_date.getTime() - 24 * 60 * 60 * 1000);\r\n    }\r\n\r\n    if( event === '7-days' ){\r\n      filter_date = new Date( (new Date(current_date)).setDate( now.getDate() - 7 ) );  \r\n      filter_date = new Date( (filter_date).setSeconds(0) );      \r\n    }\r\n\r\n    if( event === '15-days' ){\r\n      filter_date = new Date( (new Date(current_date)).setDate( now.getDate() - 15 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === '30-days' ){\r\n      filter_date = new Date( (new Date(current_date)).setDate( now.getDate() - 30 ) );\r\n      filter_date = new Date( (filter_date).setSeconds(0) );\r\n    }\r\n\r\n    if( event === 'current-month' ){\r\n      filter_date = new Date(now.getFullYear(), now.getMonth(), 1);\r\n    }\r\n\r\n    if( event === 'current-year' ){\r\n      filter_date = new Date(now.getFullYear(), 0, 1);\r\n    }\r\n\r\n    if(filter_date){        \r\n      this.result = {\r\n        start: this.getTransformDate(filter_date),\r\n        stop: this.getTransformDate(now)\r\n      } as IResultDateTime;\r\n\r\n      this.onChange.emit(this.result);\r\n      this.isValid = true;\r\n    }else{\r\n       \r\n      this.result = {} as IResultDateTime;\r\n      this.onChange.emit(this.result);\r\n      this.isValid = false;\r\n      \r\n    }\r\n\r\n  }\r\n\r\n  getTransformDate(dt: any){\r\n    //return (dt).toLocaleString('pt-BR');\r\n    return dt;\r\n    /*\r\n    const ano = dt.getFullYear();\r\n    const mes = dt.getMonth();\r\n    const dia = dt.getDate();\r\n    const horas = dt.getHours();\r\n    const minutos = dt.getMinutes();\r\n    return new Date(Date.UTC(ano, mes, dia, horas, minutos));\r\n    */\r\n  }\r\n\r\n  onChangeStartDateTime(event: any){\r\n    this.isValid = false;\r\n    if( this.result && this.result.start){\r\n      this.result.start = event.value = this.getTransformDate(event.value);\r\n      this.onChange.emit(this.result);\r\n      this.isValid = true;\r\n    }else{\r\n      this.result = {} as IResultDateTime;\r\n      this.onChange.emit(this.result);\r\n    }\r\n  }\r\n\r\n  onChangeStopDateTime(event: any){\r\n    this.isValid = false;\r\n    if( this.result && this.result.stop ){\r\n      this.result.stop = event.value = this.getTransformDate(event.value);\r\n      this.onChange.emit(this.result);\r\n      this.isValid = true;\r\n    }else{\r\n      this.result = {} as IResultDateTime;\r\n      this.onChange.emit(this.result);\r\n    }\r\n  }\r\n\r\n  toggle(){\r\n    const mode = ( `${this.mode}` === 'select' ) ? 'datepickers' : 'select';\r\n    this.defaultValuePeriodStartStop = '';\r\n    this.isValid = false;\r\n    this.result = {} as IResultDateTime;\r\n    this.mode = mode;\r\n    this.onChange.emit(this.result);\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\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    if (v !== 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      //this.toSetDefault(value);\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  public validate(c: FormControl): any {\r\n    if( c && ( typeof this.required !== 'undefined' ) ){\r\n      this.use_validation_required = true;\r\n      return (this.check_is_valid()) ? null : 'required';\r\n    }\r\n    return null;\r\n  }\r\n\r\n  check_is_valid(): boolean{\r\n    if( this.result && this.result.start && this.result.stop ){\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n}\r\n","<table class=\"tcloud-ui-filters-range-date area-range-date\">\r\n    <tr>\r\n\r\n        <td>\r\n            <div *ngIf=\"mode === 'select'\">\r\n                <div class=\"description-period\">Período</div>\r\n                <select name=\"periodo\" class=\"form-control tc-form-control\" (change)=\"onChangeOptionsDateTime($event.target)\" [(ngModel)]=\"defaultValuePeriodStartStop\"  >\r\n                    <option value=\"\"></option> \r\n                    <ng-container *ngFor=\"let item of options_date_time\">\r\n                        <option [value]=\"item.value\">{{ item.description }}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div *ngIf=\"mode === 'datepickers'\">\r\n\r\n                <table class=\"area-range-datepickers\">\r\n                    <tr>\r\n                        <td>\r\n                            <div class=\"description-start\">{{ descriptionStart }}</div>\r\n                            <tcloud-ui-datepicker-time \r\n                                #_input_start \r\n                                [(ngModel)]=\"result.start\" \r\n                                name=\"input_start\" \r\n                                (eventChange)=\"onChangeStartDateTime(_input_start)\">\r\n                            </tcloud-ui-datepicker-time>\r\n                        </td>\r\n                        <td>\r\n                            <div class=\"description-stop\">{{ descriptionStop }}</div>\r\n                            <tcloud-ui-datepicker-time \r\n                                #_input_stop\r\n                                [(ngModel)]=\"result.stop\" \r\n                                name=\"input_stop\" \r\n                                (eventChange)=\"onChangeStopDateTime(_input_stop)\">\r\n                            </tcloud-ui-datepicker-time>\r\n                        </td>\r\n                    </tr>\r\n                </table>\r\n\r\n            </div>\r\n        </td>\r\n\r\n        <td>\r\n            <button class=\"btn-mode-range-date\" [class.active]=\"mode === 'select'\" (click)=\"toggle()\" type=\"button\">\r\n\r\n                <i *ngIf=\"mode === 'select'\" class=\"far fa-calendar-alt\" title=\"Alterar para calendário\"></i>\r\n                <i *ngIf=\"mode !== 'select'\" class=\"fas fa-calendar-week\" title=\"Selecionar período\"></i>\r\n\r\n                <!-- <div *ngIf=\"mode === 'select'\">Exibir<br>Calendário</div> -->\r\n                <!-- <div *ngIf=\"mode !== 'select'\">Exibir<br>Período</div> -->\r\n            </button>\r\n        </td>\r\n\r\n    </tr>\r\n</table>"]}
|