@tsparticles/plugin-interactivity 4.0.0-alpha.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/284.min.js +2 -0
- package/284.min.js.LICENSE.txt +1 -0
- package/721.min.js +2 -0
- package/721.min.js.LICENSE.txt +1 -0
- package/LICENSE +21 -0
- package/README.md +74 -0
- package/browser/DivType.js +5 -0
- package/browser/ExternalInteractorBase.js +7 -0
- package/browser/IExternalInteractor.js +1 -0
- package/browser/IInteractivityData.js +1 -0
- package/browser/IInteractor.js +1 -0
- package/browser/IMouseData.js +1 -0
- package/browser/IParticlesInteractor.js +1 -0
- package/browser/InteractionManager.js +202 -0
- package/browser/InteractivityConstants.js +1 -0
- package/browser/InteractivityDetect.js +6 -0
- package/browser/InteractivityEventListeners.js +235 -0
- package/browser/InteractivityPlugin.js +48 -0
- package/browser/InteractivityPluginInstance.js +52 -0
- package/browser/InteractorType.js +5 -0
- package/browser/Options/Classes/Events/ClickEvent.js +18 -0
- package/browser/Options/Classes/Events/DivEvent.js +27 -0
- package/browser/Options/Classes/Events/Events.js +26 -0
- package/browser/Options/Classes/Events/HoverEvent.js +18 -0
- package/browser/Options/Classes/Interactivity.js +22 -0
- package/browser/Options/Classes/Modes/Modes.js +25 -0
- package/browser/Options/Interfaces/Events/IClickEvent.js +1 -0
- package/browser/Options/Interfaces/Events/IDivEvent.js +1 -0
- package/browser/Options/Interfaces/Events/IEvents.js +1 -0
- package/browser/Options/Interfaces/Events/IHoverEvent.js +1 -0
- package/browser/Options/Interfaces/IInteractivity.js +1 -0
- package/browser/Options/Interfaces/Modes/IModeDiv.js +1 -0
- package/browser/Options/Interfaces/Modes/IModes.js +1 -0
- package/browser/ParticlesInteractorBase.js +7 -0
- package/browser/index.js +38 -0
- package/browser/package.json +1 -0
- package/browser/types.js +1 -0
- package/browser/utils.js +32 -0
- package/cjs/DivType.js +5 -0
- package/cjs/ExternalInteractorBase.js +7 -0
- package/cjs/IExternalInteractor.js +1 -0
- package/cjs/IInteractivityData.js +1 -0
- package/cjs/IInteractor.js +1 -0
- package/cjs/IMouseData.js +1 -0
- package/cjs/IParticlesInteractor.js +1 -0
- package/cjs/InteractionManager.js +202 -0
- package/cjs/InteractivityConstants.js +1 -0
- package/cjs/InteractivityDetect.js +6 -0
- package/cjs/InteractivityEventListeners.js +235 -0
- package/cjs/InteractivityPlugin.js +48 -0
- package/cjs/InteractivityPluginInstance.js +52 -0
- package/cjs/InteractorType.js +5 -0
- package/cjs/Options/Classes/Events/ClickEvent.js +18 -0
- package/cjs/Options/Classes/Events/DivEvent.js +27 -0
- package/cjs/Options/Classes/Events/Events.js +26 -0
- package/cjs/Options/Classes/Events/HoverEvent.js +18 -0
- package/cjs/Options/Classes/Interactivity.js +22 -0
- package/cjs/Options/Classes/Modes/Modes.js +25 -0
- package/cjs/Options/Interfaces/Events/IClickEvent.js +1 -0
- package/cjs/Options/Interfaces/Events/IDivEvent.js +1 -0
- package/cjs/Options/Interfaces/Events/IEvents.js +1 -0
- package/cjs/Options/Interfaces/Events/IHoverEvent.js +1 -0
- package/cjs/Options/Interfaces/IInteractivity.js +1 -0
- package/cjs/Options/Interfaces/Modes/IModeDiv.js +1 -0
- package/cjs/Options/Interfaces/Modes/IModes.js +1 -0
- package/cjs/ParticlesInteractorBase.js +7 -0
- package/cjs/index.js +38 -0
- package/cjs/package.json +1 -0
- package/cjs/types.js +1 -0
- package/cjs/utils.js +32 -0
- package/dist_browser_InteractivityPluginInstance_js.js +50 -0
- package/dist_browser_InteractivityPlugin_js.js +70 -0
- package/esm/DivType.js +5 -0
- package/esm/ExternalInteractorBase.js +7 -0
- package/esm/IExternalInteractor.js +1 -0
- package/esm/IInteractivityData.js +1 -0
- package/esm/IInteractor.js +1 -0
- package/esm/IMouseData.js +1 -0
- package/esm/IParticlesInteractor.js +1 -0
- package/esm/InteractionManager.js +202 -0
- package/esm/InteractivityConstants.js +1 -0
- package/esm/InteractivityDetect.js +6 -0
- package/esm/InteractivityEventListeners.js +235 -0
- package/esm/InteractivityPlugin.js +48 -0
- package/esm/InteractivityPluginInstance.js +52 -0
- package/esm/InteractorType.js +5 -0
- package/esm/Options/Classes/Events/ClickEvent.js +18 -0
- package/esm/Options/Classes/Events/DivEvent.js +27 -0
- package/esm/Options/Classes/Events/Events.js +26 -0
- package/esm/Options/Classes/Events/HoverEvent.js +18 -0
- package/esm/Options/Classes/Interactivity.js +22 -0
- package/esm/Options/Classes/Modes/Modes.js +25 -0
- package/esm/Options/Interfaces/Events/IClickEvent.js +1 -0
- package/esm/Options/Interfaces/Events/IDivEvent.js +1 -0
- package/esm/Options/Interfaces/Events/IEvents.js +1 -0
- package/esm/Options/Interfaces/Events/IHoverEvent.js +1 -0
- package/esm/Options/Interfaces/IInteractivity.js +1 -0
- package/esm/Options/Interfaces/Modes/IModeDiv.js +1 -0
- package/esm/Options/Interfaces/Modes/IModes.js +1 -0
- package/esm/ParticlesInteractorBase.js +7 -0
- package/esm/index.js +38 -0
- package/esm/package.json +1 -0
- package/esm/types.js +1 -0
- package/esm/utils.js +32 -0
- package/package.json +95 -0
- package/report.html +40 -0
- package/tsparticles.plugin.interactivity.js +395 -0
- package/tsparticles.plugin.interactivity.min.js +2 -0
- package/tsparticles.plugin.interactivity.min.js.LICENSE.txt +1 -0
- package/types/DivType.d.ts +4 -0
- package/types/ExternalInteractorBase.d.ts +15 -0
- package/types/IExternalInteractor.d.ts +11 -0
- package/types/IInteractivityData.d.ts +6 -0
- package/types/IInteractor.d.ts +12 -0
- package/types/IMouseData.d.ts +9 -0
- package/types/IParticlesInteractor.d.ts +7 -0
- package/types/InteractionManager.d.ts +27 -0
- package/types/InteractivityConstants.d.ts +1 -0
- package/types/InteractivityDetect.d.ts +5 -0
- package/types/InteractivityEventListeners.d.ts +23 -0
- package/types/InteractivityPlugin.d.ts +11 -0
- package/types/InteractivityPluginInstance.d.ts +20 -0
- package/types/InteractorType.d.ts +4 -0
- package/types/Options/Classes/Events/ClickEvent.d.ts +8 -0
- package/types/Options/Classes/Events/DivEvent.d.ts +11 -0
- package/types/Options/Classes/Events/Events.d.ts +12 -0
- package/types/Options/Classes/Events/HoverEvent.d.ts +8 -0
- package/types/Options/Classes/Interactivity.d.ts +14 -0
- package/types/Options/Classes/Modes/Modes.d.ts +10 -0
- package/types/Options/Interfaces/Events/IClickEvent.d.ts +5 -0
- package/types/Options/Interfaces/Events/IDivEvent.d.ts +8 -0
- package/types/Options/Interfaces/Events/IEvents.d.ts +9 -0
- package/types/Options/Interfaces/Events/IHoverEvent.d.ts +5 -0
- package/types/Options/Interfaces/IInteractivity.d.ts +9 -0
- package/types/Options/Interfaces/Modes/IModeDiv.d.ts +4 -0
- package/types/Options/Interfaces/Modes/IModes.d.ts +1 -0
- package/types/ParticlesInteractorBase.d.ts +15 -0
- package/types/index.d.ts +19 -0
- package/types/types.d.ts +32 -0
- package/types/utils.d.ts +7 -0
- package/umd/DivType.js +18 -0
- package/umd/ExternalInteractorBase.js +21 -0
- package/umd/IExternalInteractor.js +12 -0
- package/umd/IInteractivityData.js +12 -0
- package/umd/IInteractor.js +12 -0
- package/umd/IMouseData.js +12 -0
- package/umd/IParticlesInteractor.js +12 -0
- package/umd/InteractionManager.js +216 -0
- package/umd/InteractivityConstants.js +14 -0
- package/umd/InteractivityDetect.js +19 -0
- package/umd/InteractivityEventListeners.js +249 -0
- package/umd/InteractivityPlugin.js +96 -0
- package/umd/InteractivityPluginInstance.js +66 -0
- package/umd/InteractorType.js +18 -0
- package/umd/Options/Classes/Events/ClickEvent.js +32 -0
- package/umd/Options/Classes/Events/DivEvent.js +41 -0
- package/umd/Options/Classes/Events/Events.js +40 -0
- package/umd/Options/Classes/Events/HoverEvent.js +32 -0
- package/umd/Options/Classes/Interactivity.js +36 -0
- package/umd/Options/Classes/Modes/Modes.js +39 -0
- package/umd/Options/Interfaces/Events/IClickEvent.js +12 -0
- package/umd/Options/Interfaces/Events/IDivEvent.js +12 -0
- package/umd/Options/Interfaces/Events/IEvents.js +12 -0
- package/umd/Options/Interfaces/Events/IHoverEvent.js +12 -0
- package/umd/Options/Interfaces/IInteractivity.js +12 -0
- package/umd/Options/Interfaces/Modes/IModeDiv.js +12 -0
- package/umd/Options/Interfaces/Modes/IModes.js +12 -0
- package/umd/ParticlesInteractorBase.js +21 -0
- package/umd/index.js +88 -0
- package/umd/types.js +12 -0
- package/umd/utils.js +48 -0
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Author : Matteo Bruni
|
|
3
|
+
* MIT license: https://opensource.org/licenses/MIT
|
|
4
|
+
* Demo / Generator : https://particles.js.org/
|
|
5
|
+
* GitHub : https://www.github.com/matteobruni/tsparticles
|
|
6
|
+
* How to use? : Check the GitHub README
|
|
7
|
+
* v4.0.0-alpha.4
|
|
8
|
+
*/
|
|
9
|
+
"use strict";
|
|
10
|
+
/*
|
|
11
|
+
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
|
12
|
+
* This devtool is neither made for production nor for readable output files.
|
|
13
|
+
* It uses "eval()" calls to create a separate source file in the browser devtools.
|
|
14
|
+
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
15
|
+
* or disable the default devtool with "devtool: false".
|
|
16
|
+
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
17
|
+
*/
|
|
18
|
+
(this["webpackChunk_tsparticles_plugin_interactivity"] = this["webpackChunk_tsparticles_plugin_interactivity"] || []).push([["dist_browser_InteractivityPluginInstance_js"],{
|
|
19
|
+
|
|
20
|
+
/***/ "./dist/browser/InteractionManager.js"
|
|
21
|
+
/*!********************************************!*\
|
|
22
|
+
!*** ./dist/browser/InteractionManager.js ***!
|
|
23
|
+
\********************************************/
|
|
24
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
25
|
+
|
|
26
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractionManager: () => (/* binding */ InteractionManager)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./InteractivityConstants.js */ \"./dist/browser/InteractivityConstants.js\");\n/* harmony import */ var _InteractivityEventListeners_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./InteractivityEventListeners.js */ \"./dist/browser/InteractivityEventListeners.js\");\n/* harmony import */ var _InteractorType_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./InteractorType.js */ \"./dist/browser/InteractorType.js\");\n\n\n\n\nclass InteractionManager {\n constructor(engine, container) {\n this.container = container;\n this._intersectionManager = entries => {\n const {\n container\n } = this;\n if (container.destroyed || !container.actualOptions.pauseOnOutsideViewport) {\n return;\n }\n for (const entry of entries) {\n if (entry.target !== this.interactivityData.element) {\n continue;\n }\n if (entry.isIntersecting) {\n container.play();\n } else {\n container.pause();\n }\n }\n };\n this._engine = engine;\n this._interactors = [];\n this._externalInteractors = [];\n this._particleInteractors = [];\n this._clickHandlers = new Map();\n this._eventListeners = new _InteractivityEventListeners_js__WEBPACK_IMPORTED_MODULE_2__.InteractivityEventListeners(container, this);\n this.interactivityData = {\n mouse: {\n clicking: false,\n inside: false\n }\n };\n this._intersectionObserver = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.safeIntersectionObserver)(entries => {\n this._intersectionManager(entries);\n });\n }\n addClickHandler(callback) {\n const {\n container,\n interactivityData\n } = this;\n if (container.destroyed) {\n return;\n }\n const el = interactivityData.element;\n if (!el) {\n return;\n }\n const clickOrTouchHandler = (e, pos, radius) => {\n if (container.destroyed) {\n return;\n }\n const pxRatio = container.retina.pixelRatio,\n posRetina = {\n x: pos.x * pxRatio,\n y: pos.y * pxRatio\n },\n particles = container.particles.quadTree.queryCircle(posRetina, radius * pxRatio);\n callback(e, particles);\n },\n clickHandler = e => {\n if (container.destroyed) {\n return;\n }\n const mouseEvent = e,\n pos = {\n x: mouseEvent.offsetX,\n y: mouseEvent.offsetY\n };\n clickOrTouchHandler(e, pos, _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.clickRadius);\n },\n touchStartHandler = () => {\n if (container.destroyed) {\n return;\n }\n touched = true;\n touchMoved = false;\n },\n touchMoveHandler = () => {\n if (container.destroyed) {\n return;\n }\n touchMoved = true;\n },\n touchEndHandler = e => {\n if (container.destroyed) {\n return;\n }\n if (touched && !touchMoved) {\n const touchEvent = e,\n lastTouch = touchEvent.touches[touchEvent.touches.length - _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.touchEndLengthOffset];\n if (!lastTouch) {\n return;\n }\n const element = container.canvas.element,\n canvasRect = element ? element.getBoundingClientRect() : undefined,\n pos = {\n x: lastTouch.clientX - (canvasRect ? canvasRect.left : _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.minCoordinate),\n y: lastTouch.clientY - (canvasRect ? canvasRect.top : _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.minCoordinate)\n };\n clickOrTouchHandler(e, pos, Math.max(lastTouch.radiusX, lastTouch.radiusY));\n }\n touched = false;\n touchMoved = false;\n },\n touchCancelHandler = () => {\n if (container.destroyed) {\n return;\n }\n touched = false;\n touchMoved = false;\n };\n let touched = false,\n touchMoved = false;\n this._clickHandlers.set(_InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.clickEvent, clickHandler);\n this._clickHandlers.set(_InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchStartEvent, touchStartHandler);\n this._clickHandlers.set(_InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchMoveEvent, touchMoveHandler);\n this._clickHandlers.set(_InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchEndEvent, touchEndHandler);\n this._clickHandlers.set(_InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchCancelEvent, touchCancelHandler);\n for (const [key, handler] of this._clickHandlers) {\n el.addEventListener(key, handler);\n }\n }\n addListeners() {\n this._eventListeners.addListeners();\n }\n clearClickHandlers() {\n const {\n container,\n interactivityData\n } = this;\n if (container.destroyed) {\n return;\n }\n for (const [key, handler] of this._clickHandlers) {\n interactivityData.element?.removeEventListener(key, handler);\n }\n this._clickHandlers.clear();\n }\n externalInteract(delta) {\n for (const interactor of this._externalInteractors) {\n const {\n interactivityData\n } = this;\n if (interactor.isEnabled(interactivityData)) {\n interactor.interact(interactivityData, delta);\n }\n }\n }\n handleClickMode(mode) {\n if (this.container.destroyed) {\n return;\n }\n const {\n interactivityData\n } = this;\n for (const interactor of this._externalInteractors) {\n interactor.handleClickMode?.(mode, interactivityData);\n }\n }\n async init() {\n const interactors = await this._engine.getInteractors?.(this.container, true);\n if (!interactors) {\n return;\n }\n this._interactors = interactors;\n this._externalInteractors = [];\n this._particleInteractors = [];\n for (const interactor of this._interactors) {\n switch (interactor.type) {\n case _InteractorType_js__WEBPACK_IMPORTED_MODULE_3__.InteractorType.external:\n this._externalInteractors.push(interactor);\n break;\n case _InteractorType_js__WEBPACK_IMPORTED_MODULE_3__.InteractorType.particles:\n this._particleInteractors.push(interactor);\n break;\n }\n interactor.init();\n }\n }\n particlesInteract(particle, delta) {\n const {\n interactivityData\n } = this;\n for (const interactor of this._externalInteractors) {\n interactor.clear(particle, delta);\n }\n for (const interactor of this._particleInteractors) {\n if (interactor.isEnabled(particle, interactivityData)) {\n interactor.interact(particle, interactivityData, delta);\n }\n }\n }\n removeListeners() {\n this._eventListeners.removeListeners();\n }\n reset(particle) {\n const {\n interactivityData\n } = this;\n for (const interactor of this._externalInteractors) {\n if (interactor.isEnabled(interactivityData)) {\n interactor.reset(interactivityData, particle);\n }\n }\n for (const interactor of this._particleInteractors) {\n if (interactor.isEnabled(particle, interactivityData)) {\n interactor.reset(interactivityData, particle);\n }\n }\n }\n startObserving() {\n const {\n interactivityData\n } = this;\n if (interactivityData.element instanceof HTMLElement && this._intersectionObserver) {\n this._intersectionObserver.observe(interactivityData.element);\n }\n }\n stopObserving() {\n const {\n interactivityData\n } = this;\n if (interactivityData.element instanceof HTMLElement && this._intersectionObserver) {\n this._intersectionObserver.unobserve(interactivityData.element);\n }\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractionManager.js?\n}");
|
|
27
|
+
|
|
28
|
+
/***/ },
|
|
29
|
+
|
|
30
|
+
/***/ "./dist/browser/InteractivityEventListeners.js"
|
|
31
|
+
/*!*****************************************************!*\
|
|
32
|
+
!*** ./dist/browser/InteractivityEventListeners.js ***!
|
|
33
|
+
\*****************************************************/
|
|
34
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
35
|
+
|
|
36
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractivityEventListeners: () => (/* binding */ InteractivityEventListeners)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./InteractivityConstants.js */ \"./dist/browser/InteractivityConstants.js\");\n/* harmony import */ var _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./InteractivityDetect.js */ \"./dist/browser/InteractivityDetect.js\");\n\n\n\nclass InteractivityEventListeners {\n constructor(container, interactionManager) {\n this._canPush = true;\n this._doMouseTouchClick = e => {\n const container = this._container,\n interactionManager = this._interactionManager,\n options = container.actualOptions;\n if (this._canPush) {\n const mouseInteractivity = interactionManager.interactivityData.mouse,\n mousePos = mouseInteractivity.position;\n if (!mousePos) {\n return;\n }\n mouseInteractivity.clickPosition = {\n ...mousePos\n };\n mouseInteractivity.clickTime = Date.now();\n const onClick = options.interactivity?.events.onClick;\n if (!onClick?.mode) {\n return;\n }\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.executeOnSingleOrMultiple)(onClick.mode, mode => {\n interactionManager.handleClickMode(mode);\n });\n }\n if (e.type === \"touchend\") {\n setTimeout(() => {\n this._mouseTouchFinish();\n }, _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.touchDelay);\n }\n };\n this._handleVisibilityChange = () => {\n this._mouseTouchFinish();\n };\n this._manageInteractivityListeners = (mouseLeaveTmpEvent, add) => {\n const handlers = this._handlers,\n container = this._container,\n interactionManager = this._interactionManager,\n options = container.actualOptions,\n interactivityEl = interactionManager.interactivityData.element;\n if (!interactivityEl) {\n return;\n }\n const html = interactivityEl,\n canvas = container.canvas;\n canvas.setPointerEvents(html === canvas.element ? \"initial\" : \"none\");\n if (!(options.interactivity?.events.onHover.enable || options.interactivity?.events.onClick.enable)) {\n return;\n }\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseMoveEvent, handlers.mouseMove, add);\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchStartEvent, handlers.touchStart, add);\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchMoveEvent, handlers.touchMove, add);\n if (options.interactivity.events.onClick.enable) {\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchEndEvent, handlers.touchEndClick, add);\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseUpEvent, handlers.mouseUp, add);\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseDownEvent, handlers.mouseDown, add);\n } else {\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchEndEvent, handlers.touchEnd, add);\n }\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, mouseLeaveTmpEvent, handlers.mouseLeave, add);\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(interactivityEl, _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.touchCancelEvent, handlers.touchCancel, add);\n };\n this._manageListeners = add => {\n const handlers = this._handlers,\n container = this._container,\n interactionManager = this._interactionManager,\n options = container.actualOptions,\n detectType = options.interactivity?.detectsOn,\n canvasEl = container.canvas.element;\n let mouseLeaveTmpEvent = _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseLeaveEvent;\n if (detectType === _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_2__.InteractivityDetect.window) {\n interactionManager.interactivityData.element = globalThis;\n mouseLeaveTmpEvent = _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseOutEvent;\n } else if (detectType === _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_2__.InteractivityDetect.parent && canvasEl) {\n interactionManager.interactivityData.element = canvasEl.parentElement ?? canvasEl.parentNode;\n } else {\n interactionManager.interactivityData.element = canvasEl;\n }\n this._manageInteractivityListeners(mouseLeaveTmpEvent, add);\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.manageListener)(document, _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.visibilityChangeEvent, handlers.visibilityChange, add, false);\n };\n this._mouseDown = () => {\n const {\n interactivityData\n } = this._interactionManager,\n {\n mouse\n } = interactivityData;\n mouse.clicking = true;\n mouse.downPosition = mouse.position;\n };\n this._mouseTouchClick = e => {\n const container = this._container,\n interactionManager = this._interactionManager,\n options = container.actualOptions,\n {\n mouse\n } = interactionManager.interactivityData;\n mouse.inside = true;\n let handled = false;\n const mousePosition = mouse.position;\n if (!mousePosition || !options.interactivity?.events.onClick.enable) {\n return;\n }\n for (const plugin of container.plugins) {\n if (!plugin.clickPositionValid) {\n continue;\n }\n handled = plugin.clickPositionValid(mousePosition);\n if (handled) {\n break;\n }\n }\n if (!handled) {\n this._doMouseTouchClick(e);\n }\n mouse.clicking = false;\n };\n this._mouseTouchFinish = () => {\n const {\n interactivityData\n } = this._interactionManager,\n {\n mouse\n } = interactivityData;\n delete mouse.position;\n delete mouse.clickPosition;\n delete mouse.downPosition;\n interactivityData.status = _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseLeaveEvent;\n mouse.inside = false;\n mouse.clicking = false;\n };\n this._mouseTouchMove = e => {\n const container = this._container,\n interactionManager = this._interactionManager,\n options = container.actualOptions,\n interactivity = interactionManager.interactivityData,\n canvasEl = container.canvas.element;\n if (!interactivity.element) {\n return;\n }\n interactivity.mouse.inside = true;\n let pos;\n if (e.type.startsWith(\"pointer\")) {\n this._canPush = true;\n const mouseEvent = e;\n if (interactivity.element === globalThis) {\n if (canvasEl) {\n const clientRect = canvasEl.getBoundingClientRect();\n pos = {\n x: mouseEvent.clientX - clientRect.left,\n y: mouseEvent.clientY - clientRect.top\n };\n }\n } else if (options.interactivity?.detectsOn === _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_2__.InteractivityDetect.parent) {\n const source = mouseEvent.target,\n target = mouseEvent.currentTarget;\n if (canvasEl) {\n const sourceRect = source.getBoundingClientRect(),\n targetRect = target.getBoundingClientRect(),\n canvasRect = canvasEl.getBoundingClientRect();\n pos = {\n x: mouseEvent.offsetX + _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.double * sourceRect.left - (targetRect.left + canvasRect.left),\n y: mouseEvent.offsetY + _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.double * sourceRect.top - (targetRect.top + canvasRect.top)\n };\n } else {\n pos = {\n x: mouseEvent.offsetX,\n y: mouseEvent.offsetY\n };\n }\n } else if (mouseEvent.target === canvasEl) {\n pos = {\n x: mouseEvent.offsetX,\n y: mouseEvent.offsetY\n };\n }\n } else {\n this._canPush = e.type !== \"touchmove\";\n if (canvasEl) {\n const touchEvent = e,\n lastTouch = touchEvent.touches[touchEvent.touches.length - _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.lengthOffset],\n canvasRect = canvasEl.getBoundingClientRect();\n if (!lastTouch) {\n return;\n }\n pos = {\n x: lastTouch.clientX - canvasRect.left,\n y: lastTouch.clientY - canvasRect.top\n };\n }\n }\n const pxRatio = container.retina.pixelRatio;\n if (pos) {\n pos.x *= pxRatio;\n pos.y *= pxRatio;\n }\n interactivity.mouse.position = pos;\n interactivity.status = _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_1__.mouseMoveEvent;\n };\n this._touchEnd = e => {\n const evt = e,\n touches = Array.from(evt.changedTouches);\n for (const touch of touches) {\n this._touches.delete(touch.identifier);\n }\n this._mouseTouchFinish();\n };\n this._touchEndClick = e => {\n const evt = e,\n touches = Array.from(evt.changedTouches);\n for (const touch of touches) {\n this._touches.delete(touch.identifier);\n }\n this._mouseTouchClick(e);\n };\n this._touchStart = e => {\n const evt = e,\n touches = Array.from(evt.changedTouches);\n for (const touch of touches) {\n this._touches.set(touch.identifier, performance.now());\n }\n this._mouseTouchMove(e);\n };\n this._container = container;\n this._interactionManager = interactionManager;\n this._touches = new Map();\n this._handlers = {\n mouseDown: () => {\n this._mouseDown();\n },\n mouseLeave: () => {\n this._mouseTouchFinish();\n },\n mouseMove: e => {\n this._mouseTouchMove(e);\n },\n mouseUp: e => {\n this._mouseTouchClick(e);\n },\n touchStart: e => {\n this._touchStart(e);\n },\n touchMove: e => {\n this._mouseTouchMove(e);\n },\n touchEnd: e => {\n this._touchEnd(e);\n },\n touchCancel: e => {\n this._touchEnd(e);\n },\n touchEndClick: e => {\n this._touchEndClick(e);\n },\n visibilityChange: () => {\n this._handleVisibilityChange();\n }\n };\n }\n addListeners() {\n this._manageListeners(true);\n }\n removeListeners() {\n this._manageListeners(false);\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractivityEventListeners.js?\n}");
|
|
37
|
+
|
|
38
|
+
/***/ },
|
|
39
|
+
|
|
40
|
+
/***/ "./dist/browser/InteractivityPluginInstance.js"
|
|
41
|
+
/*!*****************************************************!*\
|
|
42
|
+
!*** ./dist/browser/InteractivityPluginInstance.js ***!
|
|
43
|
+
\*****************************************************/
|
|
44
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
45
|
+
|
|
46
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractivityPluginInstance: () => (/* binding */ InteractivityPluginInstance)\n/* harmony export */ });\n/* harmony import */ var _InteractionManager_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./InteractionManager.js */ \"./dist/browser/InteractionManager.js\");\n/* harmony import */ var _Options_Classes_Interactivity_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Options/Classes/Interactivity.js */ \"./dist/browser/Options/Classes/Interactivity.js\");\n\n\nclass InteractivityPluginInstance {\n constructor(engine, container) {\n this._container = container;\n this._engine = engine;\n this.interactionManager = new _InteractionManager_js__WEBPACK_IMPORTED_MODULE_0__.InteractionManager(engine, container);\n this._container.addClickHandler = callback => {\n this.interactionManager.addClickHandler(callback);\n };\n }\n addClickHandler(callback) {\n this.interactionManager.addClickHandler(callback);\n }\n clearClickHandlers() {\n this.interactionManager.clearClickHandlers();\n }\n destroy() {\n this.clearClickHandlers();\n this._engine.interactors?.delete(this._container);\n }\n particleCreated(particle) {\n const interactivityParticle = particle,\n interactivity = new _Options_Classes_Interactivity_js__WEBPACK_IMPORTED_MODULE_1__.Interactivity(this._engine, this._container);\n interactivity.load(this._container.actualOptions.interactivity);\n interactivity.load(interactivityParticle.options.interactivity);\n interactivityParticle.interactivity = interactivity;\n }\n particleReset(particle) {\n this.interactionManager.reset(particle);\n }\n postParticleUpdate(particle, delta) {\n this.interactionManager.particlesInteract(particle, delta);\n }\n postUpdate(delta) {\n this.interactionManager.externalInteract(delta);\n }\n async preInit() {\n await this.interactionManager.init();\n }\n async redrawInit() {\n await this.interactionManager.init();\n }\n start() {\n this.interactionManager.addListeners();\n this.interactionManager.startObserving();\n return Promise.resolve();\n }\n stop() {\n this.interactionManager.removeListeners();\n this.interactionManager.stopObserving();\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractivityPluginInstance.js?\n}");
|
|
47
|
+
|
|
48
|
+
/***/ }
|
|
49
|
+
|
|
50
|
+
}]);
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Author : Matteo Bruni
|
|
3
|
+
* MIT license: https://opensource.org/licenses/MIT
|
|
4
|
+
* Demo / Generator : https://particles.js.org/
|
|
5
|
+
* GitHub : https://www.github.com/matteobruni/tsparticles
|
|
6
|
+
* How to use? : Check the GitHub README
|
|
7
|
+
* v4.0.0-alpha.4
|
|
8
|
+
*/
|
|
9
|
+
"use strict";
|
|
10
|
+
/*
|
|
11
|
+
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
|
12
|
+
* This devtool is neither made for production nor for readable output files.
|
|
13
|
+
* It uses "eval()" calls to create a separate source file in the browser devtools.
|
|
14
|
+
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
15
|
+
* or disable the default devtool with "devtool: false".
|
|
16
|
+
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
17
|
+
*/
|
|
18
|
+
(this["webpackChunk_tsparticles_plugin_interactivity"] = this["webpackChunk_tsparticles_plugin_interactivity"] || []).push([["dist_browser_InteractivityPlugin_js"],{
|
|
19
|
+
|
|
20
|
+
/***/ "./dist/browser/InteractivityPlugin.js"
|
|
21
|
+
/*!*********************************************!*\
|
|
22
|
+
!*** ./dist/browser/InteractivityPlugin.js ***!
|
|
23
|
+
\*********************************************/
|
|
24
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
25
|
+
|
|
26
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractivityPlugin: () => (/* binding */ InteractivityPlugin)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _Options_Classes_Interactivity_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Options/Classes/Interactivity.js */ \"./dist/browser/Options/Classes/Interactivity.js\");\n\n\nclass InteractivityPlugin {\n constructor(engine) {\n this._engine = engine;\n this.id = \"interactivity\";\n }\n async getPlugin(container) {\n const {\n InteractivityPluginInstance\n } = await __webpack_require__.e(/*! import() */ \"dist_browser_InteractivityPluginInstance_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./InteractivityPluginInstance.js */ \"./dist/browser/InteractivityPluginInstance.js\"));\n return new InteractivityPluginInstance(this._engine, container);\n }\n loadOptions(container, options, source) {\n if (!this.needsPlugin()) {\n return;\n }\n let interactivityOptions = options.interactivity;\n if (!interactivityOptions?.load) {\n options.interactivity = interactivityOptions = new _Options_Classes_Interactivity_js__WEBPACK_IMPORTED_MODULE_1__.Interactivity(this._engine, container);\n }\n interactivityOptions.load(source?.interactivity);\n const interactors = this._engine.interactors?.get(container);\n if (!interactors) {\n return;\n }\n for (const interactor of interactors) {\n if (interactor.loadOptions) {\n interactor.loadOptions(options, source);\n }\n }\n }\n loadParticlesOptions(container, options, source) {\n if (source?.interactivity) {\n options.interactivity = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.deepExtend)({}, source.interactivity);\n }\n const interactors = this._engine.interactors?.get(container);\n if (!interactors) {\n return;\n }\n for (const interactor of interactors) {\n if (interactor.loadParticlesOptions) {\n interactor.loadParticlesOptions(options, source);\n }\n }\n }\n needsPlugin() {\n return true;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractivityPlugin.js?\n}");
|
|
27
|
+
|
|
28
|
+
/***/ },
|
|
29
|
+
|
|
30
|
+
/***/ "./dist/browser/Options/Classes/Events/ClickEvent.js"
|
|
31
|
+
/*!***********************************************************!*\
|
|
32
|
+
!*** ./dist/browser/Options/Classes/Events/ClickEvent.js ***!
|
|
33
|
+
\***********************************************************/
|
|
34
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
35
|
+
|
|
36
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ClickEvent: () => (/* binding */ ClickEvent)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n\nclass ClickEvent {\n constructor() {\n this.enable = false;\n this.mode = [];\n }\n load(data) {\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(data)) {\n return;\n }\n if (data.enable !== undefined) {\n this.enable = data.enable;\n }\n if (data.mode !== undefined) {\n this.mode = data.mode;\n }\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Options/Classes/Events/ClickEvent.js?\n}");
|
|
37
|
+
|
|
38
|
+
/***/ },
|
|
39
|
+
|
|
40
|
+
/***/ "./dist/browser/Options/Classes/Events/Events.js"
|
|
41
|
+
/*!*******************************************************!*\
|
|
42
|
+
!*** ./dist/browser/Options/Classes/Events/Events.js ***!
|
|
43
|
+
\*******************************************************/
|
|
44
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
45
|
+
|
|
46
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Events: () => (/* binding */ Events)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _ClickEvent_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ClickEvent.js */ \"./dist/browser/Options/Classes/Events/ClickEvent.js\");\n/* harmony import */ var _DivEvent_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./DivEvent.js */ \"./dist/browser/Options/Classes/Events/DivEvent.js\");\n/* harmony import */ var _HoverEvent_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./HoverEvent.js */ \"./dist/browser/Options/Classes/Events/HoverEvent.js\");\n\n\n\n\nclass Events {\n constructor() {\n this.onClick = new _ClickEvent_js__WEBPACK_IMPORTED_MODULE_1__.ClickEvent();\n this.onDiv = new _DivEvent_js__WEBPACK_IMPORTED_MODULE_2__.DivEvent();\n this.onHover = new _HoverEvent_js__WEBPACK_IMPORTED_MODULE_3__.HoverEvent();\n }\n load(data) {\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(data)) {\n return;\n }\n this.onClick.load(data.onClick);\n const onDiv = data.onDiv;\n if (onDiv !== undefined) {\n this.onDiv = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.executeOnSingleOrMultiple)(onDiv, t => {\n const tmp = new _DivEvent_js__WEBPACK_IMPORTED_MODULE_2__.DivEvent();\n tmp.load(t);\n return tmp;\n });\n }\n this.onHover.load(data.onHover);\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Options/Classes/Events/Events.js?\n}");
|
|
47
|
+
|
|
48
|
+
/***/ },
|
|
49
|
+
|
|
50
|
+
/***/ "./dist/browser/Options/Classes/Events/HoverEvent.js"
|
|
51
|
+
/*!***********************************************************!*\
|
|
52
|
+
!*** ./dist/browser/Options/Classes/Events/HoverEvent.js ***!
|
|
53
|
+
\***********************************************************/
|
|
54
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
55
|
+
|
|
56
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ HoverEvent: () => (/* binding */ HoverEvent)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n\nclass HoverEvent {\n constructor() {\n this.enable = false;\n this.mode = [];\n }\n load(data) {\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(data)) {\n return;\n }\n if (data.enable !== undefined) {\n this.enable = data.enable;\n }\n if (data.mode !== undefined) {\n this.mode = data.mode;\n }\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Options/Classes/Events/HoverEvent.js?\n}");
|
|
57
|
+
|
|
58
|
+
/***/ },
|
|
59
|
+
|
|
60
|
+
/***/ "./dist/browser/Options/Classes/Interactivity.js"
|
|
61
|
+
/*!*******************************************************!*\
|
|
62
|
+
!*** ./dist/browser/Options/Classes/Interactivity.js ***!
|
|
63
|
+
\*******************************************************/
|
|
64
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
65
|
+
|
|
66
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Interactivity: () => (/* binding */ Interactivity)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _Events_Events_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Events/Events.js */ \"./dist/browser/Options/Classes/Events/Events.js\");\n/* harmony import */ var _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../InteractivityDetect.js */ \"./dist/browser/InteractivityDetect.js\");\n/* harmony import */ var _Modes_Modes_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Modes/Modes.js */ \"./dist/browser/Options/Classes/Modes/Modes.js\");\n\n\n\n\nclass Interactivity {\n constructor(engine, container) {\n this.detectsOn = _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_2__.InteractivityDetect.window;\n this.events = new _Events_Events_js__WEBPACK_IMPORTED_MODULE_1__.Events();\n this.modes = new _Modes_Modes_js__WEBPACK_IMPORTED_MODULE_3__.Modes(engine, container);\n }\n load(data) {\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(data)) {\n return;\n }\n const detectsOn = data.detectsOn;\n if (detectsOn !== undefined) {\n this.detectsOn = detectsOn;\n }\n this.events.load(data.events);\n this.modes.load(data.modes);\n }\n}\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Options/Classes/Interactivity.js?\n}");
|
|
67
|
+
|
|
68
|
+
/***/ }
|
|
69
|
+
|
|
70
|
+
}]);
|
package/esm/DivType.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import { clickRadius, minCoordinate, safeIntersectionObserver, touchEndLengthOffset, } from "@tsparticles/engine";
|
|
2
|
+
import { clickEvent, touchCancelEvent, touchEndEvent, touchMoveEvent, touchStartEvent, } from "./InteractivityConstants.js";
|
|
3
|
+
import { InteractivityEventListeners } from "./InteractivityEventListeners.js";
|
|
4
|
+
import { InteractorType } from "./InteractorType.js";
|
|
5
|
+
export class InteractionManager {
|
|
6
|
+
constructor(engine, container) {
|
|
7
|
+
this.container = container;
|
|
8
|
+
this._intersectionManager = entries => {
|
|
9
|
+
const { container } = this;
|
|
10
|
+
if (container.destroyed || !container.actualOptions.pauseOnOutsideViewport) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
for (const entry of entries) {
|
|
14
|
+
if (entry.target !== this.interactivityData.element) {
|
|
15
|
+
continue;
|
|
16
|
+
}
|
|
17
|
+
if (entry.isIntersecting) {
|
|
18
|
+
container.play();
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
container.pause();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
this._engine = engine;
|
|
26
|
+
this._interactors = [];
|
|
27
|
+
this._externalInteractors = [];
|
|
28
|
+
this._particleInteractors = [];
|
|
29
|
+
this._clickHandlers = new Map();
|
|
30
|
+
this._eventListeners = new InteractivityEventListeners(container, this);
|
|
31
|
+
this.interactivityData = {
|
|
32
|
+
mouse: {
|
|
33
|
+
clicking: false,
|
|
34
|
+
inside: false,
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
this._intersectionObserver = safeIntersectionObserver(entries => {
|
|
38
|
+
this._intersectionManager(entries);
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
addClickHandler(callback) {
|
|
42
|
+
const { container, interactivityData } = this;
|
|
43
|
+
if (container.destroyed) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const el = interactivityData.element;
|
|
47
|
+
if (!el) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
const clickOrTouchHandler = (e, pos, radius) => {
|
|
51
|
+
if (container.destroyed) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
const pxRatio = container.retina.pixelRatio, posRetina = {
|
|
55
|
+
x: pos.x * pxRatio,
|
|
56
|
+
y: pos.y * pxRatio,
|
|
57
|
+
}, particles = container.particles.quadTree.queryCircle(posRetina, radius * pxRatio);
|
|
58
|
+
callback(e, particles);
|
|
59
|
+
}, clickHandler = (e) => {
|
|
60
|
+
if (container.destroyed) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const mouseEvent = e, pos = {
|
|
64
|
+
x: mouseEvent.offsetX,
|
|
65
|
+
y: mouseEvent.offsetY,
|
|
66
|
+
};
|
|
67
|
+
clickOrTouchHandler(e, pos, clickRadius);
|
|
68
|
+
}, touchStartHandler = () => {
|
|
69
|
+
if (container.destroyed) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
touched = true;
|
|
73
|
+
touchMoved = false;
|
|
74
|
+
}, touchMoveHandler = () => {
|
|
75
|
+
if (container.destroyed) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
touchMoved = true;
|
|
79
|
+
}, touchEndHandler = (e) => {
|
|
80
|
+
if (container.destroyed) {
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
if (touched && !touchMoved) {
|
|
84
|
+
const touchEvent = e, lastTouch = touchEvent.touches[touchEvent.touches.length - touchEndLengthOffset];
|
|
85
|
+
if (!lastTouch) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const element = container.canvas.element, canvasRect = element ? element.getBoundingClientRect() : undefined, pos = {
|
|
89
|
+
x: lastTouch.clientX - (canvasRect ? canvasRect.left : minCoordinate),
|
|
90
|
+
y: lastTouch.clientY - (canvasRect ? canvasRect.top : minCoordinate),
|
|
91
|
+
};
|
|
92
|
+
clickOrTouchHandler(e, pos, Math.max(lastTouch.radiusX, lastTouch.radiusY));
|
|
93
|
+
}
|
|
94
|
+
touched = false;
|
|
95
|
+
touchMoved = false;
|
|
96
|
+
}, touchCancelHandler = () => {
|
|
97
|
+
if (container.destroyed) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
touched = false;
|
|
101
|
+
touchMoved = false;
|
|
102
|
+
};
|
|
103
|
+
let touched = false, touchMoved = false;
|
|
104
|
+
this._clickHandlers.set(clickEvent, clickHandler);
|
|
105
|
+
this._clickHandlers.set(touchStartEvent, touchStartHandler);
|
|
106
|
+
this._clickHandlers.set(touchMoveEvent, touchMoveHandler);
|
|
107
|
+
this._clickHandlers.set(touchEndEvent, touchEndHandler);
|
|
108
|
+
this._clickHandlers.set(touchCancelEvent, touchCancelHandler);
|
|
109
|
+
for (const [key, handler] of this._clickHandlers) {
|
|
110
|
+
el.addEventListener(key, handler);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
addListeners() {
|
|
114
|
+
this._eventListeners.addListeners();
|
|
115
|
+
}
|
|
116
|
+
clearClickHandlers() {
|
|
117
|
+
const { container, interactivityData } = this;
|
|
118
|
+
if (container.destroyed) {
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
for (const [key, handler] of this._clickHandlers) {
|
|
122
|
+
interactivityData.element?.removeEventListener(key, handler);
|
|
123
|
+
}
|
|
124
|
+
this._clickHandlers.clear();
|
|
125
|
+
}
|
|
126
|
+
externalInteract(delta) {
|
|
127
|
+
for (const interactor of this._externalInteractors) {
|
|
128
|
+
const { interactivityData } = this;
|
|
129
|
+
if (interactor.isEnabled(interactivityData)) {
|
|
130
|
+
interactor.interact(interactivityData, delta);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
handleClickMode(mode) {
|
|
135
|
+
if (this.container.destroyed) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
const { interactivityData } = this;
|
|
139
|
+
for (const interactor of this._externalInteractors) {
|
|
140
|
+
interactor.handleClickMode?.(mode, interactivityData);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
async init() {
|
|
144
|
+
const interactors = await this._engine.getInteractors?.(this.container, true);
|
|
145
|
+
if (!interactors) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
this._interactors = interactors;
|
|
149
|
+
this._externalInteractors = [];
|
|
150
|
+
this._particleInteractors = [];
|
|
151
|
+
for (const interactor of this._interactors) {
|
|
152
|
+
switch (interactor.type) {
|
|
153
|
+
case InteractorType.external:
|
|
154
|
+
this._externalInteractors.push(interactor);
|
|
155
|
+
break;
|
|
156
|
+
case InteractorType.particles:
|
|
157
|
+
this._particleInteractors.push(interactor);
|
|
158
|
+
break;
|
|
159
|
+
}
|
|
160
|
+
interactor.init();
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
particlesInteract(particle, delta) {
|
|
164
|
+
const { interactivityData } = this;
|
|
165
|
+
for (const interactor of this._externalInteractors) {
|
|
166
|
+
interactor.clear(particle, delta);
|
|
167
|
+
}
|
|
168
|
+
for (const interactor of this._particleInteractors) {
|
|
169
|
+
if (interactor.isEnabled(particle, interactivityData)) {
|
|
170
|
+
interactor.interact(particle, interactivityData, delta);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
removeListeners() {
|
|
175
|
+
this._eventListeners.removeListeners();
|
|
176
|
+
}
|
|
177
|
+
reset(particle) {
|
|
178
|
+
const { interactivityData } = this;
|
|
179
|
+
for (const interactor of this._externalInteractors) {
|
|
180
|
+
if (interactor.isEnabled(interactivityData)) {
|
|
181
|
+
interactor.reset(interactivityData, particle);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
for (const interactor of this._particleInteractors) {
|
|
185
|
+
if (interactor.isEnabled(particle, interactivityData)) {
|
|
186
|
+
interactor.reset(interactivityData, particle);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
startObserving() {
|
|
191
|
+
const { interactivityData } = this;
|
|
192
|
+
if (interactivityData.element instanceof HTMLElement && this._intersectionObserver) {
|
|
193
|
+
this._intersectionObserver.observe(interactivityData.element);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
stopObserving() {
|
|
197
|
+
const { interactivityData } = this;
|
|
198
|
+
if (interactivityData.element instanceof HTMLElement && this._intersectionObserver) {
|
|
199
|
+
this._intersectionObserver.unobserve(interactivityData.element);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const clickEvent = "click", mouseDownEvent = "pointerdown", mouseUpEvent = "pointerup", mouseLeaveEvent = "pointerleave", mouseOutEvent = "pointerout", mouseMoveEvent = "pointermove", touchStartEvent = "touchstart", touchEndEvent = "touchend", touchMoveEvent = "touchmove", touchCancelEvent = "touchcancel";
|