@dev-tcloud/tcloud-ui 0.0.63 → 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 CHANGED
@@ -30,6 +30,7 @@ npm install @dev-tcloud/tcloud-ui --save
30
30
  - TCloudUiAccordionModule
31
31
  - TCloudUiDatepickerComponent
32
32
  - TCloudUiDatepickerTimeComponent
33
+ - TCloudUiMultiplesValuesModule
33
34
 
34
35
  ## tcloud-ui directives
35
36
  - TCloudUiTooltipDirective
@@ -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"]}
@@ -0,0 +1,289 @@
1
+ import { Component, Input, forwardRef } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/forms";
6
+ const CUSTOM_INPUT_VALIDATORS = {
7
+ provide: NG_VALIDATORS,
8
+ useExisting: forwardRef(() => TCloudUiMultiplesValuesComponent),
9
+ multi: true
10
+ };
11
+ const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
12
+ provide: NG_VALUE_ACCESSOR,
13
+ useExisting: forwardRef(() => TCloudUiMultiplesValuesComponent),
14
+ multi: true
15
+ };
16
+ const noop = () => {
17
+ };
18
+ export class TCloudUiMultiplesValuesComponent {
19
+ constructor() {
20
+ this.viewport_width = 0;
21
+ this.viewport_height = 0;
22
+ this.box_height = 0;
23
+ this.box_style = '';
24
+ this.menu_on_top = '';
25
+ this.search_text = '';
26
+ this.id = '';
27
+ this.show_itens = false;
28
+ this.input_items = '';
29
+ this.items = [];
30
+ this.delimiter = ',';
31
+ this.placeholder = '';
32
+ this.disabled = false;
33
+ this.loading = false;
34
+ this.search = true;
35
+ this.uppercase = false;
36
+ this.lowercase = false;
37
+ this.use_validation_required = false;
38
+ this.placeholder_list = '';
39
+ //Placeholders for the callbacks which are later providesd
40
+ //by the Control Value Accessor
41
+ this.onTouchedCallback = noop;
42
+ this.onChangeCallback = noop;
43
+ }
44
+ ngOnInit() {
45
+ this.id = this.generateID();
46
+ this.toResize();
47
+ this.toClick();
48
+ this.set_placeholder_list();
49
+ }
50
+ check_is_valid() {
51
+ if (this.items) {
52
+ return ((this.items).length > 0) ? true : false;
53
+ }
54
+ return false;
55
+ }
56
+ generateID() {
57
+ return `multiple-values-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;
58
+ }
59
+ remove_duplicates(items) {
60
+ return [...new Set(items)];
61
+ }
62
+ item_width(text) {
63
+ const value = `${text}`;
64
+ const value_len = (value).length;
65
+ let max_width = 155;
66
+ if (value_len < 15) {
67
+ max_width = 138;
68
+ }
69
+ if (value_len < 10) {
70
+ max_width = 105;
71
+ }
72
+ if (value_len < 8) {
73
+ max_width = 85;
74
+ }
75
+ if (value_len < 5) {
76
+ max_width = 70;
77
+ }
78
+ return { 'max-width': max_width + 'px' };
79
+ }
80
+ add_itens() {
81
+ if (this.disabled) {
82
+ return;
83
+ }
84
+ const input_items = this.input_items;
85
+ this.input_items = '';
86
+ let items = [];
87
+ if (input_items && input_items !== '') {
88
+ items = (input_items).split(this.delimiter);
89
+ }
90
+ if ((items).length === 0) {
91
+ let txt = `${(input_items).trim()}`;
92
+ items = [txt];
93
+ }
94
+ //items = [...new Set(items)];
95
+ for (let i = 0; i < (items).length; i++) {
96
+ let txt = `${(items[i]).trim()}`;
97
+ if (this.uppercase) {
98
+ txt = (txt).toLocaleUpperCase();
99
+ }
100
+ if (this.lowercase) {
101
+ txt = (txt).toLocaleLowerCase();
102
+ }
103
+ if (txt !== '') {
104
+ (this.items).push(txt);
105
+ }
106
+ }
107
+ this.items = this.remove_duplicates(this.items);
108
+ this.set_placeholder_list();
109
+ }
110
+ set_placeholder_list() {
111
+ let placeholder_list = '';
112
+ let delimiter = '';
113
+ const items = this.items;
114
+ if (items && (items).length > 0) {
115
+ for (let i = 0; i < (items).length; i++) {
116
+ placeholder_list += delimiter + `${(items[i]).trim()}`;
117
+ delimiter = `${this.delimiter} `;
118
+ }
119
+ }
120
+ this.placeholder_list = (placeholder_list !== '') ? placeholder_list : this.placeholder;
121
+ this.onChangeTouched();
122
+ this.onChangeCallback(this.items);
123
+ }
124
+ removeItem(item, index) {
125
+ if (this.disabled) {
126
+ return;
127
+ }
128
+ if (this.items) {
129
+ for (let i = 0; i < (this.items).length; i++) {
130
+ const row = this.items[i];
131
+ if (item === row && i === index) {
132
+ (this.items).splice(index, 1);
133
+ break;
134
+ }
135
+ }
136
+ }
137
+ this.set_placeholder_list();
138
+ }
139
+ remove_all() {
140
+ if (this.disabled) {
141
+ return;
142
+ }
143
+ this.items = [];
144
+ this.set_placeholder_list();
145
+ }
146
+ toClick() {
147
+ const box = `area-${this.id}`;
148
+ window.addEventListener('click', (e) => {
149
+ if (this.show_itens) {
150
+ try {
151
+ if (!(document.getElementById(box)?.contains(e.target))) {
152
+ if ('box-action' !== e.target.parentElement.className) {
153
+ this.show_itens = false;
154
+ }
155
+ console.log('toClick', e.target.parentElement.className);
156
+ }
157
+ }
158
+ catch (error) {
159
+ }
160
+ }
161
+ });
162
+ const boxsub = `${this.id}-options`;
163
+ }
164
+ toResize() {
165
+ window.addEventListener('resize', () => {
166
+ this.viewport_width = window.innerWidth;
167
+ this.viewport_height = window.innerHeight;
168
+ this.resolve_position_dropdown(this.show_itens);
169
+ });
170
+ }
171
+ toOpen() {
172
+ this.show_itens = !this.show_itens;
173
+ this.resolve_position_dropdown(this.show_itens);
174
+ }
175
+ toClose() {
176
+ this.show_itens = false;
177
+ }
178
+ resolve_position_dropdown(open) {
179
+ if (open) {
180
+ this.box_style = '';
181
+ this.menu_on_top = '';
182
+ const id = `${this.id}`;
183
+ const box = `box-${this.id}`;
184
+ if (this.viewport_height === 0) {
185
+ this.viewport_height = window.innerWidth;
186
+ }
187
+ const rect = document.getElementById(id)?.getBoundingClientRect();
188
+ const box_position = rect?.bottom || 0;
189
+ setTimeout(() => {
190
+ this.box_height = document.getElementById(box)?.clientHeight || 0;
191
+ if ((this.viewport_height - box_position) < this.box_height) {
192
+ this.menu_on_top = 'menu-on-top';
193
+ this.box_style = `top: -${(this.box_height)}px; height: ${this.box_height}px;`;
194
+ }
195
+ });
196
+ }
197
+ }
198
+ clearTextSearch() {
199
+ this.search_text = '';
200
+ this.toSearch('');
201
+ }
202
+ toSearch(e) {
203
+ let input = (e && e.target && e.target.value) ? e.target.value : '';
204
+ let filter = (((input).normalize('NFD').replace(/[\u0300-\u036f]/g, "")).trim()).toLowerCase();
205
+ let ul = document.getElementById(`${this.id}-options`);
206
+ let li = ul.getElementsByTagName("label");
207
+ for (let i = 0; i < li.length; i++) {
208
+ const a = li[i];
209
+ const txtValue = (((a.textContent || a.innerText).normalize('NFD').replace(/[\u0300-\u036f]/g, "")).trim()).toLowerCase();
210
+ if (txtValue.indexOf(filter) > -1) {
211
+ li[i].style.display = "";
212
+ }
213
+ else {
214
+ li[i].style.display = "none";
215
+ }
216
+ }
217
+ }
218
+ onChangeTouched() {
219
+ this.onTouchedCallback();
220
+ }
221
+ toSetDefault(v) {
222
+ this.items = v;
223
+ this.add_itens();
224
+ }
225
+ //get accessor
226
+ get value() {
227
+ return this.innerValue;
228
+ }
229
+ ;
230
+ //set accessor including call the onchange callback
231
+ set value(v) {
232
+ if (v !== this.innerValue) {
233
+ this.innerValue = v;
234
+ this.toSetDefault(v);
235
+ this.onChangeCallback(v);
236
+ }
237
+ }
238
+ //Set touched on blur
239
+ onBlur() {
240
+ this.onTouchedCallback();
241
+ }
242
+ //From ControlValueAccessor interface
243
+ writeValue(value) {
244
+ if (value !== this.innerValue) {
245
+ this.innerValue = value;
246
+ this.toSetDefault(value);
247
+ }
248
+ }
249
+ //From ControlValueAccessor interface
250
+ registerOnChange(fn) {
251
+ this.onChangeCallback = fn;
252
+ }
253
+ //From ControlValueAccessor interface
254
+ registerOnTouched(fn) {
255
+ this.onTouchedCallback = fn;
256
+ }
257
+ validate(c) {
258
+ if (c && (typeof this.required !== 'undefined')) {
259
+ this.use_validation_required = true;
260
+ return (this.check_is_valid()) ? null : 'required';
261
+ }
262
+ return null;
263
+ }
264
+ ngOnDestroy() {
265
+ }
266
+ }
267
+ TCloudUiMultiplesValuesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiMultiplesValuesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
268
+ TCloudUiMultiplesValuesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiMultiplesValuesComponent, selector: "tcloud-ui-multiples-values", inputs: { delimiter: "delimiter", placeholder: "placeholder", disabled: "disabled", loading: "loading", required: "required", search: "search", uppercase: "uppercase", lowercase: "lowercase" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS], ngImport: i0, template: "<div class=\"tc-dropdown\" id=\"area-{{ id }}\" [class.tc-parent-validation]=\"use_validation_required\">\n\n\n <form #_formulario=\"ngForm\">\n\n <!-- {{ input_items }} -->\n\n <div class=\"dropdown-toggle\" id=\"{{id}}\" [attr.aria-haspopup]=\"'true'\" [attr.aria-expanded]=\"'false'\">\n <table class=\"group-input-action\">\n <tr>\n <td class=\"box-input\">\n <div class=\"input\">\n <input \n [disabled]=\"disabled\"\n [class.text-lowercase]=\"lowercase\"\n [class.text-uppercase]=\"uppercase\"\n type=\"text\" name=\"items\" class=\"form-control tc-form-control\" [(ngModel)]=\"input_items\" [placeholder]=\"placeholder_list\" required [title]=\"placeholder_list\">\n </div>\n </td>\n <td class=\"count-list\" *ngIf=\"(items && items.length > 0)\">\n <div class=\"input\">\n <input type=\"text\" value=\"{{ items.length }} {{ (items.length > 1) ? 'registros' : 'registro' }}\" disabled readonly>\n \n </div>\n </td>\n <td class=\"action-input-arrow\">\n <button (click)=\"toOpen()\" title=\"Lista de valores\" [disabled]=\"disabled\">\n <i class=\"fas fa-angle-up\" *ngIf=\"show_itens\"></i>\n <i class=\"fas fa-angle-down\" *ngIf=\"!show_itens\"></i>\n </button>\n </td>\n <td class=\"action-input\" *ngIf=\"!disabled\">\n <button [disabled]=\"!_formulario.valid\" class=\"tc-btn tc-btn-primary btn-new-green\" (click)=\"add_itens()\" title=\"Adicionar item\">\n <i class=\"fas fa-plus\"></i>\n </button>\n </td>\n </tr>\n </table>\n </div>\n \n <!-- <pre>\n {{ items | json }}\n </pre> -->\n\n </form> \n\n <!-- box-itens-selected -->\n <div class=\"tc-dropdown-menu box-itens-selected {{ menu_on_top }}\" id=\"box-{{ id }}\" [attr.aria-labelledby]=\"id\" [class.to-hide]=\"!show_itens\" [style]=\"box_style\">\n \n\n <div class=\"line-search\" *ngIf=\"search\">\n <table class=\"box-search\">\n <tr>\n \n <td class=\"area-input\">\n <input type=\"text\" class=\"tc-form-control\" [(ngModel)]=\"search_text\" (input)=\"toSearch($event)\" placeholder=\"Buscar...\" > \n </td>\n \n <td class=\"area-icon\">\n <i *ngIf=\"search_text === ''\" class=\"fas fa-search icon-search\"></i>\n <button class=\"box-action\" type=\"button\" *ngIf=\"search_text !== ''\" (click)=\"clearTextSearch()\"><i class=\"fas fa-times\"></i></button>\n </td>\n \n </tr>\n </table>\n </div>\n\n <div class=\"area-options\" id=\"{{ id }}-options\">\n <ng-container *ngFor=\"let item of items; let i = index\">\n \n <label class=\"box-label\" [ngStyle]=\"item_width(item)\">\n <div class=\"box-value\" [title]=\"item\" >\n {{ item }} \n </div>\n <div class=\"box-action\">\n <button\n class=\"box-action\"\n [disabled]=\"items === undefined || (items && items.length === 0) || disabled || loading\"\n title=\"Remover\"\n type=\"button\"\n (click)=\"removeItem(item, i)\">\n <i class=\"fas fa-times\"></i>\n </button>\n </div>\n </label>\n\n </ng-container>\n </div>\n\n <div class=\"mt-5\" *ngIf=\"items && (items).length > 5\">\n <div class=\"btn-remove-all\">\n <button class=\"box-action\" type=\"button\" (click)=\"remove_all()\">\n Limpar toda a lista\n </button>\n </div>\n </div>\n\n </div>\n</div>", styles: ["table{border-collapse:collapse}td,th{padding:0;margin:0}::placeholder{font-style:italic;color:#999;text-transform:none!important}.box-input .input{background-color:#fff;border-left:1px solid #ccc;border-top:1px solid #ccc;border-bottom:1px solid #ccc;border-radius:5px 0 0 5px}.group-input-action{width:100%}.group-input-action input{height:40px;border:none}.count-list{width:90px;text-align:center;background:#fff}.count-list .input{background-color:#fff;border-bottom:1px solid #ccc;border-top:1px solid #ccc}.count-list .input input{height:40px;border:none;text-align:center;width:100px}.action-input-arrow{width:30px;background-color:#fff;position:relative;z-index:0}.action-input-arrow button{cursor:pointer;background-color:transparent;text-align:center;font-size:15px;height:42px;border-top:1px solid #ccc;border-right:1px solid #ccc;border-bottom:1px solid #ccc;border-left:none;width:30px;border-radius:0 3px 3px 0}.action-input-arrow button i{position:relative;z-index:-1}.action-input{width:50px;padding-left:10px}.action-input .tc-btn{width:100%!important;padding:0;text-align:center;border-radius:3px;display:block;margin:0}.action-input .tc-btn i{width:100%;text-align:center;padding:0!important;margin:0!important}.box-itens-selected{display:block;padding:9px;background-color:#ededed;border-radius:4px;width:100%}.box-itens-selected .box-label{position:relative;display:inline-block;height:35px;min-width:60px;background-color:var(--verde);color:#fff;padding:8px 15px 10px;border:none;border-radius:5px;margin:2px;width:100%}.box-itens-selected .box-label .box-value{width:100%;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.box-itens-selected .box-label div.box-action{position:absolute;right:4px;top:7px}.box-itens-selected .box-label div.box-action button{color:#d72020;background-color:transparent;border:none;font-weight:700;cursor:pointer}.box-itens-selected .box-label div.box-action button i{font-size:12px}.to-hide{display:none}.dropdown-toggle:after{display:none!important}.tc-dropdown{position:relative}.tc-dropdown .tc-dropdown-menu{width:100%;border:1px solid #ccc;background-color:#fff;position:absolute;z-index:1}.tc-dropdown .area-options{max-height:200px;overflow-y:scroll;overflow-x:hidden}.tc-dropdown .menu-on-top{position:absolute}.line-search{padding:3px}.line-search .box-search{width:100%;border-collapse:collapse}.line-search .box-search td.area-icon{padding:4px 0 2px 8px;width:35px}.line-search .box-search td.area-icon .icon-search{color:#666}.line-search .box-search td.area-icon button{border:none;background-color:transparent;color:#999;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.line-search .box-search td.area-input{border:none}.line-search .box-search td.area-input input{width:100%}.line-search .box-search input{width:100%;font-size:13px;height:33px;border:1px solid #ccc;padding:10px}.btn-remove-all{text-align:right}.btn-remove-all button{background-color:transparent;border:none;color:#dd5353;cursor:pointer}.btn-remove-all button:hover{color:red!important}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
269
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiMultiplesValuesComponent, decorators: [{
270
+ type: Component,
271
+ args: [{ selector: 'tcloud-ui-multiples-values', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS], template: "<div class=\"tc-dropdown\" id=\"area-{{ id }}\" [class.tc-parent-validation]=\"use_validation_required\">\n\n\n <form #_formulario=\"ngForm\">\n\n <!-- {{ input_items }} -->\n\n <div class=\"dropdown-toggle\" id=\"{{id}}\" [attr.aria-haspopup]=\"'true'\" [attr.aria-expanded]=\"'false'\">\n <table class=\"group-input-action\">\n <tr>\n <td class=\"box-input\">\n <div class=\"input\">\n <input \n [disabled]=\"disabled\"\n [class.text-lowercase]=\"lowercase\"\n [class.text-uppercase]=\"uppercase\"\n type=\"text\" name=\"items\" class=\"form-control tc-form-control\" [(ngModel)]=\"input_items\" [placeholder]=\"placeholder_list\" required [title]=\"placeholder_list\">\n </div>\n </td>\n <td class=\"count-list\" *ngIf=\"(items && items.length > 0)\">\n <div class=\"input\">\n <input type=\"text\" value=\"{{ items.length }} {{ (items.length > 1) ? 'registros' : 'registro' }}\" disabled readonly>\n \n </div>\n </td>\n <td class=\"action-input-arrow\">\n <button (click)=\"toOpen()\" title=\"Lista de valores\" [disabled]=\"disabled\">\n <i class=\"fas fa-angle-up\" *ngIf=\"show_itens\"></i>\n <i class=\"fas fa-angle-down\" *ngIf=\"!show_itens\"></i>\n </button>\n </td>\n <td class=\"action-input\" *ngIf=\"!disabled\">\n <button [disabled]=\"!_formulario.valid\" class=\"tc-btn tc-btn-primary btn-new-green\" (click)=\"add_itens()\" title=\"Adicionar item\">\n <i class=\"fas fa-plus\"></i>\n </button>\n </td>\n </tr>\n </table>\n </div>\n \n <!-- <pre>\n {{ items | json }}\n </pre> -->\n\n </form> \n\n <!-- box-itens-selected -->\n <div class=\"tc-dropdown-menu box-itens-selected {{ menu_on_top }}\" id=\"box-{{ id }}\" [attr.aria-labelledby]=\"id\" [class.to-hide]=\"!show_itens\" [style]=\"box_style\">\n \n\n <div class=\"line-search\" *ngIf=\"search\">\n <table class=\"box-search\">\n <tr>\n \n <td class=\"area-input\">\n <input type=\"text\" class=\"tc-form-control\" [(ngModel)]=\"search_text\" (input)=\"toSearch($event)\" placeholder=\"Buscar...\" > \n </td>\n \n <td class=\"area-icon\">\n <i *ngIf=\"search_text === ''\" class=\"fas fa-search icon-search\"></i>\n <button class=\"box-action\" type=\"button\" *ngIf=\"search_text !== ''\" (click)=\"clearTextSearch()\"><i class=\"fas fa-times\"></i></button>\n </td>\n \n </tr>\n </table>\n </div>\n\n <div class=\"area-options\" id=\"{{ id }}-options\">\n <ng-container *ngFor=\"let item of items; let i = index\">\n \n <label class=\"box-label\" [ngStyle]=\"item_width(item)\">\n <div class=\"box-value\" [title]=\"item\" >\n {{ item }} \n </div>\n <div class=\"box-action\">\n <button\n class=\"box-action\"\n [disabled]=\"items === undefined || (items && items.length === 0) || disabled || loading\"\n title=\"Remover\"\n type=\"button\"\n (click)=\"removeItem(item, i)\">\n <i class=\"fas fa-times\"></i>\n </button>\n </div>\n </label>\n\n </ng-container>\n </div>\n\n <div class=\"mt-5\" *ngIf=\"items && (items).length > 5\">\n <div class=\"btn-remove-all\">\n <button class=\"box-action\" type=\"button\" (click)=\"remove_all()\">\n Limpar toda a lista\n </button>\n </div>\n </div>\n\n </div>\n</div>", styles: ["table{border-collapse:collapse}td,th{padding:0;margin:0}::placeholder{font-style:italic;color:#999;text-transform:none!important}.box-input .input{background-color:#fff;border-left:1px solid #ccc;border-top:1px solid #ccc;border-bottom:1px solid #ccc;border-radius:5px 0 0 5px}.group-input-action{width:100%}.group-input-action input{height:40px;border:none}.count-list{width:90px;text-align:center;background:#fff}.count-list .input{background-color:#fff;border-bottom:1px solid #ccc;border-top:1px solid #ccc}.count-list .input input{height:40px;border:none;text-align:center;width:100px}.action-input-arrow{width:30px;background-color:#fff;position:relative;z-index:0}.action-input-arrow button{cursor:pointer;background-color:transparent;text-align:center;font-size:15px;height:42px;border-top:1px solid #ccc;border-right:1px solid #ccc;border-bottom:1px solid #ccc;border-left:none;width:30px;border-radius:0 3px 3px 0}.action-input-arrow button i{position:relative;z-index:-1}.action-input{width:50px;padding-left:10px}.action-input .tc-btn{width:100%!important;padding:0;text-align:center;border-radius:3px;display:block;margin:0}.action-input .tc-btn i{width:100%;text-align:center;padding:0!important;margin:0!important}.box-itens-selected{display:block;padding:9px;background-color:#ededed;border-radius:4px;width:100%}.box-itens-selected .box-label{position:relative;display:inline-block;height:35px;min-width:60px;background-color:var(--verde);color:#fff;padding:8px 15px 10px;border:none;border-radius:5px;margin:2px;width:100%}.box-itens-selected .box-label .box-value{width:100%;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.box-itens-selected .box-label div.box-action{position:absolute;right:4px;top:7px}.box-itens-selected .box-label div.box-action button{color:#d72020;background-color:transparent;border:none;font-weight:700;cursor:pointer}.box-itens-selected .box-label div.box-action button i{font-size:12px}.to-hide{display:none}.dropdown-toggle:after{display:none!important}.tc-dropdown{position:relative}.tc-dropdown .tc-dropdown-menu{width:100%;border:1px solid #ccc;background-color:#fff;position:absolute;z-index:1}.tc-dropdown .area-options{max-height:200px;overflow-y:scroll;overflow-x:hidden}.tc-dropdown .menu-on-top{position:absolute}.line-search{padding:3px}.line-search .box-search{width:100%;border-collapse:collapse}.line-search .box-search td.area-icon{padding:4px 0 2px 8px;width:35px}.line-search .box-search td.area-icon .icon-search{color:#666}.line-search .box-search td.area-icon button{border:none;background-color:transparent;color:#999;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.line-search .box-search td.area-input{border:none}.line-search .box-search td.area-input input{width:100%}.line-search .box-search input{width:100%;font-size:13px;height:33px;border:1px solid #ccc;padding:10px}.btn-remove-all{text-align:right}.btn-remove-all button{background-color:transparent;border:none;color:#dd5353;cursor:pointer}.btn-remove-all button:hover{color:red!important}\n"] }]
272
+ }], ctorParameters: function () { return []; }, propDecorators: { delimiter: [{
273
+ type: Input
274
+ }], placeholder: [{
275
+ type: Input
276
+ }], disabled: [{
277
+ type: Input
278
+ }], loading: [{
279
+ type: Input
280
+ }], required: [{
281
+ type: Input
282
+ }], search: [{
283
+ type: Input
284
+ }], uppercase: [{
285
+ type: Input
286
+ }], lowercase: [{
287
+ type: Input
288
+ }] } });
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-multiples-values.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit, forwardRef } from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS, FormControl, Validator } from '@angular/forms';\n\nconst  CUSTOM_INPUT_VALIDATORS: any = { \n  provide: NG_VALIDATORS, \n  useExisting: forwardRef(() => TCloudUiMultiplesValuesComponent),\n  multi: true\n}\n\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => TCloudUiMultiplesValuesComponent),\n  multi: true\n};\n\nconst noop = () => {\n};\n\n@Component({\n  selector: 'tcloud-ui-multiples-values',\n  templateUrl: './tcloud-ui-multiples-values.component.html',\n  styleUrls: ['./tcloud-ui-multiples-values.component.scss'],\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR, CUSTOM_INPUT_VALIDATORS]\n})\nexport class TCloudUiMultiplesValuesComponent implements OnInit, OnDestroy, Validator  {\n\n  viewport_width: number = 0;\n  viewport_height: number = 0;\n  box_height: number = 0;\n  box_style: string = '';\n  menu_on_top: string = '';\n  search_text: string = '';\n\n  id: string = '';\n  show_itens: boolean = false;\n\n  \n\n  input_items: string = '';\n\n  items = [] as string[];\n\n  \n \n  @Input() delimiter: string = ',';\n  @Input() placeholder: string = '';\n  @Input() disabled: boolean = false;\n  @Input() loading: boolean = false;\n  @Input() required: string | undefined;\n  @Input() search: boolean = true;\n  @Input() uppercase: boolean = false;\n  @Input() lowercase: boolean = false;\n\n  use_validation_required: boolean = false;\n\n  placeholder_list: string = '';\n\n  constructor() { }\n\n  ngOnInit(): void {\n    this.id = this.generateID();\n    this.toResize();\n    this.toClick();\n    this.set_placeholder_list();\n  }\n\n  check_is_valid(): boolean{\n    if( this.items ){\n      return ((this.items).length > 0) ? true : false;\n    }\n    return false;\n  }\n\n  generateID(): string{\n    return `multiple-values-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\n  }\n\n  remove_duplicates(items: string[]): string[] {\n    return [...new Set(items)];\n  }\n\n  item_width(text: any) {\n    const value = `${text}`;\n    const value_len = (value).length;\n    let max_width = 155;\n    if( value_len < 15 ){ max_width = 138; }\n    if( value_len < 10 ){ max_width = 105; }\n    if( value_len < 8 ){ max_width = 85; }\n    if( value_len < 5 ){ max_width = 70; }\n    return { 'max-width': max_width + 'px'};\n  }\n\n  add_itens(){\n\n    if( this.disabled ){ return; }\n\n    const input_items = this.input_items;\n\n    this.input_items = '';\n    \n    let items = [];\n    if( input_items && input_items !== '' ){\n\n      items = <any> (input_items).split(this.delimiter);\n\n    }\n\n    if( (items).length === 0 ){\n      let txt = `${(input_items).trim()}`;\n      items = [txt];\n    }\n\n    //items = [...new Set(items)];\n\n    for( let i = 0; i < (items).length; i++){\n      let txt = `${(items[i]).trim()}`;\n\n      if( this.uppercase ){\n        txt = (txt).toLocaleUpperCase();\n      }\n\n      if( this.lowercase ){\n        txt = (txt).toLocaleLowerCase();\n      }\n\n      if( txt !== '' ){\n        (this.items).push(txt);\n      }\n      \n    }\n\n    this.items = this.remove_duplicates(this.items);\n    this.set_placeholder_list();\n  }\n\n  set_placeholder_list(){\n    let placeholder_list = '';\n    let delimiter = '';\n    const items = this.items;\n    if( items && (items).length > 0 ){\n      for( let i = 0; i < (items).length; i++){\n        placeholder_list +=  delimiter + `${(items[i]).trim()}`;\n        delimiter = `${this.delimiter} `;\n      }\n    }\n    this.placeholder_list = (placeholder_list !== '') ? placeholder_list : this.placeholder;\n    this.onChangeTouched();\n    this.onChangeCallback(this.items);\n  }\n\n\n  removeItem(item: any, index: number): void{\n    if( this.disabled ){ return; }\n    if( this.items ){\n      for( let i = 0; i < (this.items).length; i++ ){\n        const row = this.items[i];\n        if( item === row && i === index ){\n          (this.items).splice(index,1);\n          break;\n        }\n      }\n    }\n    this.set_placeholder_list();\n  }\n\n  remove_all(){\n    if( this.disabled ){ return; }\n    this.items = [];\n    this.set_placeholder_list();\n  }\n\n  toClick(){\n    const box = `area-${this.id}`;\n    window.addEventListener('click',(e: any) => {  \n\n      if( this.show_itens ){        \n        try {\n          if( !(document.getElementById(box)?.contains(e.target)) ){  \n            if( 'box-action' !== e.target.parentElement.className ){\n              this.show_itens = false;\n            }  \n            console.log('toClick', e.target.parentElement.className);    \n            \n          }\n        } catch (error) {\n          \n        }\n        \n      }\n    });\n\n    const boxsub = `${this.id}-options`;\n  }\n\n  toResize(){\n    window.addEventListener('resize', () => {\n      this.viewport_width = window.innerWidth;\n      this.viewport_height = window.innerHeight;\n      this.resolve_position_dropdown(this.show_itens);\n    });\n  }\n\n  toOpen(){\n    this.show_itens = !this.show_itens;\n    this.resolve_position_dropdown(this.show_itens);\n  }\n\n  toClose(){\n    this.show_itens = false;\n  }\n\n  resolve_position_dropdown(open: boolean){\n    if( open ){\n      this.box_style = '';\n      this.menu_on_top = '';   \n      const id = `${this.id}`; \n      const box = `box-${this.id}`;\n      if( this.viewport_height === 0 ){\n        this.viewport_height = window.innerWidth;\n      }\n      const rect  = document.getElementById(id)?.getBoundingClientRect();\n      const box_position = rect?.bottom || 0;      \n      setTimeout(() => {\n        this.box_height  = document.getElementById(box)?.clientHeight || 0;\n        if( ( this.viewport_height - box_position) < this.box_height ){\n          this.menu_on_top = 'menu-on-top';\n          this.box_style = `top: -${ (this.box_height) }px; height: ${this.box_height}px;`;\n        }\n      });    \n    }\n  }\n\n\n\n  clearTextSearch(){\n    this.search_text = '';\n    this.toSearch('');\n  }\n\n  toSearch(e: any) {\n    let input = (e && e.target && e.target.value) ? e.target.value : '';\n    \n    let filter = ( ( (input).normalize('NFD').replace(/[\\u0300-\\u036f]/g, \"\") ).trim() ).toLowerCase();\n    let ul = <any> document.getElementById(`${this.id}-options`);\n    let li = ul.getElementsByTagName(\"label\");\n    for (let i = 0; i < li.length; i++) {\n        const a = li[i];\n        const txtValue = ( ( ( a.textContent || a.innerText ).normalize('NFD').replace(/[\\u0300-\\u036f]/g, \"\") ).trim() ).toLowerCase();\n        if (txtValue.indexOf(filter) > -1) {\n            li[i].style.display = \"\";\n        } else {\n            li[i].style.display = \"none\";\n        }\n    }\n  }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n  onChangeTouched(){  \n    this.onTouchedCallback();     \n  }\n\n\n  toSetDefault(v:any){\n    this.items = v;\n    this.add_itens();\n  }\n\n  innerValue: any | undefined;\n  //Placeholders for the callbacks which are later providesd\n  //by the Control Value Accessor\n  private onTouchedCallback: () => void = noop;\n  private onChangeCallback: (_: any) => void = noop;\n\n  //get accessor\n  get value(): any {\n      return this.innerValue;\n  };\n\n  //set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.innerValue) {\n      this.innerValue = v; \n      this.toSetDefault(v);     \n      this.onChangeCallback(v);\n    }\n  }\n\n  //Set touched on blur\n  onBlur() {\n    this.onTouchedCallback();\n  }\n\n  //From ControlValueAccessor interface\n  writeValue(value: any) {\n    if (value !== this.innerValue) {\n      this.innerValue = value;\n      this.toSetDefault(value);\n    }\n  }\n\n  //From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeCallback = fn;\n  }\n\n  //From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedCallback = fn;\n  }\n\n\n\n  public validate(c: FormControl): any {\n    if( c && ( typeof this.required !== 'undefined' ) ){\n      this.use_validation_required = true;\n      return (this.check_is_valid()) ? null : 'required';\n    }\n    return null;\n  }\n\n\n  ngOnDestroy(): void {\n    \n  }\n\n}\n","<div class=\"tc-dropdown\" id=\"area-{{ id }}\" [class.tc-parent-validation]=\"use_validation_required\">\n\n\n    <form #_formulario=\"ngForm\">\n\n        <!-- {{ input_items }} -->\n\n        <div class=\"dropdown-toggle\" id=\"{{id}}\" [attr.aria-haspopup]=\"'true'\" [attr.aria-expanded]=\"'false'\">\n            <table class=\"group-input-action\">\n                <tr>\n                    <td class=\"box-input\">\n                        <div class=\"input\">\n                            <input \n                                [disabled]=\"disabled\"\n                                [class.text-lowercase]=\"lowercase\"\n                                [class.text-uppercase]=\"uppercase\"\n                                type=\"text\" name=\"items\" class=\"form-control tc-form-control\" [(ngModel)]=\"input_items\" [placeholder]=\"placeholder_list\" required [title]=\"placeholder_list\">\n                        </div>\n                    </td>\n                    <td class=\"count-list\" *ngIf=\"(items && items.length > 0)\">\n                        <div class=\"input\">\n                            <input type=\"text\" value=\"{{ items.length }} {{ (items.length > 1) ? 'registros' : 'registro' }}\" disabled readonly>\n                            \n                        </div>\n                    </td>\n                    <td class=\"action-input-arrow\">\n                        <button (click)=\"toOpen()\" title=\"Lista de valores\" [disabled]=\"disabled\">\n                            <i class=\"fas fa-angle-up\" *ngIf=\"show_itens\"></i>\n                            <i class=\"fas fa-angle-down\" *ngIf=\"!show_itens\"></i>\n                        </button>\n                    </td>\n                    <td class=\"action-input\" *ngIf=\"!disabled\">\n                        <button [disabled]=\"!_formulario.valid\" class=\"tc-btn tc-btn-primary btn-new-green\" (click)=\"add_itens()\" title=\"Adicionar item\">\n                            <i class=\"fas fa-plus\"></i>\n                        </button>\n                    </td>\n                </tr>\n            </table>\n        </div>\n        \n        <!-- <pre>\n            {{ items | json }}\n        </pre> -->\n\n    </form> \n\n    <!-- box-itens-selected  -->\n    <div class=\"tc-dropdown-menu box-itens-selected  {{ menu_on_top }}\" id=\"box-{{ id }}\" [attr.aria-labelledby]=\"id\" [class.to-hide]=\"!show_itens\" [style]=\"box_style\">\n        \n\n        <div class=\"line-search\" *ngIf=\"search\">\n            <table class=\"box-search\">\n              <tr>\n      \n                <td class=\"area-input\">\n                  <input type=\"text\" class=\"tc-form-control\" [(ngModel)]=\"search_text\" (input)=\"toSearch($event)\" placeholder=\"Buscar...\" >            \n                </td>\n      \n                <td class=\"area-icon\">\n                  <i *ngIf=\"search_text === ''\" class=\"fas fa-search icon-search\"></i>\n                  <button class=\"box-action\" type=\"button\" *ngIf=\"search_text !== ''\" (click)=\"clearTextSearch()\"><i class=\"fas fa-times\"></i></button>\n                </td>\n                \n              </tr>\n            </table>\n        </div>\n\n        <div class=\"area-options\" id=\"{{ id }}-options\">\n            <ng-container *ngFor=\"let item of items; let i = index\">\n            \n                <label class=\"box-label\" [ngStyle]=\"item_width(item)\">\n                    <div class=\"box-value\" [title]=\"item\"  >\n                    {{ item }}          \n                    </div>\n                    <div class=\"box-action\">\n                        <button\n                            class=\"box-action\"\n                            [disabled]=\"items === undefined || (items && items.length === 0) || disabled || loading\"\n                            title=\"Remover\"\n                            type=\"button\"\n                            (click)=\"removeItem(item, i)\">\n                            <i class=\"fas fa-times\"></i>\n                        </button>\n                    </div>\n                </label>\n\n            </ng-container>\n        </div>\n\n        <div class=\"mt-5\" *ngIf=\"items && (items).length > 5\">\n            <div class=\"btn-remove-all\">\n                <button class=\"box-action\" type=\"button\" (click)=\"remove_all()\">\n                    Limpar toda a lista\n                </button>\n            </div>\n        </div>\n\n    </div>\n</div>"]}
@@ -0,0 +1,31 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { TCloudUiMultiplesValuesComponent } from './tcloud-ui-multiples-values.component';
4
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
5
+ import * as i0 from "@angular/core";
6
+ export class TCloudUiMultiplesValuesModule {
7
+ }
8
+ TCloudUiMultiplesValuesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiMultiplesValuesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ TCloudUiMultiplesValuesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiMultiplesValuesModule, declarations: [TCloudUiMultiplesValuesComponent], imports: [CommonModule,
10
+ FormsModule,
11
+ ReactiveFormsModule], exports: [TCloudUiMultiplesValuesComponent] });
12
+ TCloudUiMultiplesValuesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiMultiplesValuesModule, imports: [CommonModule,
13
+ FormsModule,
14
+ ReactiveFormsModule] });
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiMultiplesValuesModule, decorators: [{
16
+ type: NgModule,
17
+ args: [{
18
+ declarations: [
19
+ TCloudUiMultiplesValuesComponent
20
+ ],
21
+ exports: [
22
+ TCloudUiMultiplesValuesComponent
23
+ ],
24
+ imports: [
25
+ CommonModule,
26
+ FormsModule,
27
+ ReactiveFormsModule
28
+ ]
29
+ }]
30
+ }] });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGNsb3VkLXVpLW11bHRpcGxlcy12YWx1ZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGNsb3VkLXVpL3NyYy9saWIvX21vZHVsZXMvdGNsb3VkLXVpLW11bHRpcGxlcy12YWx1ZXMvdGNsb3VkLXVpLW11bHRpcGxlcy12YWx1ZXMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzFGLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFpQmxFLE1BQU0sT0FBTyw2QkFBNkI7OzJIQUE3Qiw2QkFBNkI7NEhBQTdCLDZCQUE2QixpQkFYdEMsZ0NBQWdDLGFBTWhDLFlBQVk7UUFDWixXQUFXO1FBQ1gsbUJBQW1CLGFBTG5CLGdDQUFnQzs0SEFRdkIsNkJBQTZCLFlBTHRDLFlBQVk7UUFDWixXQUFXO1FBQ1gsbUJBQW1COzRGQUdWLDZCQUE2QjtrQkFiekMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osZ0NBQWdDO3FCQUNqQztvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsZ0NBQWdDO3FCQUNqQztvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFRDbG91ZFVpTXVsdGlwbGVzVmFsdWVzQ29tcG9uZW50IH0gZnJvbSAnLi90Y2xvdWQtdWktbXVsdGlwbGVzLXZhbHVlcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBUQ2xvdWRVaU11bHRpcGxlc1ZhbHVlc0NvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgVENsb3VkVWlNdWx0aXBsZXNWYWx1ZXNDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgVENsb3VkVWlNdWx0aXBsZXNWYWx1ZXNNb2R1bGUgeyB9XG4iXX0=