Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Socket
Sign inDemoInstall

@pixi/extensions

Package Overview
Dependencies
Maintainers
3
Versions
51
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@pixi/extensions - npm Package Compare versions

Comparing version 6.5.3 to 7.0.0-alpha

279

dist/cjs/extensions.js
/*!
* @pixi/extensions - v6.5.3
* Compiled Fri, 09 Sep 2022 13:55:20 UTC
* @pixi/extensions - v7.0.0-alpha
* Compiled Fri, 09 Sep 2022 16:09:18 UTC
*

@@ -12,198 +12,95 @@ * @pixi/extensions is licensed under the MIT License.

/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
var __assign = function() {
__assign = Object.assign || function __assign(t) {
var arguments$1 = arguments;
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments$1[i];
for (var p in s) { if (Object.prototype.hasOwnProperty.call(s, p)) { t[p] = s[p]; } }
}
return t;
};
return __assign.apply(this, arguments);
var ExtensionType = /* @__PURE__ */ ((ExtensionType2) => {
ExtensionType2["Renderer"] = "renderer";
ExtensionType2["Application"] = "application";
ExtensionType2["RendererSystem"] = "renderer-webgl-system";
ExtensionType2["RendererPlugin"] = "renderer-webgl-plugin";
ExtensionType2["CanvasRendererSystem"] = "renderer-canvas-system";
ExtensionType2["CanvasRendererPlugin"] = "renderer-canvas-plugin";
ExtensionType2["LoadParser"] = "load-parser";
ExtensionType2["ResolveParser"] = "resolve-parser";
ExtensionType2["CacheParser"] = "cache-parser";
ExtensionType2["DetectionParser"] = "detection-parser";
return ExtensionType2;
})(ExtensionType || {});
const normalizeExtension = (ext) => {
if (typeof ext === "function" || typeof ext === "object" && ext.extension) {
if (!ext.extension) {
throw new Error("Extension class must have an extension object");
}
const metadata = typeof ext.extension !== "object" ? { type: ext.extension } : ext.extension;
ext = { ...metadata, ref: ext };
}
if (typeof ext === "object") {
ext = { ...ext };
} else {
throw new Error("Invalid extension type");
}
if (typeof ext.type === "string") {
ext.type = [ext.type];
}
return ext;
};
/**
* Collection of valid extension types.
* @memberof PIXI
* @property {string} Application - Application plugins
* @property {string} RendererPlugin - Plugins for Renderer
* @property {string} CanvasRendererPlugin - Plugins for CanvasRenderer
* @property {string} Loader - Plugins to use with Loader
* @property {string} LoadParser - Parsers for Assets loader.
* @property {string} ResolveParser - Parsers for Assets resolvers.
* @property {string} CacheParser - Parsers for Assets cache.
*/
exports.ExtensionType = void 0;
(function (ExtensionType) {
ExtensionType["Application"] = "application";
ExtensionType["RendererPlugin"] = "renderer-webgl-plugin";
ExtensionType["CanvasRendererPlugin"] = "renderer-canvas-plugin";
ExtensionType["Loader"] = "loader";
ExtensionType["LoadParser"] = "load-parser";
ExtensionType["ResolveParser"] = "resolve-parser";
ExtensionType["CacheParser"] = "cache-parser";
ExtensionType["DetectionParser"] = "detection-parser";
})(exports.ExtensionType || (exports.ExtensionType = {}));
/**
* Convert input into extension format data.
* @ignore
*/
var normalizeExtension = function (ext) {
// Class/Object submission, use extension object
if (typeof ext === 'function' || (typeof ext === 'object' && ext.extension)) {
if (!ext.extension) {
throw new Error('Extension class must have an extension object');
const extensions = {
_addHandlers: {},
_removeHandlers: {},
_queue: {},
remove(...extensions2) {
extensions2.map(normalizeExtension).forEach((ext) => {
ext.type.forEach((type) => this._removeHandlers[type]?.(ext));
});
return this;
},
add(...extensions2) {
extensions2.map(normalizeExtension).forEach((ext) => {
ext.type.forEach((type) => {
const handlers = this._addHandlers;
const queue = this._queue;
if (!handlers[type]) {
queue[type] = queue[type] || [];
queue[type].push(ext);
} else {
handlers[type](ext);
}
var metadata = (typeof ext.extension !== 'object')
? { type: ext.extension }
: ext.extension;
ext = __assign(__assign({}, metadata), { ref: ext });
});
});
return this;
},
handle(type, onAdd, onRemove) {
const addHandlers = this._addHandlers;
const removeHandlers = this._removeHandlers;
if (addHandlers[type] || removeHandlers[type]) {
throw new Error(`Extension type ${type} already has a handler`);
}
if (typeof ext === 'object') {
ext = __assign({}, ext);
addHandlers[type] = onAdd;
removeHandlers[type] = onRemove;
const queue = this._queue;
if (queue[type]) {
queue[type].forEach((ext) => onAdd(ext));
delete queue[type];
}
else {
throw new Error('Invalid extension type');
}
if (typeof ext.type === 'string') {
ext.type = [ext.type];
}
return ext;
return this;
},
handleByMap(type, map) {
return this.handle(type, (extension) => {
map[extension.name] = extension.ref;
}, (extension) => {
delete map[extension.name];
});
},
handleByList(type, list) {
return this.handle(type, (extension) => {
list.push(extension.ref);
list.sort((a, b) => (b.priority ?? -1) - (a.priority ?? -1));
}, (extension) => {
const index = list.indexOf(extension.ref);
if (index !== -1) {
list.splice(index, 1);
}
});
}
};
/**
* Global registration of all PixiJS extensions. One-stop-shop for extensibility.
* @memberof PIXI
* @namespace extensions
*/
var extensions = {
/** @ignore */
_addHandlers: null,
/** @ignore */
_removeHandlers: null,
/** @ignore */
_queue: {},
/**
* Remove extensions from PixiJS.
* @param extensions - Extensions to be removed.
* @returns {PIXI.extensions} For chaining.
*/
remove: function () {
var arguments$1 = arguments;
var _this = this;
var extensions = [];
for (var _i = 0; _i < arguments.length; _i++) {
extensions[_i] = arguments$1[_i];
}
extensions.map(normalizeExtension).forEach(function (ext) {
ext.type.forEach(function (type) { var _a, _b; return (_b = (_a = _this._removeHandlers)[type]) === null || _b === void 0 ? void 0 : _b.call(_a, ext); });
});
return this;
},
/**
* Register new extensions with PixiJS.
* @param extensions - The spread of extensions to add to PixiJS.
* @returns {PIXI.extensions} For chaining.
*/
add: function () {
var arguments$1 = arguments;
var _this = this;
var extensions = [];
for (var _i = 0; _i < arguments.length; _i++) {
extensions[_i] = arguments$1[_i];
}
// Handle any extensions either passed as class w/ data or as data
extensions.map(normalizeExtension).forEach(function (ext) {
ext.type.forEach(function (type) {
var handlers = _this._addHandlers;
var queue = _this._queue;
if (!handlers[type]) {
queue[type] = queue[type] || [];
queue[type].push(ext);
}
else {
handlers[type](ext);
}
});
});
return this;
},
/**
* Internal method to handle extensions by name.
* @param type - The extension type.
* @param onAdd - Function for handling when extensions are added/registered passes {@link PIXI.ExtensionFormat}.
* @param onRemove - Function for handling when extensions are removed/unregistered passes {@link PIXI.ExtensionFormat}.
* @returns {PIXI.extensions} For chaining.
*/
handle: function (type, onAdd, onRemove) {
var addHandlers = this._addHandlers = this._addHandlers || {};
var removeHandlers = this._removeHandlers = this._removeHandlers || {};
if (addHandlers[type] || removeHandlers[type]) {
throw new Error("Extension type " + type + " already has a handler");
}
addHandlers[type] = onAdd;
removeHandlers[type] = onRemove;
// Process the queue
var queue = this._queue;
// Process any plugins that have been registered before the handler
if (queue[type]) {
queue[type].forEach(function (ext) { return onAdd(ext); });
delete queue[type];
}
return this;
},
/**
* Handle a type, but using a map by `name` property.
* @param type - Type of extension to handle.
* @param map - The object map of named extensions.
* @returns {PIXI.extensions} For chaining.
*/
handleByMap: function (type, map) {
return this.handle(type, function (extension) {
map[extension.name] = extension.ref;
}, function (extension) {
delete map[extension.name];
});
},
/**
* Handle a type, but using a list of extensions.
* @param type - Type of extension to handle.
* @param list - The list of extensions.
* @returns {PIXI.extensions} For chaining.
*/
handleByList: function (type, list) {
return this.handle(type, function (extension) {
var _a, _b;
list.push(extension.ref);
// TODO: remove me later, only added for @pixi/loaders
if (type === exports.ExtensionType.Loader) {
(_b = (_a = extension.ref).add) === null || _b === void 0 ? void 0 : _b.call(_a);
}
}, function (extension) {
var index = list.indexOf(extension.ref);
if (index !== -1) {
list.splice(index, 1);
}
});
},
};
exports.ExtensionType = ExtensionType;
exports.extensions = extensions;
//# sourceMappingURL=extensions.js.map

@@ -1,9 +0,8 @@

/*!
* @pixi/extensions - v6.5.3
* Compiled Fri, 09 Sep 2022 13:55:20 UTC
"use strict";/*!
* @pixi/extensions - v7.0.0-alpha
* Compiled Fri, 09 Sep 2022 16:09:18 UTC
*
* @pixi/extensions is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e,n=function(){return n=Object.assign||function(e){for(var n,r=arguments,t=1,o=arguments.length;t<o;t++)for(var a in n=r[t])Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a]);return e},n.apply(this,arguments)};exports.ExtensionType=void 0,(e=exports.ExtensionType||(exports.ExtensionType={})).Application="application",e.RendererPlugin="renderer-webgl-plugin",e.CanvasRendererPlugin="renderer-canvas-plugin",e.Loader="loader",e.LoadParser="load-parser",e.ResolveParser="resolve-parser",e.CacheParser="cache-parser",e.DetectionParser="detection-parser";var r=function(e){if("function"==typeof e||"object"==typeof e&&e.extension){var r="object"!=typeof e.extension?{type:e.extension}:e.extension;e=n(n({},r),{ref:e})}if("object"!=typeof e)throw new Error("Invalid extension type");return"string"==typeof(e=n({},e)).type&&(e.type=[e.type]),e},t={_addHandlers:null,_removeHandlers:null,_queue:{},remove:function(){for(var e=arguments,n=this,t=[],o=0;o<arguments.length;o++)t[o]=e[o];return t.map(r).forEach((function(e){e.type.forEach((function(r){var t,o;return null===(o=(t=n._removeHandlers)[r])||void 0===o?void 0:o.call(t,e)}))})),this},add:function(){for(var e=arguments,n=this,t=[],o=0;o<arguments.length;o++)t[o]=e[o];return t.map(r).forEach((function(e){e.type.forEach((function(r){var t=n._addHandlers,o=n._queue;t[r]?t[r](e):(o[r]=o[r]||[],o[r].push(e))}))})),this},handle:function(e,n,r){var t=this._addHandlers=this._addHandlers||{},o=this._removeHandlers=this._removeHandlers||{};t[e]=n,o[e]=r;var a=this._queue;return a[e]&&(a[e].forEach((function(e){return n(e)})),delete a[e]),this},handleByMap:function(e,n){return this.handle(e,(function(e){n[e.name]=e.ref}),(function(e){delete n[e.name]}))},handleByList:function(e,n){return this.handle(e,(function(r){var t,o;n.push(r.ref),e===exports.ExtensionType.Loader&&(null===(o=(t=r.ref).add)||void 0===o||o.call(t))}),(function(e){var r=n.indexOf(e.ref);-1!==r&&n.splice(r,1)}))}};exports.extensions=t;
*/Object.defineProperty(exports,"__esModule",{value:!0});var i=(e=>(e.Renderer="renderer",e.Application="application",e.RendererSystem="renderer-webgl-system",e.RendererPlugin="renderer-webgl-plugin",e.CanvasRendererSystem="renderer-canvas-system",e.CanvasRendererPlugin="renderer-canvas-plugin",e.LoadParser="load-parser",e.ResolveParser="resolve-parser",e.CacheParser="cache-parser",e.DetectionParser="detection-parser",e))(i||{});const a=e=>{if((typeof e=="function"||typeof e=="object"&&e.extension)&&(e={...typeof e.extension!="object"?{type:e.extension}:e.extension,ref:e}),typeof e=="object")e={...e};else throw new Error("Invalid extension type");return typeof e.type=="string"&&(e.type=[e.type]),e},p={_addHandlers:{},_removeHandlers:{},_queue:{},remove(...e){return e.map(a).forEach(t=>{t.type.forEach(r=>this._removeHandlers[r]?.(t))}),this},add(...e){return e.map(a).forEach(t=>{t.type.forEach(r=>{const s=this._addHandlers,n=this._queue;s[r]?s[r](t):(n[r]=n[r]||[],n[r].push(t))})}),this},handle(e,t,r){const s=this._addHandlers,n=this._removeHandlers;s[e]=t,n[e]=r;const o=this._queue;return o[e]&&(o[e].forEach(d=>t(d)),delete o[e]),this},handleByMap(e,t){return this.handle(e,r=>{t[r.name]=r.ref},r=>{delete t[r.name]})},handleByList(e,t){return this.handle(e,r=>{t.push(r.ref),t.sort((s,n)=>(n.priority??-1)-(s.priority??-1))},r=>{const s=t.indexOf(r.ref);s!==-1&&t.splice(s,1)})}};exports.ExtensionType=i,exports.extensions=p;
//# sourceMappingURL=extensions.min.js.map

@@ -21,2 +21,4 @@ /**

name?: string;
/** Optional, used for sorting the plugins in a particular order */
priority?: number;
/** Reference to the plugin object/class */

@@ -33,2 +35,3 @@ ref: any;

name?: string;
priority?: number;
}

@@ -96,6 +99,8 @@

export declare enum ExtensionType {
Renderer = "renderer",
Application = "application",
RendererSystem = "renderer-webgl-system",
RendererPlugin = "renderer-webgl-plugin",
CanvasRendererSystem = "renderer-canvas-system",
CanvasRendererPlugin = "renderer-canvas-plugin",
Loader = "loader",
LoadParser = "load-parser",

@@ -102,0 +107,0 @@ ResolveParser = "resolve-parser",

{
"name": "@pixi/extensions",
"version": "6.5.3",
"version": "7.0.0-alpha",
"main": "dist/cjs/extensions.js",
"module": "dist/esm/extensions.mjs",
"bundle": "dist/browser/extensions.js",
"types": "index.d.ts",

@@ -33,7 +32,6 @@ "exports": {

"files": [
"lib",
"dist",
"*.d.ts"
],
"gitHead": "28e6b2841a65837a5e2873a3d5a9c27cabbe795a"
"gitHead": "da993226df64b804a9c00ed9ee4d011191467b8a"
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc