i-tech-shared-components 1.1.42 → 1.1.44
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/esm2022/lib/components/autocomplete-select/autocomplete-select.component.mjs +1 -2
- package/esm2022/lib/components/date-time-picker/date-time-picker.component.mjs +28 -3
- package/fesm2022/i-tech-shared-components.mjs +27 -3
- package/fesm2022/i-tech-shared-components.mjs.map +1 -1
- package/lib/components/date-time-picker/date-time-picker.component.d.ts +4 -1
- package/package.json +1 -1
- package/theme/_date_time_picker.scss +68 -0
- package/theme.scss +1 -0
|
@@ -184,7 +184,6 @@ export class AutocompleteSelectComponent {
|
|
|
184
184
|
if (this.searchInput) {
|
|
185
185
|
if (this.selectConfig.multiple) {
|
|
186
186
|
this.toggleShowingDataInSelectedOptionsMultipleCase(showingData);
|
|
187
|
-
this.searchInput?.nativeElement?.focus();
|
|
188
187
|
}
|
|
189
188
|
else {
|
|
190
189
|
this.inputFocusOut();
|
|
@@ -440,4 +439,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
440
439
|
type: HostListener,
|
|
441
440
|
args: ['document:visibilitychange']
|
|
442
441
|
}] } });
|
|
443
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-select.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/autocomplete-select/autocomplete-select.component.ts","../../../../../../projects/shared-components/src/lib/components/autocomplete-select/autocomplete-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef, HostListener, AfterViewInit\n} from '@angular/core';\nimport { MatSelect, MatSelectModule } from \"@angular/material/select\";\nimport { AutocompleteConfigsInterface } from \"../../interfaces/autocomplete-configs.interface\";\nimport { FormControlName, ReactiveFormsModule } from \"@angular/forms\";\nimport { InputService } from '../../services/input.service';\nimport { ButtonType } from '../../interfaces/button-types.enum';\nimport { NgClass, NgFor, NgIf, NgOptimizedImage } from \"@angular/common\";\nimport { MatTooltip } from \"@angular/material/tooltip\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { IconButtonComponent } from \"../icon-button/icon-button.component\";\nimport { ButtonComponent } from \"../button/button.component\";\nimport { GetValueByKeyFromObjectPipe } from \"../../pipes/get-value-by-key-from-object.pipe\";\nimport { ArrayToStringPipe } from \"../../pipes/array-to-string.pipe\";\nimport { MatIcon } from \"@angular/material/icon\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\nimport { ClearValueComponent } from \"../clear-value/clear-value.component\";\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\n\n@Component({\n  selector: 'i-tech-autocomplete-select',\n  templateUrl: './autocomplete-select.component.html',\n  styleUrls: ['./autocomplete-select.component.scss'],\n  imports: [\n    NgClass,\n    MatTooltip,\n    NgIf,\n    NgFor,\n    TranslateModule,\n    IconButtonComponent,\n    ReactiveFormsModule,\n    MatSelectModule,\n    ButtonComponent,\n    GetValueByKeyFromObjectPipe,\n    ArrayToStringPipe,\n    NgOptimizedImage,\n    MatIcon,\n    GenerateErrorMessagesPipe,\n    ClearValueComponent,\n    MatFormFieldModule\n  ],\n  standalone: true\n})\nexport class AutocompleteSelectComponent implements OnChanges, AfterViewInit {\n  @ViewChild('matSelect') matSelect!: MatSelect;\n  @ViewChild('searchInput') searchInput!: ElementRef;\n  @Input() className!: string;\n  @Input() submitValue!: boolean;\n\n  /**\n   * See AutocompleteConfigsInterface for available configurations.\n   */\n  @Input() set configs(data: AutocompleteConfigsInterface) {\n    this.selectConfig = data;\n    if (!data) {\n      return;\n    }\n\n    if ((typeof this.selectConfig.paginate) === 'function') {\n      if (this.firstRequest) {\n        return;\n      }\n      this.getData();\n      this.firstRequest = true\n      return;\n    }\n\n    this.data = this.selectConfig.paginate;\n    this.findAndSetDefaultValueFromData();\n  };\n\n  @Input() detectChanges!: boolean;\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() emitAction = new EventEmitter<any>();\n  @ViewChild('allSelected') allSelected!: MatSelect;\n  pending = false;\n  defaultValue!: any;\n  data: Array<any> = [];\n  paginationData: any = { current: 1, last: 0 };\n  ngControl: FormControlName;\n  selectConfig!: AutocompleteConfigsInterface;\n  firstRequest = false;\n  showPlaceholder = true;\n  isNeededForRecall = false;\n  showingValue: any;\n  selectedOptionForMultipleSelection: Array<any> = [];\n  searchTimeoutId: any;\n  tabVisibility!: boolean;\n  accessToNextRequest = true;\n  disabled = false;\n  blockRecallDefaultValueSetter = false;\n  baseData: any;\n  requestLoading = false;\n  protected readonly ButtonType = ButtonType;\n\n  @HostListener('document:visibilitychange')\n  handleVisibilityChange(): void {\n    this.tabVisibility = !document.hidden;\n    if (this.ngControl.control.value) {\n      return;\n    }\n    this.closePanelAndUnsetFocus();\n    if (!document.hidden) {\n      this.isNeededForRecall = true;\n      this.pending = true;\n      setTimeout(() => {\n        this.pending = false\n      }, 4000)\n    }\n  }\n\n  constructor(private inputService: InputService) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['selectConfig'] && this.selectConfig) {\n      if ((typeof this.selectConfig.paginate) === 'function') {\n        this.getData();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.ngControl.control.valueChanges.subscribe((res: any) => {\n      if (this.data.length && res && !this.blockRecallDefaultValueSetter) {\n        this.findAndSetDefaultValueFromData();\n      }\n    })\n  }\n\n  hardReload(): void {\n    this.getData('', true);\n  }\n\n  /**\n   * Dynamic request for select data.\n   * @param searchText - The input value to search options by.\n   * @param fromSearch - Access for search.\n   * @returns Select data.\n   */\n  getData(searchText?: string, fromSearch?: boolean): void {\n    if (!fromSearch && !this.accessToNextRequest) {\n      return;\n    }\n\n    if (this.requestLoading) {\n      return;\n    }\n\n    if (fromSearch) {\n      this.paginationData.current = 1;\n      this.accessToNextRequest = true;\n    }\n\n    const functionToDo = this.selectConfig.paginate(this.paginationData.current, searchText);\n\n    this.requestLoading = true;\n    functionToDo?.subscribe((data: Array<any> | any) => {\n      const dataToAdd = ('content' in data) ? data.content : data;\n\n      if ('content' in data) {\n        this.accessToNextRequest = !data.last || (data.totalPages > this.paginationData.current);\n      }\n\n      this.data = (fromSearch || this.selectConfig?.blockPagination) ? dataToAdd : [...this.data, ...dataToAdd];\n      this.pending = false;\n      this.requestLoading = false;\n\n      if (!dataToAdd.length) {\n        this.paginationData.last = this.paginationData.current;\n        return;\n      }\n\n      this.paginationData.current += 1;\n      this.paginationData.last += 1;\n      setTimeout(() => {\n        this.findAndSetDefaultValueFromData();\n      }, 10)\n    }, () => {\n      this.pending = false;\n      this.requestLoading = false;\n    })\n  }\n\n  findAndSetDefaultValueFromData(): void {\n    if (this.selectConfig.multiple) {\n      if (this.ngControl.value && this.ngControl.value.length == 1) {\n        this.setShowingValue(this.data.find((item) => item.id === this.ngControl.value[0]))\n      }\n    } else {\n      const isDisabled = this.ngControl.disabled;\n      if (isDisabled) {\n        // TODO Remove after migrating all selects\n        // this.ngControl.control.enable();\n        // if (!this.ngControl.value && !this.data.length) {\n        //     this.ngControl.control.disable();\n        //     return;\n        // }\n        // this.setDefaultValue();\n        // this.ngControl.control.disable();\n      } else {\n        if (!this.ngControl.value && !this.data) {\n          return;\n        }\n        this.setDefaultValue();\n      }\n\n    }\n  }\n\n  setDefaultValue(): void {\n    this.defaultValue = this.data.find((item) => item.id === this.ngControl.value);\n    this.baseData = this.defaultValue\n    if (!this.defaultValue) {\n      return;\n    }\n    this.selectionChange.emit()\n    this.setShowingValue(this.defaultValue);\n  }\n\n  optionClick(showingData: any): void {\n    this.baseData = showingData\n    if (!this.selectConfig.multiple) {\n      this.setShowingValue(showingData);\n      this.matSelect.close();\n      return;\n    }\n    if (this.searchInput) {\n      if (this.selectConfig.multiple) {\n        this.toggleShowingDataInSelectedOptionsMultipleCase(showingData);\n        this.searchInput?.nativeElement?.focus()\n      } else {\n        this.inputFocusOut();\n      }\n    }\n\n    this.setShowingValue(showingData);\n    this.showPlaceholder = false;\n  }\n\n  toggleShowingDataInSelectedOptionsMultipleCase(showingData: any): void {\n    const showingDataByJson = JSON.stringify(showingData);\n    const indexOfExistingOption = this.selectedOptionForMultipleSelection.findIndex(\n      (optionValue: any) => JSON.stringify(optionValue) === showingDataByJson\n    )\n    if (indexOfExistingOption >= 0) {\n      this.selectedOptionForMultipleSelection.splice(indexOfExistingOption, 1);\n    } else {\n      this.selectedOptionForMultipleSelection.push(showingData);\n    }\n  }\n\n  addNewItemEvent(): void {\n    this.isNeededForRecall = true;\n    this.emitAction.emit();\n  }\n\n  /**\n   * Filter and show.\n   * @param data - Existing chosen data.\n   */\n  setShowingValue(data: any): void {\n    if (!data) {\n      return;\n    }\n    if (this.selectConfig.multiple && this.selectConfig.search) {\n      const fullText: Array<string> = [];\n      this.selectedOptionForMultipleSelection.forEach((optionData: any) => {\n        fullText.push(this.collectAndGetSelectionToShowForOneOption(optionData))\n      })\n      this.showingValue = fullText.join(',');\n    } else {\n      this.showingValue = this.collectAndGetSelectionToShowForOneOption(data);\n    }\n    this.blockRecallDefaultValueSetter = true;\n  }\n\n  collectAndGetSelectionToShowForOneOption(data: any): string {\n    let include = data;\n    let includeOptional = data;\n\n    if (this.selectConfig.valueToShowByKey) {\n      this.selectConfig.valueToShowByKey.forEach((param: Array<string | number> | string) => {\n\n        if (typeof param === 'object') {\n          param.forEach((key: string | number) => {\n            include = (include) ? include[key] : null;\n          })\n        } else {\n          include = include[param];\n        }\n      })\n      if (this.selectConfig.showFullTextWithOptionalOnSelectedValue) {\n        this.selectConfig.valueToShowByParam?.forEach((param: Array<string | number> | string) => {\n\n          if (typeof param === 'object') {\n            param.forEach((key: string | number) => {\n              includeOptional = (includeOptional) ? includeOptional[key] : null;\n            })\n          } else {\n            includeOptional = includeOptional[param];\n          }\n        })\n        if (this.selectConfig.valueToShowByParam && typeof includeOptional === 'string') {\n          include += (this.selectConfig.withParamSymbol || '') + includeOptional\n        }\n      }\n    }\n\n    return include;\n  }\n\n  /**\n   * Block another events.\n   * @param event - Element click event.\n   */\n  preventDefault(event: any) {\n    if (!this.selectConfig.multiple) {\n      return;\n    }\n    event.preventDefault()\n  }\n\n  registerPanelScrollEvent(element: MatSelect) {\n    if (this.selectConfig.paginateOnScroll === false) {\n      return;\n    }\n\n    const panel = element.panel.nativeElement;\n    panel.addEventListener('scroll', (event: any) => this.loadDataOnScroll(event));\n  }\n\n  loadDataOnScroll(event: any) {\n    const pos = (event.target.scrollTop || event.target.scrollTop) + event.target.offsetHeight;\n    const max = event.target.scrollHeight;\n    if ((pos + 1) >= max) {\n      if (this.paginationData.current === this.paginationData.last || this.selectConfig.blockPagination) {\n        return;\n      }\n      this.getData();\n    }\n  }\n\n  focusSearchInput() {\n    if (this.selectConfig.search && this.searchInput) {\n      this.searchInput.nativeElement.focus();\n    }\n  }\n\n  inputFocusOut(): void {\n    this.isNeededForRecall = !!this.searchInput.nativeElement.value;\n    this.searchInput.nativeElement.value = '';\n    this.showPlaceholder = true;\n    this.clearTimeoutForSearch();\n  }\n\n  resetValue(): void {\n    this.selectionChange.emit(null);\n    this.ngControl.reset(null);\n    this.inputFocusOut();\n  }\n\n  getDataWithSearch(value: any, event: any): void {\n    this.clearTimeoutForSearch();\n    if (value.length >= 1) {\n      this.searchTimeoutId = setTimeout(() => {\n        this.getData(value, true)\n      }, 800);\n    } else if (value.length <= 1 && event.keyCode === 8) {\n      this.getData(value, true)\n    }\n  }\n\n  clearTimeoutForSearch(): void {\n    if (this.searchTimeoutId) {\n      clearTimeout(this.searchTimeoutId);\n      this.searchTimeoutId = 0;\n    }\n  }\n\n  openSelection(): void {\n    if (this.selectConfig.disabled || this.ngControl.control.disabled) {\n      return;\n    }\n    if (this.showPlaceholder) {\n      this.matSelect.open();\n    } else {\n      this.closePanelAndUnsetFocus();\n    }\n    this.showPlaceholder = !this.showPlaceholder;\n    if (!this.showPlaceholder) {\n      this.reCallData();\n    }\n  }\n\n  closePanelAndUnsetFocus(): void {\n    this.matSelect.close();\n    if (this.searchInput) {\n      this.searchInput.nativeElement.blur()\n    }\n  }\n\n  openedChange(event: any) {\n    if (event) {\n      if (this.isNeededForRecall) {\n        this.reCallData();\n        return;\n      }\n      if (!this.selectConfig.search) {\n        this.pending = false\n        this.reCallData();\n      }\n\n      return;\n    }\n\n    this.showPlaceholder = true;\n  }\n\n  reCallData(): void {\n    // TODO refactor this part\n    if (!this.isNeededForRecall) {\n      return;\n    }\n    this.data = [];\n    this.pending = true;\n    this.paginationData = {\n      current: 1,\n      last: 0\n    };\n    this.accessToNextRequest = true;\n    if ((typeof this.selectConfig.paginate) === 'function') {\n      this.getData();\n    } else {\n      this.pending = false;\n      this.data = this.selectConfig.paginate;\n    }\n    this.isNeededForRecall = false;\n  }\n\n  emitSelectionChangeAndClose(event: any) {\n    this.selectionChange.emit(event.value);\n    if (this.selectConfig.multiple) {\n      if (!event.value?.length) {\n        this.ngControl.control.reset();\n      }\n      return;\n    }\n    this.matSelect.close();\n  }\n\n  /*\n   * Open mat-select and focus on search on icon click\n   */\n  iconClick(matSelect: MatSelect, searchInput?: ElementRef): void {\n    matSelect.open();\n    searchInput?.nativeElement?.focus();\n  }\n\n  /*\n  * Custom error state matcher for mat-select to properly show error state in mat-form-field\n   */\n  customErrorStateMatcher = {\n    isErrorState: (control: any, form: any): boolean => {\n      return !!(control && control.invalid && this.submitValue);\n    }\n  };\n}\n","<div class=\"new-mat-autocomplete\" id=\"mat_autocomplete\"\n     [ngClass]=\"{\n            'mat-select-without_icon': !selectConfig.iconUrl && !selectConfig.activeStateIconUrl,\n            'mat-select-with-search': selectConfig.search,\n            'without-label': selectConfig.hideLabel,\n            'invalid_field': ngControl.control.errors && submitValue,\n            'readonly-field': selectConfig.readOnly || ngControl.control.disabled\n         }\"\n     [matTooltip]=\"(selectConfig.hover && !ngControl.control.disabled ? ((selectConfig.hover || '') | translate) : '')\"\n     [matTooltipClass]=\"'mat-mdc-tooltip big-td-mat-tooltip'\"\n     [matTooltipPosition]=\"'above'\"\n     *ngIf=\"selectConfig && ngControl\">\n\n  <div class=\"w-100\" *ngIf=\"!selectConfig.hideLabel\">\n    <mat-label [ngClass]=\"{\n          'readonly-color' : selectConfig.readOnly || ngControl.control.disabled,\n          'invalid-label-color': !!(ngControl.control.errors && submitValue)\n        }\">\n      {{ selectConfig.label | translate }}\n    </mat-label>\n    <span *ngIf=\"selectConfig.required\" class=\"required-input\"\n          [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\n  </div>\n\n\n  <!-- Search Input -->\n  <div class=\"search-input w-100\"\n       (click)=\"$event.stopPropagation();$event.preventDefault()\"\n       [ngClass]=\"{ hide_input_placeholder: showPlaceholder || ngControl.control.disabled }\"\n       *ngIf=\"selectConfig.search\"\n  >\n    <input autocomplete=\"off\"\n           id=\"searchInput\"\n           type=\"text\"\n           [ngClass]=\"{'pr-25': !selectConfig.iconUrl}\"\n           #searchInput\n           [disabled]=\"ngControl.control.disabled || selectConfig.hover\"\n           [placeholder]=\"(ngControl.control.disabled || selectConfig.hover) ? '' : 'Search'\"\n           (focusout)=\"inputFocusOut()\"\n           (focus)=\"openSelection()\"\n           (keydown)=\"$event.stopPropagation()\"\n           (keyup)=\"getDataWithSearch(searchInput.value,$event)\">\n\n    <!-- Search Icon -->\n    <span class=\"search-icon\">\n            <i-tech-icon-button\n              class=\"mr-10\"\n              [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color'\n                                                                              : 'default-form-icon-color'\"\n              *ngIf=\"selectConfig.iconPrefix && !showPlaceholder\"\n              [iconName]=\"selectConfig.iconPrefix || ''\"\n              [disabled]=\"selectConfig.readOnly || false\"\n              matPrefix\n            >\n            </i-tech-icon-button>\n        </span>\n  </div>\n\n  <!-- Placeholder/Selected Value Display -->\n  <ng-container *ngIf=\"showPlaceholder && selectConfig.search\">\n    <div class=\"custom-placeholder\"\n         *ngIf=\"(!ngControl?.value && !ngControl?.value?.length) ||\n                 (selectConfig.multiple && ngControl?.value && !ngControl?.value?.length)\"\n         [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n    >\n      {{ ((selectConfig.placeholder || '') | translate) }}\n    </div>\n    <div class=\"custom-placeholder custom-value ellipsis\"\n         [ngClass]=\"{\n                'pr-42': selectConfig.iconUrl,\n                'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n                'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled)\n                }\"\n         *ngIf=\"ngControl?.value\"\n    >\n      {{showingValue}}\n    </div>\n  </ng-container>\n\n  <!-- Custom Icon -->\n  <img class=\"left_icon_new pointer\"\n       alt=\"Toggle Selection\"\n       (click)=\"iconClick(matSelect, searchInput)\"\n       *ngIf=\"!selectConfig.matIconName && (selectConfig.iconUrl || selectConfig.activeStateIconUrl)\"\n       [src]=\"'assets/images/icons/global/' + (ngControl.control?.value && selectConfig?.activeStateIconUrl ?\n                                                selectConfig.activeStateIconUrl\n                                                : selectConfig.iconUrl)\">\n\n  <mat-form-field appearance=\"outline\" class=\"w-100\" (click)=\"selectConfig?.search ? focusSearchInput() : null\">\n    <!-- Material Select -->\n    <mat-select #matSelect=\"matSelect\"\n                [panelClass]=\"'autocomplete-transform-panel-location'\"\n                [attr.aria-placeholder]=\"(selectConfig.placeholder || '') | translate\"\n                [aria-label]=\"selectConfig.label | translate\"\n                [id]=\"selectConfig.filtrationKey || ''\"\n                (opened)=\"registerPanelScrollEvent(matSelect)\"\n                (openedChange)=\"openedChange($event)\"\n                [formControl]=\"ngControl.control\"\n                [multiple]=\"selectConfig.multiple\"\n                (selectionChange)=\"emitSelectionChangeAndClose($event)\"\n                [errorStateMatcher]=\"customErrorStateMatcher\"\n                [placeholder]=\"(selectConfig.placeholder || '') | translate\"\n                [disabled]=\"ngControl.control.disabled\"\n    >\n\n      <!-- Loading State -->\n      <mat-option *ngIf=\"pending\" class=\"option_loading relative\">\n        <div class=\"request_loading\">\n          <img ngSrc=\"./loader.svg\" alt=\"\" height=\"200\" width=\"200\"/>\n        </div>\n      </mat-option>\n\n      <!-- Options -->\n      <ng-container *ngIf=\"data?.length && !pending\">\n        <!-- Add New Option -->\n        <mat-option *ngIf=\"selectConfig.actions\"\n                    class=\"pointer add_new\"\n                    disabled\n                    (click)=\"closePanelAndUnsetFocus();addNewItemEvent()\">\n          <!--(click)=\"ngControl.control.reset(null);\n              matSelect._onBlur();closePanelAndUnsetFocus();addNewItemEvent()\">-->\n          <i-tech-button\n            [type]=\"ButtonType.OUTLINE\"\n            [fontIcon]=\"'add'\"\n            [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \"\n            [customClass]=\"'w-100 mat-autocomplete-select-button'\">\n          </i-tech-button>\n        </mat-option>\n\n        <!-- Regular Options -->\n        <ng-container *ngIf=\"!selectConfig?.changeText && data.length\">\n          <mat-option *ngFor=\"let item of data\"\n                      [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n                      (mouseup)=\"optionClick(item)\"\n                      (mousedown)=\"preventDefault($event)\">\n            @if (selectConfig?.needTranslateOptions) {\n            {{\n            ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n              : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '') | translate\n            }}\n            }@else {\n            {{\n            ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n              : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '')\n            }}\n            }\n\n          </mat-option>\n        </ng-container>\n\n        <!-- Custom Text Options -->\n        <ng-container *ngIf=\"selectConfig?.changeText && data.length\">\n          <mat-option *ngFor=\"let item of data\"\n                      [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n                      (mouseup)=\"optionClick(item)\"\n                      (mousedown)=\"preventDefault($event)\"\n                      [disabled]=\"selectConfig?.changeText[item].disabled\">\n            {{ selectConfig?.needTranslateOptions ? (selectConfig?.changeText[item].text | translate ) : selectConfig?.changeText[item].text}}\n          </mat-option>\n        </ng-container>\n      </ng-container>\n\n      <!-- Empty State -->\n      <ng-container *ngIf=\"!pending && !data.length\">\n        <mat-option disabled class=\"empty_selection_state\">\n          <div class=\"actions_and_tile add_new flex_column w-100 flex_center_align_center\">\n            <span>{{ 'dropdown_no_items' | translate }}</span>\n            <div class=\"mt-10\">\n              <i-tech-button\n                *ngIf=\"selectConfig?.actions\"\n                [type]=\"ButtonType.OUTLINE\"\n                (buttonClick)=\"closePanelAndUnsetFocus();addNewItemEvent()\"\n                [customClass]=\"'mat-autocomplete-select-button'\"\n                [fontIcon]=\"'add'\"\n                [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \">\n              </i-tech-button>\n            </div>\n          </div>\n        </mat-option>\n      </ng-container>\n    </mat-select>\n    <mat-icon *ngIf=\"selectConfig.iconPrefix\"\n              matPrefix\n              [ngClass]=\"{\n                    'readonly-color' : !selectConfig['iconPrefixColor']\n                                        && (selectConfig.readOnly || ngControl.control.disabled),\n                    'default-form-icon-color' : !selectConfig['iconPrefixColor']\n                                        && !(selectConfig.readOnly || ngControl.control.disabled)\n                    }\"\n              [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n    >{{ selectConfig.iconPrefix }}\n    </mat-icon>\n\n    <mat-icon *ngIf=\"selectConfig['iconPrefixSvg']\"\n              matPrefix\n              [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n              [svgIcon]=\"selectConfig['iconPrefixSvg'] || ''\"\n    ></mat-icon>\n\n    <i-tech-icon-button\n      *ngIf=\"selectConfig.search && selectConfig.clearable && !ngControl.control.disabled && !!ngControl.control.value\"\n      iconName=\"cancel\"\n      matSuffix\n      [disabled]=\"selectConfig.readOnly || false\"\n      [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n      (click)=\"\n        $event.stopPropagation();\n        $event.preventDefault();\n        ngControl.control.reset(null);\n        matSelect._onBlur();\n        closePanelAndUnsetFocus()\n      \"\n    >\n    </i-tech-icon-button>\n    <mat-icon\n      matSuffix\n      class=\"select-arrow\"\n      [class.open]=\"matSelect.panelOpen\"\n      [ngClass]=\"{\n            'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n            'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled),\n            'mt-8': !!ngControl.control.value && selectConfig.clearable\n         }\"\n    >\n      keyboard_arrow_down\n    </mat-icon>\n    <!-- Error Message -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submitValue)\">\n      {{ ngControl.control | generateErrorMessages : selectConfig.label : selectConfig.defaultPatternKey }}\n    </mat-error>\n  </mat-form-field>\n\n  <!-- Reset Button -->\n  <i-tech-clear-value *ngIf=\"selectConfig.reset\" (resetValue)=\"resetValue()\"></i-tech-clear-value>\n</div>\n"]}
|
|
442
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-select.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/autocomplete-select/autocomplete-select.component.ts","../../../../../../projects/shared-components/src/lib/components/autocomplete-select/autocomplete-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef, HostListener, AfterViewInit\n} from '@angular/core';\nimport { MatSelect, MatSelectModule } from \"@angular/material/select\";\nimport { AutocompleteConfigsInterface } from \"../../interfaces/autocomplete-configs.interface\";\nimport { FormControlName, ReactiveFormsModule } from \"@angular/forms\";\nimport { InputService } from '../../services/input.service';\nimport { ButtonType } from '../../interfaces/button-types.enum';\nimport { NgClass, NgFor, NgIf, NgOptimizedImage } from \"@angular/common\";\nimport { MatTooltip } from \"@angular/material/tooltip\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { IconButtonComponent } from \"../icon-button/icon-button.component\";\nimport { ButtonComponent } from \"../button/button.component\";\nimport { GetValueByKeyFromObjectPipe } from \"../../pipes/get-value-by-key-from-object.pipe\";\nimport { ArrayToStringPipe } from \"../../pipes/array-to-string.pipe\";\nimport { MatIcon } from \"@angular/material/icon\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\nimport { ClearValueComponent } from \"../clear-value/clear-value.component\";\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\n\n@Component({\n  selector: 'i-tech-autocomplete-select',\n  templateUrl: './autocomplete-select.component.html',\n  styleUrls: ['./autocomplete-select.component.scss'],\n  imports: [\n    NgClass,\n    MatTooltip,\n    NgIf,\n    NgFor,\n    TranslateModule,\n    IconButtonComponent,\n    ReactiveFormsModule,\n    MatSelectModule,\n    ButtonComponent,\n    GetValueByKeyFromObjectPipe,\n    ArrayToStringPipe,\n    NgOptimizedImage,\n    MatIcon,\n    GenerateErrorMessagesPipe,\n    ClearValueComponent,\n    MatFormFieldModule\n  ],\n  standalone: true\n})\nexport class AutocompleteSelectComponent implements OnChanges, AfterViewInit {\n  @ViewChild('matSelect') matSelect!: MatSelect;\n  @ViewChild('searchInput') searchInput!: ElementRef;\n  @Input() className!: string;\n  @Input() submitValue!: boolean;\n\n  /**\n   * See AutocompleteConfigsInterface for available configurations.\n   */\n  @Input() set configs(data: AutocompleteConfigsInterface) {\n    this.selectConfig = data;\n    if (!data) {\n      return;\n    }\n\n    if ((typeof this.selectConfig.paginate) === 'function') {\n      if (this.firstRequest) {\n        return;\n      }\n      this.getData();\n      this.firstRequest = true\n      return;\n    }\n\n    this.data = this.selectConfig.paginate;\n    this.findAndSetDefaultValueFromData();\n  };\n\n  @Input() detectChanges!: boolean;\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() emitAction = new EventEmitter<any>();\n  @ViewChild('allSelected') allSelected!: MatSelect;\n  pending = false;\n  defaultValue!: any;\n  data: Array<any> = [];\n  paginationData: any = { current: 1, last: 0 };\n  ngControl: FormControlName;\n  selectConfig!: AutocompleteConfigsInterface;\n  firstRequest = false;\n  showPlaceholder = true;\n  isNeededForRecall = false;\n  showingValue: any;\n  selectedOptionForMultipleSelection: Array<any> = [];\n  searchTimeoutId: any;\n  tabVisibility!: boolean;\n  accessToNextRequest = true;\n  disabled = false;\n  blockRecallDefaultValueSetter = false;\n  baseData: any;\n  requestLoading = false;\n  protected readonly ButtonType = ButtonType;\n\n  @HostListener('document:visibilitychange')\n  handleVisibilityChange(): void {\n    this.tabVisibility = !document.hidden;\n    if (this.ngControl.control.value) {\n      return;\n    }\n    this.closePanelAndUnsetFocus();\n    if (!document.hidden) {\n      this.isNeededForRecall = true;\n      this.pending = true;\n      setTimeout(() => {\n        this.pending = false\n      }, 4000)\n    }\n  }\n\n  constructor(private inputService: InputService) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['selectConfig'] && this.selectConfig) {\n      if ((typeof this.selectConfig.paginate) === 'function') {\n        this.getData();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.ngControl.control.valueChanges.subscribe((res: any) => {\n      if (this.data.length && res && !this.blockRecallDefaultValueSetter) {\n        this.findAndSetDefaultValueFromData();\n      }\n    })\n  }\n\n  hardReload(): void {\n    this.getData('', true);\n  }\n\n  /**\n   * Dynamic request for select data.\n   * @param searchText - The input value to search options by.\n   * @param fromSearch - Access for search.\n   * @returns Select data.\n   */\n  getData(searchText?: string, fromSearch?: boolean): void {\n    if (!fromSearch && !this.accessToNextRequest) {\n      return;\n    }\n\n    if (this.requestLoading) {\n      return;\n    }\n\n    if (fromSearch) {\n      this.paginationData.current = 1;\n      this.accessToNextRequest = true;\n    }\n\n    const functionToDo = this.selectConfig.paginate(this.paginationData.current, searchText);\n\n    this.requestLoading = true;\n    functionToDo?.subscribe((data: Array<any> | any) => {\n      const dataToAdd = ('content' in data) ? data.content : data;\n\n      if ('content' in data) {\n        this.accessToNextRequest = !data.last || (data.totalPages > this.paginationData.current);\n      }\n\n      this.data = (fromSearch || this.selectConfig?.blockPagination) ? dataToAdd : [...this.data, ...dataToAdd];\n      this.pending = false;\n      this.requestLoading = false;\n\n      if (!dataToAdd.length) {\n        this.paginationData.last = this.paginationData.current;\n        return;\n      }\n\n      this.paginationData.current += 1;\n      this.paginationData.last += 1;\n      setTimeout(() => {\n        this.findAndSetDefaultValueFromData();\n      }, 10)\n    }, () => {\n      this.pending = false;\n      this.requestLoading = false;\n    })\n  }\n\n  findAndSetDefaultValueFromData(): void {\n    if (this.selectConfig.multiple) {\n      if (this.ngControl.value && this.ngControl.value.length == 1) {\n        this.setShowingValue(this.data.find((item) => item.id === this.ngControl.value[0]))\n      }\n    } else {\n      const isDisabled = this.ngControl.disabled;\n      if (isDisabled) {\n        // TODO Remove after migrating all selects\n        // this.ngControl.control.enable();\n        // if (!this.ngControl.value && !this.data.length) {\n        //     this.ngControl.control.disable();\n        //     return;\n        // }\n        // this.setDefaultValue();\n        // this.ngControl.control.disable();\n      } else {\n        if (!this.ngControl.value && !this.data) {\n          return;\n        }\n        this.setDefaultValue();\n      }\n\n    }\n  }\n\n  setDefaultValue(): void {\n    this.defaultValue = this.data.find((item) => item.id === this.ngControl.value);\n    this.baseData = this.defaultValue\n    if (!this.defaultValue) {\n      return;\n    }\n    this.selectionChange.emit()\n    this.setShowingValue(this.defaultValue);\n  }\n\n  optionClick(showingData: any): void {\n    this.baseData = showingData\n    if (!this.selectConfig.multiple) {\n      this.setShowingValue(showingData);\n      this.matSelect.close();\n      return;\n    }\n    if (this.searchInput) {\n      if (this.selectConfig.multiple) {\n        this.toggleShowingDataInSelectedOptionsMultipleCase(showingData);\n      } else {\n        this.inputFocusOut();\n      }\n    }\n\n    this.setShowingValue(showingData);\n    this.showPlaceholder = false;\n  }\n\n  toggleShowingDataInSelectedOptionsMultipleCase(showingData: any): void {\n    const showingDataByJson = JSON.stringify(showingData);\n    const indexOfExistingOption = this.selectedOptionForMultipleSelection.findIndex(\n      (optionValue: any) => JSON.stringify(optionValue) === showingDataByJson\n    )\n    if (indexOfExistingOption >= 0) {\n      this.selectedOptionForMultipleSelection.splice(indexOfExistingOption, 1);\n    } else {\n      this.selectedOptionForMultipleSelection.push(showingData);\n    }\n  }\n\n  addNewItemEvent(): void {\n    this.isNeededForRecall = true;\n    this.emitAction.emit();\n  }\n\n  /**\n   * Filter and show.\n   * @param data - Existing chosen data.\n   */\n  setShowingValue(data: any): void {\n    if (!data) {\n      return;\n    }\n    if (this.selectConfig.multiple && this.selectConfig.search) {\n      const fullText: Array<string> = [];\n      this.selectedOptionForMultipleSelection.forEach((optionData: any) => {\n        fullText.push(this.collectAndGetSelectionToShowForOneOption(optionData))\n      })\n      this.showingValue = fullText.join(',');\n    } else {\n      this.showingValue = this.collectAndGetSelectionToShowForOneOption(data);\n    }\n    this.blockRecallDefaultValueSetter = true;\n  }\n\n  collectAndGetSelectionToShowForOneOption(data: any): string {\n    let include = data;\n    let includeOptional = data;\n\n    if (this.selectConfig.valueToShowByKey) {\n      this.selectConfig.valueToShowByKey.forEach((param: Array<string | number> | string) => {\n\n        if (typeof param === 'object') {\n          param.forEach((key: string | number) => {\n            include = (include) ? include[key] : null;\n          })\n        } else {\n          include = include[param];\n        }\n      })\n      if (this.selectConfig.showFullTextWithOptionalOnSelectedValue) {\n        this.selectConfig.valueToShowByParam?.forEach((param: Array<string | number> | string) => {\n\n          if (typeof param === 'object') {\n            param.forEach((key: string | number) => {\n              includeOptional = (includeOptional) ? includeOptional[key] : null;\n            })\n          } else {\n            includeOptional = includeOptional[param];\n          }\n        })\n        if (this.selectConfig.valueToShowByParam && typeof includeOptional === 'string') {\n          include += (this.selectConfig.withParamSymbol || '') + includeOptional\n        }\n      }\n    }\n\n    return include;\n  }\n\n  /**\n   * Block another events.\n   * @param event - Element click event.\n   */\n  preventDefault(event: any) {\n    if (!this.selectConfig.multiple) {\n      return;\n    }\n    event.preventDefault()\n  }\n\n  registerPanelScrollEvent(element: MatSelect) {\n    if (this.selectConfig.paginateOnScroll === false) {\n      return;\n    }\n\n    const panel = element.panel.nativeElement;\n    panel.addEventListener('scroll', (event: any) => this.loadDataOnScroll(event));\n  }\n\n  loadDataOnScroll(event: any) {\n    const pos = (event.target.scrollTop || event.target.scrollTop) + event.target.offsetHeight;\n    const max = event.target.scrollHeight;\n    if ((pos + 1) >= max) {\n      if (this.paginationData.current === this.paginationData.last || this.selectConfig.blockPagination) {\n        return;\n      }\n      this.getData();\n    }\n  }\n\n  focusSearchInput() {\n    if (this.selectConfig.search && this.searchInput) {\n      this.searchInput.nativeElement.focus();\n    }\n  }\n\n  inputFocusOut(): void {\n    this.isNeededForRecall = !!this.searchInput.nativeElement.value;\n    this.searchInput.nativeElement.value = '';\n    this.showPlaceholder = true;\n    this.clearTimeoutForSearch();\n  }\n\n  resetValue(): void {\n    this.selectionChange.emit(null);\n    this.ngControl.reset(null);\n    this.inputFocusOut();\n  }\n\n  getDataWithSearch(value: any, event: any): void {\n    this.clearTimeoutForSearch();\n    if (value.length >= 1) {\n      this.searchTimeoutId = setTimeout(() => {\n        this.getData(value, true)\n      }, 800);\n    } else if (value.length <= 1 && event.keyCode === 8) {\n      this.getData(value, true)\n    }\n  }\n\n  clearTimeoutForSearch(): void {\n    if (this.searchTimeoutId) {\n      clearTimeout(this.searchTimeoutId);\n      this.searchTimeoutId = 0;\n    }\n  }\n\n  openSelection(): void {\n    if (this.selectConfig.disabled || this.ngControl.control.disabled) {\n      return;\n    }\n    if (this.showPlaceholder) {\n      this.matSelect.open();\n    } else {\n      this.closePanelAndUnsetFocus();\n    }\n    this.showPlaceholder = !this.showPlaceholder;\n    if (!this.showPlaceholder) {\n      this.reCallData();\n    }\n  }\n\n  closePanelAndUnsetFocus(): void {\n    this.matSelect.close();\n    if (this.searchInput) {\n      this.searchInput.nativeElement.blur()\n    }\n  }\n\n  openedChange(event: any) {\n    if (event) {\n      if (this.isNeededForRecall) {\n        this.reCallData();\n        return;\n      }\n      if (!this.selectConfig.search) {\n        this.pending = false\n        this.reCallData();\n      }\n\n      return;\n    }\n\n    this.showPlaceholder = true;\n  }\n\n  reCallData(): void {\n    // TODO refactor this part\n    if (!this.isNeededForRecall) {\n      return;\n    }\n    this.data = [];\n    this.pending = true;\n    this.paginationData = {\n      current: 1,\n      last: 0\n    };\n    this.accessToNextRequest = true;\n    if ((typeof this.selectConfig.paginate) === 'function') {\n      this.getData();\n    } else {\n      this.pending = false;\n      this.data = this.selectConfig.paginate;\n    }\n    this.isNeededForRecall = false;\n  }\n\n  emitSelectionChangeAndClose(event: any) {\n    this.selectionChange.emit(event.value);\n    if (this.selectConfig.multiple) {\n      if (!event.value?.length) {\n        this.ngControl.control.reset();\n      }\n      return;\n    }\n    this.matSelect.close();\n  }\n\n  /*\n   * Open mat-select and focus on search on icon click\n   */\n  iconClick(matSelect: MatSelect, searchInput?: ElementRef): void {\n    matSelect.open();\n    searchInput?.nativeElement?.focus();\n  }\n\n  /*\n  * Custom error state matcher for mat-select to properly show error state in mat-form-field\n   */\n  customErrorStateMatcher = {\n    isErrorState: (control: any, form: any): boolean => {\n      return !!(control && control.invalid && this.submitValue);\n    }\n  };\n}\n","<div class=\"new-mat-autocomplete\" id=\"mat_autocomplete\"\n     [ngClass]=\"{\n            'mat-select-without_icon': !selectConfig.iconUrl && !selectConfig.activeStateIconUrl,\n            'mat-select-with-search': selectConfig.search,\n            'without-label': selectConfig.hideLabel,\n            'invalid_field': ngControl.control.errors && submitValue,\n            'readonly-field': selectConfig.readOnly || ngControl.control.disabled\n         }\"\n     [matTooltip]=\"(selectConfig.hover && !ngControl.control.disabled ? ((selectConfig.hover || '') | translate) : '')\"\n     [matTooltipClass]=\"'mat-mdc-tooltip big-td-mat-tooltip'\"\n     [matTooltipPosition]=\"'above'\"\n     *ngIf=\"selectConfig && ngControl\">\n\n  <div class=\"w-100\" *ngIf=\"!selectConfig.hideLabel\">\n    <mat-label [ngClass]=\"{\n          'readonly-color' : selectConfig.readOnly || ngControl.control.disabled,\n          'invalid-label-color': !!(ngControl.control.errors && submitValue)\n        }\">\n      {{ selectConfig.label | translate }}\n    </mat-label>\n    <span *ngIf=\"selectConfig.required\" class=\"required-input\"\n          [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\n  </div>\n\n\n  <!-- Search Input -->\n  <div class=\"search-input w-100\"\n       (click)=\"$event.stopPropagation();$event.preventDefault()\"\n       [ngClass]=\"{ hide_input_placeholder: showPlaceholder || ngControl.control.disabled }\"\n       *ngIf=\"selectConfig.search\"\n  >\n    <input autocomplete=\"off\"\n           id=\"searchInput\"\n           type=\"text\"\n           [ngClass]=\"{'pr-25': !selectConfig.iconUrl}\"\n           #searchInput\n           [disabled]=\"ngControl.control.disabled || selectConfig.hover\"\n           [placeholder]=\"(ngControl.control.disabled || selectConfig.hover) ? '' : 'Search'\"\n           (focusout)=\"inputFocusOut()\"\n           (focus)=\"openSelection()\"\n           (keydown)=\"$event.stopPropagation()\"\n           (keyup)=\"getDataWithSearch(searchInput.value,$event)\">\n\n    <!-- Search Icon -->\n    <span class=\"search-icon\">\n            <i-tech-icon-button\n              class=\"mr-10\"\n              [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color'\n                                                                              : 'default-form-icon-color'\"\n              *ngIf=\"selectConfig.iconPrefix && !showPlaceholder\"\n              [iconName]=\"selectConfig.iconPrefix || ''\"\n              [disabled]=\"selectConfig.readOnly || false\"\n              matPrefix\n            >\n            </i-tech-icon-button>\n        </span>\n  </div>\n\n  <!-- Placeholder/Selected Value Display -->\n  <ng-container *ngIf=\"showPlaceholder && selectConfig.search\">\n    <div class=\"custom-placeholder\"\n         *ngIf=\"(!ngControl?.value && !ngControl?.value?.length) ||\n                 (selectConfig.multiple && ngControl?.value && !ngControl?.value?.length)\"\n         [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n    >\n      {{ ((selectConfig.placeholder || '') | translate) }}\n    </div>\n    <div class=\"custom-placeholder custom-value ellipsis\"\n         [ngClass]=\"{\n                'pr-42': selectConfig.iconUrl,\n                'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n                'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled)\n                }\"\n         *ngIf=\"ngControl?.value\"\n    >\n      {{showingValue}}\n    </div>\n  </ng-container>\n\n  <!-- Custom Icon -->\n  <img class=\"left_icon_new pointer\"\n       alt=\"Toggle Selection\"\n       (click)=\"iconClick(matSelect, searchInput)\"\n       *ngIf=\"!selectConfig.matIconName && (selectConfig.iconUrl || selectConfig.activeStateIconUrl)\"\n       [src]=\"'assets/images/icons/global/' + (ngControl.control?.value && selectConfig?.activeStateIconUrl ?\n                                                selectConfig.activeStateIconUrl\n                                                : selectConfig.iconUrl)\">\n\n  <mat-form-field appearance=\"outline\" class=\"w-100\" (click)=\"selectConfig?.search ? focusSearchInput() : null\">\n    <!-- Material Select -->\n    <mat-select #matSelect=\"matSelect\"\n                [panelClass]=\"'autocomplete-transform-panel-location'\"\n                [attr.aria-placeholder]=\"(selectConfig.placeholder || '') | translate\"\n                [aria-label]=\"selectConfig.label | translate\"\n                [id]=\"selectConfig.filtrationKey || ''\"\n                (opened)=\"registerPanelScrollEvent(matSelect)\"\n                (openedChange)=\"openedChange($event)\"\n                [formControl]=\"ngControl.control\"\n                [multiple]=\"selectConfig.multiple\"\n                (selectionChange)=\"emitSelectionChangeAndClose($event)\"\n                [errorStateMatcher]=\"customErrorStateMatcher\"\n                [placeholder]=\"(selectConfig.placeholder || '') | translate\"\n                [disabled]=\"ngControl.control.disabled\"\n    >\n\n      <!-- Loading State -->\n      <mat-option *ngIf=\"pending\" class=\"option_loading relative\">\n        <div class=\"request_loading\">\n          <img ngSrc=\"./loader.svg\" alt=\"\" height=\"200\" width=\"200\"/>\n        </div>\n      </mat-option>\n\n      <!-- Options -->\n      <ng-container *ngIf=\"data?.length && !pending\">\n        <!-- Add New Option -->\n        <mat-option *ngIf=\"selectConfig.actions\"\n                    class=\"pointer add_new\"\n                    disabled\n                    (click)=\"closePanelAndUnsetFocus();addNewItemEvent()\">\n          <!--(click)=\"ngControl.control.reset(null);\n              matSelect._onBlur();closePanelAndUnsetFocus();addNewItemEvent()\">-->\n          <i-tech-button\n            [type]=\"ButtonType.OUTLINE\"\n            [fontIcon]=\"'add'\"\n            [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \"\n            [customClass]=\"'w-100 mat-autocomplete-select-button'\">\n          </i-tech-button>\n        </mat-option>\n\n        <!-- Regular Options -->\n        <ng-container *ngIf=\"!selectConfig?.changeText && data.length\">\n          <mat-option *ngFor=\"let item of data\"\n                      [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n                      (mouseup)=\"optionClick(item)\"\n                      (mousedown)=\"preventDefault($event)\">\n            @if (selectConfig?.needTranslateOptions) {\n            {{\n            ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n              : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '') | translate\n            }}\n            }@else {\n            {{\n            ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n              : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '')\n            }}\n            }\n\n          </mat-option>\n        </ng-container>\n\n        <!-- Custom Text Options -->\n        <ng-container *ngIf=\"selectConfig?.changeText && data.length\">\n          <mat-option *ngFor=\"let item of data\"\n                      [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n                      (mouseup)=\"optionClick(item)\"\n                      (mousedown)=\"preventDefault($event)\"\n                      [disabled]=\"selectConfig?.changeText[item].disabled\">\n            {{ selectConfig?.needTranslateOptions ? (selectConfig?.changeText[item].text | translate ) : selectConfig?.changeText[item].text}}\n          </mat-option>\n        </ng-container>\n      </ng-container>\n\n      <!-- Empty State -->\n      <ng-container *ngIf=\"!pending && !data.length\">\n        <mat-option disabled class=\"empty_selection_state\">\n          <div class=\"actions_and_tile add_new flex_column w-100 flex_center_align_center\">\n            <span>{{ 'dropdown_no_items' | translate }}</span>\n            <div class=\"mt-10\">\n              <i-tech-button\n                *ngIf=\"selectConfig?.actions\"\n                [type]=\"ButtonType.OUTLINE\"\n                (buttonClick)=\"closePanelAndUnsetFocus();addNewItemEvent()\"\n                [customClass]=\"'mat-autocomplete-select-button'\"\n                [fontIcon]=\"'add'\"\n                [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \">\n              </i-tech-button>\n            </div>\n          </div>\n        </mat-option>\n      </ng-container>\n    </mat-select>\n    <mat-icon *ngIf=\"selectConfig.iconPrefix\"\n              matPrefix\n              [ngClass]=\"{\n                    'readonly-color' : !selectConfig['iconPrefixColor']\n                                        && (selectConfig.readOnly || ngControl.control.disabled),\n                    'default-form-icon-color' : !selectConfig['iconPrefixColor']\n                                        && !(selectConfig.readOnly || ngControl.control.disabled)\n                    }\"\n              [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n    >{{ selectConfig.iconPrefix }}\n    </mat-icon>\n\n    <mat-icon *ngIf=\"selectConfig['iconPrefixSvg']\"\n              matPrefix\n              [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n              [svgIcon]=\"selectConfig['iconPrefixSvg'] || ''\"\n    ></mat-icon>\n\n    <i-tech-icon-button\n      *ngIf=\"selectConfig.search && selectConfig.clearable && !ngControl.control.disabled && !!ngControl.control.value\"\n      iconName=\"cancel\"\n      matSuffix\n      [disabled]=\"selectConfig.readOnly || false\"\n      [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n      (click)=\"\n        $event.stopPropagation();\n        $event.preventDefault();\n        ngControl.control.reset(null);\n        matSelect._onBlur();\n        closePanelAndUnsetFocus()\n      \"\n    >\n    </i-tech-icon-button>\n    <mat-icon\n      matSuffix\n      class=\"select-arrow\"\n      [class.open]=\"matSelect.panelOpen\"\n      [ngClass]=\"{\n            'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n            'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled),\n            'mt-8': !!ngControl.control.value && selectConfig.clearable\n         }\"\n    >\n      keyboard_arrow_down\n    </mat-icon>\n    <!-- Error Message -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submitValue)\">\n      {{ ngControl.control | generateErrorMessages : selectConfig.label : selectConfig.defaultPatternKey }}\n    </mat-error>\n  </mat-form-field>\n\n  <!-- Reset Button -->\n  <i-tech-clear-value *ngIf=\"selectConfig.reset\" (resetValue)=\"resetValue()\"></i-tech-clear-value>\n</div>\n"]}
|
|
@@ -15,12 +15,28 @@ import * as i3 from "@angular/material/datepicker";
|
|
|
15
15
|
import * as i4 from "@ngx-translate/core";
|
|
16
16
|
import * as i5 from "@angular/forms";
|
|
17
17
|
export class DateTimePickerComponent {
|
|
18
|
+
set disabled(disabled) {
|
|
19
|
+
this._disabled = disabled;
|
|
20
|
+
if (disabled) {
|
|
21
|
+
this.form.get('time')?.disable();
|
|
22
|
+
this.form.get('date')?.disable();
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
this.form.get('time')?.enable();
|
|
26
|
+
this.form.get('date')?.enable();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
;
|
|
30
|
+
get disabled() {
|
|
31
|
+
return this._disabled;
|
|
32
|
+
}
|
|
18
33
|
constructor(inputService, parseDateService) {
|
|
19
34
|
this.inputService = inputService;
|
|
20
35
|
this.parseDateService = parseDateService;
|
|
21
36
|
this.dateChangeEvent = new EventEmitter();
|
|
22
37
|
this.submit = false;
|
|
23
38
|
this.required = false;
|
|
39
|
+
this._disabled = false;
|
|
24
40
|
this.isFocused = false;
|
|
25
41
|
this.form = new UntypedFormGroup({
|
|
26
42
|
time: new UntypedFormControl(),
|
|
@@ -39,6 +55,13 @@ export class DateTimePickerComponent {
|
|
|
39
55
|
return;
|
|
40
56
|
}
|
|
41
57
|
const dateTime = this.ngControl.control.value;
|
|
58
|
+
if (!dateTime) {
|
|
59
|
+
this.form.patchValue({
|
|
60
|
+
date: null,
|
|
61
|
+
time: null
|
|
62
|
+
}, { emitEvent: false });
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
42
65
|
this.form.patchValue({
|
|
43
66
|
date: new Date(this.parseDateService.changeFormat(dateTime, 'YYYY-MM-DD') + 'T' + '00:00:00'),
|
|
44
67
|
time: this.parseDateService.changeFormat(dateTime, 'HH:mm')
|
|
@@ -68,13 +91,13 @@ export class DateTimePickerComponent {
|
|
|
68
91
|
this.isFocused = false;
|
|
69
92
|
}
|
|
70
93
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: i1.InputService }, { token: i2.ParseDateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"
|
|
94
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required", disabled: "disabled" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (selectionchange)=\"dateChange(dateElement)\"\n >\n <mat-datepicker #DatePicker></mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (change)=\"setDatTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "pipe", type: GenerateErrorMessagesPipe, name: "generateErrorMessages" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }] }); }
|
|
72
95
|
}
|
|
73
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, decorators: [{
|
|
74
97
|
type: Component,
|
|
75
98
|
args: [{ selector: 'i-tech-date-time-picker', imports: [MatDatepickerModule, NgxMaskDirective, DateMaskDirective, TranslateModule,
|
|
76
99
|
FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError
|
|
77
|
-
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"
|
|
100
|
+
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (selectionchange)=\"dateChange(dateElement)\"\n >\n <mat-datepicker #DatePicker></mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (change)=\"setDatTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n" }]
|
|
78
101
|
}], ctorParameters: () => [{ type: i1.InputService }, { type: i2.ParseDateService }], propDecorators: { dateChangeEvent: [{
|
|
79
102
|
type: Output
|
|
80
103
|
}], label: [{
|
|
@@ -83,5 +106,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
83
106
|
type: Input
|
|
84
107
|
}], required: [{
|
|
85
108
|
type: Input
|
|
109
|
+
}], disabled: [{
|
|
110
|
+
type: Input
|
|
86
111
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAEL,WAAW,EACX,mBAAmB,EACnB,kBAAkB,EAClB,gBAAgB,EACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAErE,OAAO,EAAE,yBAAyB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;AAYrF,MAAM,OAAO,uBAAuB;IAYlC,YACY,YAA0B,EAC1B,gBAAkC;QADlC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAbpC,oBAAe,GAAG,IAAI,YAAY,EAAQ,CAAC;QAE5C,WAAM,GAAG,KAAK,CAAC;QACf,aAAQ,GAAG,KAAK,CAAC;QAC1B,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAG,IAAI,gBAAgB,CAAC;YAC1B,IAAI,EAAE,IAAI,kBAAkB,EAAE;YAC9B,IAAI,EAAE,IAAI,kBAAkB,EAAE;SAC/B,CAAC,CAAA;QAOA,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;IACvD,CAAC;IAED,eAAe;QACb,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YACjD,IAAI,CAAC,QAAQ,EAAE,CAAA;QACjB,CAAC,CAAC,CAAA;IACJ,CAAC;IAEO,QAAQ;QACd,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QACD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACnB,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,QAAQ,EAAC,YAAY,CAAC,GAAG,GAAG,GAAG,UAAU,CAAC;YAC5F,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,QAAQ,EAAC,OAAO,CAAC;SAC3D,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;IAC1B,CAAC;IAEM,UAAU,CAAC,SAA2B;QAC3C,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACrB,SAAS,CAAC,KAAK,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAA;IACxB,CAAC;IAEM,eAAe;QACpB,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACjD,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAG,YAAY,CAAC,CAAC;YACrF,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAClC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAC7E,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAChE,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAA;IAC7B,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;+GA7DU,uBAAuB;mGAAvB,uBAAuB,2LAJvB,CAAC,gBAAgB,CAAC,0BCxB/B,iwCAmCA,mzBDfY,mBAAmB,+TAAmB,iBAAiB,iHAAE,eAAe,2FAChF,WAAW,mjBAAE,OAAO,mFAAE,mBAAmB,gVAAE,QAAQ,iDAAE,yBAAyB,8DAAE,IAAI,6FAAE,QAAQ;;4FAOrF,uBAAuB;kBAVnC,SAAS;+BACE,yBAAyB,WAC1B,CAAC,mBAAmB,EAAE,gBAAgB,EAAC,iBAAiB,EAAE,eAAe;wBAChF,WAAW,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,yBAAyB,EAAE,IAAI,EAAE,QAAQ;qBAC/F,cACW,IAAI,aACL,CAAC,gBAAgB,CAAC;gHAKnB,eAAe;sBAAxB,MAAM;gBACE,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,QAAQ;sBAAhB,KAAK","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDatepickerModule } from \"@angular/material/datepicker\";\nimport { NgxMaskDirective } from \"ngx-mask\";\nimport {\n  FormControlName,\n  FormsModule,\n  ReactiveFormsModule,\n  UntypedFormControl,\n  UntypedFormGroup\n} from \"@angular/forms\";\nimport { NgClass, NgIf } from \"@angular/common\";\nimport { MatError, MatLabel } from \"@angular/material/form-field\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { DateMaskDirective } from \"../../directives/date-mask.directive\";\nimport { ParseDateService } from \"../../services/parse-date.service\";\nimport { InputService } from \"../../services/input.service\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\n\n@Component({\n  selector: 'i-tech-date-time-picker',\n  imports: [MatDatepickerModule, NgxMaskDirective,DateMaskDirective, TranslateModule,\n    FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError\n  ],\n  standalone: true,\n  providers: [ParseDateService],\n  templateUrl: './date-time-picker.component.html',\n  styleUrl: './date-time-picker.component.scss'\n})\nexport class DateTimePickerComponent implements AfterViewInit {\n  @Output() dateChangeEvent = new EventEmitter<void>();\n  @Input() label!: string;\n  @Input() submit = false;\n  @Input() required = false;\n  isFocused = false;\n  form = new UntypedFormGroup({\n    time: new UntypedFormControl(),\n    date: new UntypedFormControl(),\n  })\n  ngControl: FormControlName;\n\n  constructor(\n      private inputService: InputService,\n      private parseDateService: ParseDateService\n  ) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngAfterViewInit(): void {\n    this.setValue();\n    this.ngControl.control.valueChanges.subscribe(() => {\n      this.setValue()\n    })\n  }\n\n  private setValue(): void {\n    if (!this.ngControl?.control) {\n      return;\n    }\n    const dateTime = this.ngControl.control.value;\n    this.form.patchValue({\n      date: new Date(this.parseDateService.changeFormat(dateTime,'YYYY-MM-DD') + 'T' + '00:00:00'),\n      time: this.parseDateService.changeFormat(dateTime,'HH:mm')\n    }, { emitEvent: false })\n  }\n\n  public dateChange(timeInput: HTMLInputElement): void {\n    if (!timeInput.value) {\n      timeInput.focus();\n    }\n    this.setDatTimeValue()\n  }\n\n  public setDatTimeValue(): void {\n    if (this.form.value.date && this.form.value.time) {\n      const date = this.parseDateService.changeFormat(this.form.value.date , 'YYYY-MM-DD');\n      const time = this.form.value.time;\n      this.ngControl.control.patchValue(date + 'T' + time, { emitEvent: false });\n    } else {\n      this.ngControl.control.patchValue(null, { emitEvent: false });\n    }\n    this.dateChangeEvent.emit()\n  }\n\n  public onFocus(): void {\n    this.isFocused = true;\n  }\n\n  public onBlur(): void {\n    this.isFocused = false;\n  }\n}\n","<div class=\"date_time_picker_container\"\n     *ngIf=\"ngControl?.control\"\n     [class.readonly_field]=\"ngControl.control.disabled\"\n>\n    <mat-label>{{label | translate}}</mat-label>\n    <span *ngIf=\"required\" class=\"required-input\"> *</span>\n\n    <div class=\"date_time_picker\"\n         [formGroup]=\"form\"\n         [ngClass]=\"{'focused': isFocused}\"\n    >\n        <input type=\"text\" dateMask class=\"date\"\n               placeholder=\"mm/dd/yy\"\n               formControlName=\"date\"\n               [matDatepicker]=\"DatePicker\"\n               (click)=\"DatePicker.open()\"\n               (focus)=\"onFocus()\"\n               (blur)=\"onBlur()\"\n               (selectionchange)=\"dateChange(dateElement)\"\n        >\n        <mat-datepicker #DatePicker></mat-datepicker>\n        <input type=\"time\"\n               #dateElement\n               class=\"time\"\n               formControlName=\"time\"\n               (focus)=\"onFocus()\"\n               (blur)=\"onBlur()\"\n               (change)=\"setDatTimeValue()\"\n        />\n    </div>\n    <!-- Error Messages -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n        {{ngControl.control | generateErrorMessages : (label || '')}}\n    </mat-error>\n</div>\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDatepickerModule } from \"@angular/material/datepicker\";\nimport { NgxMaskDirective } from \"ngx-mask\";\nimport {\n  FormControlName,\n  FormsModule,\n  ReactiveFormsModule,\n  UntypedFormControl,\n  UntypedFormGroup\n} from \"@angular/forms\";\nimport { NgClass, NgIf } from \"@angular/common\";\nimport { MatError, MatLabel } from \"@angular/material/form-field\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { DateMaskDirective } from \"../../directives/date-mask.directive\";\nimport { ParseDateService } from \"../../services/parse-date.service\";\nimport { InputService } from \"../../services/input.service\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\n\n@Component({\n  selector: 'i-tech-date-time-picker',\n  imports: [MatDatepickerModule, NgxMaskDirective,DateMaskDirective, TranslateModule,\n    FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError\n  ],\n  standalone: true,\n  providers: [ParseDateService],\n  templateUrl: './date-time-picker.component.html',\n  styleUrl: './date-time-picker.component.scss'\n})\nexport class DateTimePickerComponent implements AfterViewInit {\n  @Output() dateChangeEvent = new EventEmitter<void>();\n  @Input() label!: string;\n  @Input() submit = false;\n  @Input() required = false;\n  @Input() set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    if (disabled) {\n      this.form.get('time')?.disable();\n      this.form.get('date')?.disable();\n    } else {\n      this.form.get('time')?.enable();\n      this.form.get('date')?.enable();\n    }\n  };\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  private _disabled = false;\n\n  isFocused = false;\n  form = new UntypedFormGroup({\n    time: new UntypedFormControl(),\n    date: new UntypedFormControl(),\n  })\n  ngControl: FormControlName;\n\n  constructor(\n      private inputService: InputService,\n      private parseDateService: ParseDateService\n  ) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngAfterViewInit(): void {\n    this.setValue();\n    this.ngControl.control.valueChanges.subscribe(() => {\n      this.setValue()\n    })\n  }\n\n  private setValue(): void {\n    if (!this.ngControl?.control) {\n      return;\n    }\n    const dateTime = this.ngControl.control.value;\n    if (!dateTime) {\n      this.form.patchValue({\n        date: null,\n        time: null\n      }, { emitEvent: false });\n      return;\n    }\n\n    this.form.patchValue({\n      date: new Date(this.parseDateService.changeFormat(dateTime,'YYYY-MM-DD') + 'T' + '00:00:00'),\n      time: this.parseDateService.changeFormat(dateTime,'HH:mm')\n    }, { emitEvent: false })\n  }\n\n  public dateChange(timeInput: HTMLInputElement): void {\n    if (!timeInput.value) {\n      timeInput.focus();\n    }\n    this.setDatTimeValue()\n  }\n\n  public setDatTimeValue(): void {\n    if (this.form.value.date && this.form.value.time) {\n      const date = this.parseDateService.changeFormat(this.form.value.date , 'YYYY-MM-DD');\n      const time = this.form.value.time;\n      this.ngControl.control.patchValue(date + 'T' + time, { emitEvent: false });\n    } else {\n      this.ngControl.control.patchValue(null, { emitEvent: false });\n    }\n    this.dateChangeEvent.emit()\n  }\n\n  public onFocus(): void {\n    this.isFocused = true;\n  }\n\n  public onBlur(): void {\n    this.isFocused = false;\n  }\n}\n","<div class=\"date_time_picker_container\"\n     *ngIf=\"ngControl?.control\"\n     [class.readonly_field]=\"disabled\"\n>\n    <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n    <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n    <div class=\"date_time_picker\"\n         [formGroup]=\"form\"\n         [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n    >\n        <input type=\"text\" dateMask class=\"date\"\n               placeholder=\"mm/dd/yy\"\n               formControlName=\"date\"\n               [matDatepicker]=\"DatePicker\"\n               [disabled]=\"disabled\"\n               (click)=\"!disabled && DatePicker.open()\"\n               (focus)=\"onFocus()\"\n               (blur)=\"onBlur()\"\n               (selectionchange)=\"dateChange(dateElement)\"\n        >\n        <mat-datepicker #DatePicker></mat-datepicker>\n        <input type=\"time\"\n               #dateElement\n               class=\"time\"\n               formControlName=\"time\"\n               [disabled]=\"disabled\"\n               (focus)=\"onFocus()\"\n               (blur)=\"onBlur()\"\n               (change)=\"setDatTimeValue()\"\n        />\n    </div>\n    <!-- Error Messages -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n        {{ngControl.control | generateErrorMessages : (label || '')}}\n    </mat-error>\n</div>\n"]}
|
|
@@ -749,7 +749,6 @@ class AutocompleteSelectComponent {
|
|
|
749
749
|
if (this.searchInput) {
|
|
750
750
|
if (this.selectConfig.multiple) {
|
|
751
751
|
this.toggleShowingDataInSelectedOptionsMultipleCase(showingData);
|
|
752
|
-
this.searchInput?.nativeElement?.focus();
|
|
753
752
|
}
|
|
754
753
|
else {
|
|
755
754
|
this.inputFocusOut();
|
|
@@ -1398,12 +1397,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
1398
1397
|
}] } });
|
|
1399
1398
|
|
|
1400
1399
|
class DateTimePickerComponent {
|
|
1400
|
+
set disabled(disabled) {
|
|
1401
|
+
this._disabled = disabled;
|
|
1402
|
+
if (disabled) {
|
|
1403
|
+
this.form.get('time')?.disable();
|
|
1404
|
+
this.form.get('date')?.disable();
|
|
1405
|
+
}
|
|
1406
|
+
else {
|
|
1407
|
+
this.form.get('time')?.enable();
|
|
1408
|
+
this.form.get('date')?.enable();
|
|
1409
|
+
}
|
|
1410
|
+
}
|
|
1411
|
+
;
|
|
1412
|
+
get disabled() {
|
|
1413
|
+
return this._disabled;
|
|
1414
|
+
}
|
|
1401
1415
|
constructor(inputService, parseDateService) {
|
|
1402
1416
|
this.inputService = inputService;
|
|
1403
1417
|
this.parseDateService = parseDateService;
|
|
1404
1418
|
this.dateChangeEvent = new EventEmitter();
|
|
1405
1419
|
this.submit = false;
|
|
1406
1420
|
this.required = false;
|
|
1421
|
+
this._disabled = false;
|
|
1407
1422
|
this.isFocused = false;
|
|
1408
1423
|
this.form = new UntypedFormGroup({
|
|
1409
1424
|
time: new UntypedFormControl(),
|
|
@@ -1422,6 +1437,13 @@ class DateTimePickerComponent {
|
|
|
1422
1437
|
return;
|
|
1423
1438
|
}
|
|
1424
1439
|
const dateTime = this.ngControl.control.value;
|
|
1440
|
+
if (!dateTime) {
|
|
1441
|
+
this.form.patchValue({
|
|
1442
|
+
date: null,
|
|
1443
|
+
time: null
|
|
1444
|
+
}, { emitEvent: false });
|
|
1445
|
+
return;
|
|
1446
|
+
}
|
|
1425
1447
|
this.form.patchValue({
|
|
1426
1448
|
date: new Date(this.parseDateService.changeFormat(dateTime, 'YYYY-MM-DD') + 'T' + '00:00:00'),
|
|
1427
1449
|
time: this.parseDateService.changeFormat(dateTime, 'HH:mm')
|
|
@@ -1451,13 +1473,13 @@ class DateTimePickerComponent {
|
|
|
1451
1473
|
this.isFocused = false;
|
|
1452
1474
|
}
|
|
1453
1475
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: InputService }, { token: ParseDateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1454
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"
|
|
1476
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required", disabled: "disabled" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (selectionchange)=\"dateChange(dateElement)\"\n >\n <mat-datepicker #DatePicker></mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (change)=\"setDatTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3$1.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3$1.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "pipe", type: GenerateErrorMessagesPipe, name: "generateErrorMessages" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }] }); }
|
|
1455
1477
|
}
|
|
1456
1478
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, decorators: [{
|
|
1457
1479
|
type: Component,
|
|
1458
1480
|
args: [{ selector: 'i-tech-date-time-picker', imports: [MatDatepickerModule, NgxMaskDirective, DateMaskDirective, TranslateModule,
|
|
1459
1481
|
FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError
|
|
1460
|
-
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"
|
|
1482
|
+
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (selectionchange)=\"dateChange(dateElement)\"\n >\n <mat-datepicker #DatePicker></mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (change)=\"setDatTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n" }]
|
|
1461
1483
|
}], ctorParameters: () => [{ type: InputService }, { type: ParseDateService }], propDecorators: { dateChangeEvent: [{
|
|
1462
1484
|
type: Output
|
|
1463
1485
|
}], label: [{
|
|
@@ -1466,6 +1488,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
1466
1488
|
type: Input
|
|
1467
1489
|
}], required: [{
|
|
1468
1490
|
type: Input
|
|
1491
|
+
}], disabled: [{
|
|
1492
|
+
type: Input
|
|
1469
1493
|
}] } });
|
|
1470
1494
|
|
|
1471
1495
|
/*
|