UNPKG

@universal-material/angular

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.1.0.

132 lines 20.4 kB
import { Directive, HostListener, Inject, Input } from '@angular/core'; import { DOCUMENT } from '@angular/common'; import * as i0 from "@angular/core"; export class RippleDirective { constructor(_elementRef, document) { this._elementRef = _elementRef; this.document = document; this.rippleConfig = {}; this.disabled = false; this.isTouching = false; this._mousedown = (e) => { if (this.disabled || this._elementRef.nativeElement.hasAttribute('disabled') || this._elementRef.nativeElement.classList.contains('disabled')) { return; } if (!this.isTouching) { this.createRipple('mouseup', null, e.clientX, e.clientY); } }; this._touchstart = (e) => { if (this.disabled || this._elementRef.nativeElement.hasAttribute('disabled') || this._elementRef.nativeElement.classList.contains('disabled')) { return; } this.isTouching = true; this.createRipple('touchend', () => { setTimeout(() => this.isTouching = false, 100); }, e.touches[0].clientX, e.touches[0].clientY); }; } static _setElementSquareSizeAndCenter(element, size) { element.style.top = '50%'; element.style.left = '50%'; element.style.width = `${size}px`; element.style.height = `${size}px`; element.style.marginLeft = `${-size / 2}px`; element.style.marginTop = `${-size / 2}px`; } ngAfterViewInit() { const { position } = document.defaultView.getComputedStyle(this._elementRef.nativeElement); if (position !== 'absolute' && position !== 'fixed' && (!this.rippleConfig || !this.rippleConfig.dontChangePositioning)) { this._elementRef.nativeElement.style.position = 'relative'; } } createRipple(releaseEventName, releaseCallback, pageX, pageY) { if (this.disabled || this._elementRef.nativeElement.hasAttribute('disabled') || this._elementRef.nativeElement.classList.contains('disabled')) { return; } let release; const cancelRippleIfNecessary = () => { this._elementRef.nativeElement.removeEventListener("touchmove", cancelRippleIfNecessary); window.removeEventListener(releaseEventName, cancelRippleIfNecessary); if (release) { release(); } }; this._elementRef.nativeElement.addEventListener("touchmove", cancelRippleIfNecessary); window.addEventListener(releaseEventName, cancelRippleIfNecessary); const rippleWrapper = document.createElement('DIV'); rippleWrapper.classList.add('u-ripple-wrapper'); const ripple = document.createElement('DIV'); ripple.classList.add('u-ripple'); rippleWrapper.appendChild(ripple); this._elementRef.nativeElement.insertAdjacentElement('afterbegin', rippleWrapper); if (this.rippleConfig.size) { RippleDirective._setElementSquareSizeAndCenter(rippleWrapper, this.rippleConfig.size); } if (this.rippleConfig.borderRadius) { rippleWrapper.style.borderRadius = this.rippleConfig.borderRadius; } release = () => { if (ripple.classList.contains('dismiss')) { return; } ripple.classList.add('dismiss'); ripple.addEventListener('transitionend', () => { this._elementRef.nativeElement.removeChild(rippleWrapper); this._elementRef.nativeElement.removeEventListener('touchend', release); this._elementRef.nativeElement.removeEventListener('mouseleave', release); this._elementRef.nativeElement.removeEventListener('mouseup', release); }); if (releaseCallback) { releaseCallback(); releaseCallback = null; } }; this._elementRef.nativeElement.addEventListener('touchend', release); this._elementRef.nativeElement.addEventListener('mouseleave', release); this._elementRef.nativeElement.addEventListener('mouseup', release); requestAnimationFrame(() => { const clientRect = this._elementRef.nativeElement.getBoundingClientRect(); const largestDimensionSize = Math.max(rippleWrapper.clientWidth, rippleWrapper.clientHeight); const rippleSize = this.rippleConfig.size || largestDimensionSize * 2; RippleDirective._setElementSquareSizeAndCenter(ripple, rippleSize); ripple.style.transitionDuration = `${1080 * Math.pow(rippleSize, 0.3)}ms, 750ms`; const x = (pageX - clientRect.left) + ((rippleSize - this._elementRef.nativeElement.clientWidth) / 2); const y = (pageY - clientRect.top) + ((rippleSize - this._elementRef.nativeElement.clientHeight) / 2); ripple.style.transformOrigin = `${x}px ${y}px`; ripple.classList.add('show'); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RippleDirective, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: RippleDirective, selector: "[uRipple]", inputs: { rippleConfig: "rippleConfig", disabled: ["rippleDisabled", "disabled"] }, host: { listeners: { "mousedown": "_mousedown($event)", "touchstart": "_touchstart($event)" } }, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RippleDirective, decorators: [{ type: Directive, args: [{ selector: '[uRipple]', standalone: false, }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }]; }, propDecorators: { rippleConfig: [{ type: Input }], disabled: [{ type: Input, args: ['rippleDisabled'] }], _mousedown: [{ type: HostListener, args: ['mousedown', ['$event']] }], _touchstart: [{ type: HostListener, args: ['touchstart', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ripple.directive.js","sourceRoot":"","sources":["../../../../../src/ripple/ripple.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, HostListener, Inject, Input } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\nimport { RippleConfig } from './ripple-config.model';\n\n@Directive({\n  selector: '[uRipple]',\n  standalone: false,\n})\nexport class RippleDirective implements AfterViewInit {\n\n  @Input() rippleConfig: RippleConfig = {};\n  @Input('rippleDisabled') disabled = false;\n\n  isTouching = false;\n\n  constructor(protected readonly _elementRef: ElementRef<HTMLElement>,\n              @Inject(DOCUMENT) private document: any) {\n  }\n\n  private static _setElementSquareSizeAndCenter(element: HTMLElement, size: number) {\n    element.style.top = '50%';\n    element.style.left = '50%';\n    element.style.width = `${size}px`;\n    element.style.height = `${size}px`;\n    element.style.marginLeft = `${-size / 2}px`;\n    element.style.marginTop = `${-size / 2}px`;\n  }\n\n  @HostListener('mousedown', ['$event']) _mousedown = (e: MouseEvent) => {\n    if (this.disabled ||\n      this._elementRef.nativeElement.hasAttribute('disabled') ||\n      this._elementRef.nativeElement.classList.contains('disabled')) {\n      return;\n    }\n\n    if (!this.isTouching) {\n      this.createRipple('mouseup', null, e.clientX, e.clientY);\n    }\n  }\n\n  @HostListener('touchstart', ['$event']) _touchstart = (e: TouchEvent) => {\n    if (this.disabled ||\n      this._elementRef.nativeElement.hasAttribute('disabled') ||\n      this._elementRef.nativeElement.classList.contains('disabled')) {\n      return;\n    }\n\n    this.isTouching = true;\n    this.createRipple('touchend', () => {\n      setTimeout(() => this.isTouching = false, 100);\n    }, e.touches[0].clientX, e.touches[0].clientY);\n  }\n\n  ngAfterViewInit(): void {\n    const {position} = document.defaultView!.getComputedStyle(this._elementRef.nativeElement);\n\n    if (position !== 'absolute' &&\n      position !== 'fixed' &&\n      (!this.rippleConfig || !this.rippleConfig.dontChangePositioning)) {\n      this._elementRef.nativeElement.style.position = 'relative';\n    }\n  }\n\n  createRipple(releaseEventName: string, releaseCallback: Function | null, pageX: number, pageY: number) {\n    if (this.disabled ||\n      this._elementRef.nativeElement.hasAttribute('disabled') ||\n      this._elementRef.nativeElement.classList.contains('disabled')) {\n      return;\n    }\n\n    let release: () => void;\n\n    const cancelRippleIfNecessary = () => {\n\n      this._elementRef.nativeElement.removeEventListener(\"touchmove\", cancelRippleIfNecessary);\n      window.removeEventListener(releaseEventName, cancelRippleIfNecessary);\n\n      if (release) {\n        release();\n      }\n    };\n\n    this._elementRef.nativeElement.addEventListener(\"touchmove\", cancelRippleIfNecessary);\n    window.addEventListener(releaseEventName, cancelRippleIfNecessary);\n\n    const rippleWrapper = document.createElement('DIV');\n    rippleWrapper.classList.add('u-ripple-wrapper');\n\n    const ripple = document.createElement('DIV');\n    ripple.classList.add('u-ripple');\n    rippleWrapper.appendChild(ripple);\n    this._elementRef.nativeElement.insertAdjacentElement('afterbegin', rippleWrapper);\n\n    if (this.rippleConfig.size) {\n      RippleDirective._setElementSquareSizeAndCenter(rippleWrapper, this.rippleConfig.size);\n    }\n\n    if (this.rippleConfig.borderRadius) {\n      rippleWrapper.style.borderRadius = this.rippleConfig.borderRadius;\n    }\n\n    release = () => {\n\n      if (ripple.classList.contains('dismiss')) {\n        return;\n      }\n\n      ripple.classList.add('dismiss');\n\n      ripple.addEventListener('transitionend', () => {\n        this._elementRef.nativeElement.removeChild(rippleWrapper);\n        this._elementRef.nativeElement.removeEventListener('touchend', release);\n        this._elementRef.nativeElement.removeEventListener('mouseleave', release);\n        this._elementRef.nativeElement.removeEventListener('mouseup', release);\n      });\n\n      if (releaseCallback) {\n        releaseCallback();\n        releaseCallback = null;\n      }\n    };\n\n    this._elementRef.nativeElement.addEventListener('touchend', release);\n    this._elementRef.nativeElement.addEventListener('mouseleave', release);\n    this._elementRef.nativeElement.addEventListener('mouseup', release);\n\n    requestAnimationFrame(() => {\n      const clientRect = this._elementRef.nativeElement.getBoundingClientRect();\n      const largestDimensionSize = Math.max(rippleWrapper.clientWidth, rippleWrapper.clientHeight);\n      const rippleSize = this.rippleConfig.size || largestDimensionSize * 2;\n      RippleDirective._setElementSquareSizeAndCenter(ripple, rippleSize);\n      ripple.style.transitionDuration = `${1080 * Math.pow(rippleSize, 0.3)}ms, 750ms`;\n\n      const x = (pageX - clientRect.left) + ((rippleSize - this._elementRef.nativeElement.clientWidth) / 2);\n      const y = (pageY - clientRect.top) + ((rippleSize - this._elementRef.nativeElement.clientHeight) / 2);\n\n      ripple.style.transformOrigin = `${x}px ${y}px`;\n      ripple.classList.add('show');\n    });\n  }\n}\n"]}