Merge branch 'pixijs-v5'
* pixijs-v5: Merged versions for PixiJS 4 and 5. Adjustments for Pixi.JS 5.0.
This commit is contained in:
commit
fada4f9a9d
37
dist/iwmlib.pixi.js
vendored
37
dist/iwmlib.pixi.js
vendored
@ -2023,7 +2023,7 @@
|
|||||||
size = this.opts.minHeight - (2 * this.opts.padding);
|
size = this.opts.minHeight - (2 * this.opts.padding);
|
||||||
}
|
}
|
||||||
|
|
||||||
const url = Button.iconIsUrl(icon) ? icon : `../../assets/icons/png/flat/${icon}.png`;
|
const url = Button.iconIsUrl(icon) ? icon : `../../assets/icons/${icon}.png`;
|
||||||
const iconTexture = PIXI.Texture.fromImage(url, true);
|
const iconTexture = PIXI.Texture.fromImage(url, true);
|
||||||
|
|
||||||
const sprite = new PIXI.Sprite(iconTexture);
|
const sprite = new PIXI.Sprite(iconTexture);
|
||||||
@ -2479,7 +2479,7 @@
|
|||||||
// closeButton
|
// closeButton
|
||||||
//-----------------
|
//-----------------
|
||||||
if (this.opts.closeButton) {
|
if (this.opts.closeButton) {
|
||||||
let closeButton = PIXI.Sprite.fromImage('../../assets/icons/png/flat/close.png', true);
|
let closeButton = PIXI.Sprite.fromImage('../../assets/icons/close.png', true);
|
||||||
closeButton.width = this.headerStyle.fontSize;
|
closeButton.width = this.headerStyle.fontSize;
|
||||||
closeButton.height = closeButton.width;
|
closeButton.height = closeButton.width;
|
||||||
closeButton.tint = this.theme.color2;
|
closeButton.tint = this.theme.color2;
|
||||||
@ -3788,16 +3788,16 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
super({
|
super({
|
||||||
view: view,
|
view,
|
||||||
width: width,
|
width,
|
||||||
height: height,
|
height,
|
||||||
transparent: transparent,
|
transparent,
|
||||||
antialias: antialias,
|
antialias,
|
||||||
resolution: resolution,
|
resolution,
|
||||||
autoResize: autoResize,
|
autoResize,
|
||||||
backgroundColor: backgroundColor,
|
backgroundColor,
|
||||||
roundPixels: roundPixels,
|
forceCanvas,
|
||||||
forceCanvas: forceCanvas
|
roundPixels // not needed for PixiJS >= 5
|
||||||
});
|
});
|
||||||
|
|
||||||
this.width = width;
|
this.width = width;
|
||||||
@ -3809,7 +3809,12 @@
|
|||||||
this.orient = null;
|
this.orient = null;
|
||||||
this.originalMapPositionToPoint = null;
|
this.originalMapPositionToPoint = null;
|
||||||
this.monkeyPatchMapping = monkeyPatchMapping;
|
this.monkeyPatchMapping = monkeyPatchMapping;
|
||||||
|
if (parseInt(PIXI.VERSION) >= 5) {
|
||||||
|
PIXI.settings.ROUND_PIXELS = roundPixels;
|
||||||
|
PIXI.GRAPHICS_CURVES.adaptive = adaptive;
|
||||||
|
} else {
|
||||||
PIXI.Graphics.CURVES.adaptive = adaptive;
|
PIXI.Graphics.CURVES.adaptive = adaptive;
|
||||||
|
}
|
||||||
this.graphql = graphql;
|
this.graphql = graphql;
|
||||||
if (fullScreen || autoResize) {
|
if (fullScreen || autoResize) {
|
||||||
console.log('App is in fullScreen mode or autoResize mode');
|
console.log('App is in fullScreen mode or autoResize mode');
|
||||||
@ -7146,12 +7151,12 @@
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
let event = new CustomEvent('resizeStarted');
|
let event = new CustomEvent('resizeStarted');
|
||||||
|
|
||||||
let oldPostition = {x: this.element.offsetLeft, y: this.element.offsetTop};
|
let oldPostition = {x: this.element.getBoundingClientRect().left, y: this.element.getBoundingClientRect().top};
|
||||||
this.bringToFront();
|
this.bringToFront();
|
||||||
|
|
||||||
this.element.style.transformOrigin = "0% 0%";
|
this.element.style.transformOrigin = "0% 0%";
|
||||||
|
|
||||||
let newPostition = {x: this.element.offsetLeft, y: this.element.offsetTop};
|
let newPostition = {x: this.element.getBoundingClientRect().left, y: this.element.getBoundingClientRect().top};
|
||||||
|
|
||||||
let offset = Points.subtract(oldPostition, newPostition);
|
let offset = Points.subtract(oldPostition, newPostition);
|
||||||
|
|
||||||
@ -7204,9 +7209,9 @@
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
let event = new CustomEvent('resizeEnded');
|
let event = new CustomEvent('resizeEnded');
|
||||||
let oldPostition = {x: this.element.offsetLeft, y: this.element.offsetTop};
|
let oldPostition = {x: this.element.getBoundingClientRect().left, y: this.element.getBoundingClientRect().top};
|
||||||
this.element.style.transformOrigin = "50% 50%";
|
this.element.style.transformOrigin = "50% 50%";
|
||||||
let newPostition = {x: this.element.offsetLeft, y: this.element.offsetTop};
|
let newPostition = {x: this.element.getBoundingClientRect().left, y: this.element.getBoundingClientRect().top};
|
||||||
let offset = Points.subtract(oldPostition, newPostition);
|
let offset = Points.subtract(oldPostition, newPostition);
|
||||||
|
|
||||||
TweenLite.to(this.element, 0, { css: { left: "+=" + offset.x + "px" } });
|
TweenLite.to(this.element, 0, { css: { left: "+=" + offset.x + "px" } });
|
||||||
|
@ -100,16 +100,16 @@ export default class PIXIApp extends PIXI.Application {
|
|||||||
}
|
}
|
||||||
|
|
||||||
super({
|
super({
|
||||||
view: view,
|
view,
|
||||||
width: width,
|
width,
|
||||||
height: height,
|
height,
|
||||||
transparent: transparent,
|
transparent,
|
||||||
antialias: antialias,
|
antialias,
|
||||||
resolution: resolution,
|
resolution,
|
||||||
autoResize: autoResize,
|
autoResize,
|
||||||
backgroundColor: backgroundColor,
|
backgroundColor,
|
||||||
roundPixels: roundPixels,
|
forceCanvas,
|
||||||
forceCanvas: forceCanvas
|
roundPixels // not needed for PixiJS >= 5
|
||||||
})
|
})
|
||||||
|
|
||||||
this.width = width
|
this.width = width
|
||||||
@ -121,7 +121,12 @@ export default class PIXIApp extends PIXI.Application {
|
|||||||
this.orient = null
|
this.orient = null
|
||||||
this.originalMapPositionToPoint = null
|
this.originalMapPositionToPoint = null
|
||||||
this.monkeyPatchMapping = monkeyPatchMapping
|
this.monkeyPatchMapping = monkeyPatchMapping
|
||||||
|
if (parseInt(PIXI.VERSION) >= 5) {
|
||||||
|
PIXI.settings.ROUND_PIXELS = roundPixels
|
||||||
|
PIXI.GRAPHICS_CURVES.adaptive = adaptive
|
||||||
|
} else {
|
||||||
PIXI.Graphics.CURVES.adaptive = adaptive
|
PIXI.Graphics.CURVES.adaptive = adaptive
|
||||||
|
}
|
||||||
this.graphql = graphql
|
this.graphql = graphql
|
||||||
if (fullScreen || autoResize) {
|
if (fullScreen || autoResize) {
|
||||||
console.log('App is in fullScreen mode or autoResize mode')
|
console.log('App is in fullScreen mode or autoResize mode')
|
||||||
|
@ -50,7 +50,8 @@ const index = new Index(itemTemplate, [
|
|||||||
['Scatter', 'scatter.html'],
|
['Scatter', 'scatter.html'],
|
||||||
['Flip Effect', 'flipeffect.html'],
|
['Flip Effect', 'flipeffect.html'],
|
||||||
['Blur Filter', 'blurfilter.html'],
|
['Blur Filter', 'blurfilter.html'],
|
||||||
['Text', 'text.html']
|
['Text', 'text.html'],
|
||||||
|
['Scrollview', 'scrollview.html']
|
||||||
],
|
],
|
||||||
null)
|
null)
|
||||||
index.load()
|
index.load()
|
||||||
|
1
lib/pixi/scrollbox.min.js
vendored
Normal file
1
lib/pixi/scrollbox.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
74
lib/pixi/scrollview.html
Normal file
74
lib/pixi/scrollview.html
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
<!doctype html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||||
|
|
||||||
|
<title>PIXI Scrollview</title>
|
||||||
|
|
||||||
|
<link rel="stylesheet" href="../3rdparty/highlight/styles/default.css">
|
||||||
|
<link rel="stylesheet" href="../../css/doctest.css">
|
||||||
|
|
||||||
|
<script src="../3rdparty/highlight/highlight.pack.js"></script>
|
||||||
|
|
||||||
|
<script src="../../dist/iwmlib.3rdparty.js"></script>
|
||||||
|
<script src="../../dist/iwmlib.js"></script>
|
||||||
|
<script src="../../dist/iwmlib.pixi.js"></script>
|
||||||
|
<!-- <script src="./scrollbox.min.js"></script> -->
|
||||||
|
</head>
|
||||||
|
<body onload="Doctest.run()">
|
||||||
|
<h1>Scrollview</h1>
|
||||||
|
<p>A configurable scrollbox designed for pixi.js.</p>
|
||||||
|
<p><strong>Features:</strong></p>
|
||||||
|
<p>
|
||||||
|
<ul>
|
||||||
|
<li>Scrollview uses a mask to clip to desired boxWidth/boxHeight size</li>
|
||||||
|
<li>Scrollview scrolls with scrollbars (options.overflow=scroll)</li>
|
||||||
|
<li>Scrollview's scrollbars may be hidden when not needed (options.overflow=auto or hidden)</li>
|
||||||
|
<li>Scrollview may also be scrolled by dragging on the content window (options.dragScroll=true)</li>
|
||||||
|
</ul>
|
||||||
|
</p>
|
||||||
|
<p>See <a href="https://davidfig.github.io/pixi-scrollbox/jsdoc/Scrollbox.html">https://davidfig.github.io/pixi-scrollbox/jsdoc/Scrollbox.html</a> and <a href="https://davidfig.github.io/pixi-viewport/jsdoc/Viewport.html">https://davidfig.github.io/pixi-viewport/jsdoc/Viewport.html</a></p>
|
||||||
|
<p>Let's look at some switch examples:</p><br />
|
||||||
|
<canvas id="canvas" class="interactive"></canvas>
|
||||||
|
<p>
|
||||||
|
What you should see: Many switches with very different styling and behaviour.
|
||||||
|
</p>
|
||||||
|
<script class="doctest">
|
||||||
|
const app = new PIXIApp({
|
||||||
|
view: canvas,
|
||||||
|
width: 900,
|
||||||
|
height: 250,
|
||||||
|
transparent: false
|
||||||
|
}).setup().run()
|
||||||
|
|
||||||
|
// let scrollview1 = new Scrollview({
|
||||||
|
// x: 10,
|
||||||
|
// y: 20
|
||||||
|
// })
|
||||||
|
|
||||||
|
// let scrollview2 = new Scrollview({
|
||||||
|
// x: 90,
|
||||||
|
// y: 20,
|
||||||
|
// fill: 0xfd355a,
|
||||||
|
// fillActive: 0x5954d3,
|
||||||
|
// controlFill: 0xfecd2d,
|
||||||
|
// controlFillActive: 0xfd413b,
|
||||||
|
// strokeActiveWidth: 4,
|
||||||
|
// controlStrokeActive: 0x50d968,
|
||||||
|
// controlStrokeActiveWidth: 12,
|
||||||
|
// controlStrokeActiveAlpha: .8,
|
||||||
|
// tooltip: 'Dies ist ein Switch'
|
||||||
|
// })
|
||||||
|
|
||||||
|
// const scrollbox = new PIXI.extras.Scrollbox({boxWidth: 500, boxHeight: 200})
|
||||||
|
// scrollbox.x = 70
|
||||||
|
// scrollbox.y = 30
|
||||||
|
|
||||||
|
// const sprite = new PIXI.Sprite(resources.fulda.texture)
|
||||||
|
// sprite.scale.set(.5, .5)
|
||||||
|
// scrollbox.content.addChild(sprite)
|
||||||
|
// app.stage.addChild(scrollbox)
|
||||||
|
|
||||||
|
// app.scene.addChild(switch1, switch2)
|
||||||
|
</script>
|
||||||
|
</body>
|
508
lib/pixi/scrollview.js
Normal file
508
lib/pixi/scrollview.js
Normal file
@ -0,0 +1,508 @@
|
|||||||
|
import Theme from './theme.js'
|
||||||
|
import Tooltip from './tooltip.js'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Callback for the switch action.
|
||||||
|
*
|
||||||
|
* @callback actionCallback
|
||||||
|
* @param {object} event - The event object.
|
||||||
|
* @param {Switch} switch - A reference to the switch (also this refers to the switch).
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Callback for the switch action.
|
||||||
|
*
|
||||||
|
* @callback actionActiveCallback
|
||||||
|
* @param {object} event - The event object.
|
||||||
|
* @param {Switch} switch - A reference to the switch (also this refers to the switch).
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Callback for the switch beforeAction.
|
||||||
|
*
|
||||||
|
* @callback beforeActionCallback
|
||||||
|
* @param {object} event - The event object.
|
||||||
|
* @param {Switch} switch - A reference to the switch (also this refers to the switch).
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Callback for the switch afterAction.
|
||||||
|
*
|
||||||
|
* @callback afterActionCallback
|
||||||
|
* @param {object} event - The event object.
|
||||||
|
* @param {Switch} switch - A reference to the switch (also this refers to the switch).
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class that represents a PixiJS Switch.
|
||||||
|
*
|
||||||
|
* @example
|
||||||
|
* // Create the app
|
||||||
|
* const app = new PIXIApp({
|
||||||
|
* view: canvas,
|
||||||
|
* width: 900,
|
||||||
|
* height: 250
|
||||||
|
* }).setup().run()
|
||||||
|
*
|
||||||
|
* // Create the switch
|
||||||
|
* const switch1 = new Switch({
|
||||||
|
* x: 10,
|
||||||
|
* y: 20
|
||||||
|
* })
|
||||||
|
*
|
||||||
|
* // Add the switch to a DisplayObject
|
||||||
|
* app.scene.addChild(switch1)
|
||||||
|
*
|
||||||
|
* @class
|
||||||
|
* @extends PIXI.Container
|
||||||
|
* @see {@link http://pixijs.download/dev/docs/PIXI.Container.html|PIXI.Container}
|
||||||
|
* @see {@link https://www.iwm-tuebingen.de/iwmbrowser/lib/pixi/switch.html|DocTest}
|
||||||
|
*/
|
||||||
|
export default class Switch extends PIXI.Container {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance of a Switch.
|
||||||
|
*
|
||||||
|
* @constructor
|
||||||
|
* @param {object} [opts] - An options object to specify to style and behaviour of the switch.
|
||||||
|
* @param {number} [opts.id=auto generated] - The id of the switch.
|
||||||
|
* @param {number} [opts.x=0] - The x position of the switch. Can be also set after creation with switch.x = 0.
|
||||||
|
* @param {number} [opts.y=0] - The y position of the switch. Can be also set after creation with switch.y = 0.
|
||||||
|
* @param {string|Theme} [opts.theme=dark] - The theme to use for this switch. Possible values are dark, light, red
|
||||||
|
* or a Theme object.
|
||||||
|
* @param {number} [opts.width=44] - The width of the switch.
|
||||||
|
* @param {number} [opts.height=28] - The height of the switch.
|
||||||
|
* @param {number} [opts.fill=Theme.fill] - The color of the switch background as a hex value.
|
||||||
|
* @param {number} [opts.fillAlpha=Theme.fillAlpha] - The alpha value of the background.
|
||||||
|
* @param {number} [opts.fillActive=Theme.fillActive] - The color of the switch background when activated.
|
||||||
|
* @param {number} [opts.fillActiveAlpha=Theme.fillActiveAlpha] - The alpha value of the background when activated.
|
||||||
|
* @param {number} [opts.stroke=Theme.stroke] - The color of the border as a hex value.
|
||||||
|
* @param {number} [opts.strokeWidth=Theme.strokeWidth] - The width of the border in pixel.
|
||||||
|
* @param {number} [opts.strokeAlpha=Theme.strokeAlpha] - The alpha value of the border.
|
||||||
|
* @param {number} [opts.strokeActive=Theme.strokeActive] - The color of the border when activated.
|
||||||
|
* @param {number} [opts.strokeActiveWidth=Theme.strokeActiveWidth] - The width of the border in pixel when activated.
|
||||||
|
* @param {number} [opts.strokeActiveAlpha=Theme.strokeActiveAlpha] - The alpha value of the border when activated.
|
||||||
|
* @param {number} [opts.controlFill=Theme.stroke] - The color of the switch control background as a hex value.
|
||||||
|
* @param {number} [opts.controlFillAlpha=Theme.strokeAlpha] - The alpha value of the background.
|
||||||
|
* @param {number} [opts.controlFillActive=Theme.stroke] - The color of the switch control background when activated.
|
||||||
|
* @param {number} [opts.controlFillActiveAlpha=Theme.strokeAlpha] - The alpha value of the background when activated.
|
||||||
|
* @param {number} [opts.controlStroke=Theme.stroke] - The color of the border as a hex value.
|
||||||
|
* @param {number} [opts.controlStrokeWidth=Theme.strokeWidth * 0.8] - The width of the border in pixel.
|
||||||
|
* @param {number} [opts.controlStrokeAlpha=Theme.strokeAlpha] - The alpha value of the border.
|
||||||
|
* @param {number} [opts.controlStrokeActive=Theme.stroke] - The color of the border when activated.
|
||||||
|
* @param {number} [opts.controlStrokeActiveWidth=Theme.strokeActiveWidth * 0.8] - The width of the border in pixel when activated.
|
||||||
|
* @param {number} [opts.controlStrokeActiveAlpha=Theme.strokeActiveAlpha] - The alpha value of the border when activated.
|
||||||
|
* @param {number} [opts.duration=Theme.fast] - The duration of the animation when the switch gets activated in seconds.
|
||||||
|
* @param {number} [opts.durationActive=Theme.fast] - The duration of the animation when the switch gets deactivated in seconds.
|
||||||
|
* @param {boolean} [opts.disabled=false] - Is the switch disabled? When disabled, the switch has a lower alpha value
|
||||||
|
* and cannot be clicked (interactive is set to false).
|
||||||
|
* @param {boolean} [opts.active=false] - Is the button initially active?
|
||||||
|
* @param {actionCallback} [opts.action] - Executed when the switch was triggered in inactive state (by pointerup).
|
||||||
|
* @param {actionActiveCallback} [opts.actionActive] - Executed when the button was triggered in active state (by pointerup).
|
||||||
|
* @param {beforeActionCallback} [opts.beforeAction] - Executed before an action is triggered.
|
||||||
|
* @param {afterActionCallback} [opts.afterAction] - Executed after an action was triggered.
|
||||||
|
* @param {string|object} [opts.tooltip] - A string for the label of the tooltip or an object to configure the tooltip
|
||||||
|
* to display.
|
||||||
|
* @param {boolean} [opts.visible=true] - Is the switch initially visible (property visible)?
|
||||||
|
*/
|
||||||
|
constructor(opts = {}) {
|
||||||
|
|
||||||
|
super()
|
||||||
|
|
||||||
|
const theme = Theme.fromString(opts.theme)
|
||||||
|
this.theme = theme
|
||||||
|
|
||||||
|
this.opts = Object.assign({}, {
|
||||||
|
id: PIXI.utils.uid(),
|
||||||
|
x: 0,
|
||||||
|
y: 0,
|
||||||
|
width: 44,
|
||||||
|
height: 28,
|
||||||
|
fill: theme.fill,
|
||||||
|
fillAlpha: theme.fillAlpha,
|
||||||
|
fillActive: theme.primaryColor,
|
||||||
|
fillActiveAlpha: theme.fillActiveAlpha,
|
||||||
|
stroke: theme.stroke,
|
||||||
|
strokeWidth: theme.strokeWidth,
|
||||||
|
strokeAlpha: theme.strokeAlpha,
|
||||||
|
strokeActive: theme.primaryColor,
|
||||||
|
strokeActiveWidth: theme.strokeActiveWidth,
|
||||||
|
strokeActiveAlpha: theme.strokeActiveAlpha,
|
||||||
|
controlFill: theme.stroke,
|
||||||
|
controlFillAlpha: theme.strokeAlpha,
|
||||||
|
controlFillActive: theme.stroke,
|
||||||
|
controlFillActiveAlpha: theme.strokeAlpha,
|
||||||
|
controlStroke: theme.stroke,
|
||||||
|
controlStrokeWidth: theme.strokeWidth * .8,
|
||||||
|
controlStrokeAlpha: theme.strokeAlpha,
|
||||||
|
controlStrokeActive: theme.stroke,
|
||||||
|
controlStrokeActiveWidth: theme.strokeActiveWidth * .8,
|
||||||
|
controlStrokeActiveAlpha: theme.strokeActiveAlpha,
|
||||||
|
duration: theme.fast,
|
||||||
|
durationActive: theme.fast,
|
||||||
|
disabled: false,
|
||||||
|
active: false,
|
||||||
|
action: null,
|
||||||
|
actionActive: null,
|
||||||
|
beforeAction: null,
|
||||||
|
afterAction: null,
|
||||||
|
tooltip: null,
|
||||||
|
visible: true
|
||||||
|
}, opts)
|
||||||
|
|
||||||
|
this.opts.controlRadius = this.opts.controlRadius || (this.opts.height / 2)
|
||||||
|
this.opts.controlRadiusActive = this.opts.controlRadiusActive || this.opts.controlRadius
|
||||||
|
|
||||||
|
// Validation
|
||||||
|
//-----------------
|
||||||
|
if (this.opts.height > this.opts.width) {
|
||||||
|
this.opts.height = this.opts.width
|
||||||
|
}
|
||||||
|
|
||||||
|
// Properties
|
||||||
|
//-----------------
|
||||||
|
this.id = this.opts.id
|
||||||
|
this.radius = this.opts.height / 2
|
||||||
|
|
||||||
|
this._active = null
|
||||||
|
this._disabled = null
|
||||||
|
|
||||||
|
this.switchObj = null
|
||||||
|
this.control = null
|
||||||
|
this.tooltip = null
|
||||||
|
|
||||||
|
this.visible = this.opts.visible
|
||||||
|
|
||||||
|
// animated
|
||||||
|
//-----------------
|
||||||
|
this.tempAnimated = {
|
||||||
|
fill: this.opts.fill,
|
||||||
|
fillAlpha: this.opts.fillAlpha,
|
||||||
|
stroke: this.opts.stroke,
|
||||||
|
strokeWidth: this.opts.strokeWidth,
|
||||||
|
strokeAlpha: this.opts.strokeAlpha,
|
||||||
|
controlFill: this.opts.controlFill,
|
||||||
|
controlFillAlpha: this.opts.controlFillAlpha,
|
||||||
|
controlStroke: this.opts.controlStroke,
|
||||||
|
controlStrokeWidth: this.opts.controlStrokeWidth,
|
||||||
|
controlStrokeAlpha: this.opts.controlStrokeAlpha,
|
||||||
|
controlRadius: this.opts.controlRadius
|
||||||
|
}
|
||||||
|
|
||||||
|
// setup
|
||||||
|
//-----------------
|
||||||
|
this.setup()
|
||||||
|
|
||||||
|
// layout
|
||||||
|
//-----------------
|
||||||
|
this.layout()
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates children and instantiates everything.
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
* @return {Switch} A reference to the switch for chaining.
|
||||||
|
*/
|
||||||
|
setup() {
|
||||||
|
|
||||||
|
// Switch
|
||||||
|
//-----------------
|
||||||
|
let switchObj = new PIXI.Graphics()
|
||||||
|
this.switchObj = switchObj
|
||||||
|
this.addChild(switchObj)
|
||||||
|
|
||||||
|
// Control
|
||||||
|
//-----------------
|
||||||
|
this.xInactive = this.opts.controlRadius
|
||||||
|
this.xActive = this.opts.width - this.opts.controlRadiusActive
|
||||||
|
|
||||||
|
let control = new PIXI.Graphics()
|
||||||
|
control.x = this.opts.active ? this.xActive : this.xInactive
|
||||||
|
control.y = this.opts.height / 2
|
||||||
|
|
||||||
|
this.control = control
|
||||||
|
|
||||||
|
this.addChild(this.control)
|
||||||
|
|
||||||
|
// interaction
|
||||||
|
//-----------------
|
||||||
|
this.switchObj.on('pointerover', e => {
|
||||||
|
TweenLite.to(this.control, this.theme.fast, {alpha: .83})
|
||||||
|
})
|
||||||
|
|
||||||
|
this.switchObj.on('pointerout', e => {
|
||||||
|
TweenLite.to(this.control, this.theme.fast, {alpha: 1})
|
||||||
|
})
|
||||||
|
|
||||||
|
this.switchObj.on('pointerdown', e => {
|
||||||
|
TweenLite.to(this.control, this.theme.fast, {alpha: .7})
|
||||||
|
})
|
||||||
|
|
||||||
|
this.switchObj.on('pointerup', e => {
|
||||||
|
|
||||||
|
if (this.opts.beforeAction) {
|
||||||
|
this.opts.beforeAction.call(this, e, this)
|
||||||
|
}
|
||||||
|
|
||||||
|
this.active = !this.active
|
||||||
|
|
||||||
|
if (this.active) {
|
||||||
|
if (this.opts.action) {
|
||||||
|
this.opts.action.call(this, e, this)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (this.opts.actionActive) {
|
||||||
|
this.opts.actionActive.call(this, e, this)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TweenLite.to(this.control, this.theme.fast, {alpha: .83})
|
||||||
|
|
||||||
|
if (this.opts.afterAction) {
|
||||||
|
this.opts.afterAction.call(this, e, this)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// disabled
|
||||||
|
//-----------------
|
||||||
|
this.disabled = this.opts.disabled
|
||||||
|
|
||||||
|
// active
|
||||||
|
//-----------------
|
||||||
|
this.active = this.opts.active
|
||||||
|
|
||||||
|
// tooltip
|
||||||
|
//-----------------
|
||||||
|
if (this.opts.tooltip) {
|
||||||
|
if (typeof this.opts.tooltip === 'string') {
|
||||||
|
this.tooltip = new Tooltip({
|
||||||
|
object: this,
|
||||||
|
content: this.opts.tooltip
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.opts.tooltip.object = this
|
||||||
|
this.tooltip = new Tooltip(this.opts.tooltip)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Should be called to refresh the layout of the switch. Can be used after resizing.
|
||||||
|
*
|
||||||
|
* @return {Switch} A reference to the switch for chaining.
|
||||||
|
*/
|
||||||
|
layout() {
|
||||||
|
|
||||||
|
// set position
|
||||||
|
//-----------------
|
||||||
|
this.position.set(this.opts.x, this.opts.y)
|
||||||
|
|
||||||
|
// draw
|
||||||
|
//-----------------
|
||||||
|
this.draw()
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Draws the switch to the canvas.
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
* @return {Switch} A reference to the switch for chaining.
|
||||||
|
*/
|
||||||
|
draw() {
|
||||||
|
|
||||||
|
this.switchObj.clear()
|
||||||
|
if (this.active) {
|
||||||
|
this.switchObj.lineStyle(this.opts.strokeActiveWidth, this.opts.strokeActive, this.opts.strokeActiveAlpha)
|
||||||
|
this.switchObj.beginFill(this.opts.fillActive, this.opts.fillActiveAlpha)
|
||||||
|
} else {
|
||||||
|
this.switchObj.lineStyle(this.opts.strokeWidth, this.opts.stroke, this.opts.strokeAlpha)
|
||||||
|
this.switchObj.beginFill(this.opts.fill, this.opts.fillAlpha)
|
||||||
|
}
|
||||||
|
this.switchObj.moveTo(this.radius, 0)
|
||||||
|
this.switchObj.lineTo(this.opts.width - this.radius, 0)
|
||||||
|
this.switchObj.arcTo(this.opts.width, 0, this.opts.width, this.radius, this.radius)
|
||||||
|
this.switchObj.lineTo(this.opts.width, this.radius + 1) // BUGFIX: If not specified, there is a small area without a stroke.
|
||||||
|
this.switchObj.arcTo(this.opts.width, this.opts.height, this.opts.width - this.radius, this.opts.height, this.radius)
|
||||||
|
this.switchObj.lineTo(this.radius, this.opts.height)
|
||||||
|
this.switchObj.arcTo(0, this.opts.height, 0, this.radius, this.radius)
|
||||||
|
this.switchObj.arcTo(0, 0, this.radius, 0, this.radius)
|
||||||
|
this.switchObj.endFill()
|
||||||
|
|
||||||
|
// Draw control
|
||||||
|
this.control.clear()
|
||||||
|
if (this.active) {
|
||||||
|
this.control.lineStyle(this.opts.controlStrokeActiveWidth, this.opts.controlStrokeActive, this.opts.controlStrokeActiveAlpha)
|
||||||
|
this.control.beginFill(this.opts.controlFillActive, this.opts.controlFillActiveAlpha)
|
||||||
|
this.control.drawCircle(0, 0, this.opts.controlRadiusActive - 1)
|
||||||
|
} else {
|
||||||
|
this.control.lineStyle(this.opts.controlStrokeWidth, this.opts.controlStroke, this.opts.controlStrokeAlpha)
|
||||||
|
this.control.beginFill(this.opts.controlFill, this.opts.controlFillAlpha)
|
||||||
|
this.control.drawCircle(0, 0, this.opts.controlRadius - 1)
|
||||||
|
}
|
||||||
|
this.control.endFill()
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Draws the animation.
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
* @return {Switch} A reference to the switch for chaining.
|
||||||
|
*/
|
||||||
|
drawAnimated() {
|
||||||
|
|
||||||
|
this.switchObj.clear()
|
||||||
|
this.switchObj.lineStyle(this.tempAnimated.strokeWidth, this.tempAnimated.stroke, this.tempAnimated.strokeAlpha)
|
||||||
|
this.switchObj.beginFill(this.tempAnimated.fill, this.tempAnimated.fillAlpha)
|
||||||
|
this.switchObj.moveTo(this.radius, 0)
|
||||||
|
this.switchObj.lineTo(this.opts.width - this.radius, 0)
|
||||||
|
this.switchObj.arcTo(this.opts.width, 0, this.opts.width, this.radius, this.radius)
|
||||||
|
this.switchObj.lineTo(this.opts.width, this.radius + 1) // BUGFIX: If not specified, there is a small area without a stroke.
|
||||||
|
this.switchObj.arcTo(this.opts.width, this.opts.height, this.opts.width - this.radius, this.opts.height, this.radius)
|
||||||
|
this.switchObj.lineTo(this.radius, this.opts.height)
|
||||||
|
this.switchObj.arcTo(0, this.opts.height, 0, this.radius, this.radius)
|
||||||
|
this.switchObj.arcTo(0, 0, this.radius, 0, this.radius)
|
||||||
|
this.switchObj.endFill()
|
||||||
|
|
||||||
|
this.control.clear()
|
||||||
|
this.control.lineStyle(this.tempAnimated.controlStrokeWidth, this.tempAnimated.controlStroke, this.tempAnimated.controlStrokeAlpha)
|
||||||
|
this.control.beginFill(this.tempAnimated.controlFill, this.tempAnimated.controlFillAlpha)
|
||||||
|
this.control.drawCircle(0, 0, this.tempAnimated.controlRadius - 1)
|
||||||
|
this.control.endFill()
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets or sets the active state.
|
||||||
|
*
|
||||||
|
* @member {boolean}
|
||||||
|
*/
|
||||||
|
get active() {
|
||||||
|
return this._active
|
||||||
|
}
|
||||||
|
|
||||||
|
set active(value) {
|
||||||
|
|
||||||
|
this._active = value
|
||||||
|
|
||||||
|
if (this._active) {
|
||||||
|
|
||||||
|
TweenLite.to(this.control, this.opts.duration, {x: this.xActive})
|
||||||
|
TweenLite.to(this.tempAnimated, this.opts.duration, {
|
||||||
|
colorProps: {
|
||||||
|
fill: this.opts.fillActive,
|
||||||
|
stroke: this.opts.strokeActive,
|
||||||
|
controlFill: this.opts.controlFillActive,
|
||||||
|
controlStroke: this.opts.controlStrokeActive,
|
||||||
|
format: 'number'
|
||||||
|
},
|
||||||
|
fillAlpha: this.opts.fillActiveAlpha,
|
||||||
|
strokeWidth: this.opts.strokeActiveWidth,
|
||||||
|
strokeAlpha: this.opts.strokeActiveAlpha,
|
||||||
|
controlFillAlpha: this.opts.controlFillActiveAlpha,
|
||||||
|
controlStrokeWidth: this.opts.controlStrokeActiveWidth,
|
||||||
|
controlStrokeAlpha: this.opts.controlStrokeActiveAlpha,
|
||||||
|
controlRadius: this.opts.controlRadiusActive,
|
||||||
|
onUpdate: () => this.drawAnimated(),
|
||||||
|
onComplete: () => this.draw()
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
} else {
|
||||||
|
TweenLite.to(this.control, this.opts.durationActive, {x: this.xInactive})
|
||||||
|
TweenLite.to(this.tempAnimated, this.opts.durationActive, {
|
||||||
|
colorProps: {
|
||||||
|
fill: this.opts.fill,
|
||||||
|
stroke: this.opts.stroke,
|
||||||
|
controlFill: this.opts.controlFill,
|
||||||
|
controlStroke: this.opts.controlStroke,
|
||||||
|
format: 'number'
|
||||||
|
},
|
||||||
|
fillAlpha: this.opts.fillAlpha,
|
||||||
|
strokeWidth: this.opts.strokeWidth,
|
||||||
|
strokeAlpha: this.opts.strokeAlpha,
|
||||||
|
controlFillAlpha: this.opts.controlFillAlpha,
|
||||||
|
controlStrokeWidth: this.opts.controlStrokeWidth,
|
||||||
|
controlStrokeAlpha: this.opts.controlStrokeAlpha,
|
||||||
|
controlRadius: this.opts.controlRadius,
|
||||||
|
onUpdate: () => this.drawAnimated(),
|
||||||
|
onComplete: () => this.draw()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets or sets the disabled state. When disabled, the switch cannot be clicked.
|
||||||
|
*
|
||||||
|
* @member {boolean}
|
||||||
|
*/
|
||||||
|
get disabled() {
|
||||||
|
return this._disabled
|
||||||
|
}
|
||||||
|
|
||||||
|
set disabled(value) {
|
||||||
|
|
||||||
|
this._disabled = value
|
||||||
|
|
||||||
|
if (this._disabled) {
|
||||||
|
this.switchObj.interactive = false
|
||||||
|
this.switchObj.buttonMode = false
|
||||||
|
this.switchObj.alpha = .5
|
||||||
|
this.control.alpha = .5
|
||||||
|
} else {
|
||||||
|
this.switchObj.interactive = true
|
||||||
|
this.switchObj.buttonMode = true
|
||||||
|
this.switchObj.alpha = 1
|
||||||
|
this.control.alpha = 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shows the switch (sets his alpha values to 1).
|
||||||
|
*
|
||||||
|
* @return {Switch} A reference to the switch for chaining.
|
||||||
|
*/
|
||||||
|
show() {
|
||||||
|
|
||||||
|
this.opts.strokeAlpha = 1
|
||||||
|
this.opts.strokeActiveAlpha = 1
|
||||||
|
this.opts.fillAlpha = 1
|
||||||
|
this.opts.fillActiveAlpha = 1
|
||||||
|
this.opts.controlStrokeAlpha = 1
|
||||||
|
this.opts.controlStrokeActiveAlpha = 1
|
||||||
|
this.opts.controlFillAlpha = 1
|
||||||
|
this.opts.controlFillActiveAlpha = 1
|
||||||
|
|
||||||
|
this.layout()
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hides the switch (sets his alpha values to 1).
|
||||||
|
*
|
||||||
|
* @return {Switch} A reference to the switch for chaining.
|
||||||
|
*/
|
||||||
|
hide() {
|
||||||
|
|
||||||
|
this.opts.strokeAlpha = 0
|
||||||
|
this.opts.strokeActiveAlpha = 0
|
||||||
|
this.opts.fillAlpha = 0
|
||||||
|
this.opts.fillActiveAlpha = 0
|
||||||
|
this.opts.controlStrokeAlpha = 0
|
||||||
|
this.opts.controlStrokeActiveAlpha = 0
|
||||||
|
this.opts.controlFillAlpha = 0
|
||||||
|
this.opts.controlFillActiveAlpha = 0
|
||||||
|
|
||||||
|
this.layout()
|
||||||
|
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
}
|
@ -9,10 +9,10 @@
|
|||||||
<link rel="stylesheet" href="../../css/doctest.css">
|
<link rel="stylesheet" href="../../css/doctest.css">
|
||||||
|
|
||||||
<script src="../3rdparty/highlight/highlight.pack.js"></script>
|
<script src="../3rdparty/highlight/highlight.pack.js"></script>
|
||||||
<script src="../3rdparty/all.js"></script>
|
|
||||||
|
|
||||||
<script src="../all.js"></script>
|
<script src="../../dist/iwmlib.3rdparty.js"></script>
|
||||||
<script src="./all.js"></script>
|
<script src="../../dist/iwmlib.js"></script>
|
||||||
|
<script src="../../dist/iwmlib.pixi.js"></script>
|
||||||
</head>
|
</head>
|
||||||
<body onload="Doctest.run()">
|
<body onload="Doctest.run()">
|
||||||
<h1>Switch</h1>
|
<h1>Switch</h1>
|
||||||
|
188
package-lock.json
generated
188
package-lock.json
generated
@ -381,9 +381,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"async-each": {
|
"async-each": {
|
||||||
"version": "1.0.2",
|
"version": "1.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
|
||||||
"integrity": "sha512-6xrbvN0MOBKSJDdonmSSz2OwFSgxRaVtBDes26mj9KIGtDo+g9xosFRSC+i1gQh2oAN/tQ62AI/pGZGQjVOiRg==",
|
"integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"async-settle": {
|
"async-settle": {
|
||||||
@ -480,9 +480,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"binary-extensions": {
|
"binary-extensions": {
|
||||||
"version": "1.13.0",
|
"version": "1.13.1",
|
||||||
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.0.tgz",
|
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
|
||||||
"integrity": "sha512-EgmjVLMn22z7eGGv3kcnHwSnJXmFHjISTY9E/S5lIcTD3Oxw05QTcBLNkJFzcb3cNueUdF/IN4U+d78V0zO8Hw==",
|
"integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"binaryextensions": {
|
"binaryextensions": {
|
||||||
@ -620,9 +620,9 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"chokidar": {
|
"chokidar": {
|
||||||
"version": "2.1.4",
|
"version": "2.1.5",
|
||||||
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.4.tgz",
|
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.5.tgz",
|
||||||
"integrity": "sha512-ZVuFiB9IGOHqu+Jh7B7fSTmzsfDmUtC6yqd/V72UPQeXbNHONbMV0chOXtLXjsP3NvdUsHTNMg02NtXPDaSmNQ==",
|
"integrity": "sha512-i0TprVWp+Kj4WRPtInjexJ8Q+BqTE909VpH8xVhXrJkoc5QC8VO9TryGOqTr+2hljzc1sC62t22h5tZePodM/A==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"anymatch": "^2.0.0",
|
"anymatch": "^2.0.0",
|
||||||
@ -757,9 +757,9 @@
|
|||||||
"integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg=="
|
"integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg=="
|
||||||
},
|
},
|
||||||
"component-emitter": {
|
"component-emitter": {
|
||||||
"version": "1.2.1",
|
"version": "1.3.0",
|
||||||
"resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz",
|
||||||
"integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=",
|
"integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"concat-map": {
|
"concat-map": {
|
||||||
@ -1018,9 +1018,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"es5-ext": {
|
"es5-ext": {
|
||||||
"version": "0.10.49",
|
"version": "0.10.50",
|
||||||
"resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.49.tgz",
|
"resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.50.tgz",
|
||||||
"integrity": "sha512-3NMEhi57E31qdzmYp2jwRArIUsj1HI/RxbQ4bgnSB+AIKIxsAmTiK83bYMifIcpWvEc3P1X30DhUKOqEtF/kvg==",
|
"integrity": "sha512-KMzZTPBkeQV/JcSQhI5/z6d9VWJ3EnQ194USTUwIYZ2ZbpN8+SGXQKt1h68EX44+qt+Fzr8DO17vnxrw7c3agw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"es6-iterator": "~2.0.3",
|
"es6-iterator": "~2.0.3",
|
||||||
@ -1319,32 +1319,21 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"findup-sync": {
|
"findup-sync": {
|
||||||
"version": "2.0.0",
|
"version": "3.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-2.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-3.0.0.tgz",
|
||||||
"integrity": "sha1-kyaxSIwi0aYIhlCoaQGy2akKLLw=",
|
"integrity": "sha512-YbffarhcicEhOrm4CtrwdKBdCuz576RLdhJDsIfvNtxUuhdRet1qZcsMjqbePtAseKdAnDyM/IyXbu7PRPRLYg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"detect-file": "^1.0.0",
|
"detect-file": "^1.0.0",
|
||||||
"is-glob": "^3.1.0",
|
"is-glob": "^4.0.0",
|
||||||
"micromatch": "^3.0.4",
|
"micromatch": "^3.0.4",
|
||||||
"resolve-dir": "^1.0.1"
|
"resolve-dir": "^1.0.1"
|
||||||
},
|
|
||||||
"dependencies": {
|
|
||||||
"is-glob": {
|
|
||||||
"version": "3.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
|
|
||||||
"integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
|
|
||||||
"dev": true,
|
|
||||||
"requires": {
|
|
||||||
"is-extglob": "^2.1.0"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"fined": {
|
"fined": {
|
||||||
"version": "1.1.1",
|
"version": "1.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/fined/-/fined-1.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/fined/-/fined-1.2.0.tgz",
|
||||||
"integrity": "sha512-jQp949ZmEbiYHk3gkbdtpJ0G1+kgtLQBNdP5edFP7Fh+WAYceLQz6yO1SBj72Xkg8GVyTB3bBzAYrHJVh5Xd5g==",
|
"integrity": "sha512-ZYDqPLGxDkDhDZBjZBb+oD1+j0rA4E0pXY50eplAAOPg2N/gUBSSk5IM1/QhPfyVo19lJ+CvXpqfvk+b2p/8Ng==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"expand-tilde": "^2.0.2",
|
"expand-tilde": "^2.0.2",
|
||||||
@ -1416,14 +1405,14 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"fsevents": {
|
"fsevents": {
|
||||||
"version": "1.2.7",
|
"version": "1.2.9",
|
||||||
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.7.tgz",
|
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz",
|
||||||
"integrity": "sha512-Pxm6sI2MeBD7RdD12RYsqaP0nMiwx8eZBXCa6z2L+mRHm2DYrOYwihmhjpkdjUHwQhslWQjRpEgNq4XvBmaAuw==",
|
"integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"nan": "^2.9.2",
|
"nan": "^2.12.1",
|
||||||
"node-pre-gyp": "^0.10.0"
|
"node-pre-gyp": "^0.12.0"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"abbrev": {
|
"abbrev": {
|
||||||
@ -1501,12 +1490,12 @@
|
|||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"debug": {
|
"debug": {
|
||||||
"version": "2.6.9",
|
"version": "4.1.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"ms": "2.0.0"
|
"ms": "^2.1.1"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deep-extend": {
|
"deep-extend": {
|
||||||
@ -1677,24 +1666,24 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"ms": {
|
"ms": {
|
||||||
"version": "2.0.0",
|
"version": "2.1.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"needle": {
|
"needle": {
|
||||||
"version": "2.2.4",
|
"version": "2.3.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"debug": "^2.1.2",
|
"debug": "^4.1.0",
|
||||||
"iconv-lite": "^0.4.4",
|
"iconv-lite": "^0.4.4",
|
||||||
"sax": "^1.2.4"
|
"sax": "^1.2.4"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node-pre-gyp": {
|
"node-pre-gyp": {
|
||||||
"version": "0.10.3",
|
"version": "0.12.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
@ -1722,13 +1711,13 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"npm-bundled": {
|
"npm-bundled": {
|
||||||
"version": "1.0.5",
|
"version": "1.0.6",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"npm-packlist": {
|
"npm-packlist": {
|
||||||
"version": "1.2.0",
|
"version": "1.4.1",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
@ -1867,7 +1856,7 @@
|
|||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"semver": {
|
"semver": {
|
||||||
"version": "5.6.0",
|
"version": "5.7.0",
|
||||||
"bundled": true,
|
"bundled": true,
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true
|
"optional": true
|
||||||
@ -1981,9 +1970,9 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"glob": {
|
"glob": {
|
||||||
"version": "7.1.3",
|
"version": "7.1.4",
|
||||||
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz",
|
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz",
|
||||||
"integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==",
|
"integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"fs.realpath": "^1.0.0",
|
"fs.realpath": "^1.0.0",
|
||||||
@ -2296,21 +2285,21 @@
|
|||||||
"integrity": "sha512-7saMzK2HQ3OD4/hbygtkh0uAK8LUqcom6abL4YqGttyxAQdEvywQOw5VK3obKQ7GaLU8KhszArKJPxIKe8mbvg=="
|
"integrity": "sha512-7saMzK2HQ3OD4/hbygtkh0uAK8LUqcom6abL4YqGttyxAQdEvywQOw5VK3obKQ7GaLU8KhszArKJPxIKe8mbvg=="
|
||||||
},
|
},
|
||||||
"gulp": {
|
"gulp": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/gulp/-/gulp-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/gulp/-/gulp-4.0.2.tgz",
|
||||||
"integrity": "sha1-lXZsYB2t5Kd+0+eyttwDiBtZY2Y=",
|
"integrity": "sha512-dvEs27SCZt2ibF29xYgmnwwCYZxdxhQ/+LFWlbAW8y7jt68L/65402Lz3+CKy0Ov4rOs+NERmDq7YlZaDqUIfA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"glob-watcher": "^5.0.0",
|
"glob-watcher": "^5.0.3",
|
||||||
"gulp-cli": "^2.0.0",
|
"gulp-cli": "^2.2.0",
|
||||||
"undertaker": "^1.0.0",
|
"undertaker": "^1.2.1",
|
||||||
"vinyl-fs": "^3.0.0"
|
"vinyl-fs": "^3.0.0"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"gulp-cli": {
|
"gulp-cli": {
|
||||||
"version": "2.0.1",
|
"version": "2.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/gulp-cli/-/gulp-cli-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/gulp-cli/-/gulp-cli-2.2.0.tgz",
|
||||||
"integrity": "sha512-RxujJJdN8/O6IW2nPugl7YazhmrIEjmiVfPKrWt68r71UCaLKS71Hp0gpKT+F6qOUFtr7KqtifDKaAJPRVvMYQ==",
|
"integrity": "sha512-rGs3bVYHdyJpLqR0TUBnlcZ1O5O++Zs4bA0ajm+zr3WFCfiSLjGwoCBqFs18wzN+ZxahT9DkOK5nDf26iDsWjA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"ansi-colors": "^1.0.1",
|
"ansi-colors": "^1.0.1",
|
||||||
@ -2323,7 +2312,7 @@
|
|||||||
"gulplog": "^1.0.0",
|
"gulplog": "^1.0.0",
|
||||||
"interpret": "^1.1.0",
|
"interpret": "^1.1.0",
|
||||||
"isobject": "^3.0.1",
|
"isobject": "^3.0.1",
|
||||||
"liftoff": "^2.5.0",
|
"liftoff": "^3.1.0",
|
||||||
"matchdep": "^2.0.0",
|
"matchdep": "^2.0.0",
|
||||||
"mute-stdout": "^1.0.0",
|
"mute-stdout": "^1.0.0",
|
||||||
"pretty-hrtime": "^1.0.0",
|
"pretty-hrtime": "^1.0.0",
|
||||||
@ -2615,9 +2604,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"is-glob": {
|
"is-glob": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
|
||||||
"integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=",
|
"integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-extglob": "^2.1.1"
|
"is-extglob": "^2.1.1"
|
||||||
@ -2783,13 +2772,13 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"liftoff": {
|
"liftoff": {
|
||||||
"version": "2.5.0",
|
"version": "3.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/liftoff/-/liftoff-2.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/liftoff/-/liftoff-3.1.0.tgz",
|
||||||
"integrity": "sha1-IAkpG7Mc6oYbvxCnwVooyvdcMew=",
|
"integrity": "sha512-DlIPlJUkCV0Ips2zf2pJP0unEoT1kwYhiiPUGF3s/jtxTCjziNLoiVVh+jqWOWeFi6mmwQ5fNxvAUyPad4Dfog==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"extend": "^3.0.0",
|
"extend": "^3.0.0",
|
||||||
"findup-sync": "^2.0.0",
|
"findup-sync": "^3.0.0",
|
||||||
"fined": "^1.0.1",
|
"fined": "^1.0.1",
|
||||||
"flagged-respawn": "^1.0.0",
|
"flagged-respawn": "^1.0.0",
|
||||||
"is-plain-object": "^2.0.4",
|
"is-plain-object": "^2.0.4",
|
||||||
@ -2878,6 +2867,29 @@
|
|||||||
"micromatch": "^3.0.4",
|
"micromatch": "^3.0.4",
|
||||||
"resolve": "^1.4.0",
|
"resolve": "^1.4.0",
|
||||||
"stack-trace": "0.0.10"
|
"stack-trace": "0.0.10"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"findup-sync": {
|
||||||
|
"version": "2.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-2.0.0.tgz",
|
||||||
|
"integrity": "sha1-kyaxSIwi0aYIhlCoaQGy2akKLLw=",
|
||||||
|
"dev": true,
|
||||||
|
"requires": {
|
||||||
|
"detect-file": "^1.0.0",
|
||||||
|
"is-glob": "^3.1.0",
|
||||||
|
"micromatch": "^3.0.4",
|
||||||
|
"resolve-dir": "^1.0.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"is-glob": {
|
||||||
|
"version": "3.1.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
|
||||||
|
"integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
|
||||||
|
"dev": true,
|
||||||
|
"requires": {
|
||||||
|
"is-extglob": "^2.1.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"material-design-icons": {
|
"material-design-icons": {
|
||||||
@ -2964,9 +2976,9 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"nan": {
|
"nan": {
|
||||||
"version": "2.13.1",
|
"version": "2.13.2",
|
||||||
"resolved": "https://registry.npmjs.org/nan/-/nan-2.13.1.tgz",
|
"resolved": "https://registry.npmjs.org/nan/-/nan-2.13.2.tgz",
|
||||||
"integrity": "sha512-I6YB/YEuDeUZMmhscXKxGgZlFnhsn5y0hgOZBadkzfTRrZBtJDZeg6eQf7PYMIEclwmorTKK8GztsyOUSVBREA==",
|
"integrity": "sha512-TghvYc72wlMGMVMluVo9WRJc0mB8KxxF/gZ4YYFy7V2ZQX9l7rgbPg7vjS9mt6U5HXODVFVI2bOduCzwOMv/lw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
@ -3017,9 +3029,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"now-and-later": {
|
"now-and-later": {
|
||||||
"version": "2.0.0",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-2.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-2.0.1.tgz",
|
||||||
"integrity": "sha1-vGHLtFbXnLMiB85HygUTb/Ln1u4=",
|
"integrity": "sha512-KGvQ0cB70AQfg107Xvs/Fbu+dGmZoTRJp2TaPwcwQm3/7PteUyN2BCgk8KBMPGBUXZdVwyWS8fDCGFygBm19UQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"once": "^1.3.2"
|
"once": "^1.3.2"
|
||||||
@ -3663,9 +3675,9 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"resource-loader": {
|
"resource-loader": {
|
||||||
"version": "2.2.3",
|
"version": "2.2.4",
|
||||||
"resolved": "https://registry.npmjs.org/resource-loader/-/resource-loader-2.2.3.tgz",
|
"resolved": "https://registry.npmjs.org/resource-loader/-/resource-loader-2.2.4.tgz",
|
||||||
"integrity": "sha512-SsxilncV7gxwr12clSq0E2HZh8QjcosVVSEAnZ3VF9VtBNNtO3UFxxXT9pJgkVEJUHAlXg26MkkTOMjyz1kDdw==",
|
"integrity": "sha512-MrY0bEJN26us3h4bzJUSP0n4tFEb79lCpYBavtLjSezWCcXZMgxhSgvC9LxueuqpcxG+qPjhwFu5SQAcUNacdA==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"mini-signals": "^1.1.1",
|
"mini-signals": "^1.1.1",
|
||||||
"parse-uri": "^1.0.0"
|
"parse-uri": "^1.0.0"
|
||||||
@ -3692,9 +3704,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"semver": {
|
"semver": {
|
||||||
"version": "5.6.0",
|
"version": "5.7.0",
|
||||||
"resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz",
|
"resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz",
|
||||||
"integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==",
|
"integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"semver-greatest-satisfied-range": {
|
"semver-greatest-satisfied-range": {
|
||||||
@ -3904,9 +3916,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"spdx-license-ids": {
|
"spdx-license-ids": {
|
||||||
"version": "3.0.3",
|
"version": "3.0.4",
|
||||||
"resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.4.tgz",
|
||||||
"integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==",
|
"integrity": "sha512-7j8LYJLeY/Yb6ACbQ7F76qy5jHkp0U6jgBfJsk97bwWlVUnUWsAgpyaCvo17h0/RQGnQ036tVDomiwoI4pDkQA==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"split-string": {
|
"split-string": {
|
||||||
@ -4232,9 +4244,9 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"undertaker": {
|
"undertaker": {
|
||||||
"version": "1.2.0",
|
"version": "1.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/undertaker/-/undertaker-1.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/undertaker/-/undertaker-1.2.1.tgz",
|
||||||
"integrity": "sha1-M52kZGJS0ILcN45wgGcpl1DhG0k=",
|
"integrity": "sha512-71WxIzDkgYk9ZS+spIB8iZXchFhAdEo2YU8xYqBYJ39DIUIqziK78ftm26eecoIY49X0J2MLhG4hr18Yp6/CMA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"arr-flatten": "^1.0.1",
|
"arr-flatten": "^1.0.1",
|
||||||
@ -4363,9 +4375,9 @@
|
|||||||
"integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
|
"integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
|
||||||
},
|
},
|
||||||
"v8flags": {
|
"v8flags": {
|
||||||
"version": "3.1.2",
|
"version": "3.1.3",
|
||||||
"resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.3.tgz",
|
||||||
"integrity": "sha512-MtivA7GF24yMPte9Rp/BWGCYQNaUj86zeYxV/x2RRJMKagImbbv3u8iJC57lNhWLPcGLJmHcHmFWkNsplbbLWw==",
|
"integrity": "sha512-amh9CCg3ZxkzQ48Mhcb8iX7xpAfYJgePHxWMQCBWECpOSqJUXgY26ncA61UTV0BkPqfhcy6mzwCIoP4ygxpW8w==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"homedir-polyfill": "^1.0.1"
|
"homedir-polyfill": "^1.0.1"
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
"license": "LGPL-3.0-or-later",
|
"license": "LGPL-3.0-or-later",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@pixi/jsdoc-template": "^2.4.2",
|
"@pixi/jsdoc-template": "^2.4.2",
|
||||||
"gulp": "^4.0.0",
|
"gulp": "^4.0.2",
|
||||||
"gulp-concat": "^2.6.1",
|
"gulp-concat": "^2.6.1",
|
||||||
"gulp-rename": "^1.4.0",
|
"gulp-rename": "^1.4.0",
|
||||||
"gulp-replace": "^1.0.0",
|
"gulp-replace": "^1.0.0",
|
||||||
|
Loading…
Reference in New Issue
Block a user