cps-ui-kit 0.18.0 → 0.20.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -0
- package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +3 -3
- package/esm2020/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +30 -0
- package/esm2020/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +8 -13
- package/esm2020/lib/components/cps-select/cps-select.component.mjs +3 -3
- package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +3 -3
- package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +466 -0
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/cps-ui-kit.mjs +504 -19
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +490 -19
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +10 -0
- package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +2 -6
- package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +84 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
package/README.md
CHANGED
|
@@ -256,7 +256,7 @@ export class CpsAutocompleteComponent {
|
|
|
256
256
|
selected.scrollIntoView({
|
|
257
257
|
behavior: 'instant',
|
|
258
258
|
block: 'nearest',
|
|
259
|
-
inline: '
|
|
259
|
+
inline: 'center'
|
|
260
260
|
});
|
|
261
261
|
}
|
|
262
262
|
}
|
|
@@ -331,7 +331,7 @@ export class CpsAutocompleteComponent {
|
|
|
331
331
|
if (elRect.top < parentRect.top || elRect.bottom > parentRect.bottom) {
|
|
332
332
|
el.scrollIntoView({
|
|
333
333
|
block: 'nearest',
|
|
334
|
-
inline: '
|
|
334
|
+
inline: 'center'
|
|
335
335
|
});
|
|
336
336
|
}
|
|
337
337
|
}
|
|
@@ -476,4 +476,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
476
476
|
type: ViewChild,
|
|
477
477
|
args: ['autocompleteContainer']
|
|
478
478
|
}] } });
|
|
479
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-autocomplete/cps-autocomplete.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-autocomplete/cps-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/size-utils';\nimport {\n  CpsIconComponent,\n  IconType,\n  iconSizeType\n} from '../cps-icon/cps-icon.component';\nimport { CpsChipComponent } from '../cps-chip/cps-chip.component';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\nimport { ClickOutsideDirective } from '../../directives/click-outside.directive';\nimport { LabelByValuePipe } from '../../pipes/label-by-value.pipe';\nimport { CombineLabelsPipe } from '../../pipes/combine-labels.pipe';\nimport { CheckOptionSelectedPipe } from '../../pipes/check-option-selected.pipe';\nimport { find, isEqual } from 'lodash-es';\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ClickOutsideDirective,\n    CpsIconComponent,\n    CpsChipComponent,\n    CpsProgressLinearComponent,\n    LabelByValuePipe,\n    CombineLabelsPipe,\n    CheckOptionSelectedPipe\n  ],\n  providers: [LabelByValuePipe, CombineLabelsPipe, CheckOptionSelectedPipe],\n  selector: 'cps-autocomplete',\n  templateUrl: './cps-autocomplete.component.html',\n  styleUrls: ['./cps-autocomplete.component.scss']\n})\nexport class CpsAutocompleteComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input() label = '';\n  @Input() placeholder = 'Please enter';\n  @Input() hint = '';\n  @Input() returnObject = true; // if false, value will be option[optionValue]\n  @Input() multiple = false;\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() selectAll = true;\n  @Input() chips = true;\n  @Input() closableChips = true;\n  @Input() clearable = false;\n  @Input() openOnClear = true;\n  @Input() options = [] as any[];\n  @Input() optionLabel = 'label';\n  @Input() optionValue = 'value'; // needed only if returnObject === false\n  @Input() optionInfo = 'info';\n  @Input() hideDetails = false;\n  @Input() persistentClear = false;\n  @Input() prefixIcon: IconType = '';\n  @Input() prefixIconSize: iconSizeType = '18px';\n  @Input() loading = false;\n\n  @Input('value') _value: any = undefined;\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  @Output() valueChanged = new EventEmitter<any>();\n\n  @ViewChild('autocompleteContainer')\n  autocompleteContainer!: ElementRef;\n\n  error = '';\n  cvtWidth = '';\n  isOpened = false;\n  inputText = '';\n  filteredOptions = [] as any[];\n  backspaceClickedOnce = false;\n  activeSingle = false;\n  optionHighlightedIndex = -1;\n  private _statusChangesSubscription: Subscription = new Subscription();\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _labelByValue: LabelByValuePipe\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    this.filteredOptions = this.options;\n    this.cvtWidth = convertSize(this.width);\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  select(option: any, byValue: boolean): void {\n    function includes(array: any[], val: any): boolean {\n      return array ? !!find(array, (item) => isEqual(item, val)) : false;\n    }\n\n    this.backspaceClickedOnce = false;\n    const val = byValue\n      ? option\n      : this.returnObject\n      ? option\n      : option[this.optionValue];\n    if (this.multiple) {\n      let res = [] as any;\n      if (includes(this.value, val)) {\n        res = this.value.filter((v: any) => !isEqual(v, val));\n      } else {\n        this.options.forEach((o) => {\n          const ov = this.returnObject ? o : o[this.optionValue];\n          if (this.value.some((v: any) => isEqual(v, ov)) || isEqual(val, ov)) {\n            res.push(ov);\n          }\n        });\n      }\n      this.updateValue(res);\n    } else {\n      this.updateValue(val);\n    }\n    this._clearInput();\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n\n  onOptionClick(option: any, dd: HTMLElement) {\n    this._clickOption(option, dd);\n  }\n\n  toggleAll() {\n    let res = [];\n    if (this.value.length < this.options.length) {\n      if (this.returnObject) {\n        res = this.options;\n      } else {\n        this.options.forEach((o) => {\n          res.push(o[this.optionValue]);\n        });\n      }\n    }\n    this.updateValue(res);\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  filterOptions(event: any) {\n    if (!this.isOpened) {\n      this._toggleOptions(this.autocompleteContainer?.nativeElement, true);\n    }\n    this.backspaceClickedOnce = false;\n    const searchVal = (event?.target?.value || '').toLowerCase();\n\n    this.filteredOptions = this.options.filter((o: any) =>\n      o[this.optionLabel].toLowerCase().includes(searchVal)\n    );\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  clear(dd: HTMLElement, event: any): void {\n    event.stopPropagation();\n\n    if (\n      (!this.multiple && this.value) ||\n      (this.multiple && this.value?.length > 0)\n    ) {\n      if (this.openOnClear) {\n        this._toggleOptions(dd, true);\n      }\n      const val = this.multiple ? [] : this.returnObject ? undefined : '';\n      this.updateValue(val);\n    }\n    this._clearInput();\n    this._dehighlightOption();\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  onClickOutside(dd: HTMLElement) {\n    this._closeAndClear(dd);\n  }\n\n  onBoxClick() {\n    if (!this.multiple) {\n      this.activeSingle = true;\n      this.inputText = this._getValueLabel();\n      this.filteredOptions = this.options;\n    }\n    this.focus();\n    this._dehighlightOption();\n  }\n\n  onContainerKeyDown(event: any, dd: HTMLElement) {\n    const code = event.keyCode;\n    // escape\n    if (code === 27) {\n      this._closeAndClear(dd);\n    }\n    // enter\n    else if (code === 13) {\n      let idx = this.optionHighlightedIndex;\n      if (this.multiple && this.selectAll) {\n        if (idx === 0) {\n          this.toggleAll();\n          return;\n        } else idx--;\n      }\n      const option = this.filteredOptions[idx];\n      this._clickOption(option, dd);\n    }\n    // vertical arrows\n    else if ([38, 40].includes(code)) {\n      this._navigateOptionsByArrows(code === 38);\n    }\n  }\n\n  onInputKeyDown(event: any) {\n    const code = event.keyCode;\n    // backspace\n    if (code === 8) {\n      this._removeLastValue();\n      event.stopPropagation();\n    }\n    // enter\n    else if (code === 13) {\n      if (this.optionHighlightedIndex < 0) {\n        this._confirmInput(event?.target?.value || '');\n        event.stopPropagation();\n      }\n    } else if ([38, 40].includes(code)) {\n      event.preventDefault();\n    } else {\n      this._dehighlightOption();\n    }\n  }\n\n  focusInput() {\n    this.autocompleteContainer?.nativeElement?.querySelector('input')?.focus();\n  }\n\n  focus() {\n    this.autocompleteContainer?.nativeElement?.focus();\n    this.focusInput();\n    this._toggleOptions(this.autocompleteContainer?.nativeElement, true);\n  }\n\n  private _toggleOptions(dd: HTMLElement, show?: boolean): void {\n    if (this.disabled || !dd) return;\n    this.backspaceClickedOnce = false;\n    if (typeof show === 'boolean') {\n      if (show) dd.classList.add('active');\n      else dd.classList.remove('active');\n    } else dd.classList.toggle('active');\n\n    this.isOpened = dd.classList.contains('active');\n\n    if (this.isOpened) {\n      const selected =\n        this.autocompleteContainer.nativeElement.querySelector('.selected');\n      if (selected)\n        selected.scrollIntoView({\n          behavior: 'instant',\n          block: 'nearest',\n          inline: 'start'\n        });\n    }\n  }\n\n  private _clickOption(option: any, dd: HTMLElement) {\n    this.select(option, false);\n    if (!this.multiple) {\n      this._toggleOptions(dd, false);\n    }\n  }\n\n  private _checkErrors(): void {\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n    console.log('message', message);\n    this.error = message || 'Unknown error';\n  }\n\n  private updateValue(value: any): void {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _getValueLabel() {\n    return this.value\n      ? this.returnObject\n        ? this.value[this.optionLabel]\n        : this._labelByValue.transform(\n            this.value,\n            this.options,\n            this.optionValue,\n            this.optionLabel\n          )\n      : '';\n  }\n\n  private _clearInput() {\n    this.filteredOptions = this.options;\n    this.inputText = '';\n    this.activeSingle = false;\n  }\n\n  private _closeAndClear(dd: HTMLElement) {\n    this._clearInput();\n    this._toggleOptions(dd, false);\n    this._dehighlightOption();\n  }\n\n  private _getHTMLOptions() {\n    return (\n      this.autocompleteContainer?.nativeElement?.querySelectorAll(\n        '.cps-autocomplete-options-option'\n      ) || []\n    );\n  }\n\n  private _dehighlightOption(el?: HTMLElement) {\n    if (el) el.classList.remove('highlighten');\n    else {\n      if (this.optionHighlightedIndex < 0) return;\n      const optionItems = this._getHTMLOptions();\n      optionItems[this.optionHighlightedIndex].classList.remove('highlighten');\n      this.optionHighlightedIndex = -1;\n    }\n  }\n\n  private _highlightOption(el: HTMLElement) {\n    el.classList.add('highlighten');\n    const parent = el.parentElement;\n    if (!parent) return;\n    const parentRect = parent.getBoundingClientRect();\n    const elRect = el.getBoundingClientRect();\n    if (elRect.top < parentRect.top || elRect.bottom > parentRect.bottom) {\n      el.scrollIntoView({\n        block: 'nearest',\n        inline: 'start'\n      });\n    }\n  }\n\n  private _navigateOptionsByArrows(up: boolean) {\n    if (!this.isOpened) return;\n\n    const optionItems = this._getHTMLOptions();\n    const len = optionItems.length;\n    if (len < 1) return;\n\n    if (len === 1) {\n      this._highlightOption(optionItems[0]);\n      return;\n    }\n\n    if (up) {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex =\n        this.optionHighlightedIndex < 1\n          ? len - 1\n          : this.optionHighlightedIndex - 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    } else {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex = [-1, len - 1].includes(\n        this.optionHighlightedIndex\n      )\n        ? 0\n        : this.optionHighlightedIndex + 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    }\n  }\n\n  private _confirmInput(searchVal: string) {\n    if (!this.isOpened) return;\n    searchVal = searchVal.toLowerCase();\n    if (!searchVal) {\n      if (this.multiple) return;\n      const val = this.returnObject ? undefined : '';\n      this.updateValue(val);\n      this._closeAndClear(this.autocompleteContainer?.nativeElement);\n      return;\n    }\n\n    const found = this.filteredOptions.find(\n      (o: any) => o[this.optionLabel].toLowerCase() === searchVal\n    );\n    if (found) {\n      this.select(found, false);\n      this._toggleOptions(\n        this.autocompleteContainer?.nativeElement,\n        this.multiple\n      );\n    } else {\n      if (!this.multiple) {\n        this.inputText = this._getValueLabel();\n        this.filteredOptions = this.options;\n        return;\n      }\n    }\n\n    this._clearInput();\n  }\n\n  private _removeLastValue() {\n    if (!this.multiple || this.inputText) return;\n\n    if (this.value?.length) {\n      if (this.backspaceClickedOnce) {\n        this.updateValue(\n          this.value.filter(\n            (v: any, index: number) => index !== this.value.length - 1\n          )\n        );\n\n        this.backspaceClickedOnce = false;\n      } else this.backspaceClickedOnce = true;\n    } else this.backspaceClickedOnce = false;\n\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n}\n","<div\n  data-cy-id=\"cps-autocomplete\"\n  [ngStyle]=\"{ width: cvtWidth }\"\n  class=\"cps-autocomplete\"\n  tabindex=\"1\"\n  [ngClass]=\"{ disabled: disabled, error: error }\"\n  #autocompleteContainer>\n  <label *ngIf=\"label\" class=\"cps-autocomplete-label\">{{ label }}</label>\n  <div\n    (keydown)=\"onContainerKeyDown($event, autocompleteContainer)\"\n    class=\"cps-autocomplete-container\"\n    [class.focused]=\"isOpened\"\n    [ngClass]=\"{\n      'persistent-clear': persistentClear\n    }\"\n    (clickOutside)=\"onClickOutside(autocompleteContainer)\">\n    <div class=\"cps-autocomplete-box\" (click)=\"onBoxClick()\">\n      <div class=\"cps-autocomplete-box-area\">\n        <cps-icon\n          *ngIf=\"prefixIcon\"\n          [icon]=\"prefixIcon\"\n          [size]=\"prefixIconSize\"\n          class=\"prefix-icon\">\n        </cps-icon>\n        <div\n          class=\"cps-autocomplete-box-items\"\n          *ngIf=\"\n            (value && !multiple) || (value?.length > 0 && multiple);\n            else autocompleteInput\n          \">\n          <span *ngIf=\"!multiple\" class=\"single-item\">\n            <div class=\"single-item-selection\">\n              <span [style.opacity]=\"activeSingle ? 0 : 1\">{{\n                returnObject\n                  ? value[optionLabel]\n                  : (value | labelByValue : options : optionValue : optionLabel)\n              }}</span>\n            </div>\n            <ng-container\n              *ngTemplateOutlet=\"\n                autocompleteInput;\n                context: {\n                  inputClass: 'single-item-input',\n                  inputStyle: activeSingle ? 'opacity: 1' : null\n                }\n              \">\n            </ng-container>\n          </span>\n\n          <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n            <div\n              *ngFor=\"let val of value; let last = last\"\n              class=\"text-group-item\"\n              [ngClass]=\"{ 'about-to-remove': last && backspaceClickedOnce }\">\n              {{\n                returnObject\n                  ? val[optionLabel]\n                  : (val | labelByValue : options : optionValue : optionLabel)\n              }}{{ !last ? ',' : '' }}\n            </div>\n            <ng-container *ngTemplateOutlet=\"autocompleteInput\"></ng-container>\n          </div>\n\n          <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n            <cps-chip\n              *ngFor=\"let val of value; let last = last\"\n              [disabled]=\"disabled\"\n              [closable]=\"closableChips\"\n              (closed)=\"select(val, true)\"\n              [ngClass]=\"{ 'about-to-remove': last && backspaceClickedOnce }\"\n              [label]=\"\n                returnObject\n                  ? val[optionLabel]\n                  : (val | labelByValue : options : optionValue : optionLabel)\n              \">\n            </cps-chip>\n            <ng-container *ngTemplateOutlet=\"autocompleteInput\"></ng-container>\n          </div>\n        </div>\n        <span class=\"cps-autocomplete-box-icons\">\n          <span\n            *ngIf=\"clearable && !disabled\"\n            [style.visibility]=\"\n              persistentClear ||\n              (!persistentClear &&\n                ((multiple && value?.length) || (!multiple && value)))\n                ? 'visible'\n                : 'hidden'\n            \"\n            class=\"cps-autocomplete-box-clear-icon\">\n            <cps-icon\n              icon=\"delete\"\n              size=\"small\"\n              (click)=\"clear(autocompleteContainer, $event)\"></cps-icon>\n          </span>\n          <span class=\"cps-autocomplete-box-chevron\">\n            <cps-icon\n              icon=\"chevron-down\"\n              size=\"small\"\n              color=\"text-dark\"></cps-icon>\n          </span>\n        </span>\n      </div>\n    </div>\n\n    <div class=\"cps-autocomplete-options\">\n      <div\n        class=\"cps-autocomplete-options-option select-all-option\"\n        [class.allselected]=\"value?.length === options.length\"\n        *ngIf=\"multiple && selectAll\"\n        (click)=\"toggleAll()\">\n        <span class=\"cps-autocomplete-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-autocomplete-options-option-check\">\n          </span>\n          <span class=\"cps-autocomplete-options-option-label\">Select all</span>\n        </span>\n      </div>\n      <div\n        class=\"cps-autocomplete-options-option\"\n        *ngFor=\"let option of filteredOptions\"\n        (click)=\"onOptionClick(option, autocompleteContainer)\"\n        [class.selected]=\"\n          option\n            | checkOptionSelected\n              : value\n              : multiple\n              : returnObject\n              : optionValue\n        \">\n        <span class=\"cps-autocomplete-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-autocomplete-options-option-check\">\n          </span>\n          <span data-cy-id=\"cps-autocomplete-options\" class=\"cps-autocomplete-options-option-label\">{{\n            option[optionLabel]\n          }}</span>\n        </span>\n\n        <span class=\"cps-autocomplete-options-option-right\">{{\n          option[optionInfo]\n        }}</span>\n      </div>\n    </div>\n    <cps-progress-linear\n      *ngIf=\"loading\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"autocomplete-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-autocomplete-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-autocomplete-error\">\n    {{ error }}\n  </div>\n</div>\n\n<ng-template\n  #autocompleteInput\n  let-inputClass=\"inputClass\"\n  let-inputStyle=\"inputStyle\">\n  <input\n    class=\"cps-autocomplete-box-input\"\n    [class]=\"inputClass\"\n    [style]=\"inputStyle\"\n    [placeholder]=\"\n      (!value && !multiple) || (value?.length < 1 && multiple)\n        ? placeholder\n        : ''\n    \"\n    (input)=\"filterOptions($event)\"\n    (keydown)=\"onInputKeyDown($event)\"\n    [(ngModel)]=\"inputText\"\n    (blur)=\"onBlur()\" />\n</ng-template>\n"]}
|
|
479
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-autocomplete/cps-autocomplete.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-autocomplete/cps-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/size-utils';\nimport {\n  CpsIconComponent,\n  IconType,\n  iconSizeType\n} from '../cps-icon/cps-icon.component';\nimport { CpsChipComponent } from '../cps-chip/cps-chip.component';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\nimport { ClickOutsideDirective } from '../../directives/click-outside.directive';\nimport { LabelByValuePipe } from '../../pipes/label-by-value.pipe';\nimport { CombineLabelsPipe } from '../../pipes/combine-labels.pipe';\nimport { CheckOptionSelectedPipe } from '../../pipes/check-option-selected.pipe';\nimport { find, isEqual } from 'lodash-es';\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ClickOutsideDirective,\n    CpsIconComponent,\n    CpsChipComponent,\n    CpsProgressLinearComponent,\n    LabelByValuePipe,\n    CombineLabelsPipe,\n    CheckOptionSelectedPipe\n  ],\n  providers: [LabelByValuePipe, CombineLabelsPipe, CheckOptionSelectedPipe],\n  selector: 'cps-autocomplete',\n  templateUrl: './cps-autocomplete.component.html',\n  styleUrls: ['./cps-autocomplete.component.scss']\n})\nexport class CpsAutocompleteComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input() label = '';\n  @Input() placeholder = 'Please enter';\n  @Input() hint = '';\n  @Input() returnObject = true; // if false, value will be option[optionValue]\n  @Input() multiple = false;\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() selectAll = true;\n  @Input() chips = true;\n  @Input() closableChips = true;\n  @Input() clearable = false;\n  @Input() openOnClear = true;\n  @Input() options = [] as any[];\n  @Input() optionLabel = 'label';\n  @Input() optionValue = 'value'; // needed only if returnObject === false\n  @Input() optionInfo = 'info';\n  @Input() hideDetails = false;\n  @Input() persistentClear = false;\n  @Input() prefixIcon: IconType = '';\n  @Input() prefixIconSize: iconSizeType = '18px';\n  @Input() loading = false;\n\n  @Input('value') _value: any = undefined;\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  @Output() valueChanged = new EventEmitter<any>();\n\n  @ViewChild('autocompleteContainer')\n  autocompleteContainer!: ElementRef;\n\n  error = '';\n  cvtWidth = '';\n  isOpened = false;\n  inputText = '';\n  filteredOptions = [] as any[];\n  backspaceClickedOnce = false;\n  activeSingle = false;\n  optionHighlightedIndex = -1;\n  private _statusChangesSubscription: Subscription = new Subscription();\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _labelByValue: LabelByValuePipe\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    this.filteredOptions = this.options;\n    this.cvtWidth = convertSize(this.width);\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  select(option: any, byValue: boolean): void {\n    function includes(array: any[], val: any): boolean {\n      return array ? !!find(array, (item) => isEqual(item, val)) : false;\n    }\n\n    this.backspaceClickedOnce = false;\n    const val = byValue\n      ? option\n      : this.returnObject\n      ? option\n      : option[this.optionValue];\n    if (this.multiple) {\n      let res = [] as any;\n      if (includes(this.value, val)) {\n        res = this.value.filter((v: any) => !isEqual(v, val));\n      } else {\n        this.options.forEach((o) => {\n          const ov = this.returnObject ? o : o[this.optionValue];\n          if (this.value.some((v: any) => isEqual(v, ov)) || isEqual(val, ov)) {\n            res.push(ov);\n          }\n        });\n      }\n      this.updateValue(res);\n    } else {\n      this.updateValue(val);\n    }\n    this._clearInput();\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n\n  onOptionClick(option: any, dd: HTMLElement) {\n    this._clickOption(option, dd);\n  }\n\n  toggleAll() {\n    let res = [];\n    if (this.value.length < this.options.length) {\n      if (this.returnObject) {\n        res = this.options;\n      } else {\n        this.options.forEach((o) => {\n          res.push(o[this.optionValue]);\n        });\n      }\n    }\n    this.updateValue(res);\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  filterOptions(event: any) {\n    if (!this.isOpened) {\n      this._toggleOptions(this.autocompleteContainer?.nativeElement, true);\n    }\n    this.backspaceClickedOnce = false;\n    const searchVal = (event?.target?.value || '').toLowerCase();\n\n    this.filteredOptions = this.options.filter((o: any) =>\n      o[this.optionLabel].toLowerCase().includes(searchVal)\n    );\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  clear(dd: HTMLElement, event: any): void {\n    event.stopPropagation();\n\n    if (\n      (!this.multiple && this.value) ||\n      (this.multiple && this.value?.length > 0)\n    ) {\n      if (this.openOnClear) {\n        this._toggleOptions(dd, true);\n      }\n      const val = this.multiple ? [] : this.returnObject ? undefined : '';\n      this.updateValue(val);\n    }\n    this._clearInput();\n    this._dehighlightOption();\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  onClickOutside(dd: HTMLElement) {\n    this._closeAndClear(dd);\n  }\n\n  onBoxClick() {\n    if (!this.multiple) {\n      this.activeSingle = true;\n      this.inputText = this._getValueLabel();\n      this.filteredOptions = this.options;\n    }\n    this.focus();\n    this._dehighlightOption();\n  }\n\n  onContainerKeyDown(event: any, dd: HTMLElement) {\n    const code = event.keyCode;\n    // escape\n    if (code === 27) {\n      this._closeAndClear(dd);\n    }\n    // enter\n    else if (code === 13) {\n      let idx = this.optionHighlightedIndex;\n      if (this.multiple && this.selectAll) {\n        if (idx === 0) {\n          this.toggleAll();\n          return;\n        } else idx--;\n      }\n      const option = this.filteredOptions[idx];\n      this._clickOption(option, dd);\n    }\n    // vertical arrows\n    else if ([38, 40].includes(code)) {\n      this._navigateOptionsByArrows(code === 38);\n    }\n  }\n\n  onInputKeyDown(event: any) {\n    const code = event.keyCode;\n    // backspace\n    if (code === 8) {\n      this._removeLastValue();\n      event.stopPropagation();\n    }\n    // enter\n    else if (code === 13) {\n      if (this.optionHighlightedIndex < 0) {\n        this._confirmInput(event?.target?.value || '');\n        event.stopPropagation();\n      }\n    } else if ([38, 40].includes(code)) {\n      event.preventDefault();\n    } else {\n      this._dehighlightOption();\n    }\n  }\n\n  focusInput() {\n    this.autocompleteContainer?.nativeElement?.querySelector('input')?.focus();\n  }\n\n  focus() {\n    this.autocompleteContainer?.nativeElement?.focus();\n    this.focusInput();\n    this._toggleOptions(this.autocompleteContainer?.nativeElement, true);\n  }\n\n  private _toggleOptions(dd: HTMLElement, show?: boolean): void {\n    if (this.disabled || !dd) return;\n    this.backspaceClickedOnce = false;\n    if (typeof show === 'boolean') {\n      if (show) dd.classList.add('active');\n      else dd.classList.remove('active');\n    } else dd.classList.toggle('active');\n\n    this.isOpened = dd.classList.contains('active');\n\n    if (this.isOpened) {\n      const selected =\n        this.autocompleteContainer.nativeElement.querySelector('.selected');\n      if (selected)\n        selected.scrollIntoView({\n          behavior: 'instant',\n          block: 'nearest',\n          inline: 'center'\n        });\n    }\n  }\n\n  private _clickOption(option: any, dd: HTMLElement) {\n    this.select(option, false);\n    if (!this.multiple) {\n      this._toggleOptions(dd, false);\n    }\n  }\n\n  private _checkErrors(): void {\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n    console.log('message', message);\n    this.error = message || 'Unknown error';\n  }\n\n  private updateValue(value: any): void {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _getValueLabel() {\n    return this.value\n      ? this.returnObject\n        ? this.value[this.optionLabel]\n        : this._labelByValue.transform(\n            this.value,\n            this.options,\n            this.optionValue,\n            this.optionLabel\n          )\n      : '';\n  }\n\n  private _clearInput() {\n    this.filteredOptions = this.options;\n    this.inputText = '';\n    this.activeSingle = false;\n  }\n\n  private _closeAndClear(dd: HTMLElement) {\n    this._clearInput();\n    this._toggleOptions(dd, false);\n    this._dehighlightOption();\n  }\n\n  private _getHTMLOptions() {\n    return (\n      this.autocompleteContainer?.nativeElement?.querySelectorAll(\n        '.cps-autocomplete-options-option'\n      ) || []\n    );\n  }\n\n  private _dehighlightOption(el?: HTMLElement) {\n    if (el) el.classList.remove('highlighten');\n    else {\n      if (this.optionHighlightedIndex < 0) return;\n      const optionItems = this._getHTMLOptions();\n      optionItems[this.optionHighlightedIndex].classList.remove('highlighten');\n      this.optionHighlightedIndex = -1;\n    }\n  }\n\n  private _highlightOption(el: HTMLElement) {\n    el.classList.add('highlighten');\n    const parent = el.parentElement;\n    if (!parent) return;\n    const parentRect = parent.getBoundingClientRect();\n    const elRect = el.getBoundingClientRect();\n    if (elRect.top < parentRect.top || elRect.bottom > parentRect.bottom) {\n      el.scrollIntoView({\n        block: 'nearest',\n        inline: 'center'\n      });\n    }\n  }\n\n  private _navigateOptionsByArrows(up: boolean) {\n    if (!this.isOpened) return;\n\n    const optionItems = this._getHTMLOptions();\n    const len = optionItems.length;\n    if (len < 1) return;\n\n    if (len === 1) {\n      this._highlightOption(optionItems[0]);\n      return;\n    }\n\n    if (up) {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex =\n        this.optionHighlightedIndex < 1\n          ? len - 1\n          : this.optionHighlightedIndex - 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    } else {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex = [-1, len - 1].includes(\n        this.optionHighlightedIndex\n      )\n        ? 0\n        : this.optionHighlightedIndex + 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    }\n  }\n\n  private _confirmInput(searchVal: string) {\n    if (!this.isOpened) return;\n    searchVal = searchVal.toLowerCase();\n    if (!searchVal) {\n      if (this.multiple) return;\n      const val = this.returnObject ? undefined : '';\n      this.updateValue(val);\n      this._closeAndClear(this.autocompleteContainer?.nativeElement);\n      return;\n    }\n\n    const found = this.filteredOptions.find(\n      (o: any) => o[this.optionLabel].toLowerCase() === searchVal\n    );\n    if (found) {\n      this.select(found, false);\n      this._toggleOptions(\n        this.autocompleteContainer?.nativeElement,\n        this.multiple\n      );\n    } else {\n      if (!this.multiple) {\n        this.inputText = this._getValueLabel();\n        this.filteredOptions = this.options;\n        return;\n      }\n    }\n\n    this._clearInput();\n  }\n\n  private _removeLastValue() {\n    if (!this.multiple || this.inputText) return;\n\n    if (this.value?.length) {\n      if (this.backspaceClickedOnce) {\n        this.updateValue(\n          this.value.filter(\n            (v: any, index: number) => index !== this.value.length - 1\n          )\n        );\n\n        this.backspaceClickedOnce = false;\n      } else this.backspaceClickedOnce = true;\n    } else this.backspaceClickedOnce = false;\n\n    setTimeout(() => {\n      this.focusInput();\n    }, 0);\n  }\n}\n","<div\n  data-cy-id=\"cps-autocomplete\"\n  [ngStyle]=\"{ width: cvtWidth }\"\n  class=\"cps-autocomplete\"\n  tabindex=\"1\"\n  [ngClass]=\"{ disabled: disabled, error: error }\"\n  #autocompleteContainer>\n  <label *ngIf=\"label\" class=\"cps-autocomplete-label\">{{ label }}</label>\n  <div\n    (keydown)=\"onContainerKeyDown($event, autocompleteContainer)\"\n    class=\"cps-autocomplete-container\"\n    [class.focused]=\"isOpened\"\n    [ngClass]=\"{\n      'persistent-clear': persistentClear\n    }\"\n    (clickOutside)=\"onClickOutside(autocompleteContainer)\">\n    <div class=\"cps-autocomplete-box\" (click)=\"onBoxClick()\">\n      <div class=\"cps-autocomplete-box-area\">\n        <cps-icon\n          *ngIf=\"prefixIcon\"\n          [icon]=\"prefixIcon\"\n          [size]=\"prefixIconSize\"\n          class=\"prefix-icon\">\n        </cps-icon>\n        <div\n          class=\"cps-autocomplete-box-items\"\n          *ngIf=\"\n            (value && !multiple) || (value?.length > 0 && multiple);\n            else autocompleteInput\n          \">\n          <span *ngIf=\"!multiple\" class=\"single-item\">\n            <div class=\"single-item-selection\">\n              <span [style.opacity]=\"activeSingle ? 0 : 1\">{{\n                returnObject\n                  ? value[optionLabel]\n                  : (value | labelByValue : options : optionValue : optionLabel)\n              }}</span>\n            </div>\n            <ng-container\n              *ngTemplateOutlet=\"\n                autocompleteInput;\n                context: {\n                  inputClass: 'single-item-input',\n                  inputStyle: activeSingle ? 'opacity: 1' : null\n                }\n              \">\n            </ng-container>\n          </span>\n\n          <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n            <div\n              *ngFor=\"let val of value; let last = last\"\n              class=\"text-group-item\"\n              [ngClass]=\"{ 'about-to-remove': last && backspaceClickedOnce }\">\n              {{\n                returnObject\n                  ? val[optionLabel]\n                  : (val | labelByValue : options : optionValue : optionLabel)\n              }}{{ !last ? ',' : '' }}\n            </div>\n            <ng-container *ngTemplateOutlet=\"autocompleteInput\"></ng-container>\n          </div>\n\n          <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n            <cps-chip\n              *ngFor=\"let val of value; let last = last\"\n              [disabled]=\"disabled\"\n              [closable]=\"closableChips\"\n              (closed)=\"select(val, true)\"\n              [ngClass]=\"{ 'about-to-remove': last && backspaceClickedOnce }\"\n              [label]=\"\n                returnObject\n                  ? val[optionLabel]\n                  : (val | labelByValue : options : optionValue : optionLabel)\n              \">\n            </cps-chip>\n            <ng-container *ngTemplateOutlet=\"autocompleteInput\"></ng-container>\n          </div>\n        </div>\n        <span class=\"cps-autocomplete-box-icons\">\n          <span\n            *ngIf=\"clearable && !disabled\"\n            [style.visibility]=\"\n              persistentClear ||\n              (!persistentClear &&\n                ((multiple && value?.length) || (!multiple && value)))\n                ? 'visible'\n                : 'hidden'\n            \"\n            class=\"cps-autocomplete-box-clear-icon\">\n            <cps-icon\n              icon=\"delete\"\n              size=\"small\"\n              (click)=\"clear(autocompleteContainer, $event)\"></cps-icon>\n          </span>\n          <span class=\"cps-autocomplete-box-chevron\">\n            <cps-icon\n              icon=\"chevron-down\"\n              size=\"small\"\n              color=\"text-dark\"></cps-icon>\n          </span>\n        </span>\n      </div>\n    </div>\n\n    <div class=\"cps-autocomplete-options\">\n      <div\n        class=\"cps-autocomplete-options-option select-all-option\"\n        [class.allselected]=\"value?.length === options.length\"\n        *ngIf=\"multiple && selectAll\"\n        (click)=\"toggleAll()\">\n        <span class=\"cps-autocomplete-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-autocomplete-options-option-check\">\n          </span>\n          <span class=\"cps-autocomplete-options-option-label\">Select all</span>\n        </span>\n      </div>\n      <div\n        class=\"cps-autocomplete-options-option\"\n        *ngFor=\"let option of filteredOptions\"\n        (click)=\"onOptionClick(option, autocompleteContainer)\"\n        [class.selected]=\"\n          option\n            | checkOptionSelected\n              : value\n              : multiple\n              : returnObject\n              : optionValue\n        \">\n        <span class=\"cps-autocomplete-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-autocomplete-options-option-check\">\n          </span>\n          <span data-cy-id=\"cps-autocomplete-options\" class=\"cps-autocomplete-options-option-label\">{{\n            option[optionLabel]\n          }}</span>\n        </span>\n\n        <span class=\"cps-autocomplete-options-option-right\">{{\n          option[optionInfo]\n        }}</span>\n      </div>\n    </div>\n    <cps-progress-linear\n      *ngIf=\"loading\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"autocomplete-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-autocomplete-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-autocomplete-error\">\n    {{ error }}\n  </div>\n</div>\n\n<ng-template\n  #autocompleteInput\n  let-inputClass=\"inputClass\"\n  let-inputStyle=\"inputStyle\">\n  <input\n    class=\"cps-autocomplete-box-input\"\n    [class]=\"inputClass\"\n    [style]=\"inputStyle\"\n    [placeholder]=\"\n      (!value && !multiple) || (value?.length < 1 && multiple)\n        ? placeholder\n        : ''\n    \"\n    (input)=\"filterOptions($event)\"\n    (keydown)=\"onInputKeyDown($event)\"\n    [(ngModel)]=\"inputText\"\n    (blur)=\"onBlur()\" />\n</ng-template>\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, Input } from '@angular/core';
|
|
3
|
+
import { convertSize } from '../../utils/size-utils';
|
|
4
|
+
import { getCSSColor } from '../../utils/colors-utils';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class CpsProgressCircularComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.diameter = 40;
|
|
9
|
+
this.strokeWidth = 4;
|
|
10
|
+
this.color = 'calm';
|
|
11
|
+
}
|
|
12
|
+
ngOnInit() {
|
|
13
|
+
this.diameter = convertSize(this.diameter);
|
|
14
|
+
this.strokeWidth = convertSize(this.strokeWidth);
|
|
15
|
+
this.color = getCSSColor(this.color);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
CpsProgressCircularComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsProgressCircularComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
19
|
+
CpsProgressCircularComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsProgressCircularComponent, isStandalone: true, selector: "cps-progress-circular", inputs: { diameter: "diameter", strokeWidth: "strokeWidth", color: "color" }, ngImport: i0, template: "<div\n class=\"cps-progress-circular\"\n [style.width]=\"diameter\"\n [style.border]=\"strokeWidth + ' solid ' + color\"></div>\n", styles: [":host{display:inline-block}:host .cps-progress-circular{box-sizing:border-box;aspect-ratio:1;border-radius:50%;border-right-color:transparent!important;border-bottom:unset!important;animation:cps-progress-circular-animation .8s linear infinite}@keyframes cps-progress-circular-animation{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsProgressCircularComponent, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{ standalone: true, imports: [CommonModule], selector: 'cps-progress-circular', template: "<div\n class=\"cps-progress-circular\"\n [style.width]=\"diameter\"\n [style.border]=\"strokeWidth + ' solid ' + color\"></div>\n", styles: [":host{display:inline-block}:host .cps-progress-circular{box-sizing:border-box;aspect-ratio:1;border-radius:50%;border-right-color:transparent!important;border-bottom:unset!important;animation:cps-progress-circular-animation .8s linear infinite}@keyframes cps-progress-circular-animation{to{transform:rotate(360deg)}}\n"] }]
|
|
23
|
+
}], propDecorators: { diameter: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], strokeWidth: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], color: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}] } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXByb2dyZXNzLWNpcmN1bGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWNpcmN1bGFyL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFTdkQsTUFBTSxPQUFPLDRCQUE0QjtJQVB6QztRQVFXLGFBQVEsR0FBb0IsRUFBRSxDQUFDO1FBQy9CLGdCQUFXLEdBQW9CLENBQUMsQ0FBQztRQUNqQyxVQUFLLEdBQUcsTUFBTSxDQUFDO0tBUXpCO0lBTkMsUUFBUTtRQUNOLElBQUksQ0FBQyxRQUFRLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFakQsSUFBSSxDQUFDLEtBQUssR0FBRyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7O3lIQVZVLDRCQUE0Qjs2R0FBNUIsNEJBQTRCLCtKQ1p6QyxzSUFJQSx1WERHWSxZQUFZOzJGQUtYLDRCQUE0QjtrQkFQeEMsU0FBUztpQ0FDSSxJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYix1QkFBdUI7OEJBS3hCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBjb252ZXJ0U2l6ZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NpemUtdXRpbHMnO1xuaW1wb3J0IHsgZ2V0Q1NTQ29sb3IgfSBmcm9tICcuLi8uLi91dGlscy9jb2xvcnMtdXRpbHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHNlbGVjdG9yOiAnY3BzLXByb2dyZXNzLWNpcmN1bGFyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIENwc1Byb2dyZXNzQ2lyY3VsYXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBkaWFtZXRlcjogbnVtYmVyIHwgc3RyaW5nID0gNDA7XG4gIEBJbnB1dCgpIHN0cm9rZVdpZHRoOiBudW1iZXIgfCBzdHJpbmcgPSA0O1xuICBASW5wdXQoKSBjb2xvciA9ICdjYWxtJztcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYW1ldGVyID0gY29udmVydFNpemUodGhpcy5kaWFtZXRlcik7XG4gICAgdGhpcy5zdHJva2VXaWR0aCA9IGNvbnZlcnRTaXplKHRoaXMuc3Ryb2tlV2lkdGgpO1xuXG4gICAgdGhpcy5jb2xvciA9IGdldENTU0NvbG9yKHRoaXMuY29sb3IpO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiY3BzLXByb2dyZXNzLWNpcmN1bGFyXCJcbiAgW3N0eWxlLndpZHRoXT1cImRpYW1ldGVyXCJcbiAgW3N0eWxlLmJvcmRlcl09XCJzdHJva2VXaWR0aCArICcgc29saWQgJyArIGNvbG9yXCI+PC9kaXY+XG4iXX0=
|
|
@@ -12,25 +12,20 @@ export class CpsProgressLinearComponent {
|
|
|
12
12
|
this.bgColor = 'white';
|
|
13
13
|
this.opacity = 1;
|
|
14
14
|
this.radius = 0;
|
|
15
|
-
this.cvtWidth = '';
|
|
16
|
-
this.cvtHeight = '';
|
|
17
|
-
this.cvtRadius = '';
|
|
18
|
-
this.cvtColor = '';
|
|
19
|
-
this.cvtBgColor = '';
|
|
20
15
|
}
|
|
21
16
|
ngOnInit() {
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
17
|
+
this.width = convertSize(this.width);
|
|
18
|
+
this.height = convertSize(this.height);
|
|
19
|
+
this.radius = convertSize(this.radius);
|
|
20
|
+
this.color = getCSSColor(this.color);
|
|
21
|
+
this.bgColor = getCSSColor(this.bgColor);
|
|
27
22
|
}
|
|
28
23
|
}
|
|
29
24
|
CpsProgressLinearComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsProgressLinearComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
-
CpsProgressLinearComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsProgressLinearComponent, isStandalone: true, selector: "cps-progress-linear", inputs: { width: "width", height: "height", color: "color", bgColor: "bgColor", opacity: "opacity", radius: "radius" }, ngImport: i0, template: "<div\n class=\"cps-progress-linear\"\n [ngStyle]=\"{\n 'max-width':
|
|
25
|
+
CpsProgressLinearComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsProgressLinearComponent, isStandalone: true, selector: "cps-progress-linear", inputs: { width: "width", height: "height", color: "color", bgColor: "bgColor", opacity: "opacity", radius: "radius" }, ngImport: i0, template: "<div\n class=\"cps-progress-linear\"\n [ngStyle]=\"{\n 'max-width': width,\n height: height,\n 'border-radius': radius,\n background: bgColor\n }\">\n <div\n class=\"cps-progress-linear-line inc\"\n [style.background]=\"color\"\n [style.opacity]=\"opacity\"></div>\n <div\n class=\"cps-progress-linear-line dec\"\n [style.background]=\"color\"\n [style.opacity]=\"opacity\"></div>\n</div>\n", styles: [":host{width:100%}:host .cps-progress-linear{position:relative;overflow-x:hidden}:host .cps-progress-linear-line{position:absolute;height:inherit;left:-5%;top:0}:host .cps-progress-linear .inc{animation:increase 2s infinite}:host .cps-progress-linear .dec{animation:decrease 2s .5s infinite}@keyframes increase{0%{left:-5%;width:5%}to{left:130%;width:100%}}@keyframes decrease{0%{left:-80%;width:80%}to{left:110%;width:10%}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
31
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsProgressLinearComponent, decorators: [{
|
|
32
27
|
type: Component,
|
|
33
|
-
args: [{ standalone: true, imports: [CommonModule], selector: 'cps-progress-linear', template: "<div\n class=\"cps-progress-linear\"\n [ngStyle]=\"{\n 'max-width':
|
|
28
|
+
args: [{ standalone: true, imports: [CommonModule], selector: 'cps-progress-linear', template: "<div\n class=\"cps-progress-linear\"\n [ngStyle]=\"{\n 'max-width': width,\n height: height,\n 'border-radius': radius,\n background: bgColor\n }\">\n <div\n class=\"cps-progress-linear-line inc\"\n [style.background]=\"color\"\n [style.opacity]=\"opacity\"></div>\n <div\n class=\"cps-progress-linear-line dec\"\n [style.background]=\"color\"\n [style.opacity]=\"opacity\"></div>\n</div>\n", styles: [":host{width:100%}:host .cps-progress-linear{position:relative;overflow-x:hidden}:host .cps-progress-linear-line{position:absolute;height:inherit;left:-5%;top:0}:host .cps-progress-linear .inc{animation:increase 2s infinite}:host .cps-progress-linear .dec{animation:decrease 2s .5s infinite}@keyframes increase{0%{left:-5%;width:5%}to{left:130%;width:100%}}@keyframes decrease{0%{left:-80%;width:80%}to{left:110%;width:10%}}\n"] }]
|
|
34
29
|
}], propDecorators: { width: [{
|
|
35
30
|
type: Input
|
|
36
31
|
}], height: [{
|
|
@@ -44,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
44
39
|
}], radius: [{
|
|
45
40
|
type: Input
|
|
46
41
|
}] } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXByb2dyZXNzLWxpbmVhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtcHJvZ3Jlc3MtbGluZWFyL2Nwcy1wcm9ncmVzcy1saW5lYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWxpbmVhci9jcHMtcHJvZ3Jlc3MtbGluZWFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7QUFTdkQsTUFBTSxPQUFPLDBCQUEwQjtJQVB2QztRQVFXLFVBQUssR0FBb0IsTUFBTSxDQUFDO1FBQ2hDLFdBQU0sR0FBb0IsUUFBUSxDQUFDO1FBQ25DLFVBQUssR0FBRyxNQUFNLENBQUM7UUFDZixZQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ2xCLFlBQU8sR0FBb0IsQ0FBQyxDQUFDO1FBQzdCLFdBQU0sR0FBb0IsQ0FBQyxDQUFDO0tBVXRDO0lBUkMsUUFBUTtRQUNOLElBQUksQ0FBQyxLQUFLLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsTUFBTSxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdkMsSUFBSSxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXZDLElBQUksQ0FBQyxLQUFLLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsT0FBTyxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0MsQ0FBQzs7dUhBZlUsMEJBQTBCOzJHQUExQiwwQkFBMEIsdU1DWnZDLDJhQWlCQSxrZURWWSxZQUFZOzJGQUtYLDBCQUEwQjtrQkFQdEMsU0FBUztpQ0FDSSxJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYixxQkFBcUI7OEJBS3RCLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgY29udmVydFNpemUgfSBmcm9tICcuLi8uLi91dGlscy9zaXplLXV0aWxzJztcbmltcG9ydCB7IGdldENTU0NvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXV0aWxzJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBzZWxlY3RvcjogJ2Nwcy1wcm9ncmVzcy1saW5lYXInLFxuICB0ZW1wbGF0ZVVybDogJy4vY3BzLXByb2dyZXNzLWxpbmVhci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Nwcy1wcm9ncmVzcy1saW5lYXIuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDcHNQcm9ncmVzc0xpbmVhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIHdpZHRoOiBudW1iZXIgfCBzdHJpbmcgPSAnMTAwJSc7XG4gIEBJbnB1dCgpIGhlaWdodDogbnVtYmVyIHwgc3RyaW5nID0gJzAuNXJlbSc7XG4gIEBJbnB1dCgpIGNvbG9yID0gJ2NhbG0nO1xuICBASW5wdXQoKSBiZ0NvbG9yID0gJ3doaXRlJztcbiAgQElucHV0KCkgb3BhY2l0eTogbnVtYmVyIHwgc3RyaW5nID0gMTtcbiAgQElucHV0KCkgcmFkaXVzOiBudW1iZXIgfCBzdHJpbmcgPSAwO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMud2lkdGggPSBjb252ZXJ0U2l6ZSh0aGlzLndpZHRoKTtcbiAgICB0aGlzLmhlaWdodCA9IGNvbnZlcnRTaXplKHRoaXMuaGVpZ2h0KTtcbiAgICB0aGlzLnJhZGl1cyA9IGNvbnZlcnRTaXplKHRoaXMucmFkaXVzKTtcblxuICAgIHRoaXMuY29sb3IgPSBnZXRDU1NDb2xvcih0aGlzLmNvbG9yKTtcbiAgICB0aGlzLmJnQ29sb3IgPSBnZXRDU1NDb2xvcih0aGlzLmJnQ29sb3IpO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiY3BzLXByb2dyZXNzLWxpbmVhclwiXG4gIFtuZ1N0eWxlXT1cIntcbiAgICAnbWF4LXdpZHRoJzogd2lkdGgsXG4gICAgaGVpZ2h0OiBoZWlnaHQsXG4gICAgJ2JvcmRlci1yYWRpdXMnOiByYWRpdXMsXG4gICAgYmFja2dyb3VuZDogYmdDb2xvclxuICB9XCI+XG4gIDxkaXZcbiAgICBjbGFzcz1cImNwcy1wcm9ncmVzcy1saW5lYXItbGluZSBpbmNcIlxuICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cImNvbG9yXCJcbiAgICBbc3R5bGUub3BhY2l0eV09XCJvcGFjaXR5XCI+PC9kaXY+XG4gIDxkaXZcbiAgICBjbGFzcz1cImNwcy1wcm9ncmVzcy1saW5lYXItbGluZSBkZWNcIlxuICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cImNvbG9yXCJcbiAgICBbc3R5bGUub3BhY2l0eV09XCJvcGFjaXR5XCI+PC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -90,7 +90,7 @@ export class CpsSelectComponent {
|
|
|
90
90
|
selected.scrollIntoView({
|
|
91
91
|
behavior: 'instant',
|
|
92
92
|
block: 'nearest',
|
|
93
|
-
inline: '
|
|
93
|
+
inline: 'center'
|
|
94
94
|
});
|
|
95
95
|
}
|
|
96
96
|
}
|
|
@@ -164,7 +164,7 @@ export class CpsSelectComponent {
|
|
|
164
164
|
if (elRect.top < parentRect.top || elRect.bottom > parentRect.bottom) {
|
|
165
165
|
el.scrollIntoView({
|
|
166
166
|
block: 'nearest',
|
|
167
|
-
inline: '
|
|
167
|
+
inline: 'center'
|
|
168
168
|
});
|
|
169
169
|
}
|
|
170
170
|
}
|
|
@@ -370,4 +370,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
370
370
|
type: ViewChild,
|
|
371
371
|
args: ['selectContainer']
|
|
372
372
|
}] } });
|
|
373
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-select.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-select/cps-select.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-select/cps-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/size-utils';\nimport {\n  CpsIconComponent,\n  iconSizeType,\n  IconType\n} from '../cps-icon/cps-icon.component';\nimport { CpsChipComponent } from '../cps-chip/cps-chip.component';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\nimport { ClickOutsideDirective } from '../../directives/click-outside.directive';\nimport { LabelByValuePipe } from '../../pipes/label-by-value.pipe';\nimport { CombineLabelsPipe } from '../../pipes/combine-labels.pipe';\nimport { CheckOptionSelectedPipe } from '../../pipes/check-option-selected.pipe';\nimport { find, isEqual } from 'lodash-es';\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ClickOutsideDirective,\n    CpsIconComponent,\n    CpsChipComponent,\n    CpsProgressLinearComponent,\n    LabelByValuePipe,\n    CombineLabelsPipe,\n    CheckOptionSelectedPipe\n  ],\n  providers: [LabelByValuePipe, CombineLabelsPipe, CheckOptionSelectedPipe],\n  selector: 'cps-select',\n  templateUrl: './cps-select.component.html',\n  styleUrls: ['./cps-select.component.scss']\n})\nexport class CpsSelectComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input() label = '';\n  @Input() placeholder = 'Please select';\n  @Input() hint = '';\n  @Input() returnObject = true; // if false, value will be option[optionValue]\n  @Input() multiple = false;\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() selectAll = true;\n  @Input() chips = true;\n  @Input() closableChips = true;\n  @Input() clearable = false;\n  @Input() openOnClear = true;\n  @Input() options = [] as any[];\n  @Input() optionLabel = 'label';\n  @Input() optionValue = 'value'; // needed only if returnObject === false\n  @Input() optionInfo = 'info';\n  @Input() hideDetails = false;\n  @Input() persistentClear = false;\n  @Input() prefixIcon: IconType = '';\n  @Input() prefixIconSize: iconSizeType = '18px';\n  @Input() loading = false;\n\n  @Input('value') _value: any = undefined;\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<any>();\n\n  @ViewChild('selectContainer')\n  selectContainer!: ElementRef;\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n\n  error = '';\n  cvtWidth = '';\n\n  isOpened = false;\n\n  optionHighlightedIndex = -1;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    this.cvtWidth = convertSize(this.width);\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  private _toggleOptions(dd: HTMLElement, show?: boolean): void {\n    if (this.disabled || !dd) return;\n    if (typeof show === 'boolean') {\n      if (show) dd.classList.add('active');\n      else dd.classList.remove('active');\n    } else dd.classList.toggle('active');\n\n    this.isOpened = dd.classList.contains('active');\n\n    if (this.isOpened) {\n      const selected =\n        this.selectContainer.nativeElement.querySelector('.selected');\n      if (selected)\n        selected.scrollIntoView({\n          behavior: 'instant',\n          block: 'nearest',\n          inline: 'start'\n        });\n    }\n  }\n\n  // private _filterOptions() {\n  //   if (!this.optionsFilter || !this.multiple) return;\n  //   this.filteredOptions = this.options.filter((o) => {\n  //     if (this.returnObject) {\n  //       return !this.value.find((v: any) => v === o);\n  //     }\n  //     return !this.value.find((v: any) => v === o[this.optionValue]);\n  //   });\n  // }\n\n  select(option: any, byValue: boolean): void {\n    function includes(array: any[], val: any): boolean {\n      return array ? !!find(array, (item) => isEqual(item, val)) : false;\n    }\n    const val = byValue\n      ? option\n      : this.returnObject\n      ? option\n      : option[this.optionValue];\n    if (this.multiple) {\n      let res = [] as any;\n      if (includes(this.value, val)) {\n        res = this.value.filter((v: any) => !isEqual(v, val));\n      } else {\n        this.options.forEach((o) => {\n          const ov = this.returnObject ? o : o[this.optionValue];\n          if (this.value.some((v: any) => isEqual(v, ov)) || isEqual(val, ov)) {\n            res.push(ov);\n          }\n        });\n      }\n      this.updateValue(res);\n    } else {\n      this.updateValue(val);\n    }\n  }\n\n  onOptionClick(option: any, dd: HTMLElement) {\n    this._clickOption(option, dd);\n  }\n\n  private _clickOption(option: any, dd: HTMLElement) {\n    this.select(option, false);\n    if (!this.multiple) {\n      this._toggleOptions(dd, false);\n    }\n  }\n\n  private _getHTMLOptions() {\n    return (\n      this.selectContainer?.nativeElement?.querySelectorAll(\n        '.cps-select-options-option'\n      ) || []\n    );\n  }\n\n  private _dehighlightOption(el?: HTMLElement) {\n    if (el) el.classList.remove('highlighten');\n    else {\n      if (this.optionHighlightedIndex < 0) return;\n      const optionItems = this._getHTMLOptions();\n      optionItems[this.optionHighlightedIndex].classList.remove('highlighten');\n      this.optionHighlightedIndex = -1;\n    }\n  }\n\n  private _highlightOption(el: HTMLElement) {\n    el.classList.add('highlighten');\n    const parent = el.parentElement;\n    if (!parent) return;\n    const parentRect = parent.getBoundingClientRect();\n    const elRect = el.getBoundingClientRect();\n    if (elRect.top < parentRect.top || elRect.bottom > parentRect.bottom) {\n      el.scrollIntoView({\n        block: 'nearest',\n        inline: 'start'\n      });\n    }\n  }\n\n  private _navigateOptionsByArrows(up: boolean) {\n    if (!this.isOpened) return;\n\n    const optionItems = this._getHTMLOptions();\n    const len = optionItems.length;\n    if (len < 1) return;\n\n    if (len === 1) {\n      this._highlightOption(optionItems[0]);\n      return;\n    }\n\n    if (up) {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex =\n        this.optionHighlightedIndex < 1\n          ? len - 1\n          : this.optionHighlightedIndex - 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    } else {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex = [-1, len - 1].includes(\n        this.optionHighlightedIndex\n      )\n        ? 0\n        : this.optionHighlightedIndex + 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    }\n  }\n\n  onClickOutside(dd: HTMLElement) {\n    this._toggleOptions(dd, false);\n    this._dehighlightOption();\n  }\n\n  onBoxClick(dd: HTMLElement) {\n    this._toggleOptions(dd);\n    this._dehighlightOption();\n  }\n\n  onKeyDown(event: any, dd: HTMLElement) {\n    event.preventDefault();\n    const code = event.keyCode;\n    // escape\n    if (code === 27) {\n      this._toggleOptions(dd, false);\n      this._dehighlightOption();\n    }\n    // enter\n    else if (code === 13) {\n      let idx = this.optionHighlightedIndex;\n      if (idx < 0) return;\n      if (this.multiple && this.selectAll) {\n        if (idx === 0) {\n          this.toggleAll();\n          return;\n        } else idx--;\n      }\n\n      this._clickOption(this.options[idx], dd);\n    }\n    // vertical arrows\n    else if ([38, 40].includes(code)) {\n      this._navigateOptionsByArrows(code === 38);\n    }\n  }\n\n  toggleAll() {\n    let res = [];\n    if (this.value.length < this.options.length) {\n      if (this.returnObject) {\n        res = this.options;\n      } else {\n        this.options.forEach((o) => {\n          res.push(o[this.optionValue]);\n        });\n      }\n    }\n    this.updateValue(res);\n  }\n\n  private _checkErrors(): void {\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  private updateValue(value: any): void {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  clear(dd: HTMLElement, event: any): void {\n    event.stopPropagation();\n\n    if (\n      (!this.multiple && this.value) ||\n      (this.multiple && this.value?.length > 0)\n    ) {\n      if (this.openOnClear) {\n        this._toggleOptions(dd, true);\n      }\n      const val = this.multiple ? [] : this.returnObject ? undefined : '';\n      this.updateValue(val);\n    }\n    this._dehighlightOption();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  focus() {\n    this.selectContainer?.nativeElement?.focus();\n    this._toggleOptions(this.selectContainer?.nativeElement, true);\n  }\n}\n","<div\n  [ngStyle]=\"{ width: cvtWidth }\"\n  class=\"cps-select\"\n  tabindex=\"0\"\n  [ngClass]=\"{ disabled: disabled, error: error }\"\n  #selectContainer\n  (keydown)=\"onKeyDown($event, selectContainer)\"\n  (blur)=\"onBlur()\">\n  <label *ngIf=\"label\" class=\"cps-select-label\">{{ label }} </label>\n  <div\n    class=\"cps-select-container\"\n    [class.focused]=\"isOpened\"\n    [ngClass]=\"{\n      'persistent-clear': persistentClear\n    }\"\n    (clickOutside)=\"onClickOutside(selectContainer)\">\n    <div class=\"cps-select-box\" (click)=\"onBoxClick(selectContainer)\">\n      <div class=\"cps-select-box-left\">\n        <cps-icon\n          *ngIf=\"prefixIcon\"\n          [icon]=\"prefixIcon\"\n          [size]=\"prefixIconSize\"\n          class=\"prefix-icon\">\n        </cps-icon>\n        <div\n          class=\"cps-select-box-placeholder\"\n          *ngIf=\"(!value && !multiple) || (value?.length < 1 && multiple)\">\n          {{ placeholder }}\n        </div>\n        <div\n          class=\"cps-select-box-items\"\n          *ngIf=\"(value && !multiple) || (value?.length > 0 && multiple)\">\n          <span *ngIf=\"!multiple\" class=\"single-item\">\n            {{\n              returnObject\n                ? value[optionLabel]\n                : (value | labelByValue : options : optionValue : optionLabel)\n            }}</span\n          >\n          <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n            <span class=\"text-group-item\">\n              {{\n                value\n                  | combineLabels\n                    : options\n                    : optionValue\n                    : optionLabel\n                    : returnObject\n              }}\n            </span>\n          </div>\n\n          <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n            <cps-chip\n              *ngFor=\"let val of value\"\n              [disabled]=\"disabled\"\n              [closable]=\"closableChips\"\n              (closed)=\"select(val, true)\"\n              [label]=\"\n                returnObject\n                  ? val[optionLabel]\n                  : (val | labelByValue : options : optionValue : optionLabel)\n              \">\n            </cps-chip>\n          </div>\n        </div>\n      </div>\n      <span class=\"cps-select-box-icons\">\n        <span\n          *ngIf=\"clearable && !disabled\"\n          [style.visibility]=\"\n            persistentClear ||\n            (!persistentClear &&\n              ((multiple && value?.length) || (!multiple && value)))\n              ? 'visible'\n              : 'hidden'\n          \"\n          class=\"cps-select-box-clear-icon\">\n          <cps-icon\n            icon=\"delete\"\n            size=\"small\"\n            (click)=\"clear(selectContainer, $event)\"></cps-icon>\n        </span>\n        <span class=\"cps-select-box-chevron\">\n          <cps-icon\n            icon=\"chevron-down\"\n            size=\"small\"\n            color=\"text-dark\"></cps-icon>\n        </span>\n      </span>\n    </div>\n\n    <div class=\"cps-select-options\">\n      <div\n        class=\"cps-select-options-option select-all-option\"\n        [class.allselected]=\"value?.length === options.length\"\n        *ngIf=\"multiple && selectAll\"\n        (click)=\"toggleAll()\">\n        <span class=\"cps-select-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n          </span>\n          <span class=\"cps-select-options-option-label\">Select all</span>\n        </span>\n      </div>\n      <div\n        class=\"cps-select-options-option\"\n        *ngFor=\"let option of options\"\n        (click)=\"onOptionClick(option, selectContainer)\"\n        [class.selected]=\"\n          option\n            | checkOptionSelected\n              : value\n              : multiple\n              : returnObject\n              : optionValue\n        \">\n        <span class=\"cps-select-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n          </span>\n          <span class=\"cps-select-options-option-label\">{{\n            option[optionLabel]\n          }}</span>\n        </span>\n\n        <span class=\"cps-select-options-option-right\">{{\n          option[optionInfo]\n        }}</span>\n      </div>\n    </div>\n    <cps-progress-linear\n      *ngIf=\"loading\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"select-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-select-hint\">{{ hint }}</div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-select-error\">{{ error }}</div>\n</div>\n"]}
|
|
373
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-select.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-select/cps-select.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-select/cps-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/size-utils';\nimport {\n  CpsIconComponent,\n  iconSizeType,\n  IconType\n} from '../cps-icon/cps-icon.component';\nimport { CpsChipComponent } from '../cps-chip/cps-chip.component';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\nimport { ClickOutsideDirective } from '../../directives/click-outside.directive';\nimport { LabelByValuePipe } from '../../pipes/label-by-value.pipe';\nimport { CombineLabelsPipe } from '../../pipes/combine-labels.pipe';\nimport { CheckOptionSelectedPipe } from '../../pipes/check-option-selected.pipe';\nimport { find, isEqual } from 'lodash-es';\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ClickOutsideDirective,\n    CpsIconComponent,\n    CpsChipComponent,\n    CpsProgressLinearComponent,\n    LabelByValuePipe,\n    CombineLabelsPipe,\n    CheckOptionSelectedPipe\n  ],\n  providers: [LabelByValuePipe, CombineLabelsPipe, CheckOptionSelectedPipe],\n  selector: 'cps-select',\n  templateUrl: './cps-select.component.html',\n  styleUrls: ['./cps-select.component.scss']\n})\nexport class CpsSelectComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input() label = '';\n  @Input() placeholder = 'Please select';\n  @Input() hint = '';\n  @Input() returnObject = true; // if false, value will be option[optionValue]\n  @Input() multiple = false;\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() selectAll = true;\n  @Input() chips = true;\n  @Input() closableChips = true;\n  @Input() clearable = false;\n  @Input() openOnClear = true;\n  @Input() options = [] as any[];\n  @Input() optionLabel = 'label';\n  @Input() optionValue = 'value'; // needed only if returnObject === false\n  @Input() optionInfo = 'info';\n  @Input() hideDetails = false;\n  @Input() persistentClear = false;\n  @Input() prefixIcon: IconType = '';\n  @Input() prefixIconSize: iconSizeType = '18px';\n  @Input() loading = false;\n\n  @Input('value') _value: any = undefined;\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<any>();\n\n  @ViewChild('selectContainer')\n  selectContainer!: ElementRef;\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n\n  error = '';\n  cvtWidth = '';\n\n  isOpened = false;\n\n  optionHighlightedIndex = -1;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    this.cvtWidth = convertSize(this.width);\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  private _toggleOptions(dd: HTMLElement, show?: boolean): void {\n    if (this.disabled || !dd) return;\n    if (typeof show === 'boolean') {\n      if (show) dd.classList.add('active');\n      else dd.classList.remove('active');\n    } else dd.classList.toggle('active');\n\n    this.isOpened = dd.classList.contains('active');\n\n    if (this.isOpened) {\n      const selected =\n        this.selectContainer.nativeElement.querySelector('.selected');\n      if (selected)\n        selected.scrollIntoView({\n          behavior: 'instant',\n          block: 'nearest',\n          inline: 'center'\n        });\n    }\n  }\n\n  // private _filterOptions() {\n  //   if (!this.optionsFilter || !this.multiple) return;\n  //   this.filteredOptions = this.options.filter((o) => {\n  //     if (this.returnObject) {\n  //       return !this.value.find((v: any) => v === o);\n  //     }\n  //     return !this.value.find((v: any) => v === o[this.optionValue]);\n  //   });\n  // }\n\n  select(option: any, byValue: boolean): void {\n    function includes(array: any[], val: any): boolean {\n      return array ? !!find(array, (item) => isEqual(item, val)) : false;\n    }\n    const val = byValue\n      ? option\n      : this.returnObject\n      ? option\n      : option[this.optionValue];\n    if (this.multiple) {\n      let res = [] as any;\n      if (includes(this.value, val)) {\n        res = this.value.filter((v: any) => !isEqual(v, val));\n      } else {\n        this.options.forEach((o) => {\n          const ov = this.returnObject ? o : o[this.optionValue];\n          if (this.value.some((v: any) => isEqual(v, ov)) || isEqual(val, ov)) {\n            res.push(ov);\n          }\n        });\n      }\n      this.updateValue(res);\n    } else {\n      this.updateValue(val);\n    }\n  }\n\n  onOptionClick(option: any, dd: HTMLElement) {\n    this._clickOption(option, dd);\n  }\n\n  private _clickOption(option: any, dd: HTMLElement) {\n    this.select(option, false);\n    if (!this.multiple) {\n      this._toggleOptions(dd, false);\n    }\n  }\n\n  private _getHTMLOptions() {\n    return (\n      this.selectContainer?.nativeElement?.querySelectorAll(\n        '.cps-select-options-option'\n      ) || []\n    );\n  }\n\n  private _dehighlightOption(el?: HTMLElement) {\n    if (el) el.classList.remove('highlighten');\n    else {\n      if (this.optionHighlightedIndex < 0) return;\n      const optionItems = this._getHTMLOptions();\n      optionItems[this.optionHighlightedIndex].classList.remove('highlighten');\n      this.optionHighlightedIndex = -1;\n    }\n  }\n\n  private _highlightOption(el: HTMLElement) {\n    el.classList.add('highlighten');\n    const parent = el.parentElement;\n    if (!parent) return;\n    const parentRect = parent.getBoundingClientRect();\n    const elRect = el.getBoundingClientRect();\n    if (elRect.top < parentRect.top || elRect.bottom > parentRect.bottom) {\n      el.scrollIntoView({\n        block: 'nearest',\n        inline: 'center'\n      });\n    }\n  }\n\n  private _navigateOptionsByArrows(up: boolean) {\n    if (!this.isOpened) return;\n\n    const optionItems = this._getHTMLOptions();\n    const len = optionItems.length;\n    if (len < 1) return;\n\n    if (len === 1) {\n      this._highlightOption(optionItems[0]);\n      return;\n    }\n\n    if (up) {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex =\n        this.optionHighlightedIndex < 1\n          ? len - 1\n          : this.optionHighlightedIndex - 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    } else {\n      this._dehighlightOption(optionItems[this.optionHighlightedIndex]);\n      this.optionHighlightedIndex = [-1, len - 1].includes(\n        this.optionHighlightedIndex\n      )\n        ? 0\n        : this.optionHighlightedIndex + 1;\n      this._highlightOption(optionItems[this.optionHighlightedIndex]);\n    }\n  }\n\n  onClickOutside(dd: HTMLElement) {\n    this._toggleOptions(dd, false);\n    this._dehighlightOption();\n  }\n\n  onBoxClick(dd: HTMLElement) {\n    this._toggleOptions(dd);\n    this._dehighlightOption();\n  }\n\n  onKeyDown(event: any, dd: HTMLElement) {\n    event.preventDefault();\n    const code = event.keyCode;\n    // escape\n    if (code === 27) {\n      this._toggleOptions(dd, false);\n      this._dehighlightOption();\n    }\n    // enter\n    else if (code === 13) {\n      let idx = this.optionHighlightedIndex;\n      if (idx < 0) return;\n      if (this.multiple && this.selectAll) {\n        if (idx === 0) {\n          this.toggleAll();\n          return;\n        } else idx--;\n      }\n\n      this._clickOption(this.options[idx], dd);\n    }\n    // vertical arrows\n    else if ([38, 40].includes(code)) {\n      this._navigateOptionsByArrows(code === 38);\n    }\n  }\n\n  toggleAll() {\n    let res = [];\n    if (this.value.length < this.options.length) {\n      if (this.returnObject) {\n        res = this.options;\n      } else {\n        this.options.forEach((o) => {\n          res.push(o[this.optionValue]);\n        });\n      }\n    }\n    this.updateValue(res);\n  }\n\n  private _checkErrors(): void {\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  private updateValue(value: any): void {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  clear(dd: HTMLElement, event: any): void {\n    event.stopPropagation();\n\n    if (\n      (!this.multiple && this.value) ||\n      (this.multiple && this.value?.length > 0)\n    ) {\n      if (this.openOnClear) {\n        this._toggleOptions(dd, true);\n      }\n      const val = this.multiple ? [] : this.returnObject ? undefined : '';\n      this.updateValue(val);\n    }\n    this._dehighlightOption();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  focus() {\n    this.selectContainer?.nativeElement?.focus();\n    this._toggleOptions(this.selectContainer?.nativeElement, true);\n  }\n}\n","<div\n  [ngStyle]=\"{ width: cvtWidth }\"\n  class=\"cps-select\"\n  tabindex=\"0\"\n  [ngClass]=\"{ disabled: disabled, error: error }\"\n  #selectContainer\n  (keydown)=\"onKeyDown($event, selectContainer)\"\n  (blur)=\"onBlur()\">\n  <label *ngIf=\"label\" class=\"cps-select-label\">{{ label }} </label>\n  <div\n    class=\"cps-select-container\"\n    [class.focused]=\"isOpened\"\n    [ngClass]=\"{\n      'persistent-clear': persistentClear\n    }\"\n    (clickOutside)=\"onClickOutside(selectContainer)\">\n    <div class=\"cps-select-box\" (click)=\"onBoxClick(selectContainer)\">\n      <div class=\"cps-select-box-left\">\n        <cps-icon\n          *ngIf=\"prefixIcon\"\n          [icon]=\"prefixIcon\"\n          [size]=\"prefixIconSize\"\n          class=\"prefix-icon\">\n        </cps-icon>\n        <div\n          class=\"cps-select-box-placeholder\"\n          *ngIf=\"(!value && !multiple) || (value?.length < 1 && multiple)\">\n          {{ placeholder }}\n        </div>\n        <div\n          class=\"cps-select-box-items\"\n          *ngIf=\"(value && !multiple) || (value?.length > 0 && multiple)\">\n          <span *ngIf=\"!multiple\" class=\"single-item\">\n            {{\n              returnObject\n                ? value[optionLabel]\n                : (value | labelByValue : options : optionValue : optionLabel)\n            }}</span\n          >\n          <div *ngIf=\"multiple && !chips\" class=\"text-group\">\n            <span class=\"text-group-item\">\n              {{\n                value\n                  | combineLabels\n                    : options\n                    : optionValue\n                    : optionLabel\n                    : returnObject\n              }}\n            </span>\n          </div>\n\n          <div *ngIf=\"multiple && chips\" class=\"chips-group\">\n            <cps-chip\n              *ngFor=\"let val of value\"\n              [disabled]=\"disabled\"\n              [closable]=\"closableChips\"\n              (closed)=\"select(val, true)\"\n              [label]=\"\n                returnObject\n                  ? val[optionLabel]\n                  : (val | labelByValue : options : optionValue : optionLabel)\n              \">\n            </cps-chip>\n          </div>\n        </div>\n      </div>\n      <span class=\"cps-select-box-icons\">\n        <span\n          *ngIf=\"clearable && !disabled\"\n          [style.visibility]=\"\n            persistentClear ||\n            (!persistentClear &&\n              ((multiple && value?.length) || (!multiple && value)))\n              ? 'visible'\n              : 'hidden'\n          \"\n          class=\"cps-select-box-clear-icon\">\n          <cps-icon\n            icon=\"delete\"\n            size=\"small\"\n            (click)=\"clear(selectContainer, $event)\"></cps-icon>\n        </span>\n        <span class=\"cps-select-box-chevron\">\n          <cps-icon\n            icon=\"chevron-down\"\n            size=\"small\"\n            color=\"text-dark\"></cps-icon>\n        </span>\n      </span>\n    </div>\n\n    <div class=\"cps-select-options\">\n      <div\n        class=\"cps-select-options-option select-all-option\"\n        [class.allselected]=\"value?.length === options.length\"\n        *ngIf=\"multiple && selectAll\"\n        (click)=\"toggleAll()\">\n        <span class=\"cps-select-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n          </span>\n          <span class=\"cps-select-options-option-label\">Select all</span>\n        </span>\n      </div>\n      <div\n        class=\"cps-select-options-option\"\n        *ngFor=\"let option of options\"\n        (click)=\"onOptionClick(option, selectContainer)\"\n        [class.selected]=\"\n          option\n            | checkOptionSelected\n              : value\n              : multiple\n              : returnObject\n              : optionValue\n        \">\n        <span class=\"cps-select-options-option-left\">\n          <span *ngIf=\"multiple\" class=\"cps-select-options-option-check\">\n          </span>\n          <span class=\"cps-select-options-option-label\">{{\n            option[optionLabel]\n          }}</span>\n        </span>\n\n        <span class=\"cps-select-options-option-right\">{{\n          option[optionInfo]\n        }}</span>\n      </div>\n    </div>\n    <cps-progress-linear\n      *ngIf=\"loading\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"select-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-select-hint\">{{ hint }}</div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-select-error\">{{ error }}</div>\n</div>\n"]}
|