@tsparticles/effect-filter 4.0.0-beta.5 → 4.0.0-beta.6

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/719.min.js CHANGED
@@ -1 +1 @@
1
- "use strict";(this.webpackChunk_tsparticles_effect_filter=this.webpackChunk_tsparticles_effect_filter||[]).push([[719],{719(t,e,r){r.d(e,{FilterDrawer:()=>l});class l{drawAfter(t){let{context:e}=t;e.restore()}drawBefore(t){let{context:e,particle:r}=t;e.save();let l="number"==typeof r.filterBlur?`${r.filterBlur}px`:r.filterBlur,a=l?`blur(${l})`:"",i=r.filterBrightness,f=i?`brightness(${i})`:"",s=r.filterContrast,o=s?`contrast(${s})`:"",u=r.filterDropShadow,$=r.filterGrayscale,p=$?`grayscale(${$})`:"",c="number"==typeof r.filterHueRotate?`${r.filterHueRotate}deg`:r.filterHueRotate,n=c?`hue-rotate(${c})`:"",h=r.filterInvert,d=h?`invert(${h})`:"",w=r.filterOpacity,y=w?`opacity(${w})`:"",b=r.filterSaturate,S=b?`saturate(${b})`:"",g=r.filterSepia,B=g?`sepia(${g})`:"",_=r.filterUrl,v=_?`url(${_})`:"";e.filter=`${a} ${f} ${o} ${u?"drop-shadow(dropShadowValue)":""} ${p} ${n} ${d} ${y} ${S} ${B} ${v}`.trim()}particleInit(t,e){let r=e.effectData;r&&(e.filterBlur=r.blur,e.filterBrightness=r.brightness,e.filterContrast=r.contrast,e.filterDropShadow=!!r.dropShadow,e.filterGrayscale=r.grayscale,e.filterHueRotate=r.hueRotate,e.filterInvert=r.invert,e.filterOpacity=r.opacity,e.filterSaturate=r.saturate,e.filterSepia=r.sepia,e.filterUrl=r.url)}}}}]);
1
+ "use strict";(this.webpackChunk_tsparticles_effect_filter=this.webpackChunk_tsparticles_effect_filter||[]).push([[719],{719(t,e,r){r.d(e,{FilterDrawer:()=>i});var l=r(303);class i{drawAfter(t){let{context:e}=t;e.restore()}drawBefore(t){let{context:e,particle:r}=t;e.save();let i="number"==typeof r.filterBlur?`${r.filterBlur}px`:r.filterBlur,a=r.filterBrightness,s=r.filterContrast,f=r.filterDropShadow,u=r.filterGrayscale,o="number"==typeof r.filterHueRotate?`${r.filterHueRotate}deg`:r.filterHueRotate,$=r.filterInvert,p=r.filterOpacity,c=r.filterSaturate,n=r.filterSepia,h=r.filterUrl,d=i?`blur(${i})`:"",y=(0,l.isNull)(a)?"":`brightness(${a})`,w=(0,l.isNull)(s)?"":`contrast(${s})`,b=f?`drop-shadow(${f})`:"",N=(0,l.isNull)(u)?"":`grayscale(${u})`,g=(0,l.isNull)(o)?"":`hue-rotate(${o})`,B=(0,l.isNull)($)?"":`invert(${$})`,S=(0,l.isNull)(p)?"":`opacity(${p})`,v=(0,l.isNull)(c)?"":`saturate(${c})`,_=(0,l.isNull)(n)?"":`sepia(${n})`,R=h?`url(${h})`:"";e.filter=`${d} ${y} ${w} ${b} ${N} ${g} ${B} ${S} ${v} ${_} ${R}`.trim()}particleInit(t,e){let r=e.effectData;r&&(e.filterBlur=r.blur,e.filterBrightness=r.brightness,e.filterContrast=r.contrast,e.filterDropShadow=r.dropShadow,e.filterGrayscale=r.grayscale,e.filterHueRotate=r.hueRotate,e.filterInvert=r.invert,e.filterOpacity=r.opacity,e.filterSaturate=r.saturate,e.filterSepia=r.sepia,e.filterUrl=r.url)}}}}]);
@@ -1,3 +1,4 @@
1
+ import { isNull } from "@tsparticles/engine";
1
2
  export class FilterDrawer {
2
3
  drawAfter(data) {
3
4
  const { context } = data;
@@ -6,7 +7,7 @@ export class FilterDrawer {
6
7
  drawBefore(data) {
7
8
  const { context, particle } = data;
8
9
  context.save();
9
- const blurValue = typeof particle.filterBlur === "number" ? `${particle.filterBlur}px` : particle.filterBlur, blurString = blurValue ? `blur(${blurValue})` : "", brightnessValue = particle.filterBrightness, brightnessString = brightnessValue ? `brightness(${brightnessValue})` : "", contrastValue = particle.filterContrast, contrastString = contrastValue ? `contrast(${contrastValue})` : "", dropShadowValue = particle.filterDropShadow, dropShadowString = dropShadowValue ? "drop-shadow(dropShadowValue)" : "", grayscaleValue = particle.filterGrayscale, grayscaleString = grayscaleValue ? `grayscale(${grayscaleValue})` : "", hueRotateValue = typeof particle.filterHueRotate === "number" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, hueRotateString = hueRotateValue ? `hue-rotate(${hueRotateValue})` : "", invertValue = particle.filterInvert, invertString = invertValue ? `invert(${invertValue})` : "", opacityValue = particle.filterOpacity, opacityString = opacityValue ? `opacity(${opacityValue})` : "", saturateValue = particle.filterSaturate, saturateString = saturateValue ? `saturate(${saturateValue})` : "", sepiaValue = particle.filterSepia, sepiaString = sepiaValue ? `sepia(${sepiaValue})` : "", urlValue = particle.filterUrl, urlString = urlValue ? `url(${urlValue})` : "";
10
+ const blurValue = typeof particle.filterBlur === "number" ? `${particle.filterBlur}px` : particle.filterBlur, brightnessValue = particle.filterBrightness, contrastValue = particle.filterContrast, dropShadowValue = particle.filterDropShadow, grayscaleValue = particle.filterGrayscale, hueRotateValue = typeof particle.filterHueRotate === "number" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, invertValue = particle.filterInvert, opacityValue = particle.filterOpacity, saturateValue = particle.filterSaturate, sepiaValue = particle.filterSepia, urlValue = particle.filterUrl, blurString = blurValue ? `blur(${blurValue})` : "", brightnessString = isNull(brightnessValue) ? "" : `brightness(${brightnessValue})`, contrastString = isNull(contrastValue) ? "" : `contrast(${contrastValue})`, dropShadowString = dropShadowValue ? `drop-shadow(${dropShadowValue})` : "", grayscaleString = isNull(grayscaleValue) ? "" : `grayscale(${grayscaleValue})`, hueRotateString = isNull(hueRotateValue) ? "" : `hue-rotate(${hueRotateValue})`, invertString = isNull(invertValue) ? "" : `invert(${invertValue})`, opacityString = isNull(opacityValue) ? "" : `opacity(${opacityValue})`, saturateString = isNull(saturateValue) ? "" : `saturate(${saturateValue})`, sepiaString = isNull(sepiaValue) ? "" : `sepia(${sepiaValue})`, urlString = urlValue ? `url(${urlValue})` : "";
10
11
  context.filter =
11
12
  `${blurString} ${brightnessString} ${contrastString} ${dropShadowString} ${grayscaleString} ${hueRotateString} ${invertString} ${opacityString} ${saturateString} ${sepiaString} ${urlString}`.trim();
12
13
  }
@@ -18,7 +19,7 @@ export class FilterDrawer {
18
19
  particle.filterBlur = effectData.blur;
19
20
  particle.filterBrightness = effectData.brightness;
20
21
  particle.filterContrast = effectData.contrast;
21
- particle.filterDropShadow = !!effectData.dropShadow;
22
+ particle.filterDropShadow = effectData.dropShadow;
22
23
  particle.filterGrayscale = effectData.grayscale;
23
24
  particle.filterHueRotate = effectData.hueRotate;
24
25
  particle.filterInvert = effectData.invert;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
package/browser/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  export async function loadFilterEffect(engine) {
2
- engine.checkVersion("4.0.0-beta.5");
2
+ engine.checkVersion("4.0.0-beta.6");
3
3
  await engine.pluginManager.register(e => {
4
4
  e.pluginManager.addEffect("filter", async () => {
5
5
  const { FilterDrawer } = await import("./FilterDrawer.js");
@@ -1,3 +1,4 @@
1
+ import { isNull } from "@tsparticles/engine";
1
2
  export class FilterDrawer {
2
3
  drawAfter(data) {
3
4
  const { context } = data;
@@ -6,7 +7,7 @@ export class FilterDrawer {
6
7
  drawBefore(data) {
7
8
  const { context, particle } = data;
8
9
  context.save();
9
- const blurValue = typeof particle.filterBlur === "number" ? `${particle.filterBlur}px` : particle.filterBlur, blurString = blurValue ? `blur(${blurValue})` : "", brightnessValue = particle.filterBrightness, brightnessString = brightnessValue ? `brightness(${brightnessValue})` : "", contrastValue = particle.filterContrast, contrastString = contrastValue ? `contrast(${contrastValue})` : "", dropShadowValue = particle.filterDropShadow, dropShadowString = dropShadowValue ? "drop-shadow(dropShadowValue)" : "", grayscaleValue = particle.filterGrayscale, grayscaleString = grayscaleValue ? `grayscale(${grayscaleValue})` : "", hueRotateValue = typeof particle.filterHueRotate === "number" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, hueRotateString = hueRotateValue ? `hue-rotate(${hueRotateValue})` : "", invertValue = particle.filterInvert, invertString = invertValue ? `invert(${invertValue})` : "", opacityValue = particle.filterOpacity, opacityString = opacityValue ? `opacity(${opacityValue})` : "", saturateValue = particle.filterSaturate, saturateString = saturateValue ? `saturate(${saturateValue})` : "", sepiaValue = particle.filterSepia, sepiaString = sepiaValue ? `sepia(${sepiaValue})` : "", urlValue = particle.filterUrl, urlString = urlValue ? `url(${urlValue})` : "";
10
+ const blurValue = typeof particle.filterBlur === "number" ? `${particle.filterBlur}px` : particle.filterBlur, brightnessValue = particle.filterBrightness, contrastValue = particle.filterContrast, dropShadowValue = particle.filterDropShadow, grayscaleValue = particle.filterGrayscale, hueRotateValue = typeof particle.filterHueRotate === "number" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, invertValue = particle.filterInvert, opacityValue = particle.filterOpacity, saturateValue = particle.filterSaturate, sepiaValue = particle.filterSepia, urlValue = particle.filterUrl, blurString = blurValue ? `blur(${blurValue})` : "", brightnessString = isNull(brightnessValue) ? "" : `brightness(${brightnessValue})`, contrastString = isNull(contrastValue) ? "" : `contrast(${contrastValue})`, dropShadowString = dropShadowValue ? `drop-shadow(${dropShadowValue})` : "", grayscaleString = isNull(grayscaleValue) ? "" : `grayscale(${grayscaleValue})`, hueRotateString = isNull(hueRotateValue) ? "" : `hue-rotate(${hueRotateValue})`, invertString = isNull(invertValue) ? "" : `invert(${invertValue})`, opacityString = isNull(opacityValue) ? "" : `opacity(${opacityValue})`, saturateString = isNull(saturateValue) ? "" : `saturate(${saturateValue})`, sepiaString = isNull(sepiaValue) ? "" : `sepia(${sepiaValue})`, urlString = urlValue ? `url(${urlValue})` : "";
10
11
  context.filter =
11
12
  `${blurString} ${brightnessString} ${contrastString} ${dropShadowString} ${grayscaleString} ${hueRotateString} ${invertString} ${opacityString} ${saturateString} ${sepiaString} ${urlString}`.trim();
12
13
  }
@@ -18,7 +19,7 @@ export class FilterDrawer {
18
19
  particle.filterBlur = effectData.blur;
19
20
  particle.filterBrightness = effectData.brightness;
20
21
  particle.filterContrast = effectData.contrast;
21
- particle.filterDropShadow = !!effectData.dropShadow;
22
+ particle.filterDropShadow = effectData.dropShadow;
22
23
  particle.filterGrayscale = effectData.grayscale;
23
24
  particle.filterHueRotate = effectData.hueRotate;
24
25
  particle.filterInvert = effectData.invert;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
package/cjs/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  export async function loadFilterEffect(engine) {
2
- engine.checkVersion("4.0.0-beta.5");
2
+ engine.checkVersion("4.0.0-beta.6");
3
3
  await engine.pluginManager.register(e => {
4
4
  e.pluginManager.addEffect("filter", async () => {
5
5
  const { FilterDrawer } = await import("./FilterDrawer.js");
@@ -4,7 +4,7 @@
4
4
  * Demo / Generator : https://particles.js.org/
5
5
  * GitHub : https://www.github.com/matteobruni/tsparticles
6
6
  * How to use? : Check the GitHub README
7
- * v4.0.0-beta.5
7
+ * v4.0.0-beta.6
8
8
  */
9
9
  "use strict";
10
10
  /*
@@ -23,7 +23,7 @@
23
23
  \**************************************/
24
24
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
25
 
26
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ FilterDrawer: () => (/* binding */ FilterDrawer)\n/* harmony export */ });\nclass FilterDrawer {\n drawAfter(data) {\n const { context } = data;\n context.restore();\n }\n drawBefore(data) {\n const { context, particle } = data;\n context.save();\n const blurValue = typeof particle.filterBlur === \"number\" ? `${particle.filterBlur}px` : particle.filterBlur, blurString = blurValue ? `blur(${blurValue})` : \"\", brightnessValue = particle.filterBrightness, brightnessString = brightnessValue ? `brightness(${brightnessValue})` : \"\", contrastValue = particle.filterContrast, contrastString = contrastValue ? `contrast(${contrastValue})` : \"\", dropShadowValue = particle.filterDropShadow, dropShadowString = dropShadowValue ? \"drop-shadow(dropShadowValue)\" : \"\", grayscaleValue = particle.filterGrayscale, grayscaleString = grayscaleValue ? `grayscale(${grayscaleValue})` : \"\", hueRotateValue = typeof particle.filterHueRotate === \"number\" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, hueRotateString = hueRotateValue ? `hue-rotate(${hueRotateValue})` : \"\", invertValue = particle.filterInvert, invertString = invertValue ? `invert(${invertValue})` : \"\", opacityValue = particle.filterOpacity, opacityString = opacityValue ? `opacity(${opacityValue})` : \"\", saturateValue = particle.filterSaturate, saturateString = saturateValue ? `saturate(${saturateValue})` : \"\", sepiaValue = particle.filterSepia, sepiaString = sepiaValue ? `sepia(${sepiaValue})` : \"\", urlValue = particle.filterUrl, urlString = urlValue ? `url(${urlValue})` : \"\";\n context.filter = `${blurString} ${brightnessString} ${contrastString} ${dropShadowString} ${grayscaleString} ${hueRotateString} ${invertString} ${opacityString} ${saturateString} ${sepiaString} ${urlString}`.trim();\n }\n particleInit(_container, particle) {\n const effectData = particle.effectData;\n if (!effectData) {\n return;\n }\n particle.filterBlur = effectData.blur;\n particle.filterBrightness = effectData.brightness;\n particle.filterContrast = effectData.contrast;\n particle.filterDropShadow = !!effectData.dropShadow;\n particle.filterGrayscale = effectData.grayscale;\n particle.filterHueRotate = effectData.hueRotate;\n particle.filterInvert = effectData.invert;\n particle.filterOpacity = effectData.opacity;\n particle.filterSaturate = effectData.saturate;\n particle.filterSepia = effectData.sepia;\n particle.filterUrl = effectData.url;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/effect-filter/./dist/browser/FilterDrawer.js?\n}");
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ FilterDrawer: () => (/* binding */ FilterDrawer)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n\nclass FilterDrawer {\n drawAfter(data) {\n const { context } = data;\n context.restore();\n }\n drawBefore(data) {\n const { context, particle } = data;\n context.save();\n const blurValue = typeof particle.filterBlur === \"number\" ? `${particle.filterBlur}px` : particle.filterBlur, brightnessValue = particle.filterBrightness, contrastValue = particle.filterContrast, dropShadowValue = particle.filterDropShadow, grayscaleValue = particle.filterGrayscale, hueRotateValue = typeof particle.filterHueRotate === \"number\" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, invertValue = particle.filterInvert, opacityValue = particle.filterOpacity, saturateValue = particle.filterSaturate, sepiaValue = particle.filterSepia, urlValue = particle.filterUrl, blurString = blurValue ? `blur(${blurValue})` : \"\", brightnessString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(brightnessValue) ? \"\" : `brightness(${brightnessValue})`, contrastString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(contrastValue) ? \"\" : `contrast(${contrastValue})`, dropShadowString = dropShadowValue ? `drop-shadow(${dropShadowValue})` : \"\", grayscaleString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(grayscaleValue) ? \"\" : `grayscale(${grayscaleValue})`, hueRotateString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(hueRotateValue) ? \"\" : `hue-rotate(${hueRotateValue})`, invertString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(invertValue) ? \"\" : `invert(${invertValue})`, opacityString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(opacityValue) ? \"\" : `opacity(${opacityValue})`, saturateString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(saturateValue) ? \"\" : `saturate(${saturateValue})`, sepiaString = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(sepiaValue) ? \"\" : `sepia(${sepiaValue})`, urlString = urlValue ? `url(${urlValue})` : \"\";\n context.filter = `${blurString} ${brightnessString} ${contrastString} ${dropShadowString} ${grayscaleString} ${hueRotateString} ${invertString} ${opacityString} ${saturateString} ${sepiaString} ${urlString}`.trim();\n }\n particleInit(_container, particle) {\n const effectData = particle.effectData;\n if (!effectData) {\n return;\n }\n particle.filterBlur = effectData.blur;\n particle.filterBrightness = effectData.brightness;\n particle.filterContrast = effectData.contrast;\n particle.filterDropShadow = effectData.dropShadow;\n particle.filterGrayscale = effectData.grayscale;\n particle.filterHueRotate = effectData.hueRotate;\n particle.filterInvert = effectData.invert;\n particle.filterOpacity = effectData.opacity;\n particle.filterSaturate = effectData.saturate;\n particle.filterSepia = effectData.sepia;\n particle.filterUrl = effectData.url;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/effect-filter/./dist/browser/FilterDrawer.js?\n}");
27
27
 
28
28
  /***/ }
29
29
 
@@ -1,3 +1,4 @@
1
+ import { isNull } from "@tsparticles/engine";
1
2
  export class FilterDrawer {
2
3
  drawAfter(data) {
3
4
  const { context } = data;
@@ -6,7 +7,7 @@ export class FilterDrawer {
6
7
  drawBefore(data) {
7
8
  const { context, particle } = data;
8
9
  context.save();
9
- const blurValue = typeof particle.filterBlur === "number" ? `${particle.filterBlur}px` : particle.filterBlur, blurString = blurValue ? `blur(${blurValue})` : "", brightnessValue = particle.filterBrightness, brightnessString = brightnessValue ? `brightness(${brightnessValue})` : "", contrastValue = particle.filterContrast, contrastString = contrastValue ? `contrast(${contrastValue})` : "", dropShadowValue = particle.filterDropShadow, dropShadowString = dropShadowValue ? "drop-shadow(dropShadowValue)" : "", grayscaleValue = particle.filterGrayscale, grayscaleString = grayscaleValue ? `grayscale(${grayscaleValue})` : "", hueRotateValue = typeof particle.filterHueRotate === "number" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, hueRotateString = hueRotateValue ? `hue-rotate(${hueRotateValue})` : "", invertValue = particle.filterInvert, invertString = invertValue ? `invert(${invertValue})` : "", opacityValue = particle.filterOpacity, opacityString = opacityValue ? `opacity(${opacityValue})` : "", saturateValue = particle.filterSaturate, saturateString = saturateValue ? `saturate(${saturateValue})` : "", sepiaValue = particle.filterSepia, sepiaString = sepiaValue ? `sepia(${sepiaValue})` : "", urlValue = particle.filterUrl, urlString = urlValue ? `url(${urlValue})` : "";
10
+ const blurValue = typeof particle.filterBlur === "number" ? `${particle.filterBlur}px` : particle.filterBlur, brightnessValue = particle.filterBrightness, contrastValue = particle.filterContrast, dropShadowValue = particle.filterDropShadow, grayscaleValue = particle.filterGrayscale, hueRotateValue = typeof particle.filterHueRotate === "number" ? `${particle.filterHueRotate}deg` : particle.filterHueRotate, invertValue = particle.filterInvert, opacityValue = particle.filterOpacity, saturateValue = particle.filterSaturate, sepiaValue = particle.filterSepia, urlValue = particle.filterUrl, blurString = blurValue ? `blur(${blurValue})` : "", brightnessString = isNull(brightnessValue) ? "" : `brightness(${brightnessValue})`, contrastString = isNull(contrastValue) ? "" : `contrast(${contrastValue})`, dropShadowString = dropShadowValue ? `drop-shadow(${dropShadowValue})` : "", grayscaleString = isNull(grayscaleValue) ? "" : `grayscale(${grayscaleValue})`, hueRotateString = isNull(hueRotateValue) ? "" : `hue-rotate(${hueRotateValue})`, invertString = isNull(invertValue) ? "" : `invert(${invertValue})`, opacityString = isNull(opacityValue) ? "" : `opacity(${opacityValue})`, saturateString = isNull(saturateValue) ? "" : `saturate(${saturateValue})`, sepiaString = isNull(sepiaValue) ? "" : `sepia(${sepiaValue})`, urlString = urlValue ? `url(${urlValue})` : "";
10
11
  context.filter =
11
12
  `${blurString} ${brightnessString} ${contrastString} ${dropShadowString} ${grayscaleString} ${hueRotateString} ${invertString} ${opacityString} ${saturateString} ${sepiaString} ${urlString}`.trim();
12
13
  }
@@ -18,7 +19,7 @@ export class FilterDrawer {
18
19
  particle.filterBlur = effectData.blur;
19
20
  particle.filterBrightness = effectData.brightness;
20
21
  particle.filterContrast = effectData.contrast;
21
- particle.filterDropShadow = !!effectData.dropShadow;
22
+ particle.filterDropShadow = effectData.dropShadow;
22
23
  particle.filterGrayscale = effectData.grayscale;
23
24
  particle.filterHueRotate = effectData.hueRotate;
24
25
  particle.filterInvert = effectData.invert;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
package/esm/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  export async function loadFilterEffect(engine) {
2
- engine.checkVersion("4.0.0-beta.5");
2
+ engine.checkVersion("4.0.0-beta.6");
3
3
  await engine.pluginManager.register(e => {
4
4
  e.pluginManager.addEffect("filter", async () => {
5
5
  const { FilterDrawer } = await import("./FilterDrawer.js");
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/effect-filter",
3
- "version": "4.0.0-beta.5",
3
+ "version": "4.0.0-beta.6",
4
4
  "description": "tsParticles filter effect",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -99,7 +99,7 @@
99
99
  "./package.json": "./package.json"
100
100
  },
101
101
  "peerDependencies": {
102
- "@tsparticles/engine": "4.0.0-beta.5"
102
+ "@tsparticles/engine": "4.0.0-beta.6"
103
103
  },
104
104
  "publishConfig": {
105
105
  "access": "public"
package/report.html CHANGED
@@ -3,7 +3,7 @@
3
3
  <head>
4
4
  <meta charset="UTF-8" />
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1" />
6
- <title>@tsparticles/effect-filter [2 Apr 2026 at 15:26]</title>
6
+ <title>@tsparticles/effect-filter [2 Apr 2026 at 15:14]</title>
7
7
  <link
8
8
  rel="shortcut icon"
9
9
  href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAABrVBMVEUAAAD///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////+O1foceMD///+J0/qK1Pr7/v8Xdr/9///W8P4UdL7L7P0Scr2r4Pyj3vwad8D5/f/2/f+55f3E6f34+/2H0/ojfMKpzOd0rNgQcb3F3O/j9f7c8v6g3Pz0/P/w+v/q+P7n9v6T1/uQ1vuE0vqLut/y+v+Z2fvt+f+15Pzv9fuc2/vR7v2V2Pvd6/bg9P7I6/285/2y4/yp3/zp8vk8i8kqgMT7/P31+fyv4vxGkcz6/P6/6P3j7vfS5PNnpNUxhcbO7f7F6v3O4vHK3/DA2u631Ouy0eqXweKJud5wqthfoNMMbLvY8f73+v2dxeR8sNtTmdDx9/zX6PSjyeaCtd1YnNGX2PuQveCGt95Nls42h8dLlM3F4vBtAAAAM3RSTlMAAyOx0/sKBvik8opWGBMOAe3l1snDm2E9LSb06eHcu5JpHbarfHZCN9CBb08zzkdNS0kYaptYAAAFV0lEQVRYw92X51/aYBDHHS2O2qqttVbrqNq9m+TJIAYIShBkWwqIiCgoWvfeq7Z2/s29hyQNyUcR7LveGwVyXy6XH8/9rqxglLfUPLxVduUor3h0rfp2TYvpivk37929TkG037hffoX0+peVtZQc1589rigVUdXS/ABSAyEmGIO/1XfvldSK8vs3OqB6u3m0nxmIrvgB0dj7rr7Y9IbuF68hnfFaiHA/sxqm0wciIG43P60qKv9WXWc1RXGh/mFESFABTSBi0sNAKzqet17eCtOb3kZIDwxEEU0oAIJGYxNBDhBND29e0rtXXbcpuPmED9IhEAAQ/AXEaF8EPmnrrKsv0LvWR3fg5sWDNAFZOgAgaKvZDogHNU9MFwnnYROkc56RD5CjAbQX9Ow4g7upCsvYu55aSI/Nj0H1akgKQEUM94dwK65hYRmFU9MIcH/fqJYOZYcnuJSU/waKDgTOEVaVKhwrTRP5XzgSpAITYzom7UvkhFX5VutmxeNnWDjjswTKTyfgluNDGbUpWissXhF3s7mlSml+czWkg3D0l1nNjGNjz3myOQOa1KM/jOS6ebdbAVTCi4gljHSFrviza7tOgRWcS0MOUX9zdNgag5w7rRqA44Lzw0hr1WqES36dFliSJFlh2rXIae3FFcDDgKdxrUIDePr8jGcSClV1u7A9xeN0ModY/pHMxmR1EzRh8TJiwqsHmKW0l4FCEZI+jHio+JdPPE9qwQtTRxku2D8sIeRL2LnxWSllANCQGOIiqVHAz2ye2JR0DcH+HoxDkaADLjgxjKQ+AwCX/g0+DNgdG0ukYCONAe+dbc2IAc6fwt1ARoDSezNHxV2Cmzwv3O6lDMV55edBGwGK9n1+x2F8EDfAGCxug8MhpsMEcTEAWf3rx2vZhe/LAmtIn/6apE6PN0ULKgywD9mmdxbmFl3OvD5AS5fW5zLbv/YHmcsBTjf/afDz3MaZTVCfAP9z6/Bw6ycv8EUBWJIn9zYcoAWWlW9+OzO3vkTy8H+RANLmdrpOuYWdZYEXpo+TlCJrW5EARb7fF+bWdqf3hhyZI1nWJQHgznErZhbjoEsWqi8dQNoE294aldzFurwSABL2XXMf9+H1VQGke9exw5P/AnA5Pv5ngMul7LOvO922iwACu8WkCwLCafvM4CeWPxfA8lNHcWZSoi8EwMAIciKX2Z4SWCMAa3snCZ/G4EA8D6CMLNFsGQhkkz/gQNEBbPCbWsxGUpYVu3z8IyNAknwJkfPMEhLyrdi5RTyUVACkw4GSFRNWJNEW+fgPGwHD8/JxnRuLabN4CGNRkAE23na2+VmEAUmrYymSGjMAYqH84YUIyzgzs3XC7gNgH36Vcc4zKY9o9fgPBXUAiHHwVboBHGLiX6Zcjp1f2wu4tvzZKo0ecPnDtQYDQvJXaBeNzce45Fp28ZQLrEZVuFqgBwOalArKXnW1UzlnSusQKJqKYNuz4tOnI6sZG4zanpemv+7ySU2jbA9h6uhcgpfy6G2PahirDZ6zvq6zDduMVFTKvzw8wgyEdelwY9in3XkEPs3osJuwRQ4qTkfzifndg9Gfc4pdsu82+tTnHZTBa2EAMrqr2t43pguc8tNm7JQVQ2S0ukj2d22dhXYP0/veWtwKrCkNoNimAN5+Xr/oLrxswKbVJjteWrX7eR63o4j9q0GxnaBdWgGA5VStpanIjQmEhV0/nVt5VOFUvix6awJhPcAaTEShgrG+iGyvb5a0Ndb1YGHFPEwoqAinoaykaID1o1pdPNu7XsnCKQ3R+hwWIIhGvORcJUBYXe3Xa3vq/mF/N9V13ugufMkfXn+KHsRD0B8AAAAASUVORK5CYII="
@@ -4,7 +4,7 @@
4
4
  * Demo / Generator : https://particles.js.org/
5
5
  * GitHub : https://www.github.com/matteobruni/tsparticles
6
6
  * How to use? : Check the GitHub README
7
- * v4.0.0-beta.5
7
+ * v4.0.0-beta.6
8
8
  */
9
9
  /*
10
10
  * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
@@ -16,25 +16,35 @@
16
16
  */
17
17
  (function webpackUniversalModuleDefinition(root, factory) {
18
18
  if(typeof exports === 'object' && typeof module === 'object')
19
- module.exports = factory();
19
+ module.exports = factory(require("@tsparticles/engine"));
20
20
  else if(typeof define === 'function' && define.amd)
21
- define([], factory);
21
+ define(["@tsparticles/engine"], factory);
22
22
  else {
23
- var a = factory();
23
+ var a = typeof exports === 'object' ? factory(require("@tsparticles/engine")) : factory(root["window"]);
24
24
  for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
25
25
  }
26
- })(this, () => {
26
+ })(this, (__WEBPACK_EXTERNAL_MODULE__tsparticles_engine__) => {
27
27
  return /******/ (() => { // webpackBootstrap
28
28
  /******/ "use strict";
29
29
  /******/ var __webpack_modules__ = ({
30
30
 
31
+ /***/ "@tsparticles/engine"
32
+ /*!*********************************************************************************************************************************!*\
33
+ !*** external {"commonjs":"@tsparticles/engine","commonjs2":"@tsparticles/engine","amd":"@tsparticles/engine","root":"window"} ***!
34
+ \*********************************************************************************************************************************/
35
+ (module) {
36
+
37
+ module.exports = __WEBPACK_EXTERNAL_MODULE__tsparticles_engine__;
38
+
39
+ /***/ },
40
+
31
41
  /***/ "./dist/browser/index.js"
32
42
  /*!*******************************!*\
33
43
  !*** ./dist/browser/index.js ***!
34
44
  \*******************************/
35
45
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
36
46
 
37
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ loadFilterEffect: () => (/* binding */ loadFilterEffect)\n/* harmony export */ });\nasync function loadFilterEffect(engine) {\n engine.checkVersion(\"4.0.0-beta.5\");\n await engine.pluginManager.register((e)=>{\n e.pluginManager.addEffect(\"filter\", async ()=>{\n const { FilterDrawer } = await __webpack_require__.e(/*! import() */ \"dist_browser_FilterDrawer_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./FilterDrawer.js */ \"./dist/browser/FilterDrawer.js\"));\n return new FilterDrawer();\n });\n });\n}\n\n\n//# sourceURL=webpack://@tsparticles/effect-filter/./dist/browser/index.js?\n}");
47
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ loadFilterEffect: () => (/* binding */ loadFilterEffect)\n/* harmony export */ });\nasync function loadFilterEffect(engine) {\n engine.checkVersion(\"4.0.0-beta.6\");\n await engine.pluginManager.register((e)=>{\n e.pluginManager.addEffect(\"filter\", async ()=>{\n const { FilterDrawer } = await __webpack_require__.e(/*! import() */ \"dist_browser_FilterDrawer_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./FilterDrawer.js */ \"./dist/browser/FilterDrawer.js\"));\n return new FilterDrawer();\n });\n });\n}\n\n\n//# sourceURL=webpack://@tsparticles/effect-filter/./dist/browser/index.js?\n}");
38
48
 
39
49
  /***/ }
40
50
 
@@ -1,2 +1,2 @@
1
- !function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var r=t();for(var o in r)("object"==typeof exports?exports:e)[o]=r[o]}}(this,()=>(()=>{"use strict";var e,t,r,o={},i={};function n(e){var t=i[e];if(void 0!==t)return t.exports;var r=i[e]={exports:{}};return o[e](r,r.exports,n),r.exports}n.m=o,n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce((t,r)=>(n.f[r](e,t),t),[])),n.u=e=>""+e+".min.js",n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},n.l=(e,t,r,o)=>{if(a[e])return void a[e].push(t);if(void 0!==r)for(var i,c,l=document.getElementsByTagName("script"),s=0;s<l.length;s++){var f=l[s];if(f.getAttribute("src")==e||f.getAttribute("data-webpack")=="@tsparticles/effect-filter:"+r){i=f;break}}i||(c=!0,(i=document.createElement("script")).charset="utf-8",n.nc&&i.setAttribute("nonce",n.nc),i.setAttribute("data-webpack","@tsparticles/effect-filter:"+r),i.src=e),a[e]=[t];var u=(t,r)=>{i.onerror=i.onload=null,clearTimeout(p);var o=a[e];if(delete a[e],i.parentNode&&i.parentNode.removeChild(i),o&&o.forEach(e=>e(r)),t)return t(r)},p=setTimeout(u.bind(null,void 0,{type:"timeout",target:i}),12e4);i.onerror=u.bind(null,i.onerror),i.onload=u.bind(null,i.onload),c&&document.head.appendChild(i)},n.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.g.importScripts&&(c=n.g.location+"");var a,c,l=n.g.document;if(!c&&l&&(l.currentScript&&"SCRIPT"===l.currentScript.tagName.toUpperCase()&&(c=l.currentScript.src),!c)){var s=l.getElementsByTagName("script");if(s.length)for(var f=s.length-1;f>-1&&(!c||!/^http(s?):/.test(c));)c=s[f--].src}if(!c)throw Error("Automatic publicPath is not supported in this browser");n.p=c=c.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),e={956:0},n.f.j=(t,r)=>{var o=n.o(e,t)?e[t]:void 0;if(0!==o)if(o)r.push(o[2]);else{var i=new Promise((r,i)=>o=e[t]=[r,i]);r.push(o[2]=i);var a=n.p+n.u(t),c=Error();n.l(a,r=>{if(n.o(e,t)&&(0!==(o=e[t])&&(e[t]=void 0),o)){var i=r&&("load"===r.type?"missing":r.type),a=r&&r.target&&r.target.src;c.message="Loading chunk "+t+` failed.
2
- (`+i+": "+a+")",c.name="ChunkLoadError",c.type=i,c.request=a,o[1](c)}},"chunk-"+t,t)}},t=(t,r)=>{var o,i,[a,c,l]=r,s=0;if(a.some(t=>0!==e[t])){for(o in c)n.o(c,o)&&(n.m[o]=c[o]);l&&l(n)}for(t&&t(r);s<a.length;s++)i=a[s],n.o(e,i)&&e[i]&&e[i][0](),e[i]=0},(r=this.webpackChunk_tsparticles_effect_filter=this.webpackChunk_tsparticles_effect_filter||[]).forEach(t.bind(null,0)),r.push=t.bind(null,r.push.bind(r));var u={};async function p(e){e.checkVersion("4.0.0-beta.5"),await e.pluginManager.register(e=>{e.pluginManager.addEffect("filter",async()=>{let{FilterDrawer:e}=await n.e(719).then(n.bind(n,719));return new e})})}return n.r(u),n.d(u,{loadFilterEffect:()=>p}),u})());
1
+ !function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var r="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var o in r)("object"==typeof exports?exports:e)[o]=r[o]}}(this,e=>(()=>{"use strict";var t,r,o,i={303(t){t.exports=e}},n={};function a(e){var t=n[e];if(void 0!==t)return t.exports;var r=n[e]={exports:{}};return i[e](r,r.exports,a),r.exports}a.m=i,a.d=(e,t)=>{for(var r in t)a.o(t,r)&&!a.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},a.f={},a.e=e=>Promise.all(Object.keys(a.f).reduce((t,r)=>(a.f[r](e,t),t),[])),a.u=e=>""+e+".min.js",a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),c={},a.l=(e,t,r,o)=>{if(c[e])return void c[e].push(t);if(void 0!==r)for(var i,n,s=document.getElementsByTagName("script"),l=0;l<s.length;l++){var p=s[l];if(p.getAttribute("src")==e||p.getAttribute("data-webpack")=="@tsparticles/effect-filter:"+r){i=p;break}}i||(n=!0,(i=document.createElement("script")).charset="utf-8",a.nc&&i.setAttribute("nonce",a.nc),i.setAttribute("data-webpack","@tsparticles/effect-filter:"+r),i.src=e),c[e]=[t];var u=(t,r)=>{i.onerror=i.onload=null,clearTimeout(f);var o=c[e];if(delete c[e],i.parentNode&&i.parentNode.removeChild(i),o&&o.forEach(e=>e(r)),t)return t(r)},f=setTimeout(u.bind(null,void 0,{type:"timeout",target:i}),12e4);i.onerror=u.bind(null,i.onerror),i.onload=u.bind(null,i.onload),n&&document.head.appendChild(i)},a.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},a.g.importScripts&&(s=a.g.location+"");var c,s,l=a.g.document;if(!s&&l&&(l.currentScript&&"SCRIPT"===l.currentScript.tagName.toUpperCase()&&(s=l.currentScript.src),!s)){var p=l.getElementsByTagName("script");if(p.length)for(var u=p.length-1;u>-1&&(!s||!/^http(s?):/.test(s));)s=p[u--].src}if(!s)throw Error("Automatic publicPath is not supported in this browser");a.p=s=s.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),t={956:0},a.f.j=(e,r)=>{var o=a.o(t,e)?t[e]:void 0;if(0!==o)if(o)r.push(o[2]);else{var i=new Promise((r,i)=>o=t[e]=[r,i]);r.push(o[2]=i);var n=a.p+a.u(e),c=Error();a.l(n,r=>{if(a.o(t,e)&&(0!==(o=t[e])&&(t[e]=void 0),o)){var i=r&&("load"===r.type?"missing":r.type),n=r&&r.target&&r.target.src;c.message="Loading chunk "+e+` failed.
2
+ (`+i+": "+n+")",c.name="ChunkLoadError",c.type=i,c.request=n,o[1](c)}},"chunk-"+e,e)}},r=(e,r)=>{var o,i,[n,c,s]=r,l=0;if(n.some(e=>0!==t[e])){for(o in c)a.o(c,o)&&(a.m[o]=c[o]);s&&s(a)}for(e&&e(r);l<n.length;l++)i=n[l],a.o(t,i)&&t[i]&&t[i][0](),t[i]=0},(o=this.webpackChunk_tsparticles_effect_filter=this.webpackChunk_tsparticles_effect_filter||[]).forEach(r.bind(null,0)),o.push=r.bind(null,o.push.bind(o));var f={};async function d(e){e.checkVersion("4.0.0-beta.6"),await e.pluginManager.register(e=>{e.pluginManager.addEffect("filter",async()=>{let{FilterDrawer:e}=await a.e(719).then(a.bind(a,719));return new e})})}return a.r(f),a.d(f,{loadFilterEffect:()=>d}),f})());
@@ -1,20 +1,7 @@
1
- import { type Container, type IEffectDrawer, type IShapeDrawData, type Particle } from "@tsparticles/engine";
2
- type FilterParticle = Particle & {
3
- filterBlur?: number | string;
4
- filterBrightness?: number;
5
- filterContrast?: number;
6
- filterDropShadow?: boolean;
7
- filterGrayscale?: number;
8
- filterHueRotate?: number | string;
9
- filterInvert?: number;
10
- filterOpacity?: number;
11
- filterSaturate?: number;
12
- filterSepia?: number;
13
- filterUrl?: string;
14
- };
1
+ import { type Container, type IEffectDrawer, type IShapeDrawData } from "@tsparticles/engine";
2
+ import type { FilterParticle } from "./FilterParticle.js";
15
3
  export declare class FilterDrawer implements IEffectDrawer<FilterParticle> {
16
4
  drawAfter(data: IShapeDrawData<FilterParticle>): void;
17
5
  drawBefore(data: IShapeDrawData<FilterParticle>): void;
18
6
  particleInit(_container: Container, particle: FilterParticle): void;
19
7
  }
20
- export {};
@@ -0,0 +1,14 @@
1
+ import type { Particle } from "@tsparticles/engine";
2
+ export type FilterParticle = Particle & {
3
+ filterBlur?: number | string;
4
+ filterBrightness?: number;
5
+ filterContrast?: number;
6
+ filterDropShadow?: string;
7
+ filterGrayscale?: number;
8
+ filterHueRotate?: number | string;
9
+ filterInvert?: number;
10
+ filterOpacity?: number;
11
+ filterSaturate?: number;
12
+ filterSepia?: number;
13
+ filterUrl?: string;
14
+ };
@@ -0,0 +1,14 @@
1
+ import type { IShapeValues } from "@tsparticles/engine";
2
+ export interface IFilterData extends IShapeValues {
3
+ blur?: number | string;
4
+ brightness?: number;
5
+ contrast?: number;
6
+ dropShadow?: string;
7
+ grayscale?: number;
8
+ hueRotate?: number | string;
9
+ invert?: number;
10
+ opacity?: number;
11
+ saturate?: number;
12
+ sepia?: number;
13
+ url?: string;
14
+ }