@dev-tcloud/tcloud-ui 0.0.66 → 0.0.68
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/_modules/tcloud-ui-data-list/tcloud-ui-data-list.component.mjs +2 -2
- package/esm2020/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.component.mjs +12 -6
- package/esm2020/lib/_pipes/respective.mjs +15 -10
- package/fesm2015/dev-tcloud-tcloud-ui.mjs +26 -15
- package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/fesm2020/dev-tcloud-tcloud-ui.mjs +26 -15
- package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/lib/_pipes/respective.d.ts +1 -1
- package/package.json +1 -1
|
@@ -47,7 +47,7 @@ export class TCloudUiDataListComponent {
|
|
|
47
47
|
}
|
|
48
48
|
get disabled() { return this._disabled; }
|
|
49
49
|
set loading(v) {
|
|
50
|
-
if (v) {
|
|
50
|
+
if (typeof v === 'boolean' && v !== this._loading) {
|
|
51
51
|
this._loading = v;
|
|
52
52
|
this.selected_description = '';
|
|
53
53
|
this.selected_item = '';
|
|
@@ -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: boolean){\r\n    if( typeof v === 'boolean' && v !== this._loading ){\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"]}
|
package/esm2020/lib/_modules/tcloud-ui-multiples-values/tcloud-ui-multiples-values.component.mjs
CHANGED
|
@@ -88,19 +88,25 @@ export class TCloudUiMultiplesValuesComponent {
|
|
|
88
88
|
items = (input_items).split(this.delimiter);
|
|
89
89
|
}
|
|
90
90
|
if ((items).length === 0) {
|
|
91
|
-
|
|
92
|
-
|
|
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
|
|
100
|
+
if (txt && txt !== '') {
|
|
101
|
+
txt = (txt).toLocaleUpperCase();
|
|
102
|
+
}
|
|
99
103
|
}
|
|
100
104
|
if (this.lowercase) {
|
|
101
|
-
txt
|
|
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>"]}
|
|
@@ -45,18 +45,23 @@ export class RespectivePipe {
|
|
|
45
45
|
}
|
|
46
46
|
transform(v) {
|
|
47
47
|
if (v !== undefined && v !== null && v !== '') {
|
|
48
|
-
|
|
49
|
-
let
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
48
|
+
if (typeof v === 'string') {
|
|
49
|
+
for (let i = 0; i < (this.map).length; i++) {
|
|
50
|
+
let custom_v = v;
|
|
51
|
+
custom_v = (custom_v).toLowerCase();
|
|
52
|
+
custom_v = (custom_v).trim();
|
|
53
|
+
custom_v = (custom_v).replace(/\_/g, "-");
|
|
54
|
+
const current_key = (this.map[i].key).replace(/\_/g, "-");
|
|
55
|
+
if ((custom_v).toLowerCase() === current_key) {
|
|
56
|
+
return `${this.map[i].value}`;
|
|
57
|
+
}
|
|
56
58
|
}
|
|
57
59
|
}
|
|
60
|
+
else {
|
|
61
|
+
return '';
|
|
62
|
+
}
|
|
58
63
|
}
|
|
59
|
-
return v
|
|
64
|
+
return `${v}`;
|
|
60
65
|
}
|
|
61
66
|
}
|
|
62
67
|
RespectivePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RespectivePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
@@ -65,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
65
70
|
type: Pipe,
|
|
66
71
|
args: [{ name: 'respective' }]
|
|
67
72
|
}] });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzcGVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RjbG91ZC11aS9zcmMvbGliL19waXBlcy9yZXNwZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUdwRCxNQUFNLE9BQU8sY0FBYztJQUQzQjtRQUdJLFFBQUcsR0FBRztZQUNKLHFCQUFxQjtZQUNyQixFQUFFLEdBQUcsRUFBRSxZQUFZLEVBQUcsS0FBSyxFQUFFLFVBQVUsRUFBRTtZQUN6QyxFQUFFLEdBQUcsRUFBRSxhQUFhLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFO1lBQ2hELEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFO1lBRWpDLHlCQUF5QjtZQUN6QixFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUcsS0FBSyxFQUFFLFlBQVksRUFBRTtZQUN2QyxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRTtZQUVwQyxvQkFBb0I7WUFDcEIsRUFBRSxHQUFHLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDaEMsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUU7WUFDOUIsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDNUIsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUU7WUFFN0IsV0FBVztZQUNYLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQzdCLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ2hDLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFO1lB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YUFDWDtTQUdGO1FBQ0QsT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDO0lBQ2hCLENBQUM7OzRHQXhFUSxjQUFjOzBHQUFkLGNBQWM7NEZBQWQsY0FBYztrQkFEMUIsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AUGlwZSh7IG5hbWU6ICdyZXNwZWN0aXZlJ30pXHJcbmV4cG9ydCBjbGFzcyBSZXNwZWN0aXZlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG5cclxuICAgIG1hcCA9IFtcclxuICAgICAgLy8gVGlwb3MgZGUgQW1iaWVudGVzXHJcbiAgICAgIHsga2V5OiAncHJvZHVjdGlvbicsICB2YWx1ZTogJ1Byb2R1w6fDo28nIH0sXHJcbiAgICAgIHsga2V5OiAnZGV2ZWxvcG1lbnQnLCB2YWx1ZTogJ0Rlc2Vudm9sdmltZW50bycgfSxcclxuICAgICAgeyBrZXk6ICdxYScsIHZhbHVlOiAnUXVhbGlkYWRlJyB9LFxyXG5cclxuICAgICAgLy8gSW1wbGFudGHDp8OjbyAvIE1pZ3Jhw6fDo29cclxuICAgICAgeyBrZXk6ICdnb2xpdmUnLCAgdmFsdWU6ICdQcsOpIEdvTGl2ZScgfSxcclxuICAgICAgeyBrZXk6ICdraWNrb2ZmJywgdmFsdWU6ICdLaWNrb2ZmJyB9LFxyXG5cclxuICAgICAgLy8gVGlwb3MgZGUgQ2xpZW50ZXNcclxuICAgICAgeyBrZXk6ICdwcmltZScsIHZhbHVlOiAnUHJpbWUnIH0sXHJcbiAgICAgIHsga2V5OiAncCcsIHZhbHVlOiAnUGVxdWVubycgfSxcclxuICAgICAgeyBrZXk6ICdtJywgdmFsdWU6ICdNw6lkaW8nIH0sXHJcbiAgICAgIHsga2V5OiAnZycsIHZhbHVlOiAnR3JhbmRlJyB9LFxyXG5cclxuICAgICAgLy8gUHJvZHV0b3NcclxuICAgICAgeyBrZXk6ICcyYycsIHZhbHVlOiAnQ2Fyb2wnIH0sXHJcbiAgICAgIHsga2V5OiAnY2Fyb2wnLCB2YWx1ZTogJ2Nhcm9sJyB9LFxyXG4gICAgICB7IGtleTogJ2NvbnNpbmNvJywgdmFsdWU6ICdDb25zaW5jbycgfSxcclxuICAgICAgeyBrZXk6ICdkYXRhc3VsJywgdmFsdWU6ICdEYXRhc3VsJyB9LFxyXG4gICAgICB7IGtleTogJ2ZsdWlnJywgdmFsdWU6ICdGbHVpZycgfSxcclxuICAgICAgeyBrZXk6ICdsaWNlbnNlLXNlcnZlcicsIHZhbHVlOiAnTGljZW5zZSBTZXJ2ZXInIH0sXHJcbiAgICAgIHsga2V5OiAncGVwJywgdmFsdWU6ICdQRVAnIH0sXHJcbiAgICAgIHsga2V5OiAncHJvdGhldXMnLCB2YWx1ZTogJ1Byb3RoZXVzJyB9LFxyXG4gICAgICB7IGtleTogJ3B2aScsIHZhbHVlOiAnUFZJJyB9LFxyXG4gICAgICB7IGtleTogJ3JtJywgdmFsdWU6ICdSTScgfSxcclxuICAgICAgeyBrZXk6ICdzZmEnLCB2YWx1ZTogJ1NGQScgfSxcclxuICAgICAgeyBrZXk6ICdzbWFydHJtJywgdmFsdWU6ICdTbWFydCBSTScgfSxcclxuICAgICAgeyBrZXk6ICdzbWFydHJtY2x1c3RlcicsIHZhbHVlOiAnU21hcnQgUk0gQ2x1c3RlcicgfSxcclxuICAgICAgeyBrZXk6ICdzbWFydHJtY29udHJvbCcsIHZhbHVlOiAnU21hcnQgUk0gQ29udHJvbCcgfSxcclxuICAgICAgeyBrZXk6ICd0YWYnLCB2YWx1ZTogJ1RBRicgfSxcclxuICAgICAgeyBrZXk6ICd0cmVwb3J0cycsIHZhbHVlOiAnVHJlcG9ydHMnIH0sXHJcbiAgICAgIHsga2V5OiAndHNzJywgdmFsdWU6ICdUU1MnIH0sXHJcbiAgICAgIHsga2V5OiAnd2ludGhvcicsIHZhbHVlOiAnV2ludGhvcicgfSxcclxuXHJcbiAgICAgIC8vIFRpcG9zIGRlIFNPXHJcbiAgICAgIHsga2V5OiAnd2luZG93cycsICB2YWx1ZTogJ1dpbmRvd3MnIH0sXHJcbiAgICAgIHsga2V5OiAnbGludXgnLCB2YWx1ZTogJ0xpbnV4JyB9LFxyXG5cclxuICAgICAgLy8gVGlwb3MgcmVzcG9uc2F2ZWlzXHJcbiAgICAgIHsga2V5OiAncHJpbWVfY3VzdG9tZXJfc3VjY2VzcycsIHZhbHVlOiAnQ3VzdG9tZXIgU3VjY2VzcycgfSxcclxuICAgICAgeyBrZXk6ICdwcm9qZWN0X21hbmFnZXInLCB2YWx1ZTogJ0dlcmVudGUgZGUgUHJvamV0b3MnIH0sXHJcbiAgICAgIHsga2V5OiAncHJpbWVfZW5naW5lZXInLCB2YWx1ZTogJ0VuZ2VuaGVpcm8gUHJpbWUnIH1cclxuXHJcbiAgICBdO1xyXG4gICBcclxuXHJcbiAgICB0cmFuc2Zvcm0odjogYW55KTogc3RyaW5ne1xyXG5cclxuICAgICAgaWYoIHYgIT09IHVuZGVmaW5lZCAmJiB2ICE9PSBudWxsICYmIHYgIT09ICcnICl7XHJcblxyXG4gICAgICAgIGlmKCB0eXBlb2YgdiA9PT0gJ3N0cmluZycgKXtcclxuICAgICAgICAgIGZvciggbGV0IGkgPSAwOyBpIDwgKHRoaXMubWFwKS5sZW5ndGg7IGkrKyApe1xyXG4gICAgICAgICAgICBsZXQgY3VzdG9tX3YgPSB2O1xyXG4gICAgICAgICAgICBjdXN0b21fdiA9IChjdXN0b21fdikudG9Mb3dlckNhc2UoKTtcclxuICAgICAgICAgICAgY3VzdG9tX3YgPSAoY3VzdG9tX3YpLnRyaW0oKTtcclxuICAgICAgICAgICAgY3VzdG9tX3YgPSAoY3VzdG9tX3YpLnJlcGxhY2UoL1xcXy9nLCBcIi1cIik7XHJcbiAgICAgICAgICAgIGNvbnN0IGN1cnJlbnRfa2V5ID0gKHRoaXMubWFwW2ldLmtleSkucmVwbGFjZSgvXFxfL2csIFwiLVwiKTtcclxuICAgICAgICAgICAgaWYoIChjdXN0b21fdikudG9Mb3dlckNhc2UoKSA9PT0gY3VycmVudF9rZXkgKXtcclxuICAgICAgICAgICAgICByZXR1cm4gYCR7dGhpcy5tYXBbaV0udmFsdWV9YDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1lbHNle1xyXG4gICAgICAgICAgcmV0dXJuICcnO1xyXG4gICAgICAgIH1cclxuICAgICAgICBcclxuICAgICAgICBcclxuICAgICAgfVxyXG4gICAgICByZXR1cm4gYCR7dn1gO1xyXG4gICAgfVxyXG5cclxuICAgIFxyXG59Il19
|
|
@@ -1218,7 +1218,7 @@ class TCloudUiDataListComponent {
|
|
|
1218
1218
|
}
|
|
1219
1219
|
get disabled() { return this._disabled; }
|
|
1220
1220
|
set loading(v) {
|
|
1221
|
-
if (v) {
|
|
1221
|
+
if (typeof v === 'boolean' && v !== this._loading) {
|
|
1222
1222
|
this._loading = v;
|
|
1223
1223
|
this.selected_description = '';
|
|
1224
1224
|
this.selected_item = '';
|
|
@@ -1978,18 +1978,23 @@ class RespectivePipe {
|
|
|
1978
1978
|
}
|
|
1979
1979
|
transform(v) {
|
|
1980
1980
|
if (v !== undefined && v !== null && v !== '') {
|
|
1981
|
-
|
|
1982
|
-
let
|
|
1983
|
-
|
|
1984
|
-
|
|
1985
|
-
|
|
1986
|
-
|
|
1987
|
-
|
|
1988
|
-
|
|
1981
|
+
if (typeof v === 'string') {
|
|
1982
|
+
for (let i = 0; i < (this.map).length; i++) {
|
|
1983
|
+
let custom_v = v;
|
|
1984
|
+
custom_v = (custom_v).toLowerCase();
|
|
1985
|
+
custom_v = (custom_v).trim();
|
|
1986
|
+
custom_v = (custom_v).replace(/\_/g, "-");
|
|
1987
|
+
const current_key = (this.map[i].key).replace(/\_/g, "-");
|
|
1988
|
+
if ((custom_v).toLowerCase() === current_key) {
|
|
1989
|
+
return `${this.map[i].value}`;
|
|
1990
|
+
}
|
|
1989
1991
|
}
|
|
1990
1992
|
}
|
|
1993
|
+
else {
|
|
1994
|
+
return '';
|
|
1995
|
+
}
|
|
1991
1996
|
}
|
|
1992
|
-
return v
|
|
1997
|
+
return `${v}`;
|
|
1993
1998
|
}
|
|
1994
1999
|
}
|
|
1995
2000
|
RespectivePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RespectivePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
@@ -4354,19 +4359,25 @@ class TCloudUiMultiplesValuesComponent {
|
|
|
4354
4359
|
items = (input_items).split(this.delimiter);
|
|
4355
4360
|
}
|
|
4356
4361
|
if ((items).length === 0) {
|
|
4357
|
-
|
|
4358
|
-
|
|
4362
|
+
if (input_items && input_items !== '') {
|
|
4363
|
+
let txt = `${(input_items).trim()}`;
|
|
4364
|
+
items = [txt];
|
|
4365
|
+
}
|
|
4359
4366
|
}
|
|
4360
4367
|
//items = [...new Set(items)];
|
|
4361
4368
|
for (let i = 0; i < (items).length; i++) {
|
|
4362
4369
|
let txt = `${(items[i]).trim()}`;
|
|
4363
4370
|
if (this.uppercase) {
|
|
4364
|
-
txt
|
|
4371
|
+
if (txt && txt !== '') {
|
|
4372
|
+
txt = (txt).toLocaleUpperCase();
|
|
4373
|
+
}
|
|
4365
4374
|
}
|
|
4366
4375
|
if (this.lowercase) {
|
|
4367
|
-
txt
|
|
4376
|
+
if (txt && txt !== '') {
|
|
4377
|
+
txt = (txt).toLocaleLowerCase();
|
|
4378
|
+
}
|
|
4368
4379
|
}
|
|
4369
|
-
if (txt !== '') {
|
|
4380
|
+
if (txt && txt !== '') {
|
|
4370
4381
|
(this.items).push(txt);
|
|
4371
4382
|
}
|
|
4372
4383
|
}
|