@tsparticles/shape-emoji 4.0.0-beta.15 → 4.0.0-beta.17

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.
@@ -1,4 +1,4 @@
1
- import { double, executeOnSingleOrMultiple, getRangeMax, isInArray, itemFromSingleOrMultiple, safeDocument, } from "@tsparticles/engine";
1
+ import { double, executeOnSingleOrMultiple, getRangeMax, isInArray, itemFromSingleOrMultiple, } from "@tsparticles/engine";
2
2
  import { drawEmoji, validTypes } from "./Utils.js";
3
3
  import { loadFont } from "@tsparticles/canvas-utils";
4
4
  const defaultFont = '"Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif', noPadding = 0, firstItem = 0;
@@ -64,19 +64,7 @@ export class EmojiDrawer {
64
64
  particle.emojiDataKey = cacheKey;
65
65
  return;
66
66
  }
67
- const padding = emojiOptions.padding * double, maxSize = getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * double;
68
- let cacheCanvas, context;
69
- if (typeof OffscreenCanvas === "undefined") {
70
- const canvas = safeDocument().createElement("canvas");
71
- canvas.width = canvasSize;
72
- canvas.height = canvasSize;
73
- context = canvas.getContext("2d", container.canvas.render.settings);
74
- cacheCanvas = canvas;
75
- }
76
- else {
77
- cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize);
78
- context = cacheCanvas.getContext("2d", container.canvas.render.settings);
79
- }
67
+ const padding = emojiOptions.padding * double, maxSize = getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * double, cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize), context = cacheCanvas.getContext("2d", container.canvas.render.settings);
80
68
  if (!context) {
81
69
  return;
82
70
  }
package/browser/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { EmojiDrawer } from "./EmojiDrawer.js";
2
2
  import { validTypes } from "./Utils.js";
3
3
  export async function loadEmojiShape(engine) {
4
- engine.checkVersion("4.0.0-beta.15");
4
+ engine.checkVersion("4.0.0-beta.17");
5
5
  await engine.pluginManager.register(e => {
6
6
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
7
7
  });
@@ -1,6 +1,6 @@
1
1
  import { validTypes } from "./Utils.js";
2
2
  export async function loadEmojiShape(engine) {
3
- engine.checkVersion("4.0.0-beta.15");
3
+ engine.checkVersion("4.0.0-beta.17");
4
4
  await engine.pluginManager.register(async (e) => {
5
5
  const { EmojiDrawer } = await import("./EmojiDrawer.js");
6
6
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
@@ -1,4 +1,4 @@
1
- import { double, executeOnSingleOrMultiple, getRangeMax, isInArray, itemFromSingleOrMultiple, safeDocument, } from "@tsparticles/engine";
1
+ import { double, executeOnSingleOrMultiple, getRangeMax, isInArray, itemFromSingleOrMultiple, } from "@tsparticles/engine";
2
2
  import { drawEmoji, validTypes } from "./Utils.js";
3
3
  import { loadFont } from "@tsparticles/canvas-utils";
4
4
  const defaultFont = '"Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif', noPadding = 0, firstItem = 0;
@@ -64,19 +64,7 @@ export class EmojiDrawer {
64
64
  particle.emojiDataKey = cacheKey;
65
65
  return;
66
66
  }
67
- const padding = emojiOptions.padding * double, maxSize = getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * double;
68
- let cacheCanvas, context;
69
- if (typeof OffscreenCanvas === "undefined") {
70
- const canvas = safeDocument().createElement("canvas");
71
- canvas.width = canvasSize;
72
- canvas.height = canvasSize;
73
- context = canvas.getContext("2d", container.canvas.render.settings);
74
- cacheCanvas = canvas;
75
- }
76
- else {
77
- cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize);
78
- context = cacheCanvas.getContext("2d", container.canvas.render.settings);
79
- }
67
+ const padding = emojiOptions.padding * double, maxSize = getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * double, cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize), context = cacheCanvas.getContext("2d", container.canvas.render.settings);
80
68
  if (!context) {
81
69
  return;
82
70
  }
package/cjs/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { EmojiDrawer } from "./EmojiDrawer.js";
2
2
  import { validTypes } from "./Utils.js";
3
3
  export async function loadEmojiShape(engine) {
4
- engine.checkVersion("4.0.0-beta.15");
4
+ engine.checkVersion("4.0.0-beta.17");
5
5
  await engine.pluginManager.register(e => {
6
6
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
7
7
  });
package/cjs/index.lazy.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { validTypes } from "./Utils.js";
2
2
  export async function loadEmojiShape(engine) {
3
- engine.checkVersion("4.0.0-beta.15");
3
+ engine.checkVersion("4.0.0-beta.17");
4
4
  await engine.pluginManager.register(async (e) => {
5
5
  const { EmojiDrawer } = await import("./EmojiDrawer.js");
6
6
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
@@ -1,4 +1,4 @@
1
- import { double, executeOnSingleOrMultiple, getRangeMax, isInArray, itemFromSingleOrMultiple, safeDocument, } from "@tsparticles/engine";
1
+ import { double, executeOnSingleOrMultiple, getRangeMax, isInArray, itemFromSingleOrMultiple, } from "@tsparticles/engine";
2
2
  import { drawEmoji, validTypes } from "./Utils.js";
3
3
  import { loadFont } from "@tsparticles/canvas-utils";
4
4
  const defaultFont = '"Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif', noPadding = 0, firstItem = 0;
@@ -64,19 +64,7 @@ export class EmojiDrawer {
64
64
  particle.emojiDataKey = cacheKey;
65
65
  return;
66
66
  }
67
- const padding = emojiOptions.padding * double, maxSize = getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * double;
68
- let cacheCanvas, context;
69
- if (typeof OffscreenCanvas === "undefined") {
70
- const canvas = safeDocument().createElement("canvas");
71
- canvas.width = canvasSize;
72
- canvas.height = canvasSize;
73
- context = canvas.getContext("2d", container.canvas.render.settings);
74
- cacheCanvas = canvas;
75
- }
76
- else {
77
- cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize);
78
- context = cacheCanvas.getContext("2d", container.canvas.render.settings);
79
- }
67
+ const padding = emojiOptions.padding * double, maxSize = getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * double, cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize), context = cacheCanvas.getContext("2d", container.canvas.render.settings);
80
68
  if (!context) {
81
69
  return;
82
70
  }
package/esm/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { EmojiDrawer } from "./EmojiDrawer.js";
2
2
  import { validTypes } from "./Utils.js";
3
3
  export async function loadEmojiShape(engine) {
4
- engine.checkVersion("4.0.0-beta.15");
4
+ engine.checkVersion("4.0.0-beta.17");
5
5
  await engine.pluginManager.register(e => {
6
6
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
7
7
  });
package/esm/index.lazy.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { validTypes } from "./Utils.js";
2
2
  export async function loadEmojiShape(engine) {
3
- engine.checkVersion("4.0.0-beta.15");
3
+ engine.checkVersion("4.0.0-beta.17");
4
4
  await engine.pluginManager.register(async (e) => {
5
5
  const { EmojiDrawer } = await import("./EmojiDrawer.js");
6
6
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/shape-emoji",
3
- "version": "4.0.0-beta.15",
3
+ "version": "4.0.0-beta.17",
4
4
  "description": "tsParticles emoji shape",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -65,8 +65,8 @@
65
65
  "./package.json": "./package.json"
66
66
  },
67
67
  "peerDependencies": {
68
- "@tsparticles/canvas-utils": "4.0.0-beta.15",
69
- "@tsparticles/engine": "4.0.0-beta.15"
68
+ "@tsparticles/canvas-utils": "4.0.0-beta.17",
69
+ "@tsparticles/engine": "4.0.0-beta.17"
70
70
  },
71
71
  "publishConfig": {
72
72
  "access": "public"
package/report.html CHANGED
@@ -4930,7 +4930,7 @@ var drawChart = (function (exports) {
4930
4930
  </script>
4931
4931
  <script>
4932
4932
  /*<!--*/
4933
- const data = {"version":2,"tree":{"name":"root","children":[{"name":"tsparticles.shape.emoji.js","children":[{"name":"dist/browser","children":[{"uid":"074e10d3-1","name":"Utils.js"},{"uid":"074e10d3-3","name":"EmojiDrawer.js"},{"uid":"074e10d3-5","name":"index.js"},{"uid":"074e10d3-7","name":"browser.js"}]}]}],"isRoot":true},"nodeParts":{"074e10d3-1":{"renderedLength":370,"gzipLength":0,"brotliLength":0,"metaUid":"074e10d3-0"},"074e10d3-3":{"renderedLength":3777,"gzipLength":0,"brotliLength":0,"metaUid":"074e10d3-2"},"074e10d3-5":{"renderedLength":250,"gzipLength":0,"brotliLength":0,"metaUid":"074e10d3-4"},"074e10d3-7":{"renderedLength":171,"gzipLength":0,"brotliLength":0,"metaUid":"074e10d3-6"}},"nodeMetas":{"074e10d3-0":{"id":"/dist/browser/Utils.js","moduleParts":{"tsparticles.shape.emoji.js":"074e10d3-1"},"imported":[{"uid":"074e10d3-8"}],"importedBy":[{"uid":"074e10d3-4"},{"uid":"074e10d3-2"}]},"074e10d3-2":{"id":"/dist/browser/EmojiDrawer.js","moduleParts":{"tsparticles.shape.emoji.js":"074e10d3-3"},"imported":[{"uid":"074e10d3-8"},{"uid":"074e10d3-0"},{"uid":"074e10d3-9"}],"importedBy":[{"uid":"074e10d3-4"}]},"074e10d3-4":{"id":"/dist/browser/index.js","moduleParts":{"tsparticles.shape.emoji.js":"074e10d3-5"},"imported":[{"uid":"074e10d3-2"},{"uid":"074e10d3-0"}],"importedBy":[{"uid":"074e10d3-6"}]},"074e10d3-6":{"id":"/dist/browser/browser.js","moduleParts":{"tsparticles.shape.emoji.js":"074e10d3-7"},"imported":[{"uid":"074e10d3-4"}],"importedBy":[],"isEntry":true},"074e10d3-8":{"id":"@tsparticles/engine","moduleParts":{},"imported":[],"importedBy":[{"uid":"074e10d3-2"},{"uid":"074e10d3-0"}],"isExternal":true},"074e10d3-9":{"id":"@tsparticles/canvas-utils","moduleParts":{},"imported":[],"importedBy":[{"uid":"074e10d3-2"}],"isExternal":true}},"env":{"rollup":"4.60.3"},"options":{"gzip":false,"brotli":false,"sourcemap":false}};
4933
+ const data = {"version":2,"tree":{"name":"root","children":[{"name":"tsparticles.shape.emoji.js","children":[{"name":"dist/browser","children":[{"uid":"8340647b-1","name":"Utils.js"},{"uid":"8340647b-3","name":"EmojiDrawer.js"},{"uid":"8340647b-5","name":"index.js"},{"uid":"8340647b-7","name":"browser.js"}]}]}],"isRoot":true},"nodeParts":{"8340647b-1":{"renderedLength":370,"gzipLength":0,"brotliLength":0,"metaUid":"8340647b-0"},"8340647b-3":{"renderedLength":3314,"gzipLength":0,"brotliLength":0,"metaUid":"8340647b-2"},"8340647b-5":{"renderedLength":250,"gzipLength":0,"brotliLength":0,"metaUid":"8340647b-4"},"8340647b-7":{"renderedLength":171,"gzipLength":0,"brotliLength":0,"metaUid":"8340647b-6"}},"nodeMetas":{"8340647b-0":{"id":"/dist/browser/Utils.js","moduleParts":{"tsparticles.shape.emoji.js":"8340647b-1"},"imported":[{"uid":"8340647b-8"}],"importedBy":[{"uid":"8340647b-4"},{"uid":"8340647b-2"}]},"8340647b-2":{"id":"/dist/browser/EmojiDrawer.js","moduleParts":{"tsparticles.shape.emoji.js":"8340647b-3"},"imported":[{"uid":"8340647b-8"},{"uid":"8340647b-0"},{"uid":"8340647b-9"}],"importedBy":[{"uid":"8340647b-4"}]},"8340647b-4":{"id":"/dist/browser/index.js","moduleParts":{"tsparticles.shape.emoji.js":"8340647b-5"},"imported":[{"uid":"8340647b-2"},{"uid":"8340647b-0"}],"importedBy":[{"uid":"8340647b-6"}]},"8340647b-6":{"id":"/dist/browser/browser.js","moduleParts":{"tsparticles.shape.emoji.js":"8340647b-7"},"imported":[{"uid":"8340647b-4"}],"importedBy":[],"isEntry":true},"8340647b-8":{"id":"@tsparticles/engine","moduleParts":{},"imported":[],"importedBy":[{"uid":"8340647b-2"},{"uid":"8340647b-0"}],"isExternal":true},"8340647b-9":{"id":"@tsparticles/canvas-utils","moduleParts":{},"imported":[],"importedBy":[{"uid":"8340647b-2"}],"isExternal":true}},"env":{"rollup":"4.60.3"},"options":{"gzip":false,"brotli":false,"sourcemap":false}};
4934
4934
 
4935
4935
  const run = () => {
4936
4936
  const width = window.innerWidth;
@@ -1,5 +1,5 @@
1
1
  (function(g){g.__tsParticlesInternals=g.__tsParticlesInternals||{};g.__tsParticlesInternals.bundles=g.__tsParticlesInternals.bundles||{};g.__tsParticlesInternals.effects=g.__tsParticlesInternals.effects||{};g.__tsParticlesInternals.engine=g.__tsParticlesInternals.engine||{};g.__tsParticlesInternals.interactions=g.__tsParticlesInternals.interactions||{};g.__tsParticlesInternals.palettes=g.__tsParticlesInternals.palettes||{};g.__tsParticlesInternals.paths=g.__tsParticlesInternals.paths||{};g.__tsParticlesInternals.plugins=g.__tsParticlesInternals.plugins||{};g.__tsParticlesInternals.plugins=g.__tsParticlesInternals.plugins||{};g.__tsParticlesInternals.plugins.emittersShapes=g.__tsParticlesInternals.plugins.emittersShapes||{};g.__tsParticlesInternals.presets=g.__tsParticlesInternals.presets||{};g.__tsParticlesInternals.shapes=g.__tsParticlesInternals.shapes||{};g.__tsParticlesInternals.updaters=g.__tsParticlesInternals.updaters||{};g.__tsParticlesInternals.utils=g.__tsParticlesInternals.utils||{};g.__tsParticlesInternals.canvas=g.__tsParticlesInternals.canvas||{};g.__tsParticlesInternals.canvas=g.__tsParticlesInternals.canvas||{};g.__tsParticlesInternals.canvas.utils=g.__tsParticlesInternals.canvas.utils||{};g.__tsParticlesInternals.path=g.__tsParticlesInternals.path||{};g.__tsParticlesInternals.path=g.__tsParticlesInternals.path||{};g.__tsParticlesInternals.path.utils=g.__tsParticlesInternals.path.utils||{};var __tsProxyFactory=typeof Proxy!=="undefined"?function(obj){return new Proxy(obj,{get:function(target,key){if(!(key in target)){target[key]={};}return target[key];}});}:function(obj){return obj;};g.__tsParticlesInternals.bundles=__tsProxyFactory(g.__tsParticlesInternals.bundles);g.__tsParticlesInternals.effects=__tsProxyFactory(g.__tsParticlesInternals.effects);g.__tsParticlesInternals.interactions=__tsProxyFactory(g.__tsParticlesInternals.interactions);g.__tsParticlesInternals.palettes=__tsProxyFactory(g.__tsParticlesInternals.palettes);g.__tsParticlesInternals.paths=__tsProxyFactory(g.__tsParticlesInternals.paths);g.__tsParticlesInternals.plugins=__tsProxyFactory(g.__tsParticlesInternals.plugins);g.__tsParticlesInternals.plugins.emittersShapes=__tsProxyFactory(g.__tsParticlesInternals.plugins.emittersShapes);g.__tsParticlesInternals.presets=__tsProxyFactory(g.__tsParticlesInternals.presets);g.__tsParticlesInternals.shapes=__tsProxyFactory(g.__tsParticlesInternals.shapes);g.__tsParticlesInternals.updaters=__tsProxyFactory(g.__tsParticlesInternals.updaters);g.__tsParticlesInternals.utils=__tsProxyFactory(g.__tsParticlesInternals.utils);g.__tsParticlesInternals.canvas=__tsProxyFactory(g.__tsParticlesInternals.canvas);g.__tsParticlesInternals.path=__tsProxyFactory(g.__tsParticlesInternals.path);g.tsparticlesInternalExports=g.tsparticlesInternalExports||{};})(typeof globalThis!=="undefined"?globalThis:typeof window!=="undefined"?window:this);
2
- /* Shape v4.0.0-beta.15 */
2
+ /* Shape v4.0.0-beta.17 */
3
3
  (function (global, factory) {
4
4
  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@tsparticles/engine'), require('@tsparticles/canvas-utils')) :
5
5
  typeof define === 'function' && define.amd ? define(['exports', '@tsparticles/engine', '@tsparticles/canvas-utils'], factory) :
@@ -77,19 +77,7 @@
77
77
  particle.emojiDataKey = cacheKey;
78
78
  return;
79
79
  }
80
- const padding = emojiOptions.padding * engine.double, maxSize = engine.getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * engine.double;
81
- let cacheCanvas, context;
82
- if (typeof OffscreenCanvas === "undefined") {
83
- const canvas = engine.safeDocument().createElement("canvas");
84
- canvas.width = canvasSize;
85
- canvas.height = canvasSize;
86
- context = canvas.getContext("2d", container.canvas.render.settings);
87
- cacheCanvas = canvas;
88
- }
89
- else {
90
- cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize);
91
- context = cacheCanvas.getContext("2d", container.canvas.render.settings);
92
- }
80
+ const padding = emojiOptions.padding * engine.double, maxSize = engine.getRangeMax(particle.size.value), fullSize = maxSize + padding, canvasSize = fullSize * engine.double, cacheCanvas = new OffscreenCanvas(canvasSize, canvasSize), context = cacheCanvas.getContext("2d", container.canvas.render.settings);
93
81
  if (!context) {
94
82
  return;
95
83
  }
@@ -104,7 +92,7 @@
104
92
  }
105
93
 
106
94
  async function loadEmojiShape(engine) {
107
- engine.checkVersion("4.0.0-beta.15");
95
+ engine.checkVersion("4.0.0-beta.17");
108
96
  await engine.pluginManager.register(e => {
109
97
  e.pluginManager.addShape(validTypes, () => Promise.resolve(new EmojiDrawer()));
110
98
  });
@@ -1 +1 @@
1
- !function(t){t.__tsParticlesInternals=t.__tsParticlesInternals||{},t.__tsParticlesInternals.bundles=t.__tsParticlesInternals.bundles||{},t.__tsParticlesInternals.effects=t.__tsParticlesInternals.effects||{},t.__tsParticlesInternals.engine=t.__tsParticlesInternals.engine||{},t.__tsParticlesInternals.interactions=t.__tsParticlesInternals.interactions||{},t.__tsParticlesInternals.palettes=t.__tsParticlesInternals.palettes||{},t.__tsParticlesInternals.paths=t.__tsParticlesInternals.paths||{},t.__tsParticlesInternals.plugins=t.__tsParticlesInternals.plugins||{},t.__tsParticlesInternals.plugins=t.__tsParticlesInternals.plugins||{},t.__tsParticlesInternals.plugins.emittersShapes=t.__tsParticlesInternals.plugins.emittersShapes||{},t.__tsParticlesInternals.presets=t.__tsParticlesInternals.presets||{},t.__tsParticlesInternals.shapes=t.__tsParticlesInternals.shapes||{},t.__tsParticlesInternals.updaters=t.__tsParticlesInternals.updaters||{},t.__tsParticlesInternals.utils=t.__tsParticlesInternals.utils||{},t.__tsParticlesInternals.canvas=t.__tsParticlesInternals.canvas||{},t.__tsParticlesInternals.canvas=t.__tsParticlesInternals.canvas||{},t.__tsParticlesInternals.canvas.utils=t.__tsParticlesInternals.canvas.utils||{},t.__tsParticlesInternals.path=t.__tsParticlesInternals.path||{},t.__tsParticlesInternals.path=t.__tsParticlesInternals.path||{},t.__tsParticlesInternals.path.utils=t.__tsParticlesInternals.path.utils||{};var s="undefined"!=typeof Proxy?function(t){return new Proxy(t,{get:function(t,s){return s in t||(t[s]={}),t[s]}})}:function(t){return t};t.__tsParticlesInternals.bundles=s(t.__tsParticlesInternals.bundles),t.__tsParticlesInternals.effects=s(t.__tsParticlesInternals.effects),t.__tsParticlesInternals.interactions=s(t.__tsParticlesInternals.interactions),t.__tsParticlesInternals.palettes=s(t.__tsParticlesInternals.palettes),t.__tsParticlesInternals.paths=s(t.__tsParticlesInternals.paths),t.__tsParticlesInternals.plugins=s(t.__tsParticlesInternals.plugins),t.__tsParticlesInternals.plugins.emittersShapes=s(t.__tsParticlesInternals.plugins.emittersShapes),t.__tsParticlesInternals.presets=s(t.__tsParticlesInternals.presets),t.__tsParticlesInternals.shapes=s(t.__tsParticlesInternals.shapes),t.__tsParticlesInternals.updaters=s(t.__tsParticlesInternals.updaters),t.__tsParticlesInternals.utils=s(t.__tsParticlesInternals.utils),t.__tsParticlesInternals.canvas=s(t.__tsParticlesInternals.canvas),t.__tsParticlesInternals.path=s(t.__tsParticlesInternals.path),t.tsparticlesInternalExports=t.tsparticlesInternalExports||{}}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:this),function(t,s){"object"==typeof exports&&"undefined"!=typeof module?s(exports,require("@tsparticles/engine"),require("@tsparticles/canvas-utils")):"function"==typeof define&&define.amd?define(["exports","@tsparticles/engine","@tsparticles/canvas-utils"],s):s(((t="undefined"!=typeof globalThis?globalThis:t||self).__tsParticlesInternals=t.__tsParticlesInternals||{},t.__tsParticlesInternals.shapes=t.__tsParticlesInternals.shapes||{},t.__tsParticlesInternals.shapes.emoji=t.__tsParticlesInternals.shapes.emoji||{}),t.__tsParticlesInternals.engine,t.__tsParticlesInternals.canvas.utils)}(this,function(t,s,e){"use strict";const a=["emoji"];const n='"Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif';class l{_emojiShapeDict=new Map;destroy(){for(const[t,s]of this._emojiShapeDict)s instanceof ImageBitmap&&s.close(),this._emojiShapeDict.delete(t)}draw(t){const e=t.particle.emojiDataKey;if(!e)return;const a=this._emojiShapeDict.get(e);a&&function(t,e){const{context:a,opacity:n}=t,l=a.globalAlpha,r=e.width,i=r*s.half;a.globalAlpha=n,a.drawImage(e,-i,-i,r,r),a.globalAlpha=l}(t,a)}async init(t){const l=t.actualOptions.particles.shape;if(!a.some(t=>s.isInArray(t,l.type)))return;const r=[e.loadFont(n)],i=a.map(t=>l.options[t])[0];s.executeOnSingleOrMultiple(i,t=>{t.font&&r.push(e.loadFont(t.font))}),await Promise.all(r)}particleDestroy(t){t.emojiDataKey=void 0}particleInit(t,e){const a=e.shapeData;if(!a.value)return;const l=s.itemFromSingleOrMultiple(a.value,e.randomIndexData);if(!l)return;const r="string"==typeof l?{font:a.font??n,padding:a.padding??0,value:l}:{font:n,padding:0,...a,...l},i=r.font,_=r.value,c=`${_}_${i}`;if(this._emojiShapeDict.has(c))return void(e.emojiDataKey=c);const o=r.padding*s.double,p=s.getRangeMax(e.size.value),I=p+o,P=I*s.double;let u,h;if("undefined"==typeof OffscreenCanvas){const e=s.safeDocument().createElement("canvas");e.width=P,e.height=P,h=e.getContext("2d",t.canvas.render.settings),u=e}else u=new OffscreenCanvas(P,P),h=u.getContext("2d",t.canvas.render.settings);if(!h)return;h.font=`400 ${(p*s.double).toString()}px ${i}`,h.textBaseline="middle",h.textAlign="center",h.fillText(_,I,I);const d=u instanceof HTMLCanvasElement?u:u.transferToImageBitmap();this._emojiShapeDict.set(c,d),e.emojiDataKey=c}}async function r(t){t.checkVersion("4.0.0-beta.15"),await t.pluginManager.register(t=>{t.pluginManager.addShape(a,()=>Promise.resolve(new l))})}const i=globalThis;i.__tsParticlesInternals=i.__tsParticlesInternals??{},i.loadEmojiShape=r,t.loadEmojiShape=r}),Object.assign(globalThis.window||globalThis,{loadEmojiShape:(globalThis.__tsParticlesInternals.shapes.emoji||{}).loadEmojiShape}),delete(globalThis.window||globalThis).tsparticlesInternalExports;
1
+ !function(t){t.__tsParticlesInternals=t.__tsParticlesInternals||{},t.__tsParticlesInternals.bundles=t.__tsParticlesInternals.bundles||{},t.__tsParticlesInternals.effects=t.__tsParticlesInternals.effects||{},t.__tsParticlesInternals.engine=t.__tsParticlesInternals.engine||{},t.__tsParticlesInternals.interactions=t.__tsParticlesInternals.interactions||{},t.__tsParticlesInternals.palettes=t.__tsParticlesInternals.palettes||{},t.__tsParticlesInternals.paths=t.__tsParticlesInternals.paths||{},t.__tsParticlesInternals.plugins=t.__tsParticlesInternals.plugins||{},t.__tsParticlesInternals.plugins=t.__tsParticlesInternals.plugins||{},t.__tsParticlesInternals.plugins.emittersShapes=t.__tsParticlesInternals.plugins.emittersShapes||{},t.__tsParticlesInternals.presets=t.__tsParticlesInternals.presets||{},t.__tsParticlesInternals.shapes=t.__tsParticlesInternals.shapes||{},t.__tsParticlesInternals.updaters=t.__tsParticlesInternals.updaters||{},t.__tsParticlesInternals.utils=t.__tsParticlesInternals.utils||{},t.__tsParticlesInternals.canvas=t.__tsParticlesInternals.canvas||{},t.__tsParticlesInternals.canvas=t.__tsParticlesInternals.canvas||{},t.__tsParticlesInternals.canvas.utils=t.__tsParticlesInternals.canvas.utils||{},t.__tsParticlesInternals.path=t.__tsParticlesInternals.path||{},t.__tsParticlesInternals.path=t.__tsParticlesInternals.path||{},t.__tsParticlesInternals.path.utils=t.__tsParticlesInternals.path.utils||{};var s="undefined"!=typeof Proxy?function(t){return new Proxy(t,{get:function(t,s){return s in t||(t[s]={}),t[s]}})}:function(t){return t};t.__tsParticlesInternals.bundles=s(t.__tsParticlesInternals.bundles),t.__tsParticlesInternals.effects=s(t.__tsParticlesInternals.effects),t.__tsParticlesInternals.interactions=s(t.__tsParticlesInternals.interactions),t.__tsParticlesInternals.palettes=s(t.__tsParticlesInternals.palettes),t.__tsParticlesInternals.paths=s(t.__tsParticlesInternals.paths),t.__tsParticlesInternals.plugins=s(t.__tsParticlesInternals.plugins),t.__tsParticlesInternals.plugins.emittersShapes=s(t.__tsParticlesInternals.plugins.emittersShapes),t.__tsParticlesInternals.presets=s(t.__tsParticlesInternals.presets),t.__tsParticlesInternals.shapes=s(t.__tsParticlesInternals.shapes),t.__tsParticlesInternals.updaters=s(t.__tsParticlesInternals.updaters),t.__tsParticlesInternals.utils=s(t.__tsParticlesInternals.utils),t.__tsParticlesInternals.canvas=s(t.__tsParticlesInternals.canvas),t.__tsParticlesInternals.path=s(t.__tsParticlesInternals.path),t.tsparticlesInternalExports=t.tsparticlesInternalExports||{}}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:this),function(t,s){"object"==typeof exports&&"undefined"!=typeof module?s(exports,require("@tsparticles/engine"),require("@tsparticles/canvas-utils")):"function"==typeof define&&define.amd?define(["exports","@tsparticles/engine","@tsparticles/canvas-utils"],s):s(((t="undefined"!=typeof globalThis?globalThis:t||self).__tsParticlesInternals=t.__tsParticlesInternals||{},t.__tsParticlesInternals.shapes=t.__tsParticlesInternals.shapes||{},t.__tsParticlesInternals.shapes.emoji=t.__tsParticlesInternals.shapes.emoji||{}),t.__tsParticlesInternals.engine,t.__tsParticlesInternals.canvas.utils)}(this,function(t,s,e){"use strict";const a=["emoji"];const n='"Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif';class l{_emojiShapeDict=new Map;destroy(){for(const[t,s]of this._emojiShapeDict)s instanceof ImageBitmap&&s.close(),this._emojiShapeDict.delete(t)}draw(t){const e=t.particle.emojiDataKey;if(!e)return;const a=this._emojiShapeDict.get(e);a&&function(t,e){const{context:a,opacity:n}=t,l=a.globalAlpha,r=e.width,i=r*s.half;a.globalAlpha=n,a.drawImage(e,-i,-i,r,r),a.globalAlpha=l}(t,a)}async init(t){const l=t.actualOptions.particles.shape;if(!a.some(t=>s.isInArray(t,l.type)))return;const r=[e.loadFont(n)],i=a.map(t=>l.options[t])[0];s.executeOnSingleOrMultiple(i,t=>{t.font&&r.push(e.loadFont(t.font))}),await Promise.all(r)}particleDestroy(t){t.emojiDataKey=void 0}particleInit(t,e){const a=e.shapeData;if(!a.value)return;const l=s.itemFromSingleOrMultiple(a.value,e.randomIndexData);if(!l)return;const r="string"==typeof l?{font:a.font??n,padding:a.padding??0,value:l}:{font:n,padding:0,...a,...l},i=r.font,_=r.value,c=`${_}_${i}`;if(this._emojiShapeDict.has(c))return void(e.emojiDataKey=c);const o=r.padding*s.double,p=s.getRangeMax(e.size.value),I=p+o,P=I*s.double,u=new OffscreenCanvas(P,P),h=u.getContext("2d",t.canvas.render.settings);if(!h)return;h.font=`400 ${(p*s.double).toString()}px ${i}`,h.textBaseline="middle",h.textAlign="center",h.fillText(_,I,I);const d=u instanceof HTMLCanvasElement?u:u.transferToImageBitmap();this._emojiShapeDict.set(c,d),e.emojiDataKey=c}}async function r(t){t.checkVersion("4.0.0-beta.17"),await t.pluginManager.register(t=>{t.pluginManager.addShape(a,()=>Promise.resolve(new l))})}const i=globalThis;i.__tsParticlesInternals=i.__tsParticlesInternals??{},i.loadEmojiShape=r,t.loadEmojiShape=r}),Object.assign(globalThis.window||globalThis,{loadEmojiShape:(globalThis.__tsParticlesInternals.shapes.emoji||{}).loadEmojiShape}),delete(globalThis.window||globalThis).tsparticlesInternalExports;