@progressio_resources/gravity-design-system 3.5.0 → 3.5.2
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/gravity-dropdown-list/gravity-dropdown-list.component.mjs +2 -1
- package/esm2022/lib/components/gravity-push-notifications/gravity-push-notifications.component.mjs +3 -3
- package/fesm2022/progressio_resources-gravity-design-system.mjs +3 -2
- package/fesm2022/progressio_resources-gravity-design-system.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -258,6 +258,7 @@ export class GravityDropdownListComponent {
|
|
|
258
258
|
}
|
|
259
259
|
clearSelection() {
|
|
260
260
|
this.selectedItems = [];
|
|
261
|
+
this.networkConfig = null;
|
|
261
262
|
if (this.multiple) {
|
|
262
263
|
this.selectedItemsResponse.emit(this.selectedItems);
|
|
263
264
|
}
|
|
@@ -508,4 +509,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
508
509
|
type: HostListener,
|
|
509
510
|
args: ['document:click', ['$event']]
|
|
510
511
|
}] } });
|
|
511
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-dropdown-list.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Subscription} from \"rxjs\";\nimport {FilterByPipe} from \"./filter-by.pipe\";\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\nimport {GravityDropdownManagerService} from \"../../services/gravity-dropdown-manager.service\";\nimport {Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChange, SimpleChanges, ViewChild} from '@angular/core';\n\n@Component({\n  selector: 'gravity-dropdown-list',\n  templateUrl: './gravity-dropdown-list.component.html',\n  styleUrls: ['./gravity-dropdown-list.component.scss'],\n  providers: [FilterByPipe]\n})\nexport class GravityDropdownListComponent implements OnChanges, OnInit, OnDestroy {\n  // Component features\n  @Input() public label: string;\n  @Input() public iconLeft: string;\n  @Input() public items: Array<any>;\n  @Input() public cypressTag: string;\n  @Input() public placeholder: string;\n  @Input() public supportText: string;\n  @Input() public hasError: boolean = false;\n  @Input() public clearable: boolean = true;\n  @Input() public multiple: boolean = false;\n  @Input() public required: boolean = false;\n  @Input() public currentLang: string = 'en';\n  @Input() public isCurrency: boolean = false;\n  @Input() public isDisabled: boolean = false;\n  @Input() public isReadonly: boolean = false;\n  @Input() public customValues: Array<any> | any;\n  @Input() public config?: { label: string; value: string; };\n\n  // Appearance settings\n  @Input() public labelSize: 'sm' | 'md' | 'lg' = 'sm';\n  @Input() public size: 'sm' | 'md' | 'lg' | 'xl' = 'md';\n  @Input() public inputType: 'field' | 'label' = 'field';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n  @Input()\n  get dropdownState(): boolean {\n    return this.dropdownOpened;\n  }\n\n  set dropdownState(value: boolean) {\n    this.dropdownOpened = value;\n  }\n\n  @Output() dropdownStateChange = new EventEmitter<boolean>();\n  @Output('response') public selectedItemsResponse: EventEmitter<any[] | any> = new EventEmitter();\n\n  @ViewChild('searchInput')\n  set watch(searchInput: ElementRef<HTMLInputElement>) {\n    if (searchInput) {\n      searchInput.nativeElement.focus({preventScroll: true});\n    }\n  };\n\n  public searchText: string = '';\n  public selectedItems: any[] = [];\n  public isoConfig: string = 'iso';\n\tpublic nameConfig: string = 'name';\n  public availableOptions: any[] = [];\n  public dropdownOpened: boolean = false;\n  public openChildrenMap = new Map<any, boolean>();\n  public networkConfig: { label: string; iso: string; id: number; } = null;\n\n\tprivate dropdownManagerSubscription!: Subscription;\n\n\tconstructor(private dropdownService: GravityDropdownManagerService, private _eref: ElementRef) { }\n\n\tngOnInit() {\n\t\tthis.dropdownManagerSubscription = this.dropdownService.dropdownOpened$.subscribe(openedDropdown => {\n\t\t\tif (openedDropdown !== this && this.dropdownOpened) {\n\t\t\t\tthis.closeDropdown();\n\t\t\t}\n\t\t});\n\t}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']) {\n      const changeItem: SimpleChange = changes['customValues'];\n      const currentValue = changeItem?.currentValue;\n\n      const findOptionRecursively = (items: any[], value: any): any | null => {\n        for (const item of items) {\n          const itemValue = this.config ? item[this.config.value] : item;\n          if (itemValue == value) {\n            return item;\n          }\n\n          if (item.children) {\n            const foundChild = findOptionRecursively(item.children, value);\n            if (foundChild) return foundChild;\n          }\n        }\n        return null;\n      };\n\n      this.selectedItems = [];\n\n      if (Array.isArray(currentValue)) {\n        currentValue.forEach((val: any) => {\n          const found = findOptionRecursively(this.items, val);\n          if (found && !this.selectedItems.includes(found)) {\n            this.selectedItems.push(found);\n          }\n        });\n      } else if (currentValue != null && currentValue !== '') {\n        const found = findOptionRecursively(this.items, currentValue);\n        if (found) {\n          this.selectedItems = [found];\n        }\n      } else if (!currentValue && !changeItem.firstChange) {\n        this.clearSelection();\n      }\n    }\n  }\n\n\tngOnDestroy() {\n\t\tif (this.dropdownManagerSubscription) {\n\t\t\tthis.dropdownManagerSubscription.unsubscribe();\n\t\t}\n\t}\n\n\tpublic getStatus(): string {\n    if (this.isDisabled) {\n      return 'disabled';\n    } else if (this.isReadonly) {\n      return 'readonly';\n    } else if (this.hasError) {\n      return 'error';\n    } else if (this.dropdownOpened) {\n      return 'open';\n    } else if (this.selectedItems.length > 0) {\n      return 'selected';\n    } else {\n      return 'active';\n    }\n  }\n\n  public isIconLeftNew(): boolean {\n    if (this.iconLeft) {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    }\n\n    return false;\n  }\n\n\tpublic toggleDropdown(): void {\n\t\tevent.stopPropagation();\n\t\tthis.networkConfig = null;\n\n\t\tif (!this.isDisabled && !this.isReadonly) {\n\t\t\tif (this.dropdownOpened) {\n\t\t\t\tthis.emitSelection();\n\t\t\t\tthis.searchText = '';\n\t\t\t\tthis.closeDropdown();\n\t\t\t} else {\n\t\t\t\tthis.openDropdown();\n\t\t\t\tthis.selectedItems?.forEach(sel => {\n\t\t\t\t\tthis.items?.forEach(parent => {\n\t\t\t\t\t\tif (parent.children?.includes(sel)) {\n\t\t\t\t\t\t\tthis.openChildrenMap.set(parent, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate emitSelection(): void {\n\t\tif (this.multiple) {\n\t\t\tif (this.selectedItems?.length > 0) {\n\t\t\t\tthis.selectedItemsResponse.emit(this.selectedItems);\n\t\t\t}\n\t\t} else {\n\t\t\tif (this.selectedItems[0]) {\n\t\t\t\tthis.selectedItemsResponse.emit(this.selectedItems[0]);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic selectItem(itemToAdd: any): void {\n    const isParent = !!itemToAdd.children;\n\n    if (this.multiple) {\n      const isSelected = this.checkIfSelected(itemToAdd);\n\n      if (isSelected) {\n        this.selectedItems = this.selectedItems.filter(i =>\n          (this.config ? i[this.config.value] : i) !==\n          (this.config ? itemToAdd[this.config.value] : itemToAdd)\n        );\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            this.selectedItems = this.selectedItems.filter(i => i !== child);\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const anySelected = parent.children.some(child => this.checkIfSelected(child));\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (!anySelected) {\n                this.selectedItems = this.selectedItems.filter(i => i !== parent);\n              } else if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n\n      } else {\n        this.selectedItems.push(itemToAdd);\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            if (!this.checkIfSelected(child)) {\n              this.selectedItems.push(child);\n            }\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n      }\n    } else {\n      this.selectedItems = [itemToAdd];\n      this.toggleDropdown();\n    }\n  }\n\n  public isPartiallySelected(item: any): boolean {\n    if (!item.children?.length) return false;\n\n    const selectedChildren = item.children.filter(child => this.checkIfSelected(child));\n    return selectedChildren.length > 0 && selectedChildren.length < item.children.length;\n  }\n\n  public checkIfSelected(item?: any): boolean {\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    if (item) {\n      return this.selectedItems.some(selected => getValue(selected) === getValue(item));\n    }\n\n    const flatten = this.flattenItems(this.availableOptions);\n    return flatten.length > 0 && flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n  }\n\n  public selectAllItems(event: MouseEvent): void {\n    event.stopPropagation();\n    const flatten = this.flattenItems(this.availableOptions);\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    const allSelected = flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n\n    if (allSelected) {\n      this.selectedItems = this.selectedItems.filter(selected =>\n        !flatten.some(option => getValue(selected) === getValue(option))\n      );\n    } else {\n      flatten.forEach(option => {\n        if (!this.selectedItems.some(selected => getValue(selected) === getValue(option))) {\n          this.selectedItems.push(option);\n        }\n      });\n    }\n  }\n\n  private flattenItems(items: any[]): any[] {\n    return items.reduce((acc, item) => {\n      acc.push(item);\n      if (item.children?.length) {\n        acc.push(...this.flattenItems(item.children));\n      }\n      return acc;\n    }, []);\n  }\n\n  public clearSelection(): void {\n    this.selectedItems = [];\n\n    if (this.multiple) {\n      this.selectedItemsResponse.emit(this.selectedItems);\n    } else {\n      this.selectedItemsResponse.emit(null);\n    }\n  }\n\n\tpublic filterItems(): void {\n\t\tconst search = this.searchText?.toLowerCase();\n\t\tthis.openChildrenMap.clear();\n\n\t\tif (!search) {\n\t\t\tthis.availableOptions = JSON.parse(JSON.stringify(this.items));\n\t\t\treturn;\n\t\t}\n\n\t\tconst filterRecursive = (items: any[]): any[] => {\n\t\t\tconst result = [];\n\n\t\t\titems.forEach(item => {\n\t\t\t\tconst hasChildren = !!item.children?.length;\n\n\t\t\t\tconst fieldsToSearch: any[] = [];\n\t\t\t\tif (this.config) {\n\t\t\t\t\tfieldsToSearch.push(item[this.isoConfig]);\n\t\t\t\t\tfieldsToSearch.push(item[this.nameConfig]);\n\n\t\t\t\t\tif(this.config.label) {\n\t\t\t\t\t\tfieldsToSearch.push(item[this.config.label]);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst match = fieldsToSearch.some(field =>\n\t\t\t\t\tfield?.toString().toLowerCase().includes(search)\n\t\t\t\t);\n\n\t\t\t\tlet filteredChildren: any[] = [];\n\t\t\t\tif (hasChildren) {\n\t\t\t\t\tfilteredChildren = filterRecursive(item.children);\n\t\t\t\t}\n\n\t\t\t\tconst includeItem = hasChildren ? filteredChildren.length > 0 : match;\n\n\t\t\t\tif (includeItem) {\n\t\t\t\t\tconst newItem = { ...item };\n\t\t\t\t\tif (filteredChildren.length > 0) {\n\t\t\t\t\t\tnewItem.children = filteredChildren;\n\t\t\t\t\t\tthis.openChildrenMap.set(newItem, true);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdelete newItem.children;\n\t\t\t\t\t}\n\t\t\t\t\tresult.push(newItem);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn result;\n\t\t};\n\n\t\tthis.availableOptions = filterRecursive(this.items);\n\t}\n\n\t@HostListener('document:click', ['$event']) onDocumentClick($event: PointerEvent): void {\n    if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {\n      if (this.multiple) {\n        this.selectedItemsResponse.emit(this.selectedItems);\n      } else {\n        if (this.selectedItems[0]) {\n          this.selectedItemsResponse.emit(this.selectedItems[0]);\n        }\n      }\n\n     this.closeDropdown();\n    }\n  }\n\n\tpublic openDropdown(): void {\n\t\tthis.dropdownOpened = true;\n\t\tthis.dropdownService.notifyDropdownOpened(this);\n\t\tthis.dropdownStateChange.emit(this.dropdownOpened);\n\t}\n\n\tpublic closeDropdown(): void {\n\t\tthis.searchText = '';\n\t\tthis.dropdownOpened = false;\n\t\tthis.availableOptions = this.items;\n\t\tthis.dropdownStateChange.emit(this.dropdownOpened);\n\t}\n\n  public getCurrencyIconSize(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'sm-16';\n      case 'lg':\n        return 'lg-32';\n      case 'xl':\n        return 'xl-40';\n      default:\n        return 'md-24';\n    }\n  }\n\n  public getSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-xxs';\n      case 'md':\n        return 'gravity-margin-right-xs';\n      case 'lg':\n        return 'gravity-margin-right-sm';\n      case 'xl':\n        return 'gravity-margin-right-md';\n      default:\n        return '';\n    }\n  }\n\n  public getMultilevelSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-md';\n      case 'md':\n        return 'gravity-margin-right-lg';\n      default:\n        return '';\n    }\n  }\n\n  public getLabelText(): string {\n    let result: string = '';\n    if (this.selectedItems.length === 0) {\n      result = this.label;\n    } else {\n      this.selectedItems.forEach((item, i) => {\n        let displayValue = this.config ? item[this.config.label] : item;\n        let separator = i !== this.selectedItems.length - 1 ? ',' : '';\n        result = result + displayValue + separator;\n      });\n    }\n    return result;\n  }\n\n  public isChildrenOpen(item: any): boolean {\n    return this.openChildrenMap.get(item) === true;\n  }\n\n  public toggleChildren(item: any, event: MouseEvent): void {\n    event.stopPropagation();\n    const current = this.openChildrenMap.get(item) || false;\n    this.openChildrenMap.set(item, !current);\n  }\n\n  public getDisplayValue(child: any, config?: { label: string }): string {\n    if (config?.label && typeof child === 'object' && child !== null) {\n      return child[config.label] ?? '';\n    }\n    return child ?? '';\n  }\n\n  public inputDisplayValue(): string {\n    if (!this.selectedItems?.length) return '';\n\n    const getValue = (item: any) => this.config ? item[this.config.value] : item;\n\n    const getLabel = (item: any): string => {\n      const baseLabel = this.config ? item[this.config.label] : item;\n\n      if (!this.multiple && item.network?.code && (item.network_id !== item.currency_id || item.children || item.is_ERC20)) {\n        this.networkConfig = {label: baseLabel, iso: item.network?.code, id: item.network_id}\n      }\n\n      return baseLabel;\n    };\n\n    if (!this.items?.length) {\n      return this.selectedItems.map(getLabel).join(', ');\n    }\n\n    const labels: string[] = [];\n\n    for (const parent of this.items) {\n      if (parent.children?.length) {\n        const allChildrenSelected = parent.children.every(child =>\n          this.selectedItems.some(sel => getValue(sel) === getValue(child))\n        );\n\n        if (allChildrenSelected) {\n          labels.push(getLabel(parent));\n        } else {\n          for (const child of parent.children) {\n            if (this.selectedItems.some(sel => getValue(sel) === getValue(child))) {\n              labels.push(getLabel(child));\n            }\n          }\n        }\n      } else if (this.selectedItems.some(sel => getValue(sel) === getValue(parent))) {\n        labels.push(getLabel(parent));\n      }\n    }\n\n    return this.truncate(labels);\n  }\n\n  private truncate(labels: string[]): string {\n    const maxItems = this.width === 'short' ? 3 : this.width === 'medium' ? 6 : 12;\n    if (labels.length <= maxItems) return labels.join(', ');\n    return labels.slice(0, maxItems).join(', ') + '...';\n  }\n\n  public clearSearch(): void {\n    this.searchText = '';\n    this.availableOptions = JSON.parse(JSON.stringify(this.items));\n  }\n\n  public preventTypingWhenLocked(event: KeyboardEvent, input: HTMLInputElement) {\n    const isLocked = !this.dropdownOpened || !this.items;\n\n    if (isLocked) {\n      if (event.key.length === 1 || event.key === 'Backspace' || event.key === 'Delete') {\n        event.preventDefault();\n      }\n\n      input.blur();\n    }\n  }\n}\n","<ng-container *ngIf=\"inputType === 'field'\">\n  <label class=\"hr-label sm-bold {{getStatus()}}\" *ngIf=\"label\">\n    {{ label }} <span *ngIf=\"required || hasError\">*</span>\n  </label>\n</ng-container>\n\n<div class=\"gravity-input-field {{inputType}}-{{labelSize}} {{size}} {{width}}-width {{getStatus()}}\"\n     [attr.data-cy]=\"cypressTag\" (click)=\"toggleDropdown();\">\n\n  <ng-container *ngIf=\"inputType === 'field'\">\n    <gravity-icon class=\"left\" [iconName]=\"iconLeft\" [iconSize]=\"isIconLeftNew() ? 'md-16' : null\"\n                  *ngIf=\"(iconLeft && !dropdownOpened) || (iconLeft && !items)\"></gravity-icon>\n\n    <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"\n                  *ngIf=\"(dropdownOpened && items)\"></gravity-icon>\n\n    <div *ngIf=\"!dropdownOpened && networkConfig\" class=\"network-pill\">\n      <span class=\"hr-label {{size}}-regular\">{{networkConfig.label}}</span>\n      <gravity-network-pill [disabled]=\"isDisabled\" [network]=\"{iso: networkConfig.iso, id: networkConfig.id}\"></gravity-network-pill>\n    </div>\n\n    <input *ngIf=\"!networkConfig || dropdownOpened\" autocomplete=\"off\"\n           class=\"hr-label {{size}}-regular {{getStatus()}}\"\n           (focus)=\"searchText = ''\" [class.locked]=\"!dropdownOpened || !items\"\n           (keydown)=\"preventTypingWhenLocked($event, searchInput)\"\n           (input)=\"filterItems(); dropdownOpened = true\"\n           [attr.data-cy]=\"cypressTag + '_search_input'\"\n           #searchInput\n           [ngModel]=\"(dropdownOpened && items) ? searchText : inputDisplayValue()\"\n           (ngModelChange)=\"searchText = $event\"\n           placeholder=\"{{(dropdownOpened && items) ? (currentLang == 'es' ? 'Buscar' : 'Search input') : (placeholder ? placeholder : label)}}\">\n\n    <gravity-icon class=\"right\" [iconName]=\"dropdownOpened ? 'arrow-up': 'arrow-down'\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"!isReadonly && searchText.length == 0\"></gravity-icon>\n\n    <gravity-icon class=\"right\" [iconName]=\"'unsuccess'\" (click)=\"clearSearch()\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"dropdownOpened && searchText.length > 0\"></gravity-icon>\n  </ng-container>\n\n  <ng-container *ngIf=\"inputType === 'label'\">\n    <gravity-dropdown-label (onClickLabel)=\"toggleDropdown()\" [label]=\"getLabelText()\"\n                            [size]=\"labelSize\" [isOpen]=\"dropdownOpened\">\n    </gravity-dropdown-label>\n  </ng-container>\n\n  <div class=\"dropdown-panel {{getStatus()}}\" (click)=\"$event.stopPropagation()\" *ngIf=\"items && dropdownOpened\"\n       [attr.data-cy]=\"cypressTag + '_panel'\">\n    <div class=\"search-input\" *ngIf=\"inputType === 'label'\">\n      <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"></gravity-icon>\n      <input autocomplete=\"off\" class=\"hr-label {{size}}-regular\" (input)=\"filterItems()\"\n             [attr.data-cy]=\"cypressTag + '_search_input'\" #searchInput\n             [(ngModel)]=\"searchText\" placeholder=\"{{currentLang == 'es' ? 'Buscar' : 'Search input'}}\">\n      <gravity-icon class=\"pointer reset-icon\" (click)=\"searchText = ''; filterItems()\" [iconName]=\"'unsuccess'\"\n                    [iconSize]=\"'sm-12'\" *ngIf=\"searchText?.length > 0\"></gravity-icon>\n    </div>\n\n    <div class=\"select-all\" *ngIf=\"multiple && availableOptions.length != 0\">\n      <gravity-checkbox [ngClass]=\"getSpacingClass(size)\"\n                        (click)=\"selectAllItems($event)\"\n                        [checked]=\"checkIfSelected()\"></gravity-checkbox>\n      <p class=\"hr-label {{size}}-regular\">{{ currentLang == 'es' ? 'Seleccionar todo' : 'Select all' }}</p>\n    </div>\n\n    <div class=\"items-container\">\n      <div class=\"items\">\n        <div class=\"item-container\" *ngFor=\"let item of availableOptions\"\n             [attr.data-cy]=\"isCurrency ? 'currency_option_' + item.currency_id : ''\">\n          <div class=\"hr-label item {{size}}-regular pointer\"\n               [class.selected]=\"checkIfSelected(item)\"\n               [class.partial]=\"isPartiallySelected(item)\"\n               (click)=\"item.children?.length ? multiple ? selectItem(item) : toggleChildren(item, $event) : selectItem(item)\">\n\n            <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getSpacingClass(size)\"\n              [isPartial]=\"isPartiallySelected(item)\"\n              [checked]=\"checkIfSelected(item)\">\n            </gravity-checkbox>\n\n            <gravity-currency-display-v2 *ngIf=\"isCurrency\"\n                [ngClass]=\"getSpacingClass(size)\"\n                [type]=\"item.type === 'FIAT' ? 'fiat-short' : 'short-hrz'\"\n                [currency]=\"{\n                    currency_name: item.name,\n                    currency_id: item.currency_id, currency_iso: item.iso,\n                    network_id: item.network?.id, network_iso: item.network?.code,\n                    pill_type: checkIfSelected(item) ? 'secondary' : 'primary'}\" >\n            </gravity-currency-display-v2>\n\n            <div *ngIf=\"!isCurrency\" [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(item, config) }}</div>\n\n            <gravity-icon style=\"margin-left: auto\" (click)=\"toggleChildren(item, $event)\"\n                          [iconName]=\"isChildrenOpen(item) ? 'arrow-up' : 'arrow-down'\"\n                          [iconSize]=\"'md-16'\" *ngIf=\"item.children?.length\"></gravity-icon>\n          </div>\n\n          <div class=\"item-children\" *ngIf=\"item.children?.length && isChildrenOpen(item)\">\n            <ng-container *ngFor=\"let child of item.children\">\n              <div class=\"hr-label item {{size}}-regular pointer\" [ngClass]=\"{'multiple' : multiple}\"\n                   [class.selected]=\"checkIfSelected(child)\"\n                   (click)=\"selectItem(child)\">\n                <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getMultilevelSpacingClass(size)\"\n                                  [checked]=\"checkIfSelected(child)\"></gravity-checkbox>\n                <gravity-currency *ngIf=\"isCurrency\" [ngClass]=\"getSpacingClass(size)\"\n                                  [size]=\"getCurrencyIconSize(size)\"\n                                  [currency]=\"{currency_id: child.currency_id}\"></gravity-currency>\n                <div [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(child, config) }}</div>\n                <gravity-network-pill *ngIf=\"isCurrency\" [type]=\"checkIfSelected(child) ? 'secondary' : 'primary'\"\n                                      [network]=\"{ iso: child.network?.code, id: child.network?.id }\"></gravity-network-pill>\n              </div>\n            </ng-container>\n          </div>\n        </div>\n        <div class=\"item-container\" *ngIf=\"availableOptions.length === 0\">\n          <div class=\"hr-label item {{size}}-bold no-results\">\n            {{ currentLang == 'es' ? 'Sin resultados encontrados' : 'No results found.' }}\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"dropdown-footer\" *ngIf=\"selectedItems.length > 0 && availableOptions.length !== 0\"\n         [class.not-clearable]=\"!clearable\">\n      <gravity-link *ngIf=\"clearable\"\n                    (click)=\"clearSelection()\"\n                    [fontClass]=\"'hr-label sm-regular'\"\n                    [attr.data-cy]=\"cypressTag + '_clear'\"\n                    [linkText]=\"currentLang == 'es' ? 'Limpiar' : 'Clear selection'\">\n      </gravity-link>\n\n      <gravity-link *ngIf=\"availableOptions.length != 0\"\n                    [fontClass]=\"'hr-label sm-bold'\"\n                    [attr.data-cy]=\"cypressTag + '_apply'\"\n                    (click)=\"$event.stopPropagation(); toggleDropdown()\"\n                    [linkText]=\"currentLang == 'es' ? 'Aplicar' : 'Apply'\">\n      </gravity-link>\n    </div>\n    <div class=\"dropdown-footer no-results\" *ngIf=\"availableOptions.length === 0\" [class.not-clearable]=\"!clearable\">\n      <gravity-link *ngIf=\"clearable\"\n                    (click)=\"clearSearch()\"\n                    [fontClass]=\"'hr-label sm-regular'\"\n                    [attr.data-cy]=\"cypressTag + '_clear_search'\"\n                    [linkText]=\"currentLang == 'es' ? 'Limpiar búsqueda' : 'Clear search'\">\n      </gravity-link>\n    </div>\n  </div>\n\n  <section class=\"external-content\" *ngIf=\"!items && dropdownOpened\" (click)=\"$event.stopPropagation()\">\n    <ng-content></ng-content>\n  </section>\n</div>\n\n<ng-container *ngIf=\"inputType === 'field'\">\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\" *ngIf=\"supportText\">\n    {{ supportText }}\n  </p>\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\"\n     *ngIf=\"!supportText && getStatus() == 'active' && selectedItems.length == 0 && required\">\n    {{ currentLang == 'es' ? 'Requerido' : 'Required' }}\n  </p>\n</ng-container>"]}
|
|
512
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-dropdown-list.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Subscription} from \"rxjs\";\nimport {FilterByPipe} from \"./filter-by.pipe\";\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\nimport {GravityDropdownManagerService} from \"../../services/gravity-dropdown-manager.service\";\nimport {Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChange, SimpleChanges, ViewChild} from '@angular/core';\n\n@Component({\n  selector: 'gravity-dropdown-list',\n  templateUrl: './gravity-dropdown-list.component.html',\n  styleUrls: ['./gravity-dropdown-list.component.scss'],\n  providers: [FilterByPipe]\n})\nexport class GravityDropdownListComponent implements OnChanges, OnInit, OnDestroy {\n  // Component features\n  @Input() public label: string;\n  @Input() public iconLeft: string;\n  @Input() public items: Array<any>;\n  @Input() public cypressTag: string;\n  @Input() public placeholder: string;\n  @Input() public supportText: string;\n  @Input() public hasError: boolean = false;\n  @Input() public clearable: boolean = true;\n  @Input() public multiple: boolean = false;\n  @Input() public required: boolean = false;\n  @Input() public currentLang: string = 'en';\n  @Input() public isCurrency: boolean = false;\n  @Input() public isDisabled: boolean = false;\n  @Input() public isReadonly: boolean = false;\n  @Input() public customValues: Array<any> | any;\n  @Input() public config?: { label: string; value: string; };\n\n  // Appearance settings\n  @Input() public labelSize: 'sm' | 'md' | 'lg' = 'sm';\n  @Input() public size: 'sm' | 'md' | 'lg' | 'xl' = 'md';\n  @Input() public inputType: 'field' | 'label' = 'field';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n  @Input()\n  get dropdownState(): boolean {\n    return this.dropdownOpened;\n  }\n\n  set dropdownState(value: boolean) {\n    this.dropdownOpened = value;\n  }\n\n  @Output() dropdownStateChange = new EventEmitter<boolean>();\n  @Output('response') public selectedItemsResponse: EventEmitter<any[] | any> = new EventEmitter();\n\n  @ViewChild('searchInput')\n  set watch(searchInput: ElementRef<HTMLInputElement>) {\n    if (searchInput) {\n      searchInput.nativeElement.focus({preventScroll: true});\n    }\n  };\n\n  public searchText: string = '';\n  public selectedItems: any[] = [];\n  public isoConfig: string = 'iso';\n\tpublic nameConfig: string = 'name';\n  public availableOptions: any[] = [];\n  public dropdownOpened: boolean = false;\n  public openChildrenMap = new Map<any, boolean>();\n  public networkConfig: { label: string; iso: string; id: number; } = null;\n\n\tprivate dropdownManagerSubscription!: Subscription;\n\n\tconstructor(private dropdownService: GravityDropdownManagerService, private _eref: ElementRef) { }\n\n\tngOnInit() {\n\t\tthis.dropdownManagerSubscription = this.dropdownService.dropdownOpened$.subscribe(openedDropdown => {\n\t\t\tif (openedDropdown !== this && this.dropdownOpened) {\n\t\t\t\tthis.closeDropdown();\n\t\t\t}\n\t\t});\n\t}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']) {\n      const changeItem: SimpleChange = changes['customValues'];\n      const currentValue = changeItem?.currentValue;\n\n      const findOptionRecursively = (items: any[], value: any): any | null => {\n        for (const item of items) {\n          const itemValue = this.config ? item[this.config.value] : item;\n          if (itemValue == value) {\n            return item;\n          }\n\n          if (item.children) {\n            const foundChild = findOptionRecursively(item.children, value);\n            if (foundChild) return foundChild;\n          }\n        }\n        return null;\n      };\n\n      this.selectedItems = [];\n\n      if (Array.isArray(currentValue)) {\n        currentValue.forEach((val: any) => {\n          const found = findOptionRecursively(this.items, val);\n          if (found && !this.selectedItems.includes(found)) {\n            this.selectedItems.push(found);\n          }\n        });\n      } else if (currentValue != null && currentValue !== '') {\n        const found = findOptionRecursively(this.items, currentValue);\n        if (found) {\n          this.selectedItems = [found];\n        }\n      } else if (!currentValue && !changeItem.firstChange) {\n        this.clearSelection();\n      }\n    }\n  }\n\n\tngOnDestroy() {\n\t\tif (this.dropdownManagerSubscription) {\n\t\t\tthis.dropdownManagerSubscription.unsubscribe();\n\t\t}\n\t}\n\n\tpublic getStatus(): string {\n    if (this.isDisabled) {\n      return 'disabled';\n    } else if (this.isReadonly) {\n      return 'readonly';\n    } else if (this.hasError) {\n      return 'error';\n    } else if (this.dropdownOpened) {\n      return 'open';\n    } else if (this.selectedItems.length > 0) {\n      return 'selected';\n    } else {\n      return 'active';\n    }\n  }\n\n  public isIconLeftNew(): boolean {\n    if (this.iconLeft) {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    }\n\n    return false;\n  }\n\n\tpublic toggleDropdown(): void {\n\t\tevent.stopPropagation();\n\t\tthis.networkConfig = null;\n\n\t\tif (!this.isDisabled && !this.isReadonly) {\n\t\t\tif (this.dropdownOpened) {\n\t\t\t\tthis.emitSelection();\n\t\t\t\tthis.searchText = '';\n\t\t\t\tthis.closeDropdown();\n\t\t\t} else {\n\t\t\t\tthis.openDropdown();\n\t\t\t\tthis.selectedItems?.forEach(sel => {\n\t\t\t\t\tthis.items?.forEach(parent => {\n\t\t\t\t\t\tif (parent.children?.includes(sel)) {\n\t\t\t\t\t\t\tthis.openChildrenMap.set(parent, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate emitSelection(): void {\n\t\tif (this.multiple) {\n\t\t\tif (this.selectedItems?.length > 0) {\n\t\t\t\tthis.selectedItemsResponse.emit(this.selectedItems);\n\t\t\t}\n\t\t} else {\n\t\t\tif (this.selectedItems[0]) {\n\t\t\t\tthis.selectedItemsResponse.emit(this.selectedItems[0]);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic selectItem(itemToAdd: any): void {\n    const isParent = !!itemToAdd.children;\n\n    if (this.multiple) {\n      const isSelected = this.checkIfSelected(itemToAdd);\n\n      if (isSelected) {\n        this.selectedItems = this.selectedItems.filter(i =>\n          (this.config ? i[this.config.value] : i) !==\n          (this.config ? itemToAdd[this.config.value] : itemToAdd)\n        );\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            this.selectedItems = this.selectedItems.filter(i => i !== child);\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const anySelected = parent.children.some(child => this.checkIfSelected(child));\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (!anySelected) {\n                this.selectedItems = this.selectedItems.filter(i => i !== parent);\n              } else if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n\n      } else {\n        this.selectedItems.push(itemToAdd);\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            if (!this.checkIfSelected(child)) {\n              this.selectedItems.push(child);\n            }\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n      }\n    } else {\n      this.selectedItems = [itemToAdd];\n      this.toggleDropdown();\n    }\n  }\n\n  public isPartiallySelected(item: any): boolean {\n    if (!item.children?.length) return false;\n\n    const selectedChildren = item.children.filter(child => this.checkIfSelected(child));\n    return selectedChildren.length > 0 && selectedChildren.length < item.children.length;\n  }\n\n  public checkIfSelected(item?: any): boolean {\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    if (item) {\n      return this.selectedItems.some(selected => getValue(selected) === getValue(item));\n    }\n\n    const flatten = this.flattenItems(this.availableOptions);\n    return flatten.length > 0 && flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n  }\n\n  public selectAllItems(event: MouseEvent): void {\n    event.stopPropagation();\n    const flatten = this.flattenItems(this.availableOptions);\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    const allSelected = flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n\n    if (allSelected) {\n      this.selectedItems = this.selectedItems.filter(selected =>\n        !flatten.some(option => getValue(selected) === getValue(option))\n      );\n    } else {\n      flatten.forEach(option => {\n        if (!this.selectedItems.some(selected => getValue(selected) === getValue(option))) {\n          this.selectedItems.push(option);\n        }\n      });\n    }\n  }\n\n  private flattenItems(items: any[]): any[] {\n    return items.reduce((acc, item) => {\n      acc.push(item);\n      if (item.children?.length) {\n        acc.push(...this.flattenItems(item.children));\n      }\n      return acc;\n    }, []);\n  }\n\n  public clearSelection(): void {\n    this.selectedItems = [];\n\t\tthis.networkConfig = null;\n\n    if (this.multiple) {\n      this.selectedItemsResponse.emit(this.selectedItems);\n    } else {\n      this.selectedItemsResponse.emit(null);\n    }\n  }\n\n\tpublic filterItems(): void {\n\t\tconst search = this.searchText?.toLowerCase();\n\t\tthis.openChildrenMap.clear();\n\n\t\tif (!search) {\n\t\t\tthis.availableOptions = JSON.parse(JSON.stringify(this.items));\n\t\t\treturn;\n\t\t}\n\n\t\tconst filterRecursive = (items: any[]): any[] => {\n\t\t\tconst result = [];\n\n\t\t\titems.forEach(item => {\n\t\t\t\tconst hasChildren = !!item.children?.length;\n\n\t\t\t\tconst fieldsToSearch: any[] = [];\n\t\t\t\tif (this.config) {\n\t\t\t\t\tfieldsToSearch.push(item[this.isoConfig]);\n\t\t\t\t\tfieldsToSearch.push(item[this.nameConfig]);\n\n\t\t\t\t\tif(this.config.label) {\n\t\t\t\t\t\tfieldsToSearch.push(item[this.config.label]);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst match = fieldsToSearch.some(field =>\n\t\t\t\t\tfield?.toString().toLowerCase().includes(search)\n\t\t\t\t);\n\n\t\t\t\tlet filteredChildren: any[] = [];\n\t\t\t\tif (hasChildren) {\n\t\t\t\t\tfilteredChildren = filterRecursive(item.children);\n\t\t\t\t}\n\n\t\t\t\tconst includeItem = hasChildren ? filteredChildren.length > 0 : match;\n\n\t\t\t\tif (includeItem) {\n\t\t\t\t\tconst newItem = { ...item };\n\t\t\t\t\tif (filteredChildren.length > 0) {\n\t\t\t\t\t\tnewItem.children = filteredChildren;\n\t\t\t\t\t\tthis.openChildrenMap.set(newItem, true);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdelete newItem.children;\n\t\t\t\t\t}\n\t\t\t\t\tresult.push(newItem);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn result;\n\t\t};\n\n\t\tthis.availableOptions = filterRecursive(this.items);\n\t}\n\n\t@HostListener('document:click', ['$event']) onDocumentClick($event: PointerEvent): void {\n    if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {\n      if (this.multiple) {\n        this.selectedItemsResponse.emit(this.selectedItems);\n      } else {\n        if (this.selectedItems[0]) {\n          this.selectedItemsResponse.emit(this.selectedItems[0]);\n        }\n      }\n\n     this.closeDropdown();\n    }\n  }\n\n\tpublic openDropdown(): void {\n\t\tthis.dropdownOpened = true;\n\t\tthis.dropdownService.notifyDropdownOpened(this);\n\t\tthis.dropdownStateChange.emit(this.dropdownOpened);\n\t}\n\n\tpublic closeDropdown(): void {\n\t\tthis.searchText = '';\n\t\tthis.dropdownOpened = false;\n\t\tthis.availableOptions = this.items;\n\t\tthis.dropdownStateChange.emit(this.dropdownOpened);\n\t}\n\n  public getCurrencyIconSize(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'sm-16';\n      case 'lg':\n        return 'lg-32';\n      case 'xl':\n        return 'xl-40';\n      default:\n        return 'md-24';\n    }\n  }\n\n  public getSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-xxs';\n      case 'md':\n        return 'gravity-margin-right-xs';\n      case 'lg':\n        return 'gravity-margin-right-sm';\n      case 'xl':\n        return 'gravity-margin-right-md';\n      default:\n        return '';\n    }\n  }\n\n  public getMultilevelSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-md';\n      case 'md':\n        return 'gravity-margin-right-lg';\n      default:\n        return '';\n    }\n  }\n\n  public getLabelText(): string {\n    let result: string = '';\n    if (this.selectedItems.length === 0) {\n      result = this.label;\n    } else {\n      this.selectedItems.forEach((item, i) => {\n        let displayValue = this.config ? item[this.config.label] : item;\n        let separator = i !== this.selectedItems.length - 1 ? ',' : '';\n        result = result + displayValue + separator;\n      });\n    }\n    return result;\n  }\n\n  public isChildrenOpen(item: any): boolean {\n    return this.openChildrenMap.get(item) === true;\n  }\n\n  public toggleChildren(item: any, event: MouseEvent): void {\n    event.stopPropagation();\n    const current = this.openChildrenMap.get(item) || false;\n    this.openChildrenMap.set(item, !current);\n  }\n\n  public getDisplayValue(child: any, config?: { label: string }): string {\n    if (config?.label && typeof child === 'object' && child !== null) {\n      return child[config.label] ?? '';\n    }\n    return child ?? '';\n  }\n\n  public inputDisplayValue(): string {\n    if (!this.selectedItems?.length) return '';\n\n    const getValue = (item: any) => this.config ? item[this.config.value] : item;\n\n    const getLabel = (item: any): string => {\n      const baseLabel = this.config ? item[this.config.label] : item;\n\n      if (!this.multiple && item.network?.code && (item.network_id !== item.currency_id || item.children || item.is_ERC20)) {\n        this.networkConfig = {label: baseLabel, iso: item.network?.code, id: item.network_id}\n      }\n\n      return baseLabel;\n    };\n\n    if (!this.items?.length) {\n      return this.selectedItems.map(getLabel).join(', ');\n    }\n\n    const labels: string[] = [];\n\n    for (const parent of this.items) {\n      if (parent.children?.length) {\n        const allChildrenSelected = parent.children.every(child =>\n          this.selectedItems.some(sel => getValue(sel) === getValue(child))\n        );\n\n        if (allChildrenSelected) {\n          labels.push(getLabel(parent));\n        } else {\n          for (const child of parent.children) {\n            if (this.selectedItems.some(sel => getValue(sel) === getValue(child))) {\n              labels.push(getLabel(child));\n            }\n          }\n        }\n      } else if (this.selectedItems.some(sel => getValue(sel) === getValue(parent))) {\n        labels.push(getLabel(parent));\n      }\n    }\n\n    return this.truncate(labels);\n  }\n\n  private truncate(labels: string[]): string {\n    const maxItems = this.width === 'short' ? 3 : this.width === 'medium' ? 6 : 12;\n    if (labels.length <= maxItems) return labels.join(', ');\n    return labels.slice(0, maxItems).join(', ') + '...';\n  }\n\n  public clearSearch(): void {\n    this.searchText = '';\n    this.availableOptions = JSON.parse(JSON.stringify(this.items));\n  }\n\n  public preventTypingWhenLocked(event: KeyboardEvent, input: HTMLInputElement) {\n    const isLocked = !this.dropdownOpened || !this.items;\n\n    if (isLocked) {\n      if (event.key.length === 1 || event.key === 'Backspace' || event.key === 'Delete') {\n        event.preventDefault();\n      }\n\n      input.blur();\n    }\n  }\n}\n","<ng-container *ngIf=\"inputType === 'field'\">\n  <label class=\"hr-label sm-bold {{getStatus()}}\" *ngIf=\"label\">\n    {{ label }} <span *ngIf=\"required || hasError\">*</span>\n  </label>\n</ng-container>\n\n<div class=\"gravity-input-field {{inputType}}-{{labelSize}} {{size}} {{width}}-width {{getStatus()}}\"\n     [attr.data-cy]=\"cypressTag\" (click)=\"toggleDropdown();\">\n\n  <ng-container *ngIf=\"inputType === 'field'\">\n    <gravity-icon class=\"left\" [iconName]=\"iconLeft\" [iconSize]=\"isIconLeftNew() ? 'md-16' : null\"\n                  *ngIf=\"(iconLeft && !dropdownOpened) || (iconLeft && !items)\"></gravity-icon>\n\n    <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"\n                  *ngIf=\"(dropdownOpened && items)\"></gravity-icon>\n\n    <div *ngIf=\"!dropdownOpened && networkConfig\" class=\"network-pill\">\n      <span class=\"hr-label {{size}}-regular\">{{networkConfig.label}}</span>\n      <gravity-network-pill [disabled]=\"isDisabled\" [network]=\"{iso: networkConfig.iso, id: networkConfig.id}\"></gravity-network-pill>\n    </div>\n\n    <input *ngIf=\"!networkConfig || dropdownOpened\" autocomplete=\"off\"\n           class=\"hr-label {{size}}-regular {{getStatus()}}\"\n           (focus)=\"searchText = ''\" [class.locked]=\"!dropdownOpened || !items\"\n           (keydown)=\"preventTypingWhenLocked($event, searchInput)\"\n           (input)=\"filterItems(); dropdownOpened = true\"\n           [attr.data-cy]=\"cypressTag + '_search_input'\"\n           #searchInput\n           [ngModel]=\"(dropdownOpened && items) ? searchText : inputDisplayValue()\"\n           (ngModelChange)=\"searchText = $event\"\n           placeholder=\"{{(dropdownOpened && items) ? (currentLang == 'es' ? 'Buscar' : 'Search input') : (placeholder ? placeholder : label)}}\">\n\n    <gravity-icon class=\"right\" [iconName]=\"dropdownOpened ? 'arrow-up': 'arrow-down'\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"!isReadonly && searchText.length == 0\"></gravity-icon>\n\n    <gravity-icon class=\"right\" [iconName]=\"'unsuccess'\" (click)=\"clearSearch()\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"dropdownOpened && searchText.length > 0\"></gravity-icon>\n  </ng-container>\n\n  <ng-container *ngIf=\"inputType === 'label'\">\n    <gravity-dropdown-label (onClickLabel)=\"toggleDropdown()\" [label]=\"getLabelText()\"\n                            [size]=\"labelSize\" [isOpen]=\"dropdownOpened\">\n    </gravity-dropdown-label>\n  </ng-container>\n\n  <div class=\"dropdown-panel {{getStatus()}}\" (click)=\"$event.stopPropagation()\" *ngIf=\"items && dropdownOpened\"\n       [attr.data-cy]=\"cypressTag + '_panel'\">\n    <div class=\"search-input\" *ngIf=\"inputType === 'label'\">\n      <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"></gravity-icon>\n      <input autocomplete=\"off\" class=\"hr-label {{size}}-regular\" (input)=\"filterItems()\"\n             [attr.data-cy]=\"cypressTag + '_search_input'\" #searchInput\n             [(ngModel)]=\"searchText\" placeholder=\"{{currentLang == 'es' ? 'Buscar' : 'Search input'}}\">\n      <gravity-icon class=\"pointer reset-icon\" (click)=\"searchText = ''; filterItems()\" [iconName]=\"'unsuccess'\"\n                    [iconSize]=\"'sm-12'\" *ngIf=\"searchText?.length > 0\"></gravity-icon>\n    </div>\n\n    <div class=\"select-all\" *ngIf=\"multiple && availableOptions.length != 0\">\n      <gravity-checkbox [ngClass]=\"getSpacingClass(size)\"\n                        (click)=\"selectAllItems($event)\"\n                        [checked]=\"checkIfSelected()\"></gravity-checkbox>\n      <p class=\"hr-label {{size}}-regular\">{{ currentLang == 'es' ? 'Seleccionar todo' : 'Select all' }}</p>\n    </div>\n\n    <div class=\"items-container\">\n      <div class=\"items\">\n        <div class=\"item-container\" *ngFor=\"let item of availableOptions\"\n             [attr.data-cy]=\"isCurrency ? 'currency_option_' + item.currency_id : ''\">\n          <div class=\"hr-label item {{size}}-regular pointer\"\n               [class.selected]=\"checkIfSelected(item)\"\n               [class.partial]=\"isPartiallySelected(item)\"\n               (click)=\"item.children?.length ? multiple ? selectItem(item) : toggleChildren(item, $event) : selectItem(item)\">\n\n            <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getSpacingClass(size)\"\n              [isPartial]=\"isPartiallySelected(item)\"\n              [checked]=\"checkIfSelected(item)\">\n            </gravity-checkbox>\n\n            <gravity-currency-display-v2 *ngIf=\"isCurrency\"\n                [ngClass]=\"getSpacingClass(size)\"\n                [type]=\"item.type === 'FIAT' ? 'fiat-short' : 'short-hrz'\"\n                [currency]=\"{\n                    currency_name: item.name,\n                    currency_id: item.currency_id, currency_iso: item.iso,\n                    network_id: item.network?.id, network_iso: item.network?.code,\n                    pill_type: checkIfSelected(item) ? 'secondary' : 'primary'}\" >\n            </gravity-currency-display-v2>\n\n            <div *ngIf=\"!isCurrency\" [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(item, config) }}</div>\n\n            <gravity-icon style=\"margin-left: auto\" (click)=\"toggleChildren(item, $event)\"\n                          [iconName]=\"isChildrenOpen(item) ? 'arrow-up' : 'arrow-down'\"\n                          [iconSize]=\"'md-16'\" *ngIf=\"item.children?.length\"></gravity-icon>\n          </div>\n\n          <div class=\"item-children\" *ngIf=\"item.children?.length && isChildrenOpen(item)\">\n            <ng-container *ngFor=\"let child of item.children\">\n              <div class=\"hr-label item {{size}}-regular pointer\" [ngClass]=\"{'multiple' : multiple}\"\n                   [class.selected]=\"checkIfSelected(child)\"\n                   (click)=\"selectItem(child)\">\n                <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getMultilevelSpacingClass(size)\"\n                                  [checked]=\"checkIfSelected(child)\"></gravity-checkbox>\n                <gravity-currency *ngIf=\"isCurrency\" [ngClass]=\"getSpacingClass(size)\"\n                                  [size]=\"getCurrencyIconSize(size)\"\n                                  [currency]=\"{currency_id: child.currency_id}\"></gravity-currency>\n                <div [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(child, config) }}</div>\n                <gravity-network-pill *ngIf=\"isCurrency\" [type]=\"checkIfSelected(child) ? 'secondary' : 'primary'\"\n                                      [network]=\"{ iso: child.network?.code, id: child.network?.id }\"></gravity-network-pill>\n              </div>\n            </ng-container>\n          </div>\n        </div>\n        <div class=\"item-container\" *ngIf=\"availableOptions.length === 0\">\n          <div class=\"hr-label item {{size}}-bold no-results\">\n            {{ currentLang == 'es' ? 'Sin resultados encontrados' : 'No results found.' }}\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"dropdown-footer\" *ngIf=\"selectedItems.length > 0 && availableOptions.length !== 0\"\n         [class.not-clearable]=\"!clearable\">\n      <gravity-link *ngIf=\"clearable\"\n                    (click)=\"clearSelection()\"\n                    [fontClass]=\"'hr-label sm-regular'\"\n                    [attr.data-cy]=\"cypressTag + '_clear'\"\n                    [linkText]=\"currentLang == 'es' ? 'Limpiar' : 'Clear selection'\">\n      </gravity-link>\n\n      <gravity-link *ngIf=\"availableOptions.length != 0\"\n                    [fontClass]=\"'hr-label sm-bold'\"\n                    [attr.data-cy]=\"cypressTag + '_apply'\"\n                    (click)=\"$event.stopPropagation(); toggleDropdown()\"\n                    [linkText]=\"currentLang == 'es' ? 'Aplicar' : 'Apply'\">\n      </gravity-link>\n    </div>\n    <div class=\"dropdown-footer no-results\" *ngIf=\"availableOptions.length === 0\" [class.not-clearable]=\"!clearable\">\n      <gravity-link *ngIf=\"clearable\"\n                    (click)=\"clearSearch()\"\n                    [fontClass]=\"'hr-label sm-regular'\"\n                    [attr.data-cy]=\"cypressTag + '_clear_search'\"\n                    [linkText]=\"currentLang == 'es' ? 'Limpiar búsqueda' : 'Clear search'\">\n      </gravity-link>\n    </div>\n  </div>\n\n  <section class=\"external-content\" *ngIf=\"!items && dropdownOpened\" (click)=\"$event.stopPropagation()\">\n    <ng-content></ng-content>\n  </section>\n</div>\n\n<ng-container *ngIf=\"inputType === 'field'\">\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\" *ngIf=\"supportText\">\n    {{ supportText }}\n  </p>\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\"\n     *ngIf=\"!supportText && getStatus() == 'active' && selectedItems.length == 0 && required\">\n    {{ currentLang == 'es' ? 'Requerido' : 'Required' }}\n  </p>\n</ng-container>"]}
|
package/esm2022/lib/components/gravity-push-notifications/gravity-push-notifications.component.mjs
CHANGED
|
@@ -39,11 +39,11 @@ export class GravityPushNotificationsComponent {
|
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityPushNotificationsComponent, deps: [{ token: i1.PushNotificationsService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityPushNotificationsComponent, selector: "gravity-push-notifications", inputs: { userNotifications: "userNotifications" }, outputs: { viewedNotificationsResponse: "viewedNotificationsResponse" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;
|
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityPushNotificationsComponent, selector: "gravity-push-notifications", inputs: { userNotifications: "userNotifications" }, outputs: { viewedNotificationsResponse: "viewedNotificationsResponse" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right elevation-sm\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;top:42px!important;right:-26px!important;border-radius:.9375rem;border:1px solid rgba(0,0,0,.175);background-color:var(--bg-dialog-primary)}@media (min-width: 993px){.dropdown-menu{width:25rem}}@media (max-width: 992px){.dropdown-menu{width:19rem}}.dropdown-menu:before{top:-6px;z-index:1;content:\"\";right:33px;width:12px;height:12px;position:absolute;transform:rotate(45deg);border-left:1px solid rgba(0,0,0,.175);border-top:1px solid rgba(0,0,0,.175);background-color:var(--on-bg-highlight-neutro-primary)}.panel-header{display:flex;padding:1rem 2rem;justify-content:space-between;border-radius:.9375rem .9375rem 0 0;background-color:var(--on-bg-highlight-neutro-primary)}.panel-header p{font-weight:600;letter-spacing:1.023px;color:var(--on-bg-notification-list-primary)}.notifications{padding:.75rem 2rem;color:var(--text-primary)}.notifications .notification:last-of-type{padding-bottom:0}.notification{display:flex;padding-block:1rem;align-items:flex-start}.notification .notification-content{margin-left:1.5rem}.notification .notification-content .title{margin-bottom:.25rem}.notification .notification-content .title span.pending-notification-circle{width:.625rem;height:.625rem;min-width:.625rem;min-height:.625rem;margin-right:.25rem;display:inline-block;border-radius:1.5625rem;background-color:var(--notification-success-highlight-primary)}.notification .notification-content .body{overflow:hidden;text-overflow:ellipsis}@media (min-width: 993px){.notification .notification-content .body{width:18rem}}@media (max-width: 992px){.notification .notification-content .body{width:10rem}}.notification .notification-content .body.white-space-nowrap{white-space:nowrap}hr{margin:0;border-top-color:var(--divider-primary)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "iconSize", "hoverIcon", "size", "isCoin"] }] }); }
|
|
43
43
|
}
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityPushNotificationsComponent, decorators: [{
|
|
45
45
|
type: Component,
|
|
46
|
-
args: [{ selector: 'gravity-push-notifications', template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;
|
|
46
|
+
args: [{ selector: 'gravity-push-notifications', template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right elevation-sm\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;top:42px!important;right:-26px!important;border-radius:.9375rem;border:1px solid rgba(0,0,0,.175);background-color:var(--bg-dialog-primary)}@media (min-width: 993px){.dropdown-menu{width:25rem}}@media (max-width: 992px){.dropdown-menu{width:19rem}}.dropdown-menu:before{top:-6px;z-index:1;content:\"\";right:33px;width:12px;height:12px;position:absolute;transform:rotate(45deg);border-left:1px solid rgba(0,0,0,.175);border-top:1px solid rgba(0,0,0,.175);background-color:var(--on-bg-highlight-neutro-primary)}.panel-header{display:flex;padding:1rem 2rem;justify-content:space-between;border-radius:.9375rem .9375rem 0 0;background-color:var(--on-bg-highlight-neutro-primary)}.panel-header p{font-weight:600;letter-spacing:1.023px;color:var(--on-bg-notification-list-primary)}.notifications{padding:.75rem 2rem;color:var(--text-primary)}.notifications .notification:last-of-type{padding-bottom:0}.notification{display:flex;padding-block:1rem;align-items:flex-start}.notification .notification-content{margin-left:1.5rem}.notification .notification-content .title{margin-bottom:.25rem}.notification .notification-content .title span.pending-notification-circle{width:.625rem;height:.625rem;min-width:.625rem;min-height:.625rem;margin-right:.25rem;display:inline-block;border-radius:1.5625rem;background-color:var(--notification-success-highlight-primary)}.notification .notification-content .body{overflow:hidden;text-overflow:ellipsis}@media (min-width: 993px){.notification .notification-content .body{width:18rem}}@media (max-width: 992px){.notification .notification-content .body{width:10rem}}.notification .notification-content .body.white-space-nowrap{white-space:nowrap}hr{margin:0;border-top-color:var(--divider-primary)}\n"] }]
|
|
47
47
|
}], ctorParameters: function () { return [{ type: i1.PushNotificationsService }, { type: i0.ElementRef }]; }, propDecorators: { userNotifications: [{
|
|
48
48
|
type: Input
|
|
49
49
|
}], viewedNotificationsResponse: [{
|
|
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
52
52
|
type: HostListener,
|
|
53
53
|
args: ['document:click', ['$event']]
|
|
54
54
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-push-notifications.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-push-notifications/gravity-push-notifications.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-push-notifications/gravity-push-notifications.component.html"],"names":[],"mappings":"AACA,OAAO,EAAC,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAC,MAAM,eAAe,CAAC;;;;;AAQlH,MAAM,OAAO,iCAAiC;IAC7C,IAAa,iBAAiB,CAAC,KAAoC;QAClE,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,WAAW,EAAE,CAAC;IACpB,CAAC;IAQD,YAA4B,wBAAkD,EACjD,UAAsB;QADvB,6BAAwB,GAAxB,wBAAwB,CAA0B;QACjD,eAAU,GAAV,UAAU,CAAY;QAPlC,gCAA2B,GAAkD,IAAI,YAAY,EAAE,CAAC;QAE1G,gBAAW,GAAY,KAAK,CAAC;IAKmB,CAAC;IAExD,QAAQ;QACP,IAAI,CAAC,WAAW,EAAE,CAAC;IACpB,CAAC;IAED,WAAW;QACV,IAAI,CAAC,wBAAwB,CAAC,sBAAsB,EAAE,CAAC;IACxD,CAAC;IAEO,WAAW;QAClB,IAAI,CAAC,wBAAwB,CAAC,qBAAqB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC9E,CAAC;IAEM,8BAA8B;QACpC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,wBAAwB,CAAC,wBAAwB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpG,IAAG,IAAI,CAAC,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,GAAG,CAAC,EAAE;YAC5D,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;SAChE;IACF,CAAC;IAE2C,OAAO,CAAC,KAAiB;QACpE,IAAI,IAAI,CAAC,WAAW,EAAE;YACrB,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAE3E,IAAI,CAAC,aAAa,EAAE;gBACnB,IAAI,CAAC,8BAA8B,EAAE,CAAC;aACtC;SACD;IACF,CAAC;+GA3CW,iCAAiC;mGAAjC,iCAAiC,6PCT9C,o/HA6DA;;4FDpDa,iCAAiC;kBAL7C,SAAS;+BACC,4BAA4B;wIAKzB,iBAAiB;sBAA7B,KAAK;gBAKW,2BAA2B;sBAA3C,MAAM;gBA6BqC,OAAO;sBAAlD,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {NotificationViewedStatusRequest, UserNotifications} from \"../../model/gravity-push-notifications.model\";\nimport {Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport { PushNotificationsService } from \"../../services/gravity-push-notifications-service.service\";\n\n@Component({\n\tselector: 'gravity-push-notifications',\n\ttemplateUrl: './gravity-push-notifications.component.html',\n\tstyleUrls: ['./gravity-push-notifications.component.scss']\n})\nexport class GravityPushNotificationsComponent implements OnInit, OnDestroy {\n\t@Input() set userNotifications(value: UserNotifications | undefined) {\n\t\tthis._userNotifications = value;\n\t\tthis.processData();\n\t}\n\n\t@Output() public viewedNotificationsResponse: EventEmitter<NotificationViewedStatusRequest> = new EventEmitter();\n\n\tpublic isPanelOpen: boolean = false;\n\tpublic _userNotifications: UserNotifications | undefined;\n\tpublic viewedNotifications: NotificationViewedStatusRequest | undefined;\n\n\tconstructor(public readonly pushNotificationsService: PushNotificationsService,\n\t            private readonly elementRef: ElementRef) { }\n\n\tngOnInit(): void {\n\t\tthis.processData();\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis.pushNotificationsService.clearLoginNotification();\n\t}\n\n\tprivate processData(): void {\n\t\tthis.pushNotificationsService.loadUserNotifications(this._userNotifications);\n\t}\n\n\tpublic handleToggleNotificationsPanel() {\n\t\tthis.isPanelOpen = !this.isPanelOpen;\n\t\tthis.viewedNotifications = this.pushNotificationsService.toggleNotificationsPanel(this.isPanelOpen);\n\t\tif(this.viewedNotifications?.push_notifications?.length > 0) {\n\t\t\tthis.viewedNotificationsResponse.emit(this.viewedNotifications);\n\t\t}\n\t}\n\n\t@HostListener('document:click', ['$event']) onClick(event: MouseEvent) {\n\t\tif (this.isPanelOpen) {\n\t\t\tconst clickedInside = this.elementRef.nativeElement.contains(event.target);\n\n\t\t\tif (!clickedInside) {\n\t\t\t\tthis.handleToggleNotificationsPanel();\n\t\t\t}\n\t\t}\n\t}\n}","<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n  <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n       (click)=\"handleToggleNotificationsPanel()\">\n    <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n    <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n  </div>\n  <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n    <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n      <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n      <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n         *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n        {{pushNotificationsService.pendingNotifications.length}}\n      </p>\n    </div>\n    <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n        *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n      <p> New </p>\n      <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n        <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n             (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n             id=\"pending-{{index}}\">\n          <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n          <div class=\"notification-content\">\n            <p class=\"hr-title sm-bold title\">\n              <span class=\"pending-notification-circle\"></span>\n              {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n            </p>\n            <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n              {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n            </p>\n          </div>\n        </div>\n        <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n      </ng-container>\n    </div>\n    <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n    <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n      <p> Old </p>\n      <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n        <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n             (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n             id=\"seen-{{index}}\">\n          <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n          <div class=\"notification-content\">\n            <p class=\"hr-title sm-bold title\">\n              {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n            </p>\n            <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n              {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n            </p>\n          </div>\n        </div>\n        <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n      </ng-container>\n    </div>\n    <div class=\"notifications\"\n        *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n      <p class=\"no-notification\"> No new notifications </p>\n    </div>\n  </div>\n</div>\n"]}
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-push-notifications.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-push-notifications/gravity-push-notifications.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-push-notifications/gravity-push-notifications.component.html"],"names":[],"mappings":"AACA,OAAO,EAAC,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAC,MAAM,eAAe,CAAC;;;;;AAQlH,MAAM,OAAO,iCAAiC;IAC7C,IAAa,iBAAiB,CAAC,KAAoC;QAClE,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,WAAW,EAAE,CAAC;IACpB,CAAC;IAQD,YAA4B,wBAAkD,EACjD,UAAsB;QADvB,6BAAwB,GAAxB,wBAAwB,CAA0B;QACjD,eAAU,GAAV,UAAU,CAAY;QAPlC,gCAA2B,GAAkD,IAAI,YAAY,EAAE,CAAC;QAE1G,gBAAW,GAAY,KAAK,CAAC;IAKmB,CAAC;IAExD,QAAQ;QACP,IAAI,CAAC,WAAW,EAAE,CAAC;IACpB,CAAC;IAED,WAAW;QACV,IAAI,CAAC,wBAAwB,CAAC,sBAAsB,EAAE,CAAC;IACxD,CAAC;IAEO,WAAW;QAClB,IAAI,CAAC,wBAAwB,CAAC,qBAAqB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC9E,CAAC;IAEM,8BAA8B;QACpC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,wBAAwB,CAAC,wBAAwB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpG,IAAG,IAAI,CAAC,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,GAAG,CAAC,EAAE;YAC5D,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;SAChE;IACF,CAAC;IAE2C,OAAO,CAAC,KAAiB;QACpE,IAAI,IAAI,CAAC,WAAW,EAAE;YACrB,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAE3E,IAAI,CAAC,aAAa,EAAE;gBACnB,IAAI,CAAC,8BAA8B,EAAE,CAAC;aACtC;SACD;IACF,CAAC;+GA3CW,iCAAiC;mGAAjC,iCAAiC,6PCT9C,kgIA6DA;;4FDpDa,iCAAiC;kBAL7C,SAAS;+BACC,4BAA4B;wIAKzB,iBAAiB;sBAA7B,KAAK;gBAKW,2BAA2B;sBAA3C,MAAM;gBA6BqC,OAAO;sBAAlD,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {NotificationViewedStatusRequest, UserNotifications} from \"../../model/gravity-push-notifications.model\";\nimport {Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport { PushNotificationsService } from \"../../services/gravity-push-notifications-service.service\";\n\n@Component({\n\tselector: 'gravity-push-notifications',\n\ttemplateUrl: './gravity-push-notifications.component.html',\n\tstyleUrls: ['./gravity-push-notifications.component.scss']\n})\nexport class GravityPushNotificationsComponent implements OnInit, OnDestroy {\n\t@Input() set userNotifications(value: UserNotifications | undefined) {\n\t\tthis._userNotifications = value;\n\t\tthis.processData();\n\t}\n\n\t@Output() public viewedNotificationsResponse: EventEmitter<NotificationViewedStatusRequest> = new EventEmitter();\n\n\tpublic isPanelOpen: boolean = false;\n\tpublic _userNotifications: UserNotifications | undefined;\n\tpublic viewedNotifications: NotificationViewedStatusRequest | undefined;\n\n\tconstructor(public readonly pushNotificationsService: PushNotificationsService,\n\t            private readonly elementRef: ElementRef) { }\n\n\tngOnInit(): void {\n\t\tthis.processData();\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis.pushNotificationsService.clearLoginNotification();\n\t}\n\n\tprivate processData(): void {\n\t\tthis.pushNotificationsService.loadUserNotifications(this._userNotifications);\n\t}\n\n\tpublic handleToggleNotificationsPanel() {\n\t\tthis.isPanelOpen = !this.isPanelOpen;\n\t\tthis.viewedNotifications = this.pushNotificationsService.toggleNotificationsPanel(this.isPanelOpen);\n\t\tif(this.viewedNotifications?.push_notifications?.length > 0) {\n\t\t\tthis.viewedNotificationsResponse.emit(this.viewedNotifications);\n\t\t}\n\t}\n\n\t@HostListener('document:click', ['$event']) onClick(event: MouseEvent) {\n\t\tif (this.isPanelOpen) {\n\t\t\tconst clickedInside = this.elementRef.nativeElement.contains(event.target);\n\n\t\t\tif (!clickedInside) {\n\t\t\t\tthis.handleToggleNotificationsPanel();\n\t\t\t}\n\t\t}\n\t}\n}","<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n  <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n       (click)=\"handleToggleNotificationsPanel()\">\n    <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n    <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n  </div>\n  <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right  elevation-sm\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n    <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n      <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n      <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n         *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n        {{pushNotificationsService.pendingNotifications.length}}\n      </p>\n    </div>\n    <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n        *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n      <p> New </p>\n      <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n        <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n             (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n             id=\"pending-{{index}}\">\n          <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n          <div class=\"notification-content\">\n            <p class=\"hr-title sm-bold title\">\n              <span class=\"pending-notification-circle\"></span>\n              {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n            </p>\n            <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n              {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n            </p>\n          </div>\n        </div>\n        <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n      </ng-container>\n    </div>\n    <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n    <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n      <p> Old </p>\n      <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n        <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n             (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n             id=\"seen-{{index}}\">\n          <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n          <div class=\"notification-content\">\n            <p class=\"hr-title sm-bold title\">\n              {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n            </p>\n            <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n              {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n            </p>\n          </div>\n        </div>\n        <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n      </ng-container>\n    </div>\n    <div class=\"notifications\"\n        *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n      <p class=\"no-notification\"> No new notifications </p>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -679,6 +679,7 @@ class GravityDropdownListComponent {
|
|
|
679
679
|
}
|
|
680
680
|
clearSelection() {
|
|
681
681
|
this.selectedItems = [];
|
|
682
|
+
this.networkConfig = null;
|
|
682
683
|
if (this.multiple) {
|
|
683
684
|
this.selectedItemsResponse.emit(this.selectedItems);
|
|
684
685
|
}
|
|
@@ -7337,11 +7338,11 @@ class GravityPushNotificationsComponent {
|
|
|
7337
7338
|
}
|
|
7338
7339
|
}
|
|
7339
7340
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityPushNotificationsComponent, deps: [{ token: PushNotificationsService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
7340
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityPushNotificationsComponent, selector: "gravity-push-notifications", inputs: { userNotifications: "userNotifications" }, outputs: { viewedNotificationsResponse: "viewedNotificationsResponse" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;
|
|
7341
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityPushNotificationsComponent, selector: "gravity-push-notifications", inputs: { userNotifications: "userNotifications" }, outputs: { viewedNotificationsResponse: "viewedNotificationsResponse" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right elevation-sm\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;top:42px!important;right:-26px!important;border-radius:.9375rem;border:1px solid rgba(0,0,0,.175);background-color:var(--bg-dialog-primary)}@media (min-width: 993px){.dropdown-menu{width:25rem}}@media (max-width: 992px){.dropdown-menu{width:19rem}}.dropdown-menu:before{top:-6px;z-index:1;content:\"\";right:33px;width:12px;height:12px;position:absolute;transform:rotate(45deg);border-left:1px solid rgba(0,0,0,.175);border-top:1px solid rgba(0,0,0,.175);background-color:var(--on-bg-highlight-neutro-primary)}.panel-header{display:flex;padding:1rem 2rem;justify-content:space-between;border-radius:.9375rem .9375rem 0 0;background-color:var(--on-bg-highlight-neutro-primary)}.panel-header p{font-weight:600;letter-spacing:1.023px;color:var(--on-bg-notification-list-primary)}.notifications{padding:.75rem 2rem;color:var(--text-primary)}.notifications .notification:last-of-type{padding-bottom:0}.notification{display:flex;padding-block:1rem;align-items:flex-start}.notification .notification-content{margin-left:1.5rem}.notification .notification-content .title{margin-bottom:.25rem}.notification .notification-content .title span.pending-notification-circle{width:.625rem;height:.625rem;min-width:.625rem;min-height:.625rem;margin-right:.25rem;display:inline-block;border-radius:1.5625rem;background-color:var(--notification-success-highlight-primary)}.notification .notification-content .body{overflow:hidden;text-overflow:ellipsis}@media (min-width: 993px){.notification .notification-content .body{width:18rem}}@media (max-width: 992px){.notification .notification-content .body{width:10rem}}.notification .notification-content .body.white-space-nowrap{white-space:nowrap}hr{margin:0;border-top-color:var(--divider-primary)}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "iconSize", "hoverIcon", "size", "isCoin"] }] }); }
|
|
7341
7342
|
}
|
|
7342
7343
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityPushNotificationsComponent, decorators: [{
|
|
7343
7344
|
type: Component,
|
|
7344
|
-
args: [{ selector: 'gravity-push-notifications', template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;
|
|
7345
|
+
args: [{ selector: 'gravity-push-notifications', template: "<div class=\"btn-group notifications-wrapper\" data-cy=\"PUSH_NOTIFICATIONS_wrapper\">\n <div class=\"notifications-toggle pointer\" [class.active]=\"isPanelOpen\" data-cy=\"PUSH_NOTIFICATIONS_toggle\"\n (click)=\"handleToggleNotificationsPanel()\">\n <gravity-icon class=\"bell\" [iconName]=\"'bell'\" [iconSize]=\"'md-16'\"></gravity-icon>\n <span *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\" class=\"circle\"></span>\n </div>\n <div *ngIf=\"isPanelOpen\" class=\"dropdown-menu dropdown-menu-right elevation-sm\" data-cy=\"PUSH_NOTIFICATIONS_panel\">\n <div class=\"panel-header\" data-cy=\"PUSH_NOTIFICATIONS_panel_header\">\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_title\"> Notifications </p>\n <p class=\"hr-body md-regular\" data-cy=\"PUSH_NOTIFICATIONS_panel_pending_counter\"\n *ngIf=\"pushNotificationsService.pendingNotifications.length > 0\">\n {{pushNotificationsService.pendingNotifications.length}}\n </p>\n </div>\n <div class=\"notifications\" data-cy=\"PUSH_NOTIFICATIONS_item\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0\">\n <p> New </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.pendingNotifications, let index = index\">\n <div class=\"notification pending\" data-cy=\"PUSH_NOTIFICATIONS_new_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('pending-' + index)\"\n id=\"pending-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n <span class=\"pending-notification-circle\"></span>\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.pendingNotifications.length\">\n </ng-container>\n </div>\n <hr *ngIf=\"pushNotificationsService.pendingNotifications?.length > 0 && pushNotificationsService.seenNotifications?.length > 0\">\n <div class=\"notifications\" *ngIf=\"pushNotificationsService.seenNotifications?.length > 0\">\n <p> Old </p>\n <ng-container *ngFor=\"let notification of pushNotificationsService.seenNotifications, let index = index\">\n <div class=\"notification\" data-cy=\"PUSH_NOTIFICATIONS_old_notification\"\n (click)=\"$event.stopPropagation(); pushNotificationsService.removeTextOverflow('seen-' + index)\"\n id=\"seen-{{index}}\">\n <gravity-icon *ngIf=\"notification.iconName\" [iconName]=\"notification.iconName\" [hoverIcon]=\"false\" [iconSize]=\"'lg-24'\"></gravity-icon>\n <div class=\"notification-content\">\n <p class=\"hr-title sm-bold title\">\n {{pushNotificationsService.getNotificationContent(notification.titleText, notification.titleAdditionalText)}}\n </p>\n <p class=\"body hr-body md-regular white-space-nowrap\" title=\"Click to expand\">\n {{pushNotificationsService.getNotificationContent(notification.bodyAdditionalText, notification.bodyAdditionalText)}}\n </p>\n </div>\n </div>\n <hr *ngIf=\"index + 1 != pushNotificationsService.seenNotifications.length\">\n </ng-container>\n </div>\n <div class=\"notifications\"\n *ngIf=\"pushNotificationsService.pendingNotifications?.length == 0 && pushNotificationsService.seenNotifications?.length == 0\">\n <p class=\"no-notification\"> No new notifications </p>\n </div>\n </div>\n</div>\n", styles: [".border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.notifications-wrapper{--circle-top: 3.25px;--circle-width: 8.67px;--circle-right: 6.13px;--circle-height: 8.67px;--notifications-wrapper-width: 29px;--notifications-wrapper-height: 29px;--notifications-toggle-padding: 6.5px;--circle-border-radius: 6.25rem;--notifications-wrapper-border-radius: 0;--notifications-toggle-border-radius: 6.25rem}.notifications-wrapper{width:var(--notifications-wrapper-width);height:var(--notifications-wrapper-height);border-radius:var(--notifications-wrapper-border-radius)}.notifications-toggle{width:100%;height:100%;display:flex;position:relative;align-items:center;justify-content:center;padding:var(--notifications-toggle-padding);border-radius:var(--notifications-toggle-border-radius)}.notifications-toggle:hover,.notifications-toggle.active{cursor:pointer;background-color:var(--bg-notification-button-hover)}.notifications-toggle:hover .bell,.notifications-toggle.active .bell{--icon-color: var(--on-bg-notification-button-hover)}.notifications-toggle .bell{--icon-color: var(--on-bg-notification-button-active)}.notifications-toggle .circle{position:absolute;top:var(--circle-top);right:var(--circle-right);width:var(--circle-width);height:var(--circle-height);border-radius:var(--circle-border-radius);background-color:var(--bg-notification-badge-button)}.dropdown-menu{z-index:2;position:absolute;top:42px!important;right:-26px!important;border-radius:.9375rem;border:1px solid rgba(0,0,0,.175);background-color:var(--bg-dialog-primary)}@media (min-width: 993px){.dropdown-menu{width:25rem}}@media (max-width: 992px){.dropdown-menu{width:19rem}}.dropdown-menu:before{top:-6px;z-index:1;content:\"\";right:33px;width:12px;height:12px;position:absolute;transform:rotate(45deg);border-left:1px solid rgba(0,0,0,.175);border-top:1px solid rgba(0,0,0,.175);background-color:var(--on-bg-highlight-neutro-primary)}.panel-header{display:flex;padding:1rem 2rem;justify-content:space-between;border-radius:.9375rem .9375rem 0 0;background-color:var(--on-bg-highlight-neutro-primary)}.panel-header p{font-weight:600;letter-spacing:1.023px;color:var(--on-bg-notification-list-primary)}.notifications{padding:.75rem 2rem;color:var(--text-primary)}.notifications .notification:last-of-type{padding-bottom:0}.notification{display:flex;padding-block:1rem;align-items:flex-start}.notification .notification-content{margin-left:1.5rem}.notification .notification-content .title{margin-bottom:.25rem}.notification .notification-content .title span.pending-notification-circle{width:.625rem;height:.625rem;min-width:.625rem;min-height:.625rem;margin-right:.25rem;display:inline-block;border-radius:1.5625rem;background-color:var(--notification-success-highlight-primary)}.notification .notification-content .body{overflow:hidden;text-overflow:ellipsis}@media (min-width: 993px){.notification .notification-content .body{width:18rem}}@media (max-width: 992px){.notification .notification-content .body{width:10rem}}.notification .notification-content .body.white-space-nowrap{white-space:nowrap}hr{margin:0;border-top-color:var(--divider-primary)}\n"] }]
|
|
7345
7346
|
}], ctorParameters: function () { return [{ type: PushNotificationsService }, { type: i0.ElementRef }]; }, propDecorators: { userNotifications: [{
|
|
7346
7347
|
type: Input
|
|
7347
7348
|
}], viewedNotificationsResponse: [{
|