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