devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
131 lines (124 loc) • 4.95 kB
JavaScript
/**
* DevExtreme (cjs/ui/widget/utils.ink_ripple.js)
* Version: 24.2.6
* Build date: Mon Mar 17 2025
*
* Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
"use strict";
exports.hideWave = hideWave;
exports.render = exports.initConfig = void 0;
exports.showWave = showWave;
var _size = require("../../core/utils/size");
var _renderer = _interopRequireDefault(require("../../core/renderer"));
function _interopRequireDefault(e) {
return e && e.__esModule ? e : {
default: e
}
}
const INKRIPPLE_CLASS = "dx-inkripple";
const INKRIPPLE_WAVE_CLASS = "dx-inkripple-wave";
const INKRIPPLE_SHOWING_CLASS = "dx-inkripple-showing";
const INKRIPPLE_HIDING_CLASS = "dx-inkripple-hiding";
const DEFAULT_WAVE_SIZE_COEFFICIENT = 2;
const MAX_WAVE_SIZE = 4e3;
const ANIMATION_DURATION = 300;
const HOLD_ANIMATION_DURATION = 1e3;
const DEFAULT_WAVE_INDEX = 0;
const initConfig = function() {
let config = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {};
const {
useHoldAnimation: useHoldAnimation,
waveSizeCoefficient: waveSizeCoefficient,
isCentered: isCentered,
wavesNumber: wavesNumber
} = config;
return {
waveSizeCoefficient: waveSizeCoefficient || 2,
isCentered: isCentered || false,
wavesNumber: wavesNumber || 1,
durations: getDurations(useHoldAnimation ?? true)
}
};
exports.initConfig = initConfig;
const render = function(args) {
const config = initConfig(args);
return {
showWave: showWave.bind(this, config),
hideWave: hideWave.bind(this, config)
}
};
exports.render = render;
const getInkRipple = function(element) {
let result = element.children(".dx-inkripple");
if (0 === result.length) {
result = (0, _renderer.default)("<div>").addClass("dx-inkripple").appendTo(element)
}
return result
};
const getWaves = function(element, wavesNumber) {
const inkRipple = getInkRipple((0, _renderer.default)(element));
const result = inkRipple.children(".dx-inkripple-wave").toArray();
for (let i = result.length; i < wavesNumber; i++) {
const $currentWave = (0, _renderer.default)("<div>").appendTo(inkRipple).addClass("dx-inkripple-wave");
result.push($currentWave[0])
}
return (0, _renderer.default)(result)
};
const getWaveStyleConfig = function(args, config) {
const element = (0, _renderer.default)(config.element);
const elementWidth = (0, _size.getOuterWidth)(element);
const elementHeight = (0, _size.getOuterHeight)(element);
const elementDiagonal = parseInt(Math.sqrt(elementWidth * elementWidth + elementHeight * elementHeight));
const waveSize = Math.min(4e3, parseInt(elementDiagonal * args.waveSizeCoefficient));
let left;
let top;
if (args.isCentered) {
left = (elementWidth - waveSize) / 2;
top = (elementHeight - waveSize) / 2
} else {
const event = config.event;
const position = element.offset();
const x = event.pageX - position.left;
const y = event.pageY - position.top;
left = x - waveSize / 2;
top = y - waveSize / 2
}
return {
left: left,
top: top,
height: waveSize,
width: waveSize
}
};
function showWave(args, config) {
const $wave = getWaves(config.element, args.wavesNumber).eq(config.wave || DEFAULT_WAVE_INDEX);
args.hidingTimeout && clearTimeout(args.hidingTimeout);
hideSelectedWave($wave);
$wave.css(getWaveStyleConfig(args, config));
args.showingTimeout = setTimeout(showingWaveHandler.bind(this, args, $wave), 0)
}
function showingWaveHandler(args, $wave) {
const durationCss = args.durations.showingScale + "ms";
$wave.addClass(INKRIPPLE_SHOWING_CLASS).css("transitionDuration", durationCss)
}
function getDurations(useHoldAnimation) {
return {
showingScale: useHoldAnimation ? 1e3 : 300,
hidingScale: 300,
hidingOpacity: 300
}
}
function hideSelectedWave($wave) {
$wave.removeClass(INKRIPPLE_HIDING_CLASS).css("transitionDuration", "")
}
function hideWave(args, config) {
args.showingTimeout && clearTimeout(args.showingTimeout);
const $wave = getWaves(config.element, config.wavesNumber).eq(config.wave || DEFAULT_WAVE_INDEX);
const durations = args.durations;
const durationCss = durations.hidingScale + "ms, " + durations.hidingOpacity + "ms";
$wave.addClass(INKRIPPLE_HIDING_CLASS).removeClass(INKRIPPLE_SHOWING_CLASS).css("transitionDuration", durationCss);
const animationDuration = Math.max(durations.hidingScale, durations.hidingOpacity);
args.hidingTimeout = setTimeout(hideSelectedWave.bind(this, $wave), animationDuration)
}