@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
JavaScript
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"]}