UNPKG

@spartacus/storefront

Version:

Spartacus Storefront is a package that you can include in your application, which allows you to add default storefront features.

195 lines 25.3 kB
import { Directive, Input, Output, EventEmitter, HostListener, } from '@angular/core'; import { Subject } from 'rxjs'; import { PopoverComponent } from './popover.component'; import { PopoverEvent } from './popover.model'; import * as i0 from "@angular/core"; import * as i1 from "./popover.service"; import * as i2 from "@spartacus/core"; /** * Directive to bind popover with any DOM element. */ export class PopoverDirective { constructor(element, viewContainer, componentFactoryResolver, renderer, changeDetectorRef, popoverService, winRef) { this.element = element; this.viewContainer = viewContainer; this.componentFactoryResolver = componentFactoryResolver; this.renderer = renderer; this.changeDetectorRef = changeDetectorRef; this.popoverService = popoverService; this.winRef = winRef; /** * An event emitted when the popover is opened. */ this.openPopover = new EventEmitter(); /** * An event emitted when the popover is closed. */ this.closePopover = new EventEmitter(); /** * Subject which emits specific type of `PopoverEvent`. */ this.eventSubject = new Subject(); this.openTriggerEvents = [ PopoverEvent.OPEN, PopoverEvent.OPEN_BY_KEYBOARD, ]; this.focusPopoverTriggerEvents = [ PopoverEvent.OPEN_BY_KEYBOARD, ]; this.closeTriggerEvents = [ PopoverEvent.ROUTE_CHANGE, PopoverEvent.ESCAPE_KEYDOWN, PopoverEvent.OUTSIDE_CLICK, PopoverEvent.CLOSE_BUTTON_KEYDOWN, PopoverEvent.CLOSE_BUTTON_CLICK, ]; this.focusDirectiveTriggerEvents = [ PopoverEvent.ESCAPE_KEYDOWN, PopoverEvent.CLOSE_BUTTON_KEYDOWN, ]; } /** * Listen events fired on element binded to popover directive. * * Based on event type some a11y improvements can be made. * For example if popover was opened by `space` or `enter` key * dedicated `FocusConfig` can be set to autofocus first * focusable element in popover container. */ handlePress(event) { event === null || event === void 0 ? void 0 : event.preventDefault(); if ((event === null || event === void 0 ? void 0 : event.target) === this.element.nativeElement && !this.isOpen) { this.eventSubject.next(PopoverEvent.OPEN_BY_KEYBOARD); } else if (this.isOpen) { this.eventSubject.next(PopoverEvent.CLOSE_BUTTON_KEYDOWN); } } handleTab() { var _a; if (!((_a = this.focusConfig) === null || _a === void 0 ? void 0 : _a.trap) && this.isOpen) { this.eventSubject.next(PopoverEvent.CLOSE_BUTTON_KEYDOWN); } } handleEscape() { this.eventSubject.next(PopoverEvent.ESCAPE_KEYDOWN); } handleClick(event) { event === null || event === void 0 ? void 0 : event.preventDefault(); if ((event === null || event === void 0 ? void 0 : event.target) === this.element.nativeElement && !this.isOpen) { this.eventSubject.next(PopoverEvent.OPEN); } else if (this.isOpen) { this.eventSubject.next(PopoverEvent.CLOSE_BUTTON_CLICK); } } /** * Method performs open action for popover component. */ open(event) { var _a, _b; if (!((_a = this.cxPopoverOptions) === null || _a === void 0 ? void 0 : _a.disable)) { this.isOpen = true; this.focusConfig = this.popoverService.getFocusConfig(event, ((_b = this.cxPopoverOptions) === null || _b === void 0 ? void 0 : _b.appendToBody) || false); this.renderPopover(); this.openPopover.emit(); } } /** * Method performs close action for popover component. */ close() { this.isOpen = false; this.viewContainer.clear(); this.closePopover.emit(); } /** * Method subscribes for events emitted by popover component * and based on event performs specific action. */ handlePopoverEvents() { this.eventSubject.subscribe((event) => { var _a; if (this.openTriggerEvents.includes(event)) { this.open(event); } if (this.focusPopoverTriggerEvents.includes(event)) { this.popoverContainer.location.nativeElement.focus(); } if (this.closeTriggerEvents.includes(event)) { this.close(); } if (this.focusDirectiveTriggerEvents.includes(event)) { this.popoverService.setFocusOnElement(this.element, this.focusConfig, (_a = this.cxPopoverOptions) === null || _a === void 0 ? void 0 : _a.appendToBody); } }); } /** * Method creates instance and pass parameters to popover component. */ renderPopover() { var _a, _b, _c, _d, _e, _f, _g; const containerFactory = this.componentFactoryResolver.resolveComponentFactory(PopoverComponent); this.popoverContainer = this.viewContainer.createComponent(containerFactory); const componentInstance = this.popoverContainer.instance; if (componentInstance) { componentInstance.content = this.cxPopover; componentInstance.triggerElement = this.element; componentInstance.popoverInstance = this.popoverContainer; componentInstance.focusConfig = this.focusConfig; componentInstance.eventSubject = this.eventSubject; componentInstance.position = (_a = this.cxPopoverOptions) === null || _a === void 0 ? void 0 : _a.placement; componentInstance.customClass = (_b = this.cxPopoverOptions) === null || _b === void 0 ? void 0 : _b.class; componentInstance.appendToBody = (_c = this.cxPopoverOptions) === null || _c === void 0 ? void 0 : _c.appendToBody; componentInstance.positionOnScroll = (_d = this.cxPopoverOptions) === null || _d === void 0 ? void 0 : _d.positionOnScroll; componentInstance.displayCloseButton = (_e = this.cxPopoverOptions) === null || _e === void 0 ? void 0 : _e.displayCloseButton; componentInstance.autoPositioning = (_f = this.cxPopoverOptions) === null || _f === void 0 ? void 0 : _f.autoPositioning; if ((_g = this.cxPopoverOptions) === null || _g === void 0 ? void 0 : _g.appendToBody) { this.renderer.appendChild(this.winRef.document.body, this.popoverContainer.location.nativeElement); } this.popoverContainer.changeDetectorRef.detectChanges(); } } ngOnInit() { this.handlePopoverEvents(); } } PopoverDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PopoverDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i1.PopoverService }, { token: i2.WindowRef }], target: i0.ɵɵFactoryTarget.Directive }); PopoverDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.5", type: PopoverDirective, selector: "[cxPopover]", inputs: { cxPopover: "cxPopover", cxPopoverOptions: "cxPopoverOptions" }, outputs: { openPopover: "openPopover", closePopover: "closePopover" }, host: { listeners: { "keydown.enter": "handlePress($event)", "keydown.space": "handlePress($event)", "keydown.tab": "handleTab()", "keydown.shift.tab": "handleTab()", "keydown.escape": "handleEscape()", "click": "handleClick($event)" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PopoverDirective, decorators: [{ type: Directive, args: [{ selector: '[cxPopover]', }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i1.PopoverService }, { type: i2.WindowRef }]; }, propDecorators: { cxPopover: [{ type: Input }], cxPopoverOptions: [{ type: Input }], openPopover: [{ type: Output }], closePopover: [{ type: Output }], handlePress: [{ type: HostListener, args: ['keydown.enter', ['$event']] }, { type: HostListener, args: ['keydown.space', ['$event']] }], handleTab: [{ type: HostListener, args: ['keydown.tab'] }, { type: HostListener, args: ['keydown.shift.tab'] }], handleEscape: [{ type: HostListener, args: ['keydown.escape'] }], handleClick: [{ type: HostListener, args: ['click', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"","sources":["../../../../../../projects/storefrontlib/shared/components/popover/popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Input,\n  TemplateRef,\n  ViewContainerRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Renderer2,\n  ChangeDetectorRef,\n  Output,\n  EventEmitter,\n  HostListener,\n  OnInit,\n} from '@angular/core';\nimport { WindowRef } from '@spartacus/core';\nimport { Subject } from 'rxjs';\nimport { FocusConfig } from '../../../layout/a11y/keyboard-focus/keyboard-focus.model';\nimport { PopoverComponent } from './popover.component';\nimport { PopoverEvent, PopoverOptions } from './popover.model';\nimport { PopoverService } from './popover.service';\n\n/**\n * Directive to bind popover with any DOM element.\n */\n@Directive({\n  selector: '[cxPopover]',\n})\nexport class PopoverDirective implements OnInit {\n  /**\n   * Template or string to be rendered inside popover wrapper component.\n   */\n  @Input() cxPopover: string | TemplateRef<any>;\n\n  /**\n   * Options set for popover component.\n   */\n  @Input() cxPopoverOptions?: PopoverOptions;\n\n  /**\n   * An event emitted when the popover is opened.\n   */\n  @Output() openPopover: EventEmitter<void> = new EventEmitter();\n\n  /**\n   * An event emitted when the popover is closed.\n   */\n  @Output() closePopover: EventEmitter<void> = new EventEmitter();\n\n  /**\n   * Flag used to inform about current state of popover component.\n   * Popover is closed by default, so value is set to false.\n   */\n  isOpen: boolean;\n\n  /**\n   * Popover component instance.\n   */\n  popoverContainer: ComponentRef<PopoverComponent>;\n\n  /**\n   * Configuration for a11y improvements.\n   */\n  focusConfig: FocusConfig;\n\n  /**\n   * Subject which emits specific type of `PopoverEvent`.\n   */\n  eventSubject: Subject<PopoverEvent> = new Subject<PopoverEvent>();\n\n  /**\n   * Listen events fired on element binded to popover directive.\n   *\n   * Based on event type some a11y improvements can be made.\n   * For example if popover was opened by `space` or `enter` key\n   * dedicated `FocusConfig` can be set to autofocus first\n   * focusable element in popover container.\n   */\n  @HostListener('keydown.enter', ['$event'])\n  @HostListener('keydown.space', ['$event'])\n  handlePress(event: KeyboardEvent): void {\n    event?.preventDefault();\n    if (event?.target === this.element.nativeElement && !this.isOpen) {\n      this.eventSubject.next(PopoverEvent.OPEN_BY_KEYBOARD);\n    } else if (this.isOpen) {\n      this.eventSubject.next(PopoverEvent.CLOSE_BUTTON_KEYDOWN);\n    }\n  }\n\n  @HostListener('keydown.tab')\n  @HostListener('keydown.shift.tab')\n  handleTab(): void {\n    if (!this.focusConfig?.trap && this.isOpen) {\n      this.eventSubject.next(PopoverEvent.CLOSE_BUTTON_KEYDOWN);\n    }\n  }\n\n  @HostListener('keydown.escape')\n  handleEscape(): void {\n    this.eventSubject.next(PopoverEvent.ESCAPE_KEYDOWN);\n  }\n\n  @HostListener('click', ['$event'])\n  handleClick(event: MouseEvent): void {\n    event?.preventDefault();\n    if (event?.target === this.element.nativeElement && !this.isOpen) {\n      this.eventSubject.next(PopoverEvent.OPEN);\n    } else if (this.isOpen) {\n      this.eventSubject.next(PopoverEvent.CLOSE_BUTTON_CLICK);\n    }\n  }\n\n  protected openTriggerEvents: PopoverEvent[] = [\n    PopoverEvent.OPEN,\n    PopoverEvent.OPEN_BY_KEYBOARD,\n  ];\n\n  protected focusPopoverTriggerEvents: PopoverEvent[] = [\n    PopoverEvent.OPEN_BY_KEYBOARD,\n  ];\n\n  protected closeTriggerEvents: PopoverEvent[] = [\n    PopoverEvent.ROUTE_CHANGE,\n    PopoverEvent.ESCAPE_KEYDOWN,\n    PopoverEvent.OUTSIDE_CLICK,\n    PopoverEvent.CLOSE_BUTTON_KEYDOWN,\n    PopoverEvent.CLOSE_BUTTON_CLICK,\n  ];\n\n  protected focusDirectiveTriggerEvents: PopoverEvent[] = [\n    PopoverEvent.ESCAPE_KEYDOWN,\n    PopoverEvent.CLOSE_BUTTON_KEYDOWN,\n  ];\n\n  /**\n   * Method performs open action for popover component.\n   */\n  open(event: PopoverEvent) {\n    if (!this.cxPopoverOptions?.disable) {\n      this.isOpen = true;\n      this.focusConfig = this.popoverService.getFocusConfig(\n        event,\n        this.cxPopoverOptions?.appendToBody || false\n      );\n      this.renderPopover();\n      this.openPopover.emit();\n    }\n  }\n\n  /**\n   * Method performs close action for popover component.\n   */\n  close() {\n    this.isOpen = false;\n    this.viewContainer.clear();\n    this.closePopover.emit();\n  }\n\n  /**\n   * Method subscribes for events emitted by popover component\n   * and based on event performs specific action.\n   */\n  handlePopoverEvents() {\n    this.eventSubject.subscribe((event: PopoverEvent) => {\n      if (this.openTriggerEvents.includes(event)) {\n        this.open(event);\n      }\n      if (this.focusPopoverTriggerEvents.includes(event)) {\n        this.popoverContainer.location.nativeElement.focus();\n      }\n      if (this.closeTriggerEvents.includes(event)) {\n        this.close();\n      }\n      if (this.focusDirectiveTriggerEvents.includes(event)) {\n        this.popoverService.setFocusOnElement(\n          this.element,\n          this.focusConfig,\n          this.cxPopoverOptions?.appendToBody\n        );\n      }\n    });\n  }\n\n  /**\n   * Method creates instance and pass parameters to popover component.\n   */\n  renderPopover() {\n    const containerFactory =\n      this.componentFactoryResolver.resolveComponentFactory(PopoverComponent);\n    this.popoverContainer =\n      this.viewContainer.createComponent(containerFactory);\n\n    const componentInstance = this.popoverContainer.instance;\n    if (componentInstance) {\n      componentInstance.content = this.cxPopover;\n      componentInstance.triggerElement = this.element;\n      componentInstance.popoverInstance = this.popoverContainer;\n      componentInstance.focusConfig = this.focusConfig;\n      componentInstance.eventSubject = this.eventSubject;\n      componentInstance.position = this.cxPopoverOptions?.placement;\n      componentInstance.customClass = this.cxPopoverOptions?.class;\n      componentInstance.appendToBody = this.cxPopoverOptions?.appendToBody;\n      componentInstance.positionOnScroll =\n        this.cxPopoverOptions?.positionOnScroll;\n      componentInstance.displayCloseButton =\n        this.cxPopoverOptions?.displayCloseButton;\n      componentInstance.autoPositioning =\n        this.cxPopoverOptions?.autoPositioning;\n\n      if (this.cxPopoverOptions?.appendToBody) {\n        this.renderer.appendChild(\n          this.winRef.document.body,\n          this.popoverContainer.location.nativeElement\n        );\n      }\n\n      this.popoverContainer.changeDetectorRef.detectChanges();\n    }\n  }\n\n  ngOnInit() {\n    this.handlePopoverEvents();\n  }\n\n  constructor(\n    protected element: ElementRef,\n    protected viewContainer: ViewContainerRef,\n    protected componentFactoryResolver: ComponentFactoryResolver,\n    protected renderer: Renderer2,\n    protected changeDetectorRef: ChangeDetectorRef,\n    protected popoverService: PopoverService,\n    protected winRef: WindowRef\n  ) {}\n}\n"]}