@dev-tcloud/tcloud-ui 0.0.62 → 0.0.64
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/README.md +1 -0
- package/esm2020/lib/_modules/tcloud-ui-data-list/tcloud-ui-data-list.component.mjs +1 -1
- package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.mjs +3 -3
- package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.mjs +26 -10
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.mjs +2 -2
- package/esm2020/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.component.mjs +289 -0
- package/esm2020/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.module.mjs +31 -0
- package/esm2020/lib/tcloud-ui.module.mjs +8 -1
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/dev-tcloud-tcloud-ui.mjs +380 -46
- package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/fesm2020/dev-tcloud-tcloud-ui.mjs +377 -46
- package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.d.ts +3 -0
- package/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.component.d.ts +59 -0
- package/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.module.d.ts +9 -0
- package/lib/tcloud-ui.module.d.ts +4 -3
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
package/README.md
CHANGED
|
@@ -274,4 +274,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
274
274
|
}], ngModelChange: [{
|
|
275
275
|
type: Output
|
|
276
276
|
}] } });
|
|
277
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-data-list.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-data-list/tcloud-ui-data-list.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-data-list/tcloud-ui-data-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DataListService } from './services/data-list.service';\r\nimport { Component, forwardRef, OnInit, Output, EventEmitter, ViewChild, Input, OnDestroy, AfterViewChecked } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR, NgForm, FormGroup, FormBuilder, FormControl } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { ISelectOptions } from './tcloud-ui-data-list';\r\n\r\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDataListComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-data-list',\r\n  templateUrl: './tcloud-ui-data-list.component.html',\r\n  styleUrls: ['./tcloud-ui-data-list.component.scss'],\r\n  providers: [\r\n    DataListService, \r\n    CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR\r\n  ],\r\n})\r\nexport class TCloudUiDataListComponent implements OnInit, OnDestroy, AfterViewChecked {\r\n\r\n  viewport_width: number = 0;\r\n  viewport_height: number = 0;\r\n  box_height: number = 0;\r\n  box_style: string = '';\r\n  menu_on_top: string = '';\r\n\r\n  @Input() placeholder: string = '';\r\n\r\n  private _disabled: boolean = false;\r\n  @Input() set disabled(v){\r\n    if( v ){\r\n      this._disabled = v;    \r\n      this.selected_description = '';\r\n      this.selected_item ='';\r\n      this.toChange();\r\n    }\r\n  }\r\n  get disabled():boolean { return this._disabled; }\r\n\r\n  private _loading: boolean = false;\r\n  @Input() set loading(v){\r\n    if( v ){\r\n      this._loading = v;    \r\n      this.selected_description = '';\r\n      this.selected_item ='';\r\n      this.toChange();\r\n    }\r\n  }\r\n  get loading():boolean { return this._loading; }\r\n\r\n\r\n  @Input() search: boolean = true;\r\n  \r\n\r\n  @Output() onInputChange = new EventEmitter<ISelectOptions>();\r\n  @Output() onChange = new EventEmitter<ISelectOptions>();\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n    this.selected_item = v;    \r\n    this.selectDescription();   \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<any>();\r\n\r\n  list_selected_options = new Array<ISelectOptions>();\r\n\r\n  selected_item: any | undefined;\r\n  selected_description: any | undefined;\r\n\r\n  private subscription_value: Subscription | undefined;\r\n  private subscription_description: Subscription | undefined;\r\n  private subscription_options: Subscription | undefined;\r\n\r\n  menu_show: boolean = false;\r\n  search_text: string = '';\r\n  id: string = '';\r\n\r\n  formulario: FormGroup | undefined;\r\n\r\n  constructor(\r\n    private dataListService: DataListService,\r\n    private formBuilder: FormBuilder\r\n  ){\r\n  }\r\n\r\n  ngOnInit(){\r\n    this.id = this.generateID();\r\n\r\n    this.formulario = this.formBuilder.group({\r\n      \"selected_item\": new FormControl('',[]),\r\n    })\r\n\r\n    this.subscription_value = this.dataListService.stateValue$.subscribe(v => {\r\n      this.selected_item = v;      \r\n      this.selectDescription();\r\n      this.ngModelChange.emit(this.selected_item);\r\n    })\r\n\r\n    this.subscription_description = this.dataListService.stateDescription$.subscribe(v => {\r\n      this.selected_description = v;      \r\n    })\r\n\r\n\r\n    this.subscription_options = this.dataListService.stateOptions$.subscribe((v:any) => {\r\n      if( v && v.value ){\r\n        (this.list_selected_options).push(v);\r\n      }\r\n    })\r\n\r\n    this.toResize();\r\n    this.toClick();\r\n  }\r\n\r\n  t_fc: any | undefined;\r\n  ngAfterViewChecked(): void {\r\n    this.t_fc = undefined;\r\n    this.t_fc = this.get_selected_description();\r\n  }\r\n\r\n  get_selected_description(): void{\r\n    if( this.list_selected_options && (this.list_selected_options).length > 0 ){\r\n      for( let i = 0; i < (this.list_selected_options).length; i++ ){\r\n        const item = this.list_selected_options[i];\r\n        if( item.value === this.selected_item ){         \r\n          if( this.selected_description !== item.description ){\r\n            if( item.description && item.description !== this.selected_description ){\r\n              setTimeout(() => {\r\n                this.selected_description = item.description; \r\n                this.dataListService.setActiveItem(this.selected_item);\r\n              });\r\n            }\r\n          }        \r\n          break;\r\n        }\r\n      }\r\n    } \r\n  }\r\n\r\n  generateID(): string{\r\n    return `data-list-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if( this.subscription_value ){ this.subscription_value.unsubscribe(); }    \r\n    if( this.subscription_description ){ this.subscription_description.unsubscribe(); } \r\n    if( this.subscription_options ){ this.subscription_options.unsubscribe(); } \r\n  }\r\n\r\n  toSearch(e: any) {\r\n    let input = (e && e.target && e.target.value) ? e.target.value : '';\r\n    \r\n    let filter = ( ( (input).normalize('NFD').replace(/[\\u0300-\\u036f]/g, \"\") ).trim() ).toLowerCase();\r\n    let ul = <any> document.getElementById(`${this.id}-options`);\r\n    let li = ul.getElementsByTagName(\"button\");\r\n    for (let i = 0; i < li.length; i++) {\r\n        const a = li[i];\r\n        const txtValue = ( ( ( a.textContent || a.innerText ).normalize('NFD').replace(/[\\u0300-\\u036f]/g, \"\") ).trim() ).toLowerCase();\r\n        if (txtValue.indexOf(filter) > -1) {\r\n            li[i].style.display = \"\";\r\n        } else {\r\n            li[i].style.display = \"none\";\r\n        }\r\n    }\r\n  }\r\n\r\n  selectDescription(){\r\n    if( this.list_selected_options && (this.list_selected_options).length > 0 ){\r\n      for( let i = 0; i < (this.list_selected_options).length; i++ ){\r\n        const item = this.list_selected_options[i];\r\n        if( item.value === this.selected_item ){\r\n          this.selected_description = item.description;\r\n          this.toChange();\r\n          return;\r\n        }\r\n      }\r\n    }\r\n\r\n    if( this.selected_item === undefined || this.selected_item === null || this.selected_item === '' ){\r\n      this.selected_description = '';\r\n      this.toChange();\r\n    }\r\n    \r\n  }\r\n\r\n  \r\n  toInput(e: any){\r\n    this.onChange.emit(e);\r\n  }\r\n\r\n  toChange(){\r\n    setTimeout(() => {\r\n      if( this.selected_item === undefined || this.selected_item === null ){\r\n        this.selected_item = '';\r\n      }\r\n      this.toSearch('');\r\n      this.search_text = '';\r\n      this.dataListService.setActiveItem(this.selected_item);\r\n\r\n      this.onInputChange.emit(this.selected_description);\r\n\r\n      if( this.formulario ){\r\n        this.formulario?.get('selected_item')?.setValue(this.selected_item);\r\n        // const input_hidden = document.getElementById(`${this.id}-hidden`);\r\n        this.toInput(this.formulario.get('selected_item'));\r\n      }   \r\n    });\r\n  }\r\n\r\n\r\n  clearTextSearch(){\r\n    this.search_text = '';\r\n    this.toSearch('');\r\n  }\r\n\r\n  toOpen(){\r\n    this.menu_show = !this.menu_show;\r\n    this.resolve_position_dropdown(this.menu_show);\r\n  }\r\n\r\n  resolve_position_dropdown(open: boolean){\r\n    if( open ){\r\n      this.box_style = '';\r\n      this.menu_on_top = '';   \r\n      const id = `${this.id}`; \r\n      const box = `box-${this.id}`;\r\n      if( this.viewport_height === 0 ){\r\n        this.viewport_height = window.innerWidth;\r\n      }\r\n      const rect  = document.getElementById(id)?.getBoundingClientRect();\r\n      const box_position = rect?.bottom || 0;      \r\n      setTimeout(() => {\r\n        this.box_height  = document.getElementById(box)?.clientHeight || 0;\r\n        if( ( this.viewport_height - box_position) < this.box_height ){\r\n          this.menu_on_top = 'menu-on-top';\r\n          this.box_style = `top: -${ (this.box_height) }px; height: ${this.box_height}px;`;\r\n        }\r\n      });    \r\n    }\r\n  }\r\n\r\n  toClose(){\r\n    this.menu_show = false;\r\n  }\r\n\r\n\r\n  toResize(){\r\n    window.addEventListener('resize', () => {\r\n      this.viewport_width = window.innerWidth;\r\n      this.viewport_height = window.innerHeight;\r\n      this.resolve_position_dropdown(this.menu_show);\r\n    });\r\n  }\r\n\r\n  toClick(){\r\n    const box = `area-${this.id}`;\r\n    window.addEventListener('click',(e: any) => {   \r\n      if( this.menu_show ){\r\n        if( !(document.getElementById(box)?.contains(e.target)) ){        \r\n          this.menu_show = false;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  \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.selected_item;\r\n    };\r\n\r\n    //set accessor including call the onchange callback\r\n    set value(v: any) {\r\n        if (v !== this.selected_item) {\r\n            this.selected_item = 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.selected_item) {\r\n            this.selected_item = 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}\r\n\r\n","<div *ngIf=\"formulario\" id=\"area-{{ id }}\" class=\"tc-dropdown\" [class.disabled]=\"disabled || loading\">\r\n  <div *ngIf=\"loading\" class=\"loading-area\">\r\n    <i class=\"fas fa-spinner fa-spin\"></i>\r\n  </div>\r\n  <!-- [attr.data-bs-toggle]=\"'dropdown'\"  -->\r\n  <button \r\n    [class.loading-box]=\"loading\"\r\n    [disabled]=\"disabled || loading\"\r\n    class=\"dropdown-toggle button-select no-margin-bottom\" \r\n    type=\"button\" \r\n    id=\"{{ id }}\" \r\n    \r\n    [attr.aria-haspopup]=\"'true'\" \r\n    [attr.aria-expanded]=\"'false'\" \r\n    (click)=\"toOpen()\" >\r\n\r\n    <i *ngIf=\"(selected_description === undefined || selected_description === null || selected_description === '' ) && !loading \">{{ placeholder }}</i>\r\n    {{ selected_description }}\r\n    <span><i class=\"fas fa-angle-down\"></i></span>\r\n  </button>\r\n  <div class=\"tc-dropdown-menu {{ menu_on_top }}\" id=\"box-{{ id }}\" [attr.aria-labelledby]=\"id\" [class.to-hide]=\"!menu_show\" [style]=\"box_style\">\r\n\r\n    <div class=\"line-search\" *ngIf=\"search\">\r\n      <table class=\"box-search\">\r\n        <tr>\r\n\r\n          <td class=\"area-input\">\r\n            <input type=\"text\" class=\"tc-form-control\" [(ngModel)]=\"search_text\" (input)=\"toSearch($event)\" placeholder=\"Buscar...\" >            \r\n          </td>\r\n\r\n          <td class=\"area-icon\">\r\n            <i *ngIf=\"search_text === ''\" class=\"fas fa-search icon-search\"></i>\r\n            <button type=\"button\" *ngIf=\"search_text !== ''\" (click)=\"clearTextSearch()\"><i class=\"fas fa-times\"></i></button>\r\n          </td>\r\n          \r\n        </tr>\r\n      </table>\r\n    </div>\r\n    \r\n    <div class=\"area-options\" id=\"{{ id }}-options\" (click)=\"toClose()\">\r\n      <ng-content></ng-content>      \r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<div *ngIf=\"formulario\">\r\n  <form [formGroup]=\"formulario\" style=\"display: none;\" >\r\n    <input id=\"{{ id }}-hidden\" formControlName=\"selected_item\" type=\"hidden\">\r\n  </form>\r\n</div>\r\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-data-list.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-data-list/tcloud-ui-data-list.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-data-list/tcloud-ui-data-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DataListService } from './services/data-list.service';\r\nimport { Component, forwardRef, OnInit, Output, EventEmitter, ViewChild, Input, OnDestroy, AfterViewChecked } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR, NgForm, FormGroup, FormBuilder, FormControl } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { ISelectOptions } from './tcloud-ui-data-list';\r\n\r\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDataListComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-data-list',\r\n  templateUrl: './tcloud-ui-data-list.component.html',\r\n  styleUrls: ['./tcloud-ui-data-list.component.scss'],\r\n  providers: [\r\n    DataListService, \r\n    CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR\r\n  ],\r\n})\r\nexport class TCloudUiDataListComponent implements OnInit, OnDestroy, AfterViewChecked {\r\n\r\n  viewport_width: number = 0;\r\n  viewport_height: number = 0;\r\n  box_height: number = 0;\r\n  box_style: string = '';\r\n  menu_on_top: string = '';\r\n\r\n  @Input() placeholder: string = '';\r\n\r\n  private _disabled: boolean = false;\r\n  @Input() set disabled(v){\r\n    if( v ){\r\n      this._disabled = v;    \r\n      this.selected_description = '';\r\n      this.selected_item ='';\r\n      this.toChange();\r\n    }\r\n  }\r\n  get disabled():boolean { return this._disabled; }\r\n\r\n  private _loading: boolean = false;\r\n  @Input() set loading(v){\r\n    if( v ){\r\n      this._loading = v;    \r\n      this.selected_description = '';\r\n      this.selected_item ='';\r\n      this.toChange();\r\n    }\r\n  }\r\n  get loading():boolean { return this._loading; }\r\n\r\n\r\n  @Input() search: boolean = true;\r\n  \r\n\r\n  @Output() onInputChange = new EventEmitter<ISelectOptions>();\r\n  @Output() onChange = new EventEmitter<ISelectOptions>();\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n    this.selected_item = v;    \r\n    this.selectDescription();   \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<any>();\r\n\r\n  list_selected_options = new Array<ISelectOptions>();\r\n\r\n  selected_item: any | undefined;\r\n  selected_description: any | undefined;\r\n\r\n  private subscription_value: Subscription | undefined;\r\n  private subscription_description: Subscription | undefined;\r\n  private subscription_options: Subscription | undefined;\r\n\r\n  menu_show: boolean = false;\r\n  search_text: string = '';\r\n  id: string = '';\r\n\r\n  formulario: FormGroup | undefined;\r\n\r\n  constructor(\r\n    private dataListService: DataListService,\r\n    private formBuilder: FormBuilder\r\n  ){\r\n  }\r\n\r\n  ngOnInit(){\r\n    this.id = this.generateID();\r\n\r\n    this.formulario = this.formBuilder.group({\r\n      \"selected_item\": new FormControl('',[]),\r\n    })\r\n\r\n    this.subscription_value = this.dataListService.stateValue$.subscribe(v => {\r\n      this.selected_item = v;      \r\n      this.selectDescription();\r\n      this.ngModelChange.emit(this.selected_item);\r\n    })\r\n\r\n    this.subscription_description = this.dataListService.stateDescription$.subscribe(v => {\r\n      this.selected_description = v;      \r\n    })\r\n\r\n\r\n    this.subscription_options = this.dataListService.stateOptions$.subscribe((v:any) => {\r\n      if( v && v.value ){\r\n        (this.list_selected_options).push(v);\r\n      }\r\n    })\r\n\r\n    this.toResize();\r\n    this.toClick();\r\n  }\r\n\r\n  t_fc: any | undefined;\r\n  ngAfterViewChecked(): void {\r\n    this.t_fc = undefined;\r\n    this.t_fc = this.get_selected_description();\r\n  }\r\n\r\n  get_selected_description(): void{\r\n    if( this.list_selected_options && (this.list_selected_options).length > 0 ){\r\n      for( let i = 0; i < (this.list_selected_options).length; i++ ){\r\n        const item = this.list_selected_options[i];\r\n        if( item.value === this.selected_item ){         \r\n          if( this.selected_description !== item.description ){\r\n            if( item.description && item.description !== this.selected_description ){\r\n              setTimeout(() => {\r\n                this.selected_description = item.description; \r\n                this.dataListService.setActiveItem(this.selected_item);\r\n              });\r\n            }\r\n          }        \r\n          break;\r\n        }\r\n      }\r\n    } \r\n  }\r\n\r\n  generateID(): string{\r\n    return `data-list-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if( this.subscription_value ){ this.subscription_value.unsubscribe(); }    \r\n    if( this.subscription_description ){ this.subscription_description.unsubscribe(); } \r\n    if( this.subscription_options ){ this.subscription_options.unsubscribe(); } \r\n  }\r\n\r\n  toSearch(e: any) {\r\n    let input = (e && e.target && e.target.value) ? e.target.value : '';\r\n    \r\n    let filter = ( ( (input).normalize('NFD').replace(/[\\u0300-\\u036f]/g, \"\") ).trim() ).toLowerCase();\r\n    let ul = <any> document.getElementById(`${this.id}-options`);\r\n    let li = ul.getElementsByTagName(\"button\");\r\n    for (let i = 0; i < li.length; i++) {\r\n        const a = li[i];\r\n        const txtValue = ( ( ( a.textContent || a.innerText ).normalize('NFD').replace(/[\\u0300-\\u036f]/g, \"\") ).trim() ).toLowerCase();\r\n        if (txtValue.indexOf(filter) > -1) {\r\n            li[i].style.display = \"\";\r\n        } else {\r\n            li[i].style.display = \"none\";\r\n        }\r\n    }\r\n  }\r\n\r\n  selectDescription(){\r\n    if( this.list_selected_options && (this.list_selected_options).length > 0 ){\r\n      for( let i = 0; i < (this.list_selected_options).length; i++ ){\r\n        const item = this.list_selected_options[i];\r\n        if( item.value === this.selected_item ){\r\n          this.selected_description = item.description;\r\n          this.toChange();\r\n          return;\r\n        }\r\n      }\r\n    }\r\n\r\n    if( this.selected_item === undefined || this.selected_item === null || this.selected_item === '' ){\r\n      this.selected_description = '';\r\n      this.toChange();\r\n    }\r\n    \r\n  }\r\n\r\n  \r\n  toInput(e: any){\r\n    this.onChange.emit(e);\r\n  }\r\n\r\n  toChange(){\r\n    setTimeout(() => {\r\n      if( this.selected_item === undefined || this.selected_item === null ){\r\n        this.selected_item = '';\r\n      }\r\n      this.toSearch('');\r\n      this.search_text = '';\r\n      this.dataListService.setActiveItem(this.selected_item);\r\n\r\n      this.onInputChange.emit(this.selected_description);\r\n\r\n      if( this.formulario ){\r\n        this.formulario?.get('selected_item')?.setValue(this.selected_item);\r\n        // const input_hidden = document.getElementById(`${this.id}-hidden`);\r\n        this.toInput(this.formulario.get('selected_item'));\r\n      }   \r\n    });\r\n  }\r\n\r\n\r\n  clearTextSearch(){\r\n    this.search_text = '';\r\n    this.toSearch('');\r\n  }\r\n\r\n  toOpen(){\r\n    this.menu_show = !this.menu_show; \r\n    this.resolve_position_dropdown(this.menu_show);\r\n  }\r\n\r\n  resolve_position_dropdown(open: boolean){\r\n    if( open ){\r\n      this.box_style = '';\r\n      this.menu_on_top = '';   \r\n      const id = `${this.id}`; \r\n      const box = `box-${this.id}`;\r\n      if( this.viewport_height === 0 ){\r\n        this.viewport_height = window.innerWidth;\r\n      }\r\n      const rect  = document.getElementById(id)?.getBoundingClientRect();\r\n      const box_position = rect?.bottom || 0;      \r\n      setTimeout(() => {\r\n        this.box_height  = document.getElementById(box)?.clientHeight || 0;\r\n        if( ( this.viewport_height - box_position) < this.box_height ){\r\n          this.menu_on_top = 'menu-on-top';\r\n          this.box_style = `top: -${ (this.box_height) }px; height: ${this.box_height}px;`;\r\n        }\r\n      });    \r\n    }\r\n  }\r\n\r\n  toClose(){\r\n    this.menu_show = false;\r\n  }\r\n\r\n\r\n  toResize(){\r\n    window.addEventListener('resize', () => {\r\n      this.viewport_width = window.innerWidth;\r\n      this.viewport_height = window.innerHeight;\r\n      this.resolve_position_dropdown(this.menu_show);\r\n    });\r\n  }\r\n\r\n  toClick(){\r\n    const box = `area-${this.id}`;\r\n    window.addEventListener('click',(e: any) => {   \r\n      if( this.menu_show ){\r\n        if( !(document.getElementById(box)?.contains(e.target)) ){        \r\n          this.menu_show = false;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  \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.selected_item;\r\n    };\r\n\r\n    //set accessor including call the onchange callback\r\n    set value(v: any) {\r\n        if (v !== this.selected_item) {\r\n            this.selected_item = 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.selected_item) {\r\n            this.selected_item = 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}\r\n\r\n","<div *ngIf=\"formulario\" id=\"area-{{ id }}\" class=\"tc-dropdown\" [class.disabled]=\"disabled || loading\">\r\n  <div *ngIf=\"loading\" class=\"loading-area\">\r\n    <i class=\"fas fa-spinner fa-spin\"></i>\r\n  </div>\r\n  <!-- [attr.data-bs-toggle]=\"'dropdown'\"  -->\r\n  <button \r\n    [class.loading-box]=\"loading\"\r\n    [disabled]=\"disabled || loading\"\r\n    class=\"dropdown-toggle button-select no-margin-bottom\" \r\n    type=\"button\" \r\n    id=\"{{ id }}\" \r\n    \r\n    [attr.aria-haspopup]=\"'true'\" \r\n    [attr.aria-expanded]=\"'false'\" \r\n    (click)=\"toOpen()\" >\r\n\r\n    <i *ngIf=\"(selected_description === undefined || selected_description === null || selected_description === '' ) && !loading \">{{ placeholder }}</i>\r\n    {{ selected_description }}\r\n    <span><i class=\"fas fa-angle-down\"></i></span>\r\n  </button>\r\n  <div class=\"tc-dropdown-menu {{ menu_on_top }}\" id=\"box-{{ id }}\" [attr.aria-labelledby]=\"id\" [class.to-hide]=\"!menu_show\" [style]=\"box_style\">\r\n\r\n    <div class=\"line-search\" *ngIf=\"search\">\r\n      <table class=\"box-search\">\r\n        <tr>\r\n\r\n          <td class=\"area-input\">\r\n            <input type=\"text\" class=\"tc-form-control\" [(ngModel)]=\"search_text\" (input)=\"toSearch($event)\" placeholder=\"Buscar...\" >            \r\n          </td>\r\n\r\n          <td class=\"area-icon\">\r\n            <i *ngIf=\"search_text === ''\" class=\"fas fa-search icon-search\"></i>\r\n            <button type=\"button\" *ngIf=\"search_text !== ''\" (click)=\"clearTextSearch()\"><i class=\"fas fa-times\"></i></button>\r\n          </td>\r\n          \r\n        </tr>\r\n      </table>\r\n    </div>\r\n    \r\n    <div class=\"area-options\" id=\"{{ id }}-options\" (click)=\"toClose()\">\r\n      <ng-content></ng-content>      \r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<div *ngIf=\"formulario\">\r\n  <form [formGroup]=\"formulario\" style=\"display: none;\" >\r\n    <input id=\"{{ id }}-hidden\" formControlName=\"selected_item\" type=\"hidden\">\r\n  </form>\r\n</div>\r\n"]}
|
|
@@ -267,10 +267,10 @@ export class TCloudUiDatepickerComponent {
|
|
|
267
267
|
}
|
|
268
268
|
}
|
|
269
269
|
TCloudUiDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerComponent, deps: [{ token: i1.DateBRPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
270
|
-
TCloudUiDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiDatepickerComponent, selector: "tcloud-ui-datepicker", inputs: { multiple: "multiple", maxNumberOfDates: "maxNumberOfDates", daysOfWeekDisabled: "daysOfWeekDisabled", minDate: "minDate", maxDate: "maxDate", datesDisabled: "datesDisabled", modeInput: "modeInput", useBorder: "useBorder", ngModel: "ngModel", code: "code" }, outputs: { onChange: "onChange", ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "input_datepicker", first: true, predicate: ["input_datepicker"], descendants: true }], ngImport: i0, template: "<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n <table class=\"table-box-input\">\r\n <tr>\r\n <td>\r\n <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n </td>\r\n <td>\r\n <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n \r\n \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\"> \r\n <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n <tc-datepicker \r\n [multiple]=\"false\"\r\n [daysOfWeekDisabled]=\"[0,6]\"\r\n [minDate]=\"'18/11/2021'\"\r\n [maxDate]=\"'18/12/2023'\"\r\n [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n [modeInput]=\"false\"\r\n [(ngModel)]=\"dateValue\" >\r\n </tc-datepicker>\r\n \r\n // multiple = false\r\n // dateValue - string - pode ser: 12/12/2022 \r\n\r\n // multiple = true\r\n // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n <pre>data: {{ dateValue }}</pre>\r\n-->\r\n", styles: [".input_datepicker{width:100%;max-width:290px}.input-tc-datepicker{background-color:#fff;border:1px solid #ccc;border-radius:3px}.input-tc-datepicker.no-border{border:none!important}.input-tc-datepicker .table-box-input{width:100%}.input-tc-datepicker .table-box-input td
|
|
270
|
+
TCloudUiDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiDatepickerComponent, selector: "tcloud-ui-datepicker", inputs: { multiple: "multiple", maxNumberOfDates: "maxNumberOfDates", daysOfWeekDisabled: "daysOfWeekDisabled", minDate: "minDate", maxDate: "maxDate", datesDisabled: "datesDisabled", modeInput: "modeInput", useBorder: "useBorder", ngModel: "ngModel", code: "code" }, outputs: { onChange: "onChange", ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "input_datepicker", first: true, predicate: ["input_datepicker"], descendants: true }], ngImport: i0, template: "<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n <table class=\"table-box-input\">\r\n <tr>\r\n <td class=\"td-icon\">\r\n <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n </td>\r\n <td class=\"td-date\">\r\n <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n \r\n \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\"> \r\n <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n <tc-datepicker \r\n [multiple]=\"false\"\r\n [daysOfWeekDisabled]=\"[0,6]\"\r\n [minDate]=\"'18/11/2021'\"\r\n [maxDate]=\"'18/12/2023'\"\r\n [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n [modeInput]=\"false\"\r\n [(ngModel)]=\"dateValue\" >\r\n </tc-datepicker>\r\n \r\n // multiple = false\r\n // dateValue - string - pode ser: 12/12/2022 \r\n\r\n // multiple = true\r\n // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n <pre>data: {{ dateValue }}</pre>\r\n-->\r\n", styles: [".input_datepicker{width:100%;max-width:290px}.input-tc-datepicker{background-color:#fff;border:1px solid #ccc;border-radius:3px}.input-tc-datepicker.no-border{border:none!important}.input-tc-datepicker .table-box-input{width:100%}.input-tc-datepicker .table-box-input .td-icon{width:14px}.input-tc-datepicker .table-box-input .td-icon .delimiter-time-icon{text-align:center;cursor:pointer}.input-tc-datepicker .table-box-input .td-icon .delimiter-time-icon i{position:relative;left:1px;opacity:.5}.input-tc-datepicker .table-box-input .td-date{width:101px input;width-width:100%}.input-tc-datepicker .table-box-input input{border:none}\n", ".datepicker{display:none}.datepicker.active{display:block}.datepicker-dropdown{left:0;padding-top:4px;position:absolute;top:0;z-index:20}.datepicker-dropdown.datepicker-orient-top{padding-bottom:4px;padding-top:0}.datepicker-picker{background-color:#fff;border-radius:4px;display:inline-block}.datepicker-dropdown .datepicker-picker{box-shadow:0 2px 3px #0a0a0a1a,0 0 0 1px #0a0a0a1a}.datepicker-picker span{-webkit-touch-callout:none;border:0;border-radius:4px;cursor:default;display:block;flex:1;text-align:center;-webkit-user-select:none;user-select:none}.datepicker-main{padding:2px}.datepicker-footer{background-color:#f5f5f5;box-shadow:inset 0 1px 1px #0a0a0a1a}.datepicker-controls,.datepicker-grid,.datepicker-view,.datepicker-view .days-of-week{display:flex}.datepicker-grid{flex-wrap:wrap}.datepicker-view .days .datepicker-cell,.datepicker-view .dow{flex-basis:14.2857142857%}.datepicker-view.datepicker-grid .datepicker-cell{flex-basis:25%}.datepicker-cell,.datepicker-view .week{height:2.25rem;line-height:2.25rem}.datepicker-title{background-color:#f5f5f5;box-shadow:inset 0 -1px 1px #0a0a0a1a;font-weight:700;padding:.375rem .75rem;text-align:center}.datepicker-header .datepicker-controls{padding:2px 2px 0}.datepicker-controls .button{align-items:center;background-color:#fff;border:1px solid #dbdbdb;border-radius:4px;box-shadow:none;color:#363636;cursor:pointer;display:inline-flex;font-size:1rem;height:2.25em;justify-content:center;line-height:1.5;margin:0;padding:calc(.375em - 1px) .75em;position:relative;text-align:center;vertical-align:top;white-space:nowrap}.datepicker-controls .button:active,.datepicker-controls .button:focus{outline:none}.datepicker-controls .button:hover{border-color:#b5b5b5;color:#363636}.datepicker-controls .button:focus{border-color:#3273dc;color:#363636}.datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #3273dc40}.datepicker-controls .button:active{border-color:#4a4a4a;color:#363636}.datepicker-controls .button[disabled]{cursor:not-allowed}.datepicker-header .datepicker-controls .button{border-color:transparent;font-weight:700}.datepicker-header .datepicker-controls .button:hover{background-color:#f9f9f9}.datepicker-header .datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #ffffff40}.datepicker-header .datepicker-controls .button:active{background-color:#f2f2f2}.datepicker-header .datepicker-controls .button[disabled]{box-shadow:none}.datepicker-footer .datepicker-controls .button{border-radius:2px;font-size:.75rem;margin:calc(.375rem - 1px) .375rem;width:100%}.datepicker-controls .view-switch{flex:auto}.datepicker-controls .next-btn,.datepicker-controls .prev-btn{padding-left:.375rem;padding-right:.375rem;width:2.25rem}.datepicker-controls .next-btn.disabled,.datepicker-controls .prev-btn.disabled{visibility:hidden}.datepicker-view .dow{font-size:.875rem;font-weight:700;height:1.5rem;line-height:1.5rem}.datepicker-view .week{color:#b5b5b5;font-size:.75rem;width:2.25rem}@media (max-width:22.5rem){.datepicker-view .week{width:1.96875rem}}.datepicker-grid{width:15.75rem}@media (max-width:22.5rem){.calendar-weeks+.days .datepicker-grid{width:13.78125rem}}.datepicker-cell:not(.disabled):hover{background-color:#f9f9f9;cursor:pointer}.datepicker-cell.focused:not(.selected){background-color:#e8e8e8}.datepicker-cell.selected,.datepicker-cell.selected:hover{background-color:#3273dc;color:#fff;font-weight:600}.datepicker-cell.disabled{color:#dbdbdb}.datepicker-cell.next:not(.disabled),.datepicker-cell.prev:not(.disabled){color:#7a7a7a}.datepicker-cell.next.selected,.datepicker-cell.prev.selected{color:#e6e6e6}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today){background-color:#f5f5f5;border-radius:0}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today):not(.disabled):hover{background-color:#eee}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today).focused{background-color:#e8e8e8}.datepicker-cell.today:not(.selected){background-color:#00d1b2}.datepicker-cell.today:not(.selected):not(.disabled){color:#fff}.datepicker-cell.today.focused:not(.selected){background-color:#00c4a7}.datepicker-cell.range-end:not(.selected),.datepicker-cell.range-start:not(.selected){background-color:#b5b5b5;color:#fff}.datepicker-cell.range-end.focused:not(.selected),.datepicker-cell.range-start.focused:not(.selected){background-color:#afafaf}.datepicker-cell.range-start{border-radius:4px 0 0 4px}.datepicker-cell.range-end{border-radius:0 4px 4px 0}.datepicker-cell.range{background-color:#dbdbdb;border-radius:0}.datepicker-cell.range:not(.disabled):not(.focused):not(.today):hover{background-color:#d5d5d5}.datepicker-cell.range.disabled{color:#c2c2c2}.datepicker-cell.range.focused{background-color:#cfcfcf}.datepicker-view.datepicker-grid .datepicker-cell{height:4.5rem;line-height:4.5rem}.datepicker-input.in-edit{border-color:#2366d1}.datepicker-input.in-edit:active,.datepicker-input.in-edit:focus{box-shadow:0 0 .25em .25em #2366d133}\n", ".datepicker-picker{border:1px solid #ccc;padding:10px 15px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
271
271
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerComponent, decorators: [{
|
|
272
272
|
type: Component,
|
|
273
|
-
args: [{ selector: 'tcloud-ui-datepicker', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], encapsulation: ViewEncapsulation.None, template: "<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n <table class=\"table-box-input\">\r\n <tr>\r\n <td>\r\n <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n </td>\r\n <td>\r\n <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n \r\n \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\"> \r\n <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n <tc-datepicker \r\n [multiple]=\"false\"\r\n [daysOfWeekDisabled]=\"[0,6]\"\r\n [minDate]=\"'18/11/2021'\"\r\n [maxDate]=\"'18/12/2023'\"\r\n [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n [modeInput]=\"false\"\r\n [(ngModel)]=\"dateValue\" >\r\n </tc-datepicker>\r\n \r\n // multiple = false\r\n // dateValue - string - pode ser: 12/12/2022 \r\n\r\n // multiple = true\r\n // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n <pre>data: {{ dateValue }}</pre>\r\n-->\r\n", styles: [".input_datepicker{width:100%;max-width:290px}.input-tc-datepicker{background-color:#fff;border:1px solid #ccc;border-radius:3px}.input-tc-datepicker.no-border{border:none!important}.input-tc-datepicker .table-box-input{width:100%}.input-tc-datepicker .table-box-input td
|
|
273
|
+
args: [{ selector: 'tcloud-ui-datepicker', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], encapsulation: ViewEncapsulation.None, template: "<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n <table class=\"table-box-input\">\r\n <tr>\r\n <td class=\"td-icon\">\r\n <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n </td>\r\n <td class=\"td-date\">\r\n <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n \r\n \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\"> \r\n <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n <tc-datepicker \r\n [multiple]=\"false\"\r\n [daysOfWeekDisabled]=\"[0,6]\"\r\n [minDate]=\"'18/11/2021'\"\r\n [maxDate]=\"'18/12/2023'\"\r\n [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n [modeInput]=\"false\"\r\n [(ngModel)]=\"dateValue\" >\r\n </tc-datepicker>\r\n \r\n // multiple = false\r\n // dateValue - string - pode ser: 12/12/2022 \r\n\r\n // multiple = true\r\n // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n <pre>data: {{ dateValue }}</pre>\r\n-->\r\n", styles: [".input_datepicker{width:100%;max-width:290px}.input-tc-datepicker{background-color:#fff;border:1px solid #ccc;border-radius:3px}.input-tc-datepicker.no-border{border:none!important}.input-tc-datepicker .table-box-input{width:100%}.input-tc-datepicker .table-box-input .td-icon{width:14px}.input-tc-datepicker .table-box-input .td-icon .delimiter-time-icon{text-align:center;cursor:pointer}.input-tc-datepicker .table-box-input .td-icon .delimiter-time-icon i{position:relative;left:1px;opacity:.5}.input-tc-datepicker .table-box-input .td-date{width:101px input;width-width:100%}.input-tc-datepicker .table-box-input input{border:none}\n", ".datepicker{display:none}.datepicker.active{display:block}.datepicker-dropdown{left:0;padding-top:4px;position:absolute;top:0;z-index:20}.datepicker-dropdown.datepicker-orient-top{padding-bottom:4px;padding-top:0}.datepicker-picker{background-color:#fff;border-radius:4px;display:inline-block}.datepicker-dropdown .datepicker-picker{box-shadow:0 2px 3px #0a0a0a1a,0 0 0 1px #0a0a0a1a}.datepicker-picker span{-webkit-touch-callout:none;border:0;border-radius:4px;cursor:default;display:block;flex:1;text-align:center;-webkit-user-select:none;user-select:none}.datepicker-main{padding:2px}.datepicker-footer{background-color:#f5f5f5;box-shadow:inset 0 1px 1px #0a0a0a1a}.datepicker-controls,.datepicker-grid,.datepicker-view,.datepicker-view .days-of-week{display:flex}.datepicker-grid{flex-wrap:wrap}.datepicker-view .days .datepicker-cell,.datepicker-view .dow{flex-basis:14.2857142857%}.datepicker-view.datepicker-grid .datepicker-cell{flex-basis:25%}.datepicker-cell,.datepicker-view .week{height:2.25rem;line-height:2.25rem}.datepicker-title{background-color:#f5f5f5;box-shadow:inset 0 -1px 1px #0a0a0a1a;font-weight:700;padding:.375rem .75rem;text-align:center}.datepicker-header .datepicker-controls{padding:2px 2px 0}.datepicker-controls .button{align-items:center;background-color:#fff;border:1px solid #dbdbdb;border-radius:4px;box-shadow:none;color:#363636;cursor:pointer;display:inline-flex;font-size:1rem;height:2.25em;justify-content:center;line-height:1.5;margin:0;padding:calc(.375em - 1px) .75em;position:relative;text-align:center;vertical-align:top;white-space:nowrap}.datepicker-controls .button:active,.datepicker-controls .button:focus{outline:none}.datepicker-controls .button:hover{border-color:#b5b5b5;color:#363636}.datepicker-controls .button:focus{border-color:#3273dc;color:#363636}.datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #3273dc40}.datepicker-controls .button:active{border-color:#4a4a4a;color:#363636}.datepicker-controls .button[disabled]{cursor:not-allowed}.datepicker-header .datepicker-controls .button{border-color:transparent;font-weight:700}.datepicker-header .datepicker-controls .button:hover{background-color:#f9f9f9}.datepicker-header .datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #ffffff40}.datepicker-header .datepicker-controls .button:active{background-color:#f2f2f2}.datepicker-header .datepicker-controls .button[disabled]{box-shadow:none}.datepicker-footer .datepicker-controls .button{border-radius:2px;font-size:.75rem;margin:calc(.375rem - 1px) .375rem;width:100%}.datepicker-controls .view-switch{flex:auto}.datepicker-controls .next-btn,.datepicker-controls .prev-btn{padding-left:.375rem;padding-right:.375rem;width:2.25rem}.datepicker-controls .next-btn.disabled,.datepicker-controls .prev-btn.disabled{visibility:hidden}.datepicker-view .dow{font-size:.875rem;font-weight:700;height:1.5rem;line-height:1.5rem}.datepicker-view .week{color:#b5b5b5;font-size:.75rem;width:2.25rem}@media (max-width:22.5rem){.datepicker-view .week{width:1.96875rem}}.datepicker-grid{width:15.75rem}@media (max-width:22.5rem){.calendar-weeks+.days .datepicker-grid{width:13.78125rem}}.datepicker-cell:not(.disabled):hover{background-color:#f9f9f9;cursor:pointer}.datepicker-cell.focused:not(.selected){background-color:#e8e8e8}.datepicker-cell.selected,.datepicker-cell.selected:hover{background-color:#3273dc;color:#fff;font-weight:600}.datepicker-cell.disabled{color:#dbdbdb}.datepicker-cell.next:not(.disabled),.datepicker-cell.prev:not(.disabled){color:#7a7a7a}.datepicker-cell.next.selected,.datepicker-cell.prev.selected{color:#e6e6e6}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today){background-color:#f5f5f5;border-radius:0}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today):not(.disabled):hover{background-color:#eee}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today).focused{background-color:#e8e8e8}.datepicker-cell.today:not(.selected){background-color:#00d1b2}.datepicker-cell.today:not(.selected):not(.disabled){color:#fff}.datepicker-cell.today.focused:not(.selected){background-color:#00c4a7}.datepicker-cell.range-end:not(.selected),.datepicker-cell.range-start:not(.selected){background-color:#b5b5b5;color:#fff}.datepicker-cell.range-end.focused:not(.selected),.datepicker-cell.range-start.focused:not(.selected){background-color:#afafaf}.datepicker-cell.range-start{border-radius:4px 0 0 4px}.datepicker-cell.range-end{border-radius:0 4px 4px 0}.datepicker-cell.range{background-color:#dbdbdb;border-radius:0}.datepicker-cell.range:not(.disabled):not(.focused):not(.today):hover{background-color:#d5d5d5}.datepicker-cell.range.disabled{color:#c2c2c2}.datepicker-cell.range.focused{background-color:#cfcfcf}.datepicker-view.datepicker-grid .datepicker-cell{height:4.5rem;line-height:4.5rem}.datepicker-input.in-edit{border-color:#2366d1}.datepicker-input.in-edit:active,.datepicker-input.in-edit:focus{box-shadow:0 0 .25em .25em #2366d133}\n", ".datepicker-picker{border:1px solid #ccc;padding:10px 15px}\n"] }]
|
|
274
274
|
}], ctorParameters: function () { return [{ type: i1.DateBRPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { multiple: [{
|
|
275
275
|
type: Input
|
|
276
276
|
}], maxNumberOfDates: [{
|
|
@@ -299,4 +299,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
299
299
|
}], code: [{
|
|
300
300
|
type: Input
|
|
301
301
|
}] } });
|
|
302
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, Output, EventEmitter, forwardRef, Input, ViewEncapsulation, ChangeDetectorRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DateBRPipe } from '../../_pipes';\r\n\r\n// https://mymth.github.io/vanillajs-datepicker/#/\r\ndeclare var Datepicker: any;\r\n\r\nvar translation = {\r\n  ptBR: {\r\n    days: [\"Domingo\", \"Segunda\", \"Terça\", \"Quarta\", \"Quinta\", \"Sexta\", \"Sábado\"],\r\n    daysShort: [\"Dom\", \"Seg\", \"Ter\", \"Qua\", \"Qui\", \"Sex\", \"Sáb\"],\r\n    daysMin: [\"Do\", \"Se\", \"Te\", \"Qu\", \"Qu\", \"Se\", \"Sa\"],\r\n    months: [\"Janeiro\", \"Fevereiro\", \"Março\", \"Abril\", \"Maio\", \"Junho\", \"Julho\", \"Agosto\", \"Setembro\", \"Outubro\", \"Novembro\", \"Dezembro\"],\r\n    monthsShort: [\"Jan\", \"Fev\", \"Mar\", \"Abr\", \"Mai\", \"Jun\", \"Jul\", \"Ago\", \"Set\", \"Out\", \"Nov\", \"Dez\"],\r\n    today: \"Hoje\",\r\n    clear: \"Limpar\",\r\n    titleFormat: \"MM y\",\r\n    format: \"dd/mm/yyyy\",\r\n    weekStart: 0\r\n  }\r\n};\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDatepickerComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-datepicker',\r\n  templateUrl: './tcloud-ui-datepicker.component.html',\r\n  styleUrls: [\r\n    './tcloud-ui-datepicker.component.scss',\r\n    './datepicker/css/datepicker.min.css',\r\n    './datepicker/css/style.css',\r\n  ],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TCloudUiDatepickerComponent implements OnInit {\r\n\r\n  // multiple permite selecionar multiplas datas\r\n  @Input() multiple: boolean = false;\r\n\r\n  // maxNumberOfDates - Maximum number of dates users can select. No limit is applied if 0 is set.\r\n  // Depende de: multiple como true\r\n  @Input() maxNumberOfDates: number = 0;\r\n\r\n  // daysOfWeekDisabled - Dias da semana desabilidatos = 0 para sabado até 6 para domingo\r\n  @Input() daysOfWeekDisabled: number[] = [];\r\n\r\n  // minDate - Data minima para exibicao do calendario - ex: 01/01/2020\r\n  @Input() minDate: string = '';\r\n\r\n  // maxDate - Data maxima para exibicao do calendario - ex: 31/12/2020\r\n  @Input() maxDate: string = '';\r\n\r\n  // datesDisabled - Datas desabilitadas - Ex: ['12/10/2020','25/12/2020']\r\n  @Input() datesDisabled: string[] = [];\r\n\r\n  // modeInput - Exibe um input para quando clicar abrir o calendario\r\n  @Input() modeInput: boolean = false;\r\n\r\n  @Input() useBorder: boolean = true;\r\n\r\n  // onChange - Dispara a data selecionada\r\n  @Output() onChange = new EventEmitter<any|undefined>();\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n\r\n    //console.log('ngModel', v);\r\n\r\n    if( v && v !== this.innerValue ){\r\n      this.innerValue = v; //this.toSetMask(v); \r\n    } \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<any|undefined>();\r\n\r\n  @ViewChild('input_datepicker', {static: false}) input_datepicker: ElementRef<HTMLElement> | undefined;\r\n  private datepicker: any | undefined;\r\n  @Input() code: string = 'tcloud-ui-datepicker';\r\n\r\n  constructor(\r\n    private _DateBRPipe: DateBRPipe,\r\n    private _changeDetectorRef: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ID: string = '';\r\n\r\n  ngOnInit(): void {\r\n    this.ID = this.generateID();\r\n    Datepicker.locales.ptBR = translation.ptBR;    \r\n    this.start_datepicker();\r\n  }\r\n\r\n  generateID(): string{\r\n    return `tcloud-ui-datepicker-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  toSetMask(v: string){\r\n    return this._DateBRPipe.transform(v);\r\n  }\r\n\r\n  get_options(){\r\n    let options = {\r\n      nextArrow: `<i class=\"fas fa-caret-right\"></i>`,\r\n      prevArrow: `<i class=\"fas fa-caret-left\"></i>`,\r\n      format: 'dd/mm/yyyy',      \r\n      daysOfWeekHighlighted: [0,6],\r\n      language: 'ptBR'\r\n    } as any;\r\n\r\n    if( (this.daysOfWeekDisabled).length > 0 ){\r\n      options['daysOfWeekDisabled'] = this.daysOfWeekDisabled;\r\n    }\r\n\r\n    if( (this.datesDisabled).length > 0 ){\r\n      options['datesDisabled'] = this.datesDisabled;\r\n    }\r\n\r\n    if( this.minDate !== '' ){\r\n      options['minDate'] = this.minDate;\r\n    }\r\n\r\n    if( this.maxDate !== '' ){\r\n      options['maxDate'] = this.maxDate;\r\n    }\r\n\r\n    if( this.multiple ){      \r\n      options['maxNumberOfDates'] = this.maxNumberOfDates;\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  clearDate(){\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate({clear: true});\r\n    }\r\n  }\r\n\r\n  start_datepicker(){\r\n    setTimeout(() => {     \r\n      const input_datepicker = <any> this.input_datepicker?.nativeElement;\r\n      if( input_datepicker ){\r\n\r\n        input_datepicker.setAttribute('placeholder','DD/MM/YYYY');\r\n\r\n        if( !this.useBorder ){\r\n          input_datepicker.setAttribute('style','border:none; text-align: center; max-width: 105px; padding: 0;');\r\n        }\r\n        \r\n\r\n        this.datepicker = new Datepicker( input_datepicker, this.get_options() );\r\n\r\n        if( this.innerValue && this.innerValue !== '' ){\r\n          this.toSetDefaultDate(this.innerValue);\r\n        }\r\n\r\n        input_datepicker.addEventListener('keyup', (event: any) => {\r\n          const v = (input_datepicker['value']) ? input_datepicker['value'] : '';\r\n          input_datepicker['value'] = this.toSetMask(v);\r\n\r\n          if( (input_datepicker['value']).length >= 10 ){\r\n            const v = (input_datepicker['value']).substring(0, 10);\r\n            const part_date = (v).split('/');\r\n            if( (part_date).length === 3 ){\r\n\r\n              let dia = part_date[0];\r\n              let mes = part_date[1];\r\n              let ano = part_date[2];\r\n\r\n              mes = (+(mes) < 10 ) ? `0${+mes}` : mes;  \r\n              dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n\r\n              const dt = new Date(ano+'-'+mes+'-'+dia);\r\n              if( dt ){\r\n                input_datepicker?.changeDate;\r\n                document.getElementById(this.ID)?.blur();\r\n                this.onChange.emit(this.innerValue);\r\n                this.ngModelChange.emit(this.innerValue);\r\n              }\r\n            }\r\n          }else{\r\n            this.innerValue = undefined;\r\n            this.onChange.emit(this.innerValue);\r\n            this.ngModelChange.emit(this.innerValue);\r\n          }\r\n          //console.log('input_datepicker', input_datepicker['value'] );\r\n        })\r\n\r\n\r\n        input_datepicker.addEventListener('changeDate', (event: any) => {\r\n          //console.log(event);\r\n          if( event?.detail?.date ){\r\n            this.toSelectedDate( event.detail );\r\n          }else{\r\n            //console.log('event null');\r\n            this.innerValue = '';\r\n            this.ngModelChange.emit(this.innerValue);\r\n          }\r\n        })\r\n      }      \r\n    });\r\n  }\r\n\r\n  toSetDate(){\r\n    // Ex de uso\r\n    const dates = ['18/11/2022'];\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate(dates);\r\n    }    \r\n  }\r\n\r\n  toSetDefaultDate(date: string | string[]){\r\n    \r\n    if( date === undefined || date === null || date === '' ){\r\n      this.clearDate();\r\n      return;\r\n    }\r\n\r\n    let dates = [] as string[];\r\n\r\n    if( date && typeof date === 'string' ){\r\n      if( (date).includes(',') ){\r\n        const dates = (date).split(',');\r\n        date = dates;\r\n        if( !this.multiple ){\r\n          this.innerValue = date = dates[0];\r\n          this.ngModelChange.emit(this.innerValue); \r\n        }\r\n      }\r\n    }\r\n    \r\n    if( date && typeof date === 'string' ){\r\n      (dates).push( date ); \r\n    }else{\r\n      dates = <Array<string>> date;\r\n    }\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate(dates);      \r\n    } \r\n  }\r\n\r\n  toSelectedDate(detail: any){    \r\n    if( detail.datepicker.dates && (detail.datepicker.dates).length > 0 ){\r\n      if( this.multiple ){\r\n        let dates = [];\r\n        for( let i = 0; i < (detail.datepicker.dates).length; i++ ){\r\n          const timeStamp = <number> detail.datepicker.dates[i];\r\n          (dates).push( this.format_date( timeStamp ) );\r\n        }\r\n        this.innerValue = dates;\r\n        this.onChange.emit(this.innerValue);        \r\n      }else{\r\n        const timeStamp = <number> detail.datepicker.dates[0];\r\n        const date = this.format_date( timeStamp );\r\n        this.onChange.emit(date);\r\n        this.innerValue = date;\r\n      }      \r\n    }else{\r\n      this.clearDate();\r\n      this.innerValue = null;\r\n      this.onChange.emit(this.innerValue);\r\n    } \r\n    this.value = this.innerValue;\r\n    this.ngModelChange.emit(this.innerValue); \r\n  }\r\n\r\n  format_date(timeStamp: number){\r\n    var date = new Date(timeStamp);\r\n\r\n    let dia = `${date.getDate()}`;\r\n    let mes = `${date.getMonth()+1}`;\r\n    let ano = `${date.getFullYear()}`;\r\n\r\n    dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n    mes = (+(mes) < 10 ) ? `0${+mes}` : mes; \r\n\r\n    const dateFormat = `${dia}/${mes}/${ano}`;\r\n    return dateFormat;\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    const element = document.getElementById(id) as any;\r\n    setTimeout(() => {      \r\n      element?.datepicker?.show();\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\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\r\n    //console.log('value', v);\r\n\r\n    if (v !== this.innerValue) {\r\n      this.innerValue = v; // this.toSetMask(v);      \r\n      this.onChangeCallback(v);\r\n    }else{\r\n     // this.innerValue = '';\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.toSetDefaultDate(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}\r\n","<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n  <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n    <table class=\"table-box-input\">\r\n      <tr>\r\n        <td>\r\n          <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n        </td>\r\n        <td>\r\n          <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n        </td>\r\n      </tr>\r\n    </table>\r\n  </div>\r\n\r\n  \r\n  \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\">  \r\n  <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n  <tc-datepicker \r\n    [multiple]=\"false\"\r\n    [daysOfWeekDisabled]=\"[0,6]\"\r\n    [minDate]=\"'18/11/2021'\"\r\n    [maxDate]=\"'18/12/2023'\"\r\n    [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n    [modeInput]=\"false\"\r\n    [(ngModel)]=\"dateValue\" >\r\n  </tc-datepicker>\r\n  \r\n  // multiple = false\r\n  // dateValue - string - pode ser: 12/12/2022 \r\n\r\n  // multiple = true\r\n  // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n  <pre>data: {{ dateValue }}</pre>\r\n-->\r\n"]}
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, Output, EventEmitter, forwardRef, Input, ViewEncapsulation, ChangeDetectorRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DateBRPipe } from '../../_pipes';\r\n\r\n// https://mymth.github.io/vanillajs-datepicker/#/\r\ndeclare var Datepicker: any;\r\n\r\nvar translation = {\r\n  ptBR: {\r\n    days: [\"Domingo\", \"Segunda\", \"Terça\", \"Quarta\", \"Quinta\", \"Sexta\", \"Sábado\"],\r\n    daysShort: [\"Dom\", \"Seg\", \"Ter\", \"Qua\", \"Qui\", \"Sex\", \"Sáb\"],\r\n    daysMin: [\"Do\", \"Se\", \"Te\", \"Qu\", \"Qu\", \"Se\", \"Sa\"],\r\n    months: [\"Janeiro\", \"Fevereiro\", \"Março\", \"Abril\", \"Maio\", \"Junho\", \"Julho\", \"Agosto\", \"Setembro\", \"Outubro\", \"Novembro\", \"Dezembro\"],\r\n    monthsShort: [\"Jan\", \"Fev\", \"Mar\", \"Abr\", \"Mai\", \"Jun\", \"Jul\", \"Ago\", \"Set\", \"Out\", \"Nov\", \"Dez\"],\r\n    today: \"Hoje\",\r\n    clear: \"Limpar\",\r\n    titleFormat: \"MM y\",\r\n    format: \"dd/mm/yyyy\",\r\n    weekStart: 0\r\n  }\r\n};\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDatepickerComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-datepicker',\r\n  templateUrl: './tcloud-ui-datepicker.component.html',\r\n  styleUrls: [\r\n    './tcloud-ui-datepicker.component.scss',\r\n    './datepicker/css/datepicker.min.css',\r\n    './datepicker/css/style.css',\r\n  ],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TCloudUiDatepickerComponent implements OnInit {\r\n\r\n  // multiple permite selecionar multiplas datas\r\n  @Input() multiple: boolean = false;\r\n\r\n  // maxNumberOfDates - Maximum number of dates users can select. No limit is applied if 0 is set.\r\n  // Depende de: multiple como true\r\n  @Input() maxNumberOfDates: number = 0;\r\n\r\n  // daysOfWeekDisabled - Dias da semana desabilidatos = 0 para sabado até 6 para domingo\r\n  @Input() daysOfWeekDisabled: number[] = [];\r\n\r\n  // minDate - Data minima para exibicao do calendario - ex: 01/01/2020\r\n  @Input() minDate: string = '';\r\n\r\n  // maxDate - Data maxima para exibicao do calendario - ex: 31/12/2020\r\n  @Input() maxDate: string = '';\r\n\r\n  // datesDisabled - Datas desabilitadas - Ex: ['12/10/2020','25/12/2020']\r\n  @Input() datesDisabled: string[] = [];\r\n\r\n  // modeInput - Exibe um input para quando clicar abrir o calendario\r\n  @Input() modeInput: boolean = false;\r\n\r\n  @Input() useBorder: boolean = true;\r\n\r\n  // onChange - Dispara a data selecionada\r\n  @Output() onChange = new EventEmitter<any|undefined>();\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n\r\n    //console.log('ngModel', v);\r\n\r\n    if( v && v !== this.innerValue ){\r\n      this.innerValue = v; //this.toSetMask(v); \r\n    } \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<any|undefined>();\r\n\r\n  @ViewChild('input_datepicker', {static: false}) input_datepicker: ElementRef<HTMLElement> | undefined;\r\n  private datepicker: any | undefined;\r\n  @Input() code: string = 'tcloud-ui-datepicker';\r\n\r\n  constructor(\r\n    private _DateBRPipe: DateBRPipe,\r\n    private _changeDetectorRef: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ID: string = '';\r\n\r\n  ngOnInit(): void {\r\n    this.ID = this.generateID();\r\n    Datepicker.locales.ptBR = translation.ptBR;    \r\n    this.start_datepicker();\r\n  }\r\n\r\n  generateID(): string{\r\n    return `tcloud-ui-datepicker-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  toSetMask(v: string){\r\n    return this._DateBRPipe.transform(v);\r\n  }\r\n\r\n  get_options(){\r\n    let options = {\r\n      nextArrow: `<i class=\"fas fa-caret-right\"></i>`,\r\n      prevArrow: `<i class=\"fas fa-caret-left\"></i>`,\r\n      format: 'dd/mm/yyyy',      \r\n      daysOfWeekHighlighted: [0,6],\r\n      language: 'ptBR'\r\n    } as any;\r\n\r\n    if( (this.daysOfWeekDisabled).length > 0 ){\r\n      options['daysOfWeekDisabled'] = this.daysOfWeekDisabled;\r\n    }\r\n\r\n    if( (this.datesDisabled).length > 0 ){\r\n      options['datesDisabled'] = this.datesDisabled;\r\n    }\r\n\r\n    if( this.minDate !== '' ){\r\n      options['minDate'] = this.minDate;\r\n    }\r\n\r\n    if( this.maxDate !== '' ){\r\n      options['maxDate'] = this.maxDate;\r\n    }\r\n\r\n    if( this.multiple ){      \r\n      options['maxNumberOfDates'] = this.maxNumberOfDates;\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  clearDate(){\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate({clear: true});\r\n    }\r\n  }\r\n\r\n  start_datepicker(){\r\n    setTimeout(() => {     \r\n      const input_datepicker = <any> this.input_datepicker?.nativeElement;\r\n      if( input_datepicker ){\r\n\r\n        input_datepicker.setAttribute('placeholder','DD/MM/YYYY');\r\n\r\n        if( !this.useBorder ){\r\n          input_datepicker.setAttribute('style','border:none; text-align: center; max-width: 105px; padding: 0;');\r\n        }\r\n        \r\n\r\n        this.datepicker = new Datepicker( input_datepicker, this.get_options() );\r\n\r\n        if( this.innerValue && this.innerValue !== '' ){\r\n          this.toSetDefaultDate(this.innerValue);\r\n        }\r\n\r\n        input_datepicker.addEventListener('keyup', (event: any) => {\r\n          const v = (input_datepicker['value']) ? input_datepicker['value'] : '';\r\n          input_datepicker['value'] = this.toSetMask(v);\r\n\r\n          if( (input_datepicker['value']).length >= 10 ){\r\n            const v = (input_datepicker['value']).substring(0, 10);\r\n            const part_date = (v).split('/');\r\n            if( (part_date).length === 3 ){\r\n\r\n              let dia = part_date[0];\r\n              let mes = part_date[1];\r\n              let ano = part_date[2];\r\n\r\n              mes = (+(mes) < 10 ) ? `0${+mes}` : mes;  \r\n              dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n\r\n              const dt = new Date(ano+'-'+mes+'-'+dia);\r\n              if( dt ){\r\n                input_datepicker?.changeDate;\r\n                document.getElementById(this.ID)?.blur();\r\n                this.onChange.emit(this.innerValue);\r\n                this.ngModelChange.emit(this.innerValue);\r\n              }\r\n            }\r\n          }else{\r\n            this.innerValue = undefined;\r\n            this.onChange.emit(this.innerValue);\r\n            this.ngModelChange.emit(this.innerValue);\r\n          }\r\n          //console.log('input_datepicker', input_datepicker['value'] );\r\n        })\r\n\r\n\r\n        input_datepicker.addEventListener('changeDate', (event: any) => {\r\n          //console.log(event);\r\n          if( event?.detail?.date ){\r\n            this.toSelectedDate( event.detail );\r\n          }else{\r\n            //console.log('event null');\r\n            this.innerValue = '';\r\n            this.ngModelChange.emit(this.innerValue);\r\n          }\r\n        })\r\n      }      \r\n    });\r\n  }\r\n\r\n  toSetDate(){\r\n    // Ex de uso\r\n    const dates = ['18/11/2022'];\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate(dates);\r\n    }    \r\n  }\r\n\r\n  toSetDefaultDate(date: string | string[]){\r\n    \r\n    if( date === undefined || date === null || date === '' ){\r\n      this.clearDate();\r\n      return;\r\n    }\r\n\r\n    let dates = [] as string[];\r\n\r\n    if( date && typeof date === 'string' ){\r\n      if( (date).includes(',') ){\r\n        const dates = (date).split(',');\r\n        date = dates;\r\n        if( !this.multiple ){\r\n          this.innerValue = date = dates[0];\r\n          this.ngModelChange.emit(this.innerValue); \r\n        }\r\n      }\r\n    }\r\n    \r\n    if( date && typeof date === 'string' ){\r\n      (dates).push( date ); \r\n    }else{\r\n      dates = <Array<string>> date;\r\n    }\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate(dates);      \r\n    } \r\n  }\r\n\r\n  toSelectedDate(detail: any){    \r\n    if( detail.datepicker.dates && (detail.datepicker.dates).length > 0 ){\r\n      if( this.multiple ){\r\n        let dates = [];\r\n        for( let i = 0; i < (detail.datepicker.dates).length; i++ ){\r\n          const timeStamp = <number> detail.datepicker.dates[i];\r\n          (dates).push( this.format_date( timeStamp ) );\r\n        }\r\n        this.innerValue = dates;\r\n        this.onChange.emit(this.innerValue);        \r\n      }else{\r\n        const timeStamp = <number> detail.datepicker.dates[0];\r\n        const date = this.format_date( timeStamp );\r\n        this.onChange.emit(date);\r\n        this.innerValue = date;\r\n      }      \r\n    }else{\r\n      this.clearDate();\r\n      this.innerValue = null;\r\n      this.onChange.emit(this.innerValue);\r\n    } \r\n    this.value = this.innerValue;\r\n    this.ngModelChange.emit(this.innerValue); \r\n  }\r\n\r\n  format_date(timeStamp: number){\r\n    var date = new Date(timeStamp);\r\n\r\n    let dia = `${date.getDate()}`;\r\n    let mes = `${date.getMonth()+1}`;\r\n    let ano = `${date.getFullYear()}`;\r\n\r\n    dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n    mes = (+(mes) < 10 ) ? `0${+mes}` : mes; \r\n\r\n    const dateFormat = `${dia}/${mes}/${ano}`;\r\n    return dateFormat;\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    const element = document.getElementById(id) as any;\r\n    setTimeout(() => {      \r\n      element?.datepicker?.show();\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\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\r\n    //console.log('value', v);\r\n\r\n    if (v !== this.innerValue) {\r\n      this.innerValue = v; // this.toSetMask(v);      \r\n      this.onChangeCallback(v);\r\n    }else{\r\n     // this.innerValue = '';\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.toSetDefaultDate(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}\r\n","<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n  <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n    <table class=\"table-box-input\">\r\n      <tr>\r\n        <td class=\"td-icon\">\r\n          <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n        </td>\r\n        <td class=\"td-date\">\r\n          <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n        </td>\r\n      </tr>\r\n    </table>\r\n  </div>\r\n\r\n  \r\n  \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\">  \r\n  <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n  <tc-datepicker \r\n    [multiple]=\"false\"\r\n    [daysOfWeekDisabled]=\"[0,6]\"\r\n    [minDate]=\"'18/11/2021'\"\r\n    [maxDate]=\"'18/12/2023'\"\r\n    [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n    [modeInput]=\"false\"\r\n    [(ngModel)]=\"dateValue\" >\r\n  </tc-datepicker>\r\n  \r\n  // multiple = false\r\n  // dateValue - string - pode ser: 12/12/2022 \r\n\r\n  // multiple = true\r\n  // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n  <pre>data: {{ dateValue }}</pre>\r\n-->\r\n"]}
|
package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.mjs
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { Component, forwardRef, EventEmitter, Output, Input, ViewChild } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "../tcloud-ui-datepicker/tcloud-ui-datepicker.component";
|
|
6
|
+
import * as i3 from "@angular/forms";
|
|
6
7
|
const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
|
|
7
8
|
provide: NG_VALUE_ACCESSOR,
|
|
8
9
|
useExisting: forwardRef(() => TCloudUiDatepickerTimeComponent),
|
|
@@ -16,8 +17,8 @@ export class TCloudUiDatepickerTimeComponent {
|
|
|
16
17
|
this.onChange = new EventEmitter();
|
|
17
18
|
this.eventChange = new EventEmitter();
|
|
18
19
|
this.DD_MM_YYYY = '';
|
|
19
|
-
this.HH = '';
|
|
20
|
-
this.MM = '';
|
|
20
|
+
this.HH = '00';
|
|
21
|
+
this.MM = '00';
|
|
21
22
|
this.ID = '';
|
|
22
23
|
//Placeholders for the callbacks which are later providesd
|
|
23
24
|
//by the Control Value Accessor
|
|
@@ -31,10 +32,24 @@ export class TCloudUiDatepickerTimeComponent {
|
|
|
31
32
|
}
|
|
32
33
|
ngOnInit() {
|
|
33
34
|
this.ID = this.generateID();
|
|
35
|
+
this.option_HH = this.getListTIME(23);
|
|
36
|
+
this.option_MM = this.getListTIME(59);
|
|
34
37
|
}
|
|
35
38
|
generateID() {
|
|
36
39
|
return `tcloud-ui-datepicker-time-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;
|
|
37
40
|
}
|
|
41
|
+
getListTIME(v) {
|
|
42
|
+
let mm = [];
|
|
43
|
+
for (let i = 0; i <= v; i++) {
|
|
44
|
+
if (i < 10) {
|
|
45
|
+
(mm).push(`0${i}`);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
(mm).push(`${i}`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return mm;
|
|
52
|
+
}
|
|
38
53
|
toSetDate(date) {
|
|
39
54
|
console.log('toSetDate', date);
|
|
40
55
|
this.set_date_by_datepicker(date);
|
|
@@ -89,10 +104,11 @@ export class TCloudUiDatepickerTimeComponent {
|
|
|
89
104
|
if (mm === '00') {
|
|
90
105
|
this.MM = mm;
|
|
91
106
|
}
|
|
92
|
-
const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:
|
|
107
|
+
const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:00Z`;
|
|
93
108
|
const datetime = new Date(str_date);
|
|
94
109
|
if (this.checkIsDate(datetime)) {
|
|
95
110
|
this.innerValue = datetime;
|
|
111
|
+
console.log('datetime', datetime);
|
|
96
112
|
}
|
|
97
113
|
else {
|
|
98
114
|
this.innerValue = undefined;
|
|
@@ -143,8 +159,8 @@ export class TCloudUiDatepickerTimeComponent {
|
|
|
143
159
|
}
|
|
144
160
|
clean() {
|
|
145
161
|
this.DD_MM_YYYY = '';
|
|
146
|
-
this.HH = '';
|
|
147
|
-
this.MM = '';
|
|
162
|
+
this.HH = '00';
|
|
163
|
+
this.MM = '00';
|
|
148
164
|
}
|
|
149
165
|
toClickIn(id) {
|
|
150
166
|
document.getElementById(id)?.focus();
|
|
@@ -193,10 +209,10 @@ export class TCloudUiDatepickerTimeComponent {
|
|
|
193
209
|
}
|
|
194
210
|
}
|
|
195
211
|
TCloudUiDatepickerTimeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
196
|
-
TCloudUiDatepickerTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiDatepickerTimeComponent, selector: "tcloud-ui-datepicker-time", inputs: { ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange", onChange: "onChange", eventChange: "eventChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "datepickertime", first: true, predicate: ["_datepickertime"], descendants: true }], ngImport: i0, template: "<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n <div class=\"input-control-time\">\r\n <div class=\"form-control-time\">\r\n <table class=\"form-time\">\r\n <tr>\r\n <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n <td class=\"area-input-hour\"
|
|
212
|
+
TCloudUiDatepickerTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiDatepickerTimeComponent, selector: "tcloud-ui-datepicker-time", inputs: { ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange", onChange: "onChange", eventChange: "eventChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "datepickertime", first: true, predicate: ["_datepickertime"], descendants: true }], ngImport: i0, template: "<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n <div class=\"input-control-time\">\r\n <div class=\"form-control-time\">\r\n <table class=\"form-time\">\r\n <tr>\r\n <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n \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 </div>\r\n </div>\r\n</form>", styles: ["@charset \"UTF-8\";.input-control-time{background-color:#fff;border:1px solid #ccc;border-radius:3px;width:100%;height:40px}.form-control-time{max-width:220px;border:none}.form-control-time input{text-align:center}.form-time{width:100%}.delimiter-time{width:100%;text-align:center}.delimiter-time-icon{border:none;height:35px;width:10px;padding:4px;font-size:17px;text-align:center;opacity:.6}.area-icon{width:25px}.area-input-date{width:100px}.area-delimiter{width:2px;text-align:center}.area-input-hour,.area-input-minute{text-align:center;width:28px}.area-input-hour input,.area-input-minute input{height:35px;width:28px;text-align:center;color:#999;font-weight:600;font-style:italic}.area-input-hour input:focus,.area-input-minute input:focus{outline:none}.area-clean{width:15px}input,.datepicker-input{border:none!important}.select-time-date{border:none;background-color:transparent;width:35px;height:37px;padding:0 9px;font-size:12px;color:#777;font-weight:600;-webkit-appearance:none;appearance:none}.select-time-date:focus{box-shadow:0 0;border:0 none;outline:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.TCloudUiDatepickerComponent, selector: "tcloud-ui-datepicker", inputs: ["multiple", "maxNumberOfDates", "daysOfWeekDisabled", "minDate", "maxDate", "datesDisabled", "modeInput", "useBorder", "ngModel", "code"], outputs: ["onChange", "ngModelChange"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
197
213
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerTimeComponent, decorators: [{
|
|
198
214
|
type: Component,
|
|
199
|
-
args: [{ selector: 'tcloud-ui-datepicker-time', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n <div class=\"input-control-time\">\r\n <div class=\"form-control-time\">\r\n <table class=\"form-time\">\r\n <tr>\r\n <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n <td class=\"area-input-hour\"
|
|
215
|
+
args: [{ selector: 'tcloud-ui-datepicker-time', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n <div class=\"input-control-time\">\r\n <div class=\"form-control-time\">\r\n <table class=\"form-time\">\r\n <tr>\r\n <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n \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 </div>\r\n </div>\r\n</form>", styles: ["@charset \"UTF-8\";.input-control-time{background-color:#fff;border:1px solid #ccc;border-radius:3px;width:100%;height:40px}.form-control-time{max-width:220px;border:none}.form-control-time input{text-align:center}.form-time{width:100%}.delimiter-time{width:100%;text-align:center}.delimiter-time-icon{border:none;height:35px;width:10px;padding:4px;font-size:17px;text-align:center;opacity:.6}.area-icon{width:25px}.area-input-date{width:100px}.area-delimiter{width:2px;text-align:center}.area-input-hour,.area-input-minute{text-align:center;width:28px}.area-input-hour input,.area-input-minute input{height:35px;width:28px;text-align:center;color:#999;font-weight:600;font-style:italic}.area-input-hour input:focus,.area-input-minute input:focus{outline:none}.area-clean{width:15px}input,.datepicker-input{border:none!important}.select-time-date{border:none;background-color:transparent;width:35px;height:37px;padding:0 9px;font-size:12px;color:#777;font-weight:600;-webkit-appearance:none;appearance:none}.select-time-date:focus{box-shadow:0 0;border:0 none;outline:0}\n"] }]
|
|
200
216
|
}], propDecorators: { ngModel: [{
|
|
201
217
|
type: Input
|
|
202
218
|
}], ngModelChange: [{
|
|
@@ -209,4 +225,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
209
225
|
type: ViewChild,
|
|
210
226
|
args: ['_datepickertime', { static: false }]
|
|
211
227
|
}] } });
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-datepicker-time.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit, EventEmitter, Output, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDatepickerTimeComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-datepicker-time',\r\n  templateUrl: './tcloud-ui-datepicker-time.component.html',\r\n  styleUrls: ['./tcloud-ui-datepicker-time.component.scss'],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]\r\n})\r\nexport class TCloudUiDatepickerTimeComponent implements OnInit {\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n    if( v && v !== this.innerValue ){\r\n      this.innerValue = v; \r\n    } \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<Date>();\r\n\r\n  @Output() onChange = new EventEmitter<Date>();\r\n  @Output() eventChange = new EventEmitter<any>();\r\n\r\n  DD_MM_YYYY: string = '';\r\n  HH: string = '';\r\n  MM: string = '';\r\n\r\n  ID: string = '';\r\n\r\n  @ViewChild('_datepickertime', {static: false}) datepickertime: ElementRef<HTMLElement> | undefined;\r\n\r\n  ngOnInit(): void {\r\n    this.ID = this.generateID();\r\n  }\r\n\r\n  generateID(): string{\r\n    return `tcloud-ui-datepicker-time-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  toSetDate(date: string){\r\n    console.log('toSetDate', date);\r\n\r\n    this.set_date_by_datepicker(date);\r\n  }\r\n\r\n  toSetTime(){\r\n    if( this.DD_MM_YYYY && ((this.DD_MM_YYYY).trim()).length === 10){\r\n      const date = (this.DD_MM_YYYY).replace(/-/g, '/');\r\n      let date_part = (date).split('/');\r\n      let dd = date_part[0];\r\n      let mm = date_part[1];\r\n      let yy = date_part[2];\r\n      const datetime = new Date(`${yy}-${mm}-${dd}`);\r\n      if( this.checkIsDate(datetime) ){\r\n        this.set_date_by_datepicker(date);\r\n      }\r\n    }\r\n  }\r\n\r\n  set_date_by_datepicker(date: string){\r\n\r\n    if( date ){\r\n      date = (date).replace(/-/g, '/');\r\n      let date_part = (date).split('/');\r\n      let dia = date_part[0];\r\n      let mes = date_part[1];\r\n      let ano = date_part[2];\r\n\r\n      let hh = this.HH;\r\n      if( !hh ){\r\n        hh = '00';\r\n      }else{\r\n        if( ( +(hh) >= 0 && +(hh) < 24 ) ){\r\n          hh = (+(hh) < 10 ) ? `0${+(hh)}` : `${+(hh)}`;\r\n        }else{\r\n          hh = '00';\r\n        }\r\n      }\r\n\r\n      let mm = this.MM;\r\n      if( !mm ){\r\n        mm = '00';\r\n      }else{\r\n        if( ( +(mm) >= 0 && +(mm) < 60 ) ){\r\n          mm = (+(mm) < 10 ) ? `0${+(mm)}` : `${+(mm)}`;\r\n        }else{\r\n          mm = '00';\r\n        }\r\n      }\r\n\r\n      if( hh === '00' ){ this.HH = hh; }\r\n      if( mm === '00' ){ this.MM = mm; }\r\n\r\n      const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:00`;\r\n      const datetime = new Date( str_date );\r\n      if( this.checkIsDate(datetime) ){\r\n        this.innerValue = datetime;\r\n        \r\n      }else{\r\n        this.innerValue = undefined;\r\n      }\r\n\r\n      this.ngModelChange.emit( this.innerValue );\r\n      this.onChange.emit( this.innerValue );\r\n      this.eventChange.emit( this.datepickertime?.nativeElement );\r\n\r\n      console.log('str_date', str_date);\r\n    }else{\r\n      this.innerValue = undefined;\r\n      this.ngModelChange.emit( this.innerValue );\r\n      this.onChange.emit( this.innerValue );\r\n      this.eventChange.emit( this.datepickertime?.nativeElement );\r\n    }\r\n\r\n  }\r\n\r\n  // Distribuir os valores da data por pedaços: data - hora - min\r\n  to_date_hh_mm(d: Date){\r\n    let dia = `${(d).getDate()}`;\r\n    dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n    let mes = `${(d).getMonth()+1}`;\r\n    mes = (+(mes) < 10 ) ? `0${+mes}` : mes;  \r\n\r\n    let ano = `${(d).getFullYear()}`;\r\n    let hh  = `${(d).getHours()}`;\r\n    let mm  = `${(d).getMinutes()}`;\r\n\r\n    if( hh && ( +(hh) < 0 || +(hh) > 23 ) ){ hh = '00'; }\r\n    hh = (hh) ? ( (+(hh) < 10 ) ? `0${hh}` : hh ) : '00';\r\n\r\n    if( mm && ( +(mm) < 0 || +(mm) > 59 ) ){ mm = '00'; }\r\n    mm = (mm) ? ( (+(mm) < 10 ) ? `0${mm}` : mm ) : '00';\r\n\r\n    this.MM = mm;\r\n    this.HH = hh;\r\n\r\n    this.DD_MM_YYYY = `${dia}/${mes}/${ano}`;\r\n  }\r\n\r\n  checkIsDate(d: any): boolean{\r\n\r\n    if(Object.prototype.toString.call(d) === \"[object Date]\") {\r\n      if(isNaN(d)) { return false; } else { return true; }\r\n    } \r\n    return false;\r\n  }\r\n\r\n\r\n  clean(){\r\n    this.DD_MM_YYYY = '';\r\n    this.HH = '';\r\n    this.MM = '';\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    document.getElementById(id)?.focus();\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  \r\n  innerValue: any | undefined;\r\n  //Placeholders for the callbacks which are later providesd\r\n  //by the Control Value Accessor\r\n  private onTouchedCallback: () => void = noop;\r\n  private onChangeCallback: (_: any) => void = noop;\r\n\r\n  //get accessor\r\n  get value(): any {\r\n      return this.innerValue;\r\n  };\r\n\r\n  //set accessor including call the onchange callback\r\n  set value(v: any) {\r\n    //console.log('set value', v);\r\n    if (v !== this.innerValue) {\r\n      //console.log('set value this.innerValue', this.innerValue);\r\n      this.innerValue = v;      \r\n      this.onChangeCallback(v);\r\n    }\r\n  }\r\n\r\n  //Set touched on blur\r\n  onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  writeValue(value: any) {\r\n    if (value !== this.innerValue) {\r\n\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","<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n  <div class=\"input-control-time\">\r\n    <div class=\"form-control-time\">\r\n      <table class=\"form-time\">\r\n        <tr>\r\n          <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n          <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n          <td class=\"area-delimiter\"><div class=\"delimiter-time\"></div></td>\r\n          <td class=\"area-input-hour\"><input type=\"text\" placeholder=\"HH\" (keyup)=\"toSetTime()\" [(ngModel)]=\"HH\" maxlength=\"2\" name=\"hh\" pattern=\"[0][0-9]|[1][0-9]|2[0-3]\"></td>\r\n          <td class=\"area-delimiter\"><div class=\"delimiter-time\">:</div></td>\r\n          <td class=\"area-input-minute\"><input type=\"text\" placeholder=\"MM\" (keyup)=\"toSetTime()\" [(ngModel)]=\"MM\" maxlength=\"2\" name=\"mm\" pattern=\"[012345][0-9]\"></td>\r\n          <td class=\"area-clean\"></td>\r\n        </tr>\r\n      </table>\r\n    </div>\r\n  </div>\r\n</form>"]}
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-datepicker-time.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit, EventEmitter, Output, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDatepickerTimeComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-datepicker-time',\r\n  templateUrl: './tcloud-ui-datepicker-time.component.html',\r\n  styleUrls: ['./tcloud-ui-datepicker-time.component.scss'],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]\r\n})\r\nexport class TCloudUiDatepickerTimeComponent implements OnInit {\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n    if( v && v !== this.innerValue ){\r\n      this.innerValue = v; \r\n    } \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<Date>();\r\n\r\n  @Output() onChange = new EventEmitter<Date>();\r\n  @Output() eventChange = new EventEmitter<any>();\r\n\r\n  DD_MM_YYYY: string = '';\r\n  HH: string = '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  ngOnInit(): void {\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  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    console.log('toSetDate', date);\r\n\r\n    this.set_date_by_datepicker(date);\r\n  }\r\n\r\n  toSetTime(){\r\n    if( this.DD_MM_YYYY && ((this.DD_MM_YYYY).trim()).length === 10){\r\n      const date = (this.DD_MM_YYYY).replace(/-/g, '/');\r\n      let date_part = (date).split('/');\r\n      let dd = date_part[0];\r\n      let mm = date_part[1];\r\n      let yy = date_part[2];\r\n      const datetime = new Date(`${yy}-${mm}-${dd}`);\r\n      if( this.checkIsDate(datetime) ){\r\n        this.set_date_by_datepicker(date);\r\n      }\r\n    }\r\n  }\r\n\r\n  set_date_by_datepicker(date: string){\r\n\r\n    if( date ){\r\n      date = (date).replace(/-/g, '/');\r\n      let date_part = (date).split('/');\r\n      let dia = date_part[0];\r\n      let mes = date_part[1];\r\n      let ano = date_part[2];\r\n\r\n      let hh = this.HH;\r\n      if( !hh ){\r\n        hh = '00';\r\n      }else{\r\n        if( ( +(hh) >= 0 && +(hh) < 24 ) ){\r\n          hh = (+(hh) < 10 ) ? `0${+(hh)}` : `${+(hh)}`;\r\n        }else{\r\n          hh = '00';\r\n        }\r\n      }\r\n\r\n      let mm = this.MM;\r\n      if( !mm ){\r\n        mm = '00';\r\n      }else{\r\n        if( ( +(mm) >= 0 && +(mm) < 60 ) ){\r\n          mm = (+(mm) < 10 ) ? `0${+(mm)}` : `${+(mm)}`;\r\n        }else{\r\n          mm = '00';\r\n        }\r\n      }\r\n\r\n      if( hh === '00' ){ this.HH = hh; }\r\n      if( mm === '00' ){ this.MM = mm; }\r\n\r\n      const str_date = `${ano}-${mes}-${dia}T${hh}:${mm}:00Z`;\r\n      const datetime = new Date( str_date );\r\n      \r\n      if( this.checkIsDate(datetime) ){\r\n        this.innerValue = datetime;\r\n        console.log('datetime', datetime);\r\n      }else{\r\n        this.innerValue = undefined;\r\n      }\r\n\r\n      this.ngModelChange.emit( this.innerValue );\r\n      this.onChange.emit( this.innerValue );\r\n      this.eventChange.emit( this.datepickertime?.nativeElement );\r\n\r\n      console.log('str_date', str_date);\r\n    }else{\r\n      this.innerValue = undefined;\r\n      this.ngModelChange.emit( this.innerValue );\r\n      this.onChange.emit( this.innerValue );\r\n      this.eventChange.emit( this.datepickertime?.nativeElement );\r\n    }\r\n\r\n  }\r\n\r\n  // Distribuir os valores da data por pedaços: data - hora - min\r\n  to_date_hh_mm(d: Date){\r\n    let dia = `${(d).getDate()}`;\r\n    dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n    let mes = `${(d).getMonth()+1}`;\r\n    mes = (+(mes) < 10 ) ? `0${+mes}` : mes;  \r\n\r\n    let ano = `${(d).getFullYear()}`;\r\n    let hh  = `${(d).getHours()}`;\r\n    let mm  = `${(d).getMinutes()}`;\r\n\r\n    if( hh && ( +(hh) < 0 || +(hh) > 23 ) ){ hh = '00'; }\r\n    hh = (hh) ? ( (+(hh) < 10 ) ? `0${hh}` : hh ) : '00';\r\n\r\n    if( mm && ( +(mm) < 0 || +(mm) > 59 ) ){ mm = '00'; }\r\n    mm = (mm) ? ( (+(mm) < 10 ) ? `0${mm}` : mm ) : '00';\r\n\r\n    this.MM = mm;\r\n    this.HH = hh;\r\n\r\n    this.DD_MM_YYYY = `${dia}/${mes}/${ano}`;\r\n  }\r\n\r\n  checkIsDate(d: any): boolean{\r\n\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  }\r\n\r\n  toClickIn(id: string){\r\n    document.getElementById(id)?.focus();\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  \r\n  innerValue: any | undefined;\r\n  //Placeholders for the callbacks which are later providesd\r\n  //by the Control Value Accessor\r\n  private onTouchedCallback: () => void = noop;\r\n  private onChangeCallback: (_: any) => void = noop;\r\n\r\n  //get accessor\r\n  get value(): any {\r\n      return this.innerValue;\r\n  };\r\n\r\n  //set accessor including call the onchange callback\r\n  set value(v: any) {\r\n    //console.log('set value', v);\r\n    if (v !== this.innerValue) {\r\n      //console.log('set value this.innerValue', this.innerValue);\r\n      this.innerValue = v;      \r\n      this.onChangeCallback(v);\r\n    }\r\n  }\r\n\r\n  //Set touched on blur\r\n  onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  writeValue(value: any) {\r\n    if (value !== this.innerValue) {\r\n\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","<input type=\"hidden\" value=\"{{ innerValue }}\" #_datepickertime >\r\n<form #_formulario=\"ngForm\">\r\n  <div class=\"input-control-time\">\r\n    <div class=\"form-control-time\">\r\n      <table class=\"form-time\">\r\n        <tr>\r\n          <!-- <td class=\"area-icon\"><div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div></td> -->\r\n          <td class=\"area-input-date\"><tcloud-ui-datepicker #_tclouddatepickertime [modeInput]=\"true\" name=\"date\" [useBorder]=\"false\" [(ngModel)]=\"DD_MM_YYYY\" (onChange)=\"toSetDate($event)\" ></tcloud-ui-datepicker></td>\r\n          \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    </div>\r\n  </div>\r\n</form>"]}
|