@dev-tcloud/tcloud-ui 0.0.66 → 0.0.67

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.
@@ -88,19 +88,25 @@ export class TCloudUiMultiplesValuesComponent {
88
88
  items = (input_items).split(this.delimiter);
89
89
  }
90
90
  if ((items).length === 0) {
91
- let txt = `${(input_items).trim()}`;
92
- items = [txt];
91
+ if (input_items && input_items !== '') {
92
+ let txt = `${(input_items).trim()}`;
93
+ items = [txt];
94
+ }
93
95
  }
94
96
  //items = [...new Set(items)];
95
97
  for (let i = 0; i < (items).length; i++) {
96
98
  let txt = `${(items[i]).trim()}`;
97
99
  if (this.uppercase) {
98
- txt = (txt).toLocaleUpperCase();
100
+ if (txt && txt !== '') {
101
+ txt = (txt).toLocaleUpperCase();
102
+ }
99
103
  }
100
104
  if (this.lowercase) {
101
- txt = (txt).toLocaleLowerCase();
105
+ if (txt && txt !== '') {
106
+ txt = (txt).toLocaleLowerCase();
107
+ }
102
108
  }
103
- if (txt !== '') {
109
+ if (txt && txt !== '') {
104
110
  (this.items).push(txt);
105
111
  }
106
112
  }
@@ -286,4 +292,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
286
292
  }], lowercase: [{
287
293
  type: Input
288
294
  }] } });
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, ViewChild, ElementRef } 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_items(){\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_items();\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                                (keydown.enter)=\"add_items();toOpen()\"\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_items()\" 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>"]}
295
+ //# 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, ViewChild, ElementRef } 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_items(){\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      if( input_items && input_items !== '' ){\n        let txt = `${(input_items).trim()}`;\n        items = [txt];\n      }\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        if( txt && txt !== '' ){\n          txt = (txt).toLocaleUpperCase();\n        }        \n      }\n\n      if( this.lowercase ){\n        if( txt && txt !== '' ){\n          txt = (txt).toLocaleLowerCase();\n        }\n      }\n\n      if( txt && 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_items();\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                                (keydown.enter)=\"add_items();toOpen()\"\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_items()\" 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>"]}
@@ -4354,19 +4354,25 @@ class TCloudUiMultiplesValuesComponent {
4354
4354
  items = (input_items).split(this.delimiter);
4355
4355
  }
4356
4356
  if ((items).length === 0) {
4357
- let txt = `${(input_items).trim()}`;
4358
- items = [txt];
4357
+ if (input_items && input_items !== '') {
4358
+ let txt = `${(input_items).trim()}`;
4359
+ items = [txt];
4360
+ }
4359
4361
  }
4360
4362
  //items = [...new Set(items)];
4361
4363
  for (let i = 0; i < (items).length; i++) {
4362
4364
  let txt = `${(items[i]).trim()}`;
4363
4365
  if (this.uppercase) {
4364
- txt = (txt).toLocaleUpperCase();
4366
+ if (txt && txt !== '') {
4367
+ txt = (txt).toLocaleUpperCase();
4368
+ }
4365
4369
  }
4366
4370
  if (this.lowercase) {
4367
- txt = (txt).toLocaleLowerCase();
4371
+ if (txt && txt !== '') {
4372
+ txt = (txt).toLocaleLowerCase();
4373
+ }
4368
4374
  }
4369
- if (txt !== '') {
4375
+ if (txt && txt !== '') {
4370
4376
  (this.items).push(txt);
4371
4377
  }
4372
4378
  }