nira-falcon 0.1.54 → 0.1.55

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.
@@ -82,6 +82,8 @@ export class CoreSelectComponent {
82
82
  this.inputFormControl.markAsTouched();
83
83
  this.isOpenMenu = false;
84
84
  if (!selectedItem) {
85
+ this.selectedItem = {};
86
+ this.inputFormControl.reset();
85
87
  return;
86
88
  }
87
89
  this.selectedItem = selectedItem;
@@ -132,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
132
134
  type: ViewChildren,
133
135
  args: ['focusable']
134
136
  }] } });
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-select.component.js","sourceRoot":"","sources":["../../../../../projects/falcon-lib/src/lib/core-select/core-select.component.ts","../../../../../projects/falcon-lib/src/lib/core-select/core-select-falcon.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAEL,MAAM,EAEN,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;;;;AAU7D,MAAM,OAAO,mBAAmB;IAY9B,IAAa,KAAK,CAAC,IAAS;QAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IACD,IAAa,YAAY,CAAC,IAAO;QAC/B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAQD,YAAoB,GAAsB,EAAU,KAAiB;QAAjD,QAAG,GAAH,GAAG,CAAmB;QAAU,UAAK,GAAL,KAAK,CAAY;QA1BrE,iBAAY,GAAgB,EAAiB,CAAC;QAG9C,aAAQ,GAAkB,EAAE,CAAC;QAC7B,eAAU,GAAG,KAAK,CAAC;QACnB,WAAM,GAAQ,EAAE,CAAC;QAIR,SAAI,GAAW,OAAO,CAAC;QACvB,2BAAsB,GAAG,KAAK,CAAC;QAS/B,UAAK,GAAW,EAAE,CAAC;QACnB,aAAQ,GAAY,KAAK,CAAC;QACzB,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,qBAAgB,GAAgB,IAAI,WAAW,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEjE,iBAAY,GAAG,CAAC,CAAC;IAEuD,CAAC;IACzE,IAAI;QAEF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAqB,CAAC;QACjD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAqB,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACnD,IAAI,CAAC,YAAY,CACf,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,EAC9D,KAAK,CACN,CAAC;IACJ,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,eAAe,CAAC,KAAY;QAC1B,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACxB,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;gBAChC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;aACjC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,QAAiB;QAC7B,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;QACnC,IAAI,IAAI,CAAC,UAAU,IAAI,QAAQ,EAAE;YAC/B,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;gBACjD,OAAO,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACnC,CAAC,EAAE,EAAE,CAAC,CAAC;SACR;IACH,CAAC;IACD,SAAS,CAAC,KAAoB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;QAElD,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC9D,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACnD;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE;YAC3B,IAAI,CAAC,YAAY;gBACf,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC9D,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACnD;IACH,CAAC;IAED,oBAAoB,CAAC,KAAU,EAAE,IAAS;QACxC,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;YACzB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SAC/B;aAAM,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;SACzB;IACH,CAAC;IAED,YAAY,CAAC,YAAqC,EAAE,QAAiB;QACnE,IAAI,QAAQ;YAAE,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;QACpD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE;YACjB,OAAO;SACR;QACD,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAC/B,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,YAAY,CAAC,KAAK,CAChE,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IACD,YAAY,CAAC,CAAM;QACjB,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE;YACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAC1B;IACH,CAAC;IACD,QAAQ,CAAC,KAAiB;QACxB,MAAM,kBAAkB,GAAG,KAAK,CAAC,aAA4B,CAAC;QAE9D,IACE,CAAC,kBAAkB;YACnB,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EACtD;YACA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;SACvC;IACH,CAAC;+GAjHU,mBAAmB;mGAAnB,mBAAmB,ubCtBhC,0+DAkEA;;4FD5Ca,mBAAmB;kBAL/B,SAAS;+BACE,aAAa;iIAYd,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACO,KAAK;sBAAjB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,cAAc;sBAAvB,MAAM;gBACE,gBAAgB;sBAAxB,KAAK;gBACqB,iBAAiB;sBAA3C,YAAY;uBAAC,WAAW","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { environment } from '../../environments/environment';\r\ntype MenuItem<T> = {\r\n  title: T;\r\n  value: T;\r\n};\r\n@Component({\r\n  selector: 'core-select',\r\n  templateUrl: './core-select' + environment.tempName,\r\n  styleUrls: ['./core-select' + environment.styleName],\r\n})\r\nexport class CoreSelectComponent<T> {\r\n  selectedItem: MenuItem<T> = {} as MenuItem<T>;\r\n  titleKeyObject!: keyof string | number;\r\n  valueKeyObject!: keyof string | number;\r\n  newItems: MenuItem<T>[] = [];\r\n  isOpenMenu = false;\r\n  _items: any = [];\r\n  _defaultValue!: T;\r\n  @Input() titleKey!: string;\r\n  @Input() valueKey!: string;\r\n  @Input() size: string = 'small';\r\n  @Input() canHighlightBackground = false;\r\n  @Input() set items(data: any) {\r\n    this._items = data;\r\n    this.init();\r\n  }\r\n  @Input() set defaultValue(data: T) {\r\n    this._defaultValue = data;\r\n    this.init();\r\n  }\r\n  @Input() label: string = '';\r\n  @Input() disabled: boolean = false;\r\n  @Output() onItemSelected = new EventEmitter<any>();\r\n  @Input() inputFormControl: FormControl = new FormControl('', []);\r\n  @ViewChildren('focusable') focusableElements!: QueryList<ElementRef>;\r\n  currentIndex = 0;\r\n\r\n  constructor(private cdr: ChangeDetectorRef, private elRef: ElementRef) {}\r\n  init() {\r\n    type ObjectKey = (typeof this._items)[0];\r\n    this.titleKeyObject = this.titleKey as ObjectKey;\r\n    this.valueKeyObject = this.valueKey as ObjectKey;\r\n    this.newItems = this.changeItemsType(this._items);\r\n    this.inputFormControl.setValue(this._defaultValue);\r\n    this.onItemSelect(\r\n      this.newItems.find((item) => item.value == this._defaultValue),\r\n      false\r\n    );\r\n  }\r\n  ngOnInit(): void {\r\n    this.init();\r\n  }\r\n\r\n  changeItemsType(items: any[]): MenuItem<T>[] {\r\n    return items.map((item) => {\r\n      return {\r\n        title: item[this.titleKeyObject],\r\n        value: item[this.valueKeyObject],\r\n      };\r\n    });\r\n  }\r\n\r\n  openMenuClick(canFocus: boolean) {\r\n    if (this.disabled) return;\r\n    this.isOpenMenu = !this.isOpenMenu;\r\n    if (this.isOpenMenu && canFocus) {\r\n      setTimeout(() => {\r\n        const element = this.focusableElements.toArray();\r\n        element[0].nativeElement.focus();\r\n      }, 50);\r\n    }\r\n  }\r\n  handleKey(event: KeyboardEvent) {\r\n    const elements = this.focusableElements.toArray();\r\n\r\n    if (event.key === 'ArrowDown') {\r\n      this.currentIndex = (this.currentIndex + 1) % elements.length;\r\n      elements[this.currentIndex].nativeElement.focus();\r\n    }\r\n\r\n    if (event.key === 'ArrowUp') {\r\n      this.currentIndex =\r\n        (this.currentIndex - 1 + elements.length) % elements.length;\r\n      elements[this.currentIndex].nativeElement.focus();\r\n    }\r\n  }\r\n\r\n  dropdownItemKeypress(event: any, item: any) {\r\n    if (event.key === 'Enter') {\r\n      this.onItemSelect(item, true);\r\n    } else if (event.key === 'Escape') {\r\n      this.isOpenMenu = false;\r\n    }\r\n  }\r\n\r\n  onItemSelect(selectedItem: MenuItem<T> | undefined, isFromUi: boolean): void {\r\n    if (isFromUi) this.inputFormControl.markAsTouched();\r\n    this.isOpenMenu = false;\r\n    if (!selectedItem) {\r\n      return;\r\n    }\r\n    this.selectedItem = selectedItem;\r\n    const mainItem = this._items.find(\r\n      (item: any) => item[this.valueKeyObject] === selectedItem.value\r\n    );\r\n    this.inputFormControl.setValue(selectedItem.value);\r\n    this.onItemSelected.emit(mainItem);\r\n  }\r\n  onEnterPress(e: any) {\r\n    if (e.key === 'Enter') {\r\n      this.openMenuClick(true);\r\n    }\r\n  }\r\n  focusOut(event: FocusEvent) {\r\n    const nextFocusedElement = event.relatedTarget as HTMLElement;\r\n\r\n    if (\r\n      !nextFocusedElement ||\r\n      !this.elRef.nativeElement.contains(nextFocusedElement)\r\n    ) {\r\n      this.isOpenMenu = false;\r\n      this.inputFormControl.markAsTouched();\r\n    }\r\n  }\r\n}\r\n","<div class=\"dropdown\" (focusout)=\"focusOut($event)\">\r\n  <div\r\n    class=\"select\"\r\n    [ngClass]=\"{\r\n      'select-clicked': isOpenMenu,\r\n      'highlight-background':\r\n        canHighlightBackground &&\r\n        (selectedItem | json) === ({} | json) &&\r\n        !(inputFormControl.touched && inputFormControl.errors),\r\n      selectError: inputFormControl.touched && inputFormControl.errors ,\r\n      'disable-selector': disabled,\r\n\r\n    }\"\r\n    tabindex=\"0\"\r\n    (keypress)=\"onEnterPress($event)\"\r\n    (click)=\"openMenuClick(false)\"\r\n  >\r\n    <span\r\n      class=\"placeholder-top\"\r\n      *ngIf=\"(selectedItem | json) != ({} | json)\"\r\n      >{{ label }}</span\r\n    >\r\n    <arrow-down-icon\r\n      class=\"caret fill-secondary-text-color h-6\"\r\n      [ngClass]=\"{ 'caret-rotate': isOpenMenu }\"\r\n    ></arrow-down-icon>\r\n\r\n    <span\r\n      [ngClass]=\"[\r\n        label.length > 0 && (selectedItem | json) == ({} | json)\r\n          ? 'placeholder'\r\n          : 'selected'\r\n      ]\"\r\n      >{{\r\n        label.length > 0 && (selectedItem | json) == ({} | json)\r\n          ? label\r\n          : selectedItem.title\r\n      }}</span\r\n    >\r\n  </div>\r\n  <ul\r\n    class=\"menu dropdown\"\r\n    (keydown)=\"handleKey($event)\"\r\n    [ngClass]=\"{ 'menu-open': isOpenMenu }\"\r\n  >\r\n    <li\r\n      *ngFor=\"let item of newItems\"\r\n      class=\"dropdown-item\"\r\n      #focusable\r\n      [ngClass]=\"{ active: item == selectedItem }\"\r\n      (click)=\"onItemSelect(item, true)\"\r\n      (keypress)=\"dropdownItemKeypress($event, item)\"\r\n      tabindex=\"0\"\r\n    >\r\n      {{ item.title }}\r\n    </li>\r\n  </ul>\r\n  <div class=\"label-error overflow-hidden\">\r\n    <span\r\n      *ngIf=\"\r\n       inputFormControl.touched  &&\r\n      inputFormControl.errors?.['required']\"\r\n      >این فیلد خالی است</span\r\n    >\r\n  </div>\r\n</div>\r\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-select.component.js","sourceRoot":"","sources":["../../../../../projects/falcon-lib/src/lib/core-select/core-select.component.ts","../../../../../projects/falcon-lib/src/lib/core-select/core-select-falcon.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAEL,MAAM,EAEN,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;;;;AAU7D,MAAM,OAAO,mBAAmB;IAY9B,IAAa,KAAK,CAAC,IAAS;QAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IACD,IAAa,YAAY,CAAC,IAAO;QAC/B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAQD,YAAoB,GAAsB,EAAU,KAAiB;QAAjD,QAAG,GAAH,GAAG,CAAmB;QAAU,UAAK,GAAL,KAAK,CAAY;QA1BrE,iBAAY,GAAgB,EAAiB,CAAC;QAG9C,aAAQ,GAAkB,EAAE,CAAC;QAC7B,eAAU,GAAG,KAAK,CAAC;QACnB,WAAM,GAAQ,EAAE,CAAC;QAIR,SAAI,GAAW,OAAO,CAAC;QACvB,2BAAsB,GAAG,KAAK,CAAC;QAS/B,UAAK,GAAW,EAAE,CAAC;QACnB,aAAQ,GAAY,KAAK,CAAC;QACzB,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,qBAAgB,GAAgB,IAAI,WAAW,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEjE,iBAAY,GAAG,CAAC,CAAC;IAEuD,CAAC;IACzE,IAAI;QAEF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAqB,CAAC;QACjD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAqB,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACnD,IAAI,CAAC,YAAY,CACf,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,EAC9D,KAAK,CACN,CAAC;IACJ,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,eAAe,CAAC,KAAY;QAC1B,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACxB,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;gBAChC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;aACjC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,QAAiB;QAC7B,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;QACnC,IAAI,IAAI,CAAC,UAAU,IAAI,QAAQ,EAAE;YAC/B,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;gBACjD,OAAO,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACnC,CAAC,EAAE,EAAE,CAAC,CAAC;SACR;IACH,CAAC;IACD,SAAS,CAAC,KAAoB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;QAElD,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC9D,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACnD;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE;YAC3B,IAAI,CAAC,YAAY;gBACf,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC9D,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACnD;IACH,CAAC;IAED,oBAAoB,CAAC,KAAU,EAAE,IAAS;QACxC,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;YACzB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SAC/B;aAAM,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;SACzB;IACH,CAAC;IAED,YAAY,CAAC,YAAqC,EAAE,QAAiB;QACnE,IAAI,QAAQ;YAAE,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;QACpD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE;YACjB,IAAI,CAAC,YAAY,GAAG,EAAiB,CAAC;YACtC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAC9B,OAAO;SACR;QACD,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAC/B,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,YAAY,CAAC,KAAK,CAChE,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IACD,YAAY,CAAC,CAAM;QACjB,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE;YACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAC1B;IACH,CAAC;IACD,QAAQ,CAAC,KAAiB;QACxB,MAAM,kBAAkB,GAAG,KAAK,CAAC,aAA4B,CAAC;QAE9D,IACE,CAAC,kBAAkB;YACnB,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EACtD;YACA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;SACvC;IACH,CAAC;+GAnHU,mBAAmB;mGAAnB,mBAAmB,ubCtBhC,0+DAkEA;;4FD5Ca,mBAAmB;kBAL/B,SAAS;+BACE,aAAa;iIAYd,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACO,KAAK;sBAAjB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAIG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,cAAc;sBAAvB,MAAM;gBACE,gBAAgB;sBAAxB,KAAK;gBACqB,iBAAiB;sBAA3C,YAAY;uBAAC,WAAW","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { environment } from '../../environments/environment';\r\ntype MenuItem<T> = {\r\n  title: T;\r\n  value: T;\r\n};\r\n@Component({\r\n  selector: 'core-select',\r\n  templateUrl: './core-select' + environment.tempName,\r\n  styleUrls: ['./core-select' + environment.styleName],\r\n})\r\nexport class CoreSelectComponent<T> {\r\n  selectedItem: MenuItem<T> = {} as MenuItem<T>;\r\n  titleKeyObject!: keyof string | number;\r\n  valueKeyObject!: keyof string | number;\r\n  newItems: MenuItem<T>[] = [];\r\n  isOpenMenu = false;\r\n  _items: any = [];\r\n  _defaultValue!: T;\r\n  @Input() titleKey!: string;\r\n  @Input() valueKey!: string;\r\n  @Input() size: string = 'small';\r\n  @Input() canHighlightBackground = false;\r\n  @Input() set items(data: any) {\r\n    this._items = data;\r\n    this.init();\r\n  }\r\n  @Input() set defaultValue(data: T) {\r\n    this._defaultValue = data;\r\n    this.init();\r\n  }\r\n  @Input() label: string = '';\r\n  @Input() disabled: boolean = false;\r\n  @Output() onItemSelected = new EventEmitter<any>();\r\n  @Input() inputFormControl: FormControl = new FormControl('', []);\r\n  @ViewChildren('focusable') focusableElements!: QueryList<ElementRef>;\r\n  currentIndex = 0;\r\n\r\n  constructor(private cdr: ChangeDetectorRef, private elRef: ElementRef) {}\r\n  init() {\r\n    type ObjectKey = (typeof this._items)[0];\r\n    this.titleKeyObject = this.titleKey as ObjectKey;\r\n    this.valueKeyObject = this.valueKey as ObjectKey;\r\n    this.newItems = this.changeItemsType(this._items);\r\n    this.inputFormControl.setValue(this._defaultValue);\r\n    this.onItemSelect(\r\n      this.newItems.find((item) => item.value == this._defaultValue),\r\n      false\r\n    );\r\n  }\r\n  ngOnInit(): void {\r\n    this.init();\r\n  }\r\n\r\n  changeItemsType(items: any[]): MenuItem<T>[] {\r\n    return items.map((item) => {\r\n      return {\r\n        title: item[this.titleKeyObject],\r\n        value: item[this.valueKeyObject],\r\n      };\r\n    });\r\n  }\r\n\r\n  openMenuClick(canFocus: boolean) {\r\n    if (this.disabled) return;\r\n    this.isOpenMenu = !this.isOpenMenu;\r\n    if (this.isOpenMenu && canFocus) {\r\n      setTimeout(() => {\r\n        const element = this.focusableElements.toArray();\r\n        element[0].nativeElement.focus();\r\n      }, 50);\r\n    }\r\n  }\r\n  handleKey(event: KeyboardEvent) {\r\n    const elements = this.focusableElements.toArray();\r\n\r\n    if (event.key === 'ArrowDown') {\r\n      this.currentIndex = (this.currentIndex + 1) % elements.length;\r\n      elements[this.currentIndex].nativeElement.focus();\r\n    }\r\n\r\n    if (event.key === 'ArrowUp') {\r\n      this.currentIndex =\r\n        (this.currentIndex - 1 + elements.length) % elements.length;\r\n      elements[this.currentIndex].nativeElement.focus();\r\n    }\r\n  }\r\n\r\n  dropdownItemKeypress(event: any, item: any) {\r\n    if (event.key === 'Enter') {\r\n      this.onItemSelect(item, true);\r\n    } else if (event.key === 'Escape') {\r\n      this.isOpenMenu = false;\r\n    }\r\n  }\r\n\r\n  onItemSelect(selectedItem: MenuItem<T> | undefined, isFromUi: boolean): void {\r\n    if (isFromUi) this.inputFormControl.markAsTouched();\r\n    this.isOpenMenu = false;\r\n    if (!selectedItem) {\r\n      this.selectedItem = {} as MenuItem<T>;\r\n      this.inputFormControl.reset();\r\n      return;\r\n    }\r\n    this.selectedItem = selectedItem;\r\n    const mainItem = this._items.find(\r\n      (item: any) => item[this.valueKeyObject] === selectedItem.value\r\n    );\r\n    this.inputFormControl.setValue(selectedItem.value);\r\n    this.onItemSelected.emit(mainItem);\r\n  }\r\n  onEnterPress(e: any) {\r\n    if (e.key === 'Enter') {\r\n      this.openMenuClick(true);\r\n    }\r\n  }\r\n  focusOut(event: FocusEvent) {\r\n    const nextFocusedElement = event.relatedTarget as HTMLElement;\r\n\r\n    if (\r\n      !nextFocusedElement ||\r\n      !this.elRef.nativeElement.contains(nextFocusedElement)\r\n    ) {\r\n      this.isOpenMenu = false;\r\n      this.inputFormControl.markAsTouched();\r\n    }\r\n  }\r\n}\r\n","<div class=\"dropdown\" (focusout)=\"focusOut($event)\">\r\n  <div\r\n    class=\"select\"\r\n    [ngClass]=\"{\r\n      'select-clicked': isOpenMenu,\r\n      'highlight-background':\r\n        canHighlightBackground &&\r\n        (selectedItem | json) === ({} | json) &&\r\n        !(inputFormControl.touched && inputFormControl.errors),\r\n      selectError: inputFormControl.touched && inputFormControl.errors ,\r\n      'disable-selector': disabled,\r\n\r\n    }\"\r\n    tabindex=\"0\"\r\n    (keypress)=\"onEnterPress($event)\"\r\n    (click)=\"openMenuClick(false)\"\r\n  >\r\n    <span\r\n      class=\"placeholder-top\"\r\n      *ngIf=\"(selectedItem | json) != ({} | json)\"\r\n      >{{ label }}</span\r\n    >\r\n    <arrow-down-icon\r\n      class=\"caret fill-secondary-text-color h-6\"\r\n      [ngClass]=\"{ 'caret-rotate': isOpenMenu }\"\r\n    ></arrow-down-icon>\r\n\r\n    <span\r\n      [ngClass]=\"[\r\n        label.length > 0 && (selectedItem | json) == ({} | json)\r\n          ? 'placeholder'\r\n          : 'selected'\r\n      ]\"\r\n      >{{\r\n        label.length > 0 && (selectedItem | json) == ({} | json)\r\n          ? label\r\n          : selectedItem.title\r\n      }}</span\r\n    >\r\n  </div>\r\n  <ul\r\n    class=\"menu dropdown\"\r\n    (keydown)=\"handleKey($event)\"\r\n    [ngClass]=\"{ 'menu-open': isOpenMenu }\"\r\n  >\r\n    <li\r\n      *ngFor=\"let item of newItems\"\r\n      class=\"dropdown-item\"\r\n      #focusable\r\n      [ngClass]=\"{ active: item == selectedItem }\"\r\n      (click)=\"onItemSelect(item, true)\"\r\n      (keypress)=\"dropdownItemKeypress($event, item)\"\r\n      tabindex=\"0\"\r\n    >\r\n      {{ item.title }}\r\n    </li>\r\n  </ul>\r\n  <div class=\"label-error overflow-hidden\">\r\n    <span\r\n      *ngIf=\"\r\n       inputFormControl.touched  &&\r\n      inputFormControl.errors?.['required']\"\r\n      >این فیلد خالی است</span\r\n    >\r\n  </div>\r\n</div>\r\n"]}
@@ -910,6 +910,8 @@ class CoreSelectComponent {
910
910
  this.inputFormControl.markAsTouched();
911
911
  this.isOpenMenu = false;
912
912
  if (!selectedItem) {
913
+ this.selectedItem = {};
914
+ this.inputFormControl.reset();
913
915
  return;
914
916
  }
915
917
  this.selectedItem = selectedItem;