diff --git a/.gitignore b/.gitignore index 6b5fe07c..ed064843 100644 --- a/.gitignore +++ b/.gitignore @@ -2,7 +2,7 @@ node_modules/ *.DS_Store .DS_Store doc/ -dist/ + packages/*/dist demo/dist/ release/ diff --git a/dist/scene.cjs.js b/dist/scene.cjs.js new file mode 100644 index 00000000..7bfb3cbb --- /dev/null +++ b/dist/scene.cjs.js @@ -0,0 +1,4173 @@ +/* +Copyright (c) 2016 Daybrush +name: scenejs +license: MIT +author: Daybrush +repository: https://github.com/daybrush/scenejs.git +version: 1.4.0 +*/ +'use strict'; + +var utils = require('@daybrush/utils'); +var OrderMap = require('order-map'); +var styled = require('css-styled'); + +/*! ***************************************************************************** +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. +***************************************************************************** */ + +/* global Reflect, Promise */ +var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || { + __proto__: [] + } instanceof Array && function (d, b) { + d.__proto__ = b; + } || function (d, b) { + for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; + }; + + return extendStatics(d, b); +}; + +function __extends(d, b) { + extendStatics(d, b); + + function __() { + this.constructor = d; + } + + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); +} +function __decorate(decorators, target, key, desc) { + var c = arguments.length, + r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, + d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +} +function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + + for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j]; + + return r; +} + +function cubic(y1, y2, t) { + var t2 = 1 - t; // Bezier Curve Formula + + return t * t * t + 3 * t * t * t2 * y2 + 3 * t * t2 * t2 * y1; +} + +function solveFromX(x1, x2, x) { + // x 0 ~ 1 + // t 0 ~ 1 + var t = x; + var solveX = x; + var dx = 1; + + while (Math.abs(dx) > 1 / 1000) { + // 예상 t초에 의한 _x값 + solveX = cubic(x1, x2, t); + dx = solveX - x; // 차이가 미세하면 그 값을 t로 지정 + + if (Math.abs(dx) < 1 / 1000) { + return t; + } + + t -= dx / 2; + } + + return t; +} +/** + * @namespace easing + */ + +/** +* Cubic Bezier curve. +* @memberof easing +* @func bezier +* @param {number} [x1] - point1's x +* @param {number} [y1] - point1's y +* @param {number} [x2] - point2's x +* @param {number} [y2] - point2's y +* @return {function} the curve function +* @example +import {bezier} from "scenejs"; +Scene.bezier(0, 0, 1, 1) // LINEAR +Scene.bezier(0.25, 0.1, 0.25, 1) // EASE +*/ + + +function bezier(x1, y1, x2, y2) { + /* + x = f(t) + calculate inverse function by x + t = f-1(x) + */ + var func = function (x) { + var t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0)); + return cubic(y1, y2, t); + }; + + func.easingName = "cubic-bezier(" + x1 + "," + y1 + "," + x2 + "," + y2 + ")"; + return func; +} +/** +* Specifies a stepping function +* @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function} +* @memberof easing +* @func steps +* @param {number} count - point1's x +* @param {"start" | "end"} postion - point1's y +* @return {function} the curve function +* @example +import {steps} from "scenejs"; +Scene.steps(1, "start") // Scene.STEP_START +Scene.steps(1, "end") // Scene.STEP_END +*/ + +function steps(count, position) { + var func = function (time) { + var level = 1 / count; + + if (time >= 1) { + return 1; + } + + return (position === "start" ? level : 0) + Math.floor(time / level) * level; + }; + + func.easingName = "steps(" + count + ", " + position + ")"; + return func; +} +/** +* Equivalent to steps(1, start) +* @memberof easing +* @name STEP_START +* @static +* @type {function} +* @example +import {STEP_START} from "scenejs"; +Scene.STEP_START // steps(1, start) +*/ + +var STEP_START = +/*#__PURE__#*/ +steps(1, "start"); +/** +* Equivalent to steps(1, end) +* @memberof easing +* @name STEP_END +* @static +* @type {function} +* @example +import {STEP_END} from "scenejs"; +Scene.STEP_END // steps(1, end) +*/ + +var STEP_END = +/*#__PURE__#*/ +steps(1, "end"); +/** +* Linear Speed (0, 0, 1, 1) +* @memberof easing +* @name LINEAR +* @static +* @type {function} +* @example +import {LINEAR} from "scenejs"; +Scene.LINEAR +*/ + +var LINEAR = +/*#__PURE__#*/ +bezier(0, 0, 1, 1); +/** +* Ease Speed (0.25, 0.1, 0.25, 1) +* @memberof easing +* @name EASE +* @static +* @type {function} +* @example +import {EASE} from "scenejs"; +Scene.EASE +*/ + +var EASE = +/*#__PURE__#*/ +bezier(0.25, 0.1, 0.25, 1); +/** +* Ease In Speed (0.42, 0, 1, 1) +* @memberof easing +* @name EASE_IN +* @static +* @type {function} +* @example +import {EASE_IN} from "scenejs"; +Scene.EASE_IN +*/ + +var EASE_IN = +/*#__PURE__#*/ +bezier(0.42, 0, 1, 1); +/** +* Ease Out Speed (0, 0, 0.58, 1) +* @memberof easing +* @name EASE_OUT +* @static +* @type {function} +* @example +import {EASE_OUT} from "scenejs"; +Scene.EASE_OUT +*/ + +var EASE_OUT = +/*#__PURE__#*/ +bezier(0, 0, 0.58, 1); +/** +* Ease In Out Speed (0.42, 0, 0.58, 1) +* @memberof easing +* @name EASE_IN_OUT +* @static +* @type {function} +* @example +import {EASE_IN_OUT} from "scenejs"; +Scene.EASE_IN_OUT +*/ + +var EASE_IN_OUT = +/*#__PURE__#*/ +bezier(0.42, 0, 0.58, 1); + +var _a; +var PREFIX = "__SCENEJS_"; +var DATA_SCENE_ID = "data-scene-id"; +var TIMING_FUNCTION = "animation-timing-function"; +var ROLES = { + transform: {}, + filter: {}, + attribute: {}, + html: true +}; +var ALIAS = { + easing: [TIMING_FUNCTION] +}; +var FIXED = (_a = {}, _a[TIMING_FUNCTION] = true, _a.contents = true, _a.html = true, _a); +var MAXIMUM = 1000000; +var THRESHOLD = 0.000001; +var DURATION = "duration"; +var FILL_MODE = "fillMode"; +var DIRECTION = "direction"; +var ITERATION_COUNT = "iterationCount"; +var DELAY = "delay"; +var EASING = "easing"; +var PLAY_SPEED = "playSpeed"; +var EASING_NAME = "easingName"; +var ITERATION_TIME = "iterationTime"; +var PAUSED = "paused"; +var ENDED = "ended"; +var TIMEUPDATE = "timeupdate"; +var ANIMATE = "animate"; +var PLAY = "play"; +var RUNNING = "running"; +var ITERATION = "iteration"; +var START_ANIMATION = "startAnimation"; +var PAUSE_ANIMATION = "pauseAnimation"; +var ALTERNATE = "alternate"; +var REVERSE = "reverse"; +var ALTERNATE_REVERSE = "alternate-reverse"; +var NORMAL = "normal"; +var INFINITE = "infinite"; +var PLAY_STATE = "playState"; +var PLAY_CSS = "playCSS"; +var PREV_TIME = "prevTime"; +var TICK_TIME = "tickTime"; +var CURRENT_TIME = "currentTime"; +var SELECTOR = "selector"; +var TRANSFORM_NAME = "transform"; +var EASINGS = { + "linear": LINEAR, + "ease": EASE, + "ease-in": EASE_IN, + "ease-out": EASE_OUT, + "ease-in-out": EASE_IN_OUT, + "step-start": STEP_START, + "step-end": STEP_END +}; +var NAME_SEPARATOR = "_///_"; +/** +* option name list +* @name Scene.OPTIONS +* @memberof Scene +* @static +* @type {$ts:OptionType} +* @example +* Scene.OPTIONS // ["duration", "fillMode", "direction", "iterationCount", "delay", "easing", "playSpeed"] +*/ + +var OPTIONS = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED]; +/** +* Event name list +* @name Scene.EVENTS +* @memberof Scene +* @static +* @type {$ts:EventType} +* @example +* Scene.EVENTS // ["paused", "ended", "timeupdate", "animate", "play", "iteration"]; +*/ + +var EVENTS = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION]; + +/** +* attach and trigger event handlers. +*/ + +var EventTrigger = +/*#__PURE__*/ +function () { + /** + * @example + const et = new Scene.EventTrigger(); + const scene = new Scene(); + scene.on("call", e => { + console.log(e.param); + }); + et.on("call", e => { + console.log(e.param); + }); + scene.trigger("call", {param: 1}); + et.trigger("call", {param: 1}); + */ + function EventTrigger() { + this.events = {}; + } + + var __proto = EventTrigger.prototype; + + __proto._on = function (name, callback, once) { + var _this = this; + + var events = this.events; + + if (utils.isObject(name)) { + for (var n in name) { + this._on(n, name[n], once); + } + + return; + } + + if (!(name in events)) { + events[name] = []; + } + + if (!callback) { + return; + } + + if (utils.isArray(callback)) { + callback.forEach(function (func) { + return _this._on(name, func, once); + }); + return; + } + + events[name].push(once ? function callback2() { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + callback.apply(void 0, args); + this.off(name, callback2); + } : callback); + }; + /** + * Attach an event handler function for one or more events to target + * @param - event's name + * @param - function to execute when the event is triggered. + * @return {EventTrigger} An Instance itself. + * @example + target.on("animate", function() { + console.log("animate"); + }); + target.trigger("animate"); + */ + + + __proto.on = function (name, callback) { + this._on(name, callback); + + return this; + }; + /** + * Dettach an event handler function for one or more events to target + * @param - event's name + * @param - function to execute when the event is triggered. + * @return {EventTrigger} An Instance itself. + * @example + const callback = function() { + console.log("animate"); + }; + target.on("animate", callback); + target.off("animate", callback); + target.off("animate"); + */ + + + __proto.off = function (name, callback) { + if (!name) { + this.events = {}; + } else if (!callback) { + this.events[name] = []; + } else { + var callbacks = this.events[name]; + + if (!callbacks) { + return this; + } + + var index = callbacks.indexOf(callback); + + if (index !== -1) { + callbacks.splice(index, 1); + } + } + + return this; + }; + /** + * execute event handler + * @param - event's name + * @param - event handler's additional parameter + * @return {EventTrigger} An Instance itself. + * @example + target.on("animate", function(a1, a2) { + console.log("animate", a1, a2); + }); + target.trigger("animate", [1, 2]); // log => "animate", 1, 2 + */ + + + __proto.trigger = function (name) { + var _this = this; + + var data = []; + + for (var _i = 1; _i < arguments.length; _i++) { + data[_i - 1] = arguments[_i]; + } + + var events = this.events; + + if (!(name in events)) { + return this; + } + + var args = data || []; + !args[0] && (args[0] = {}); + var event = events[name]; + var target = args[0]; + target.type = name; + target.currentTarget = this; + !target.target && (target.target = this); + utils.toArray(events[name]).forEach(function (callback) { + callback.apply(_this, data); + }); + return this; + }; + + __proto.once = function (name, callback) { + this._on(name, callback, true); + + return this; + }; + + return EventTrigger; +}(); + +/** +* Make string, array to PropertyObject for the dot product +*/ + +var PropertyObject = +/*#__PURE__*/ +function () { + /** + * @param - This value is in the array format. + * @param - options + * @example + var obj = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + */ + function PropertyObject(value, options) { + this.prefix = ""; + this.suffix = ""; + this.model = ""; + this.type = ""; + this.separator = ","; + options && this.setOptions(options); + this.value = utils.isString(value) ? value.split(this.separator) : value; + } + + var __proto = PropertyObject.prototype; + + __proto.setOptions = function (newOptions) { + for (var name in newOptions) { + this[name] = newOptions[name]; + } + + return this; + }; + /** + * the number of values. + * @example + const obj1 = new PropertyObject("1,2,3", ","); + console.log(obj1.length); + // 3 + */ + + + __proto.size = function () { + return this.value.length; + }; + /** + * retrieve one of values at the index + * @param {Number} index - index + * @return {Object} one of values at the index + * @example + const obj1 = new PropertyObject("1,2,3", ","); + console.log(obj1.get(0)); + // 1 + */ + + + __proto.get = function (index) { + return this.value[index]; + }; + /** + * Set the value at that index + * @param {Number} index - index + * @param {Object} value - text, a number, object to set + * @return {PropertyObject} An instance itself + * @example + const obj1 = new PropertyObject("1,2,3", ","); + obj1.set(0, 2); + console.log(obj1.toValue()); + // 2,2,3 + */ + + + __proto.set = function (index, value) { + this.value[index] = value; + return this; + }; + /** + * create a copy of an instance itself. + * @return {PropertyObject} clone + * @example + const obj1 = new PropertyObject("1,2,3", ","); + const obj2 = obj1.clone(); + */ + + + __proto.clone = function () { + var _a = this, + separator = _a.separator, + prefix = _a.prefix, + suffix = _a.suffix, + model = _a.model, + type = _a.type; + + var arr = this.value.map(function (v) { + return v instanceof PropertyObject ? v.clone() : v; + }); + return new PropertyObject(arr, { + separator: separator, + prefix: prefix, + suffix: suffix, + model: model, + type: type + }); + }; + /** + * Make Property Object to String + * @return {String} Make Property Object to String + * @example + //rgba(100, 100, 100, 0.5) + const obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")", + }); + console.log(obj4.toValue()); + // "rgba(100,100,100,0.5)" + */ + + + __proto.toValue = function () { + return this.prefix + this.join() + this.suffix; + }; + /** + * Make Property Object's array to String + * @return {String} Join the elements of an array into a string + * @example + //rgba(100, 100, 100, 0.5) + var obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + obj4.join(); // => "100,100,100,0.5" + */ + + + __proto.join = function () { + return this.value.map(function (v) { + return v instanceof PropertyObject ? v.toValue() : v; + }).join(this.separator); + }; + /** + * executes a provided function once per array element. + * @param {Function} callback - Function to execute for each element, taking three arguments + * @param {All} [callback.currentValue] The current element being processed in the array. + * @param {Number} [callback.index] The index of the current element being processed in the array. + * @param {Array} [callback.array] the array. + * @return {PropertyObject} An instance itself + * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document. + * @example + //rgba(100, 100, 100, 0.5) + var obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + obj4.forEach(t => { + console.log(t); + }); // => "100,100,100,0.5" + */ + + + __proto.forEach = function (func) { + this.value.forEach(func); + return this; + }; + + return PropertyObject; +}(); + +/** +* @namespace +* @name Property +*/ +function splitStyle(str) { + var properties = utils.splitText(str, ";"); + var obj = {}; + var totalLength = properties.length; + var length = totalLength; + + for (var i = 0; i < totalLength; ++i) { + var matches = utils.splitText(properties[i], ":"); + + if (matches.length < 2 || !matches[1]) { + --length; + continue; + } + + obj[matches[0].trim()] = toPropertyObject(matches[1].trim()); + } + + return { + styles: obj, + length: length + }; +} +/** +* convert array to PropertyObject[type=color]. +* default model "rgba" +* @memberof Property +* @function arrayToColorObject +* @param {Array|PropertyObject} value ex) [0, 0, 0, 1] +* @return {PropertyObject} PropertyObject[type=color] +* @example +arrayToColorObject([0, 0, 0]) +// => PropertyObject(type="color", model="rgba", value=[0, 0, 0, 1], separator=",") +*/ + +function arrayToColorObject(arr) { + var model = utils.RGBA; + + if (arr.length === 3) { + arr[3] = 1; + } + + return new PropertyObject(arr, { + model: model, + separator: ",", + type: "color", + prefix: model + "(", + suffix: ")" + }); +} +/** +* convert text with parentheses to object. +* @memberof Property +* @function stringToBracketObject +* @param {String} value ex) "rgba(0,0,0,1)" +* @return {PropertyObject} PropertyObject +* @example +stringToBracketObject("abcde(0, 0, 0,1)") +// => PropertyObject(model="abcde", value=[0, 0, 0,1], separator=",") +*/ + +function stringToBracketObject(text) { + // [prefix, value, other] + var _a = utils.splitBracket(text), + model = _a.prefix, + value = _a.value, + afterModel = _a.suffix; + + if (typeof value === "undefined") { + return text; + } + + if (utils.COLOR_MODELS.indexOf(model) > -1) { + return arrayToColorObject(utils.stringToRGBA(text)); + } // divide comma(,) + + + var obj = toPropertyObject(value, model); + var arr = [value]; + var separator = ","; + var prefix = model + "("; + var suffix = ")" + afterModel; + + if (obj instanceof PropertyObject) { + separator = obj.separator; + arr = obj.value; + prefix += obj.prefix; + suffix = obj.suffix + suffix; + } + + return new PropertyObject(arr, { + separator: separator, + model: model, + prefix: prefix, + suffix: suffix + }); +} +function arrayToPropertyObject(arr, separator) { + return new PropertyObject(arr, { + type: "array", + separator: separator + }); +} +/** +* convert text with parentheses to PropertyObject[type=color]. +* If the values are not RGBA model, change them RGBA mdoel. +* @memberof Property +* @function stringToColorObject +* @param {String|PropertyObject} value ex) "rgba(0,0,0,1)" +* @return {PropertyObject} PropertyObject[type=color] +* @example +stringToColorObject("rgba(0, 0, 0,1)") +// => PropertyObject(type="color", model="rgba", value=[0, 0, 0,1], separator=",") +*/ + +function stringToColorObject(value) { + var result = utils.stringToRGBA(value); + return result ? arrayToColorObject(result) : value; +} +function toPropertyObject(value, model) { + if (!utils.isString(value)) { + if (utils.isArray(value)) { + return arrayToPropertyObject(value, ","); + } + + return value; + } + + var values = utils.splitComma(value); + + if (values.length > 1) { + return arrayToPropertyObject(values.map(function (v) { + return toPropertyObject(v); + }), ","); + } + + values = utils.splitSpace(value); + + if (values.length > 1) { + return arrayToPropertyObject(values.map(function (v) { + return toPropertyObject(v); + }), " "); + } + + values = /^(['"])([^'"]*)(['"])$/g.exec(value); + + if (values && values[1] === values[3]) { + // Quotes + return new PropertyObject([toPropertyObject(values[2])], { + prefix: values[1], + suffix: values[1] + }); + } else if (value.indexOf("(") !== -1) { + // color + return stringToBracketObject(value); + } else if (value.charAt(0) === "#" && model !== "url") { + return stringToColorObject(value); + } + + return value; +} +function toObject(object, result) { + if (result === void 0) { + result = {}; + } + + var model = object.model; + + if (model) { + object.setOptions({ + model: "", + suffix: "", + prefix: "" + }); + var value = object.size() > 1 ? object : object.get(0); + result[model] = value; + } else { + object.forEach(function (obj) { + toObject(obj, result); + }); + } + + return result; +} + +function isPropertyObject(value) { + return value instanceof PropertyObject; +} +function setAlias(name, alias) { + ALIAS[name] = alias; +} +function setRole(names, isProperty, isFixedProperty) { + var length = names.length; + var roles = ROLES; + var fixed = FIXED; + + for (var i = 0; i < length - 1; ++i) { + !roles[names[i]] && (roles[names[i]] = {}); + roles = roles[names[i]]; + + if (isFixedProperty) { + !fixed[names[i]] && (fixed[names[i]] = {}); + fixed = fixed[names[i]]; + } + } + + isFixedProperty && (fixed[names[length - 1]] = true); + roles[names[length - 1]] = isProperty ? true : {}; +} +function getType(value) { + var type = typeof value; + + if (type === utils.OBJECT) { + if (utils.isArray(value)) { + return utils.ARRAY; + } else if (isPropertyObject(value)) { + return utils.PROPERTY; + } + } else if (type === utils.STRING || type === utils.NUMBER) { + return "value"; + } + + return type; +} +function isPureObject(obj) { + return utils.isObject(obj) && obj.constructor === Object; +} +function getNames(names, stack) { + var arr = []; + + if (isPureObject(names)) { + for (var name in names) { + stack.push(name); + arr = arr.concat(getNames(names[name], stack)); + stack.pop(); + } + } else { + arr.push(stack.slice()); + } + + return arr; +} +function updateFrame(names, properties) { + for (var name in properties) { + var value = properties[name]; + + if (!isPureObject(value)) { + names[name] = true; + continue; + } + + if (!utils.isObject(names[name])) { + names[name] = {}; + } + + updateFrame(names[name], properties[name]); + } + + return names; +} +function toFixed(num) { + return Math.round(num * MAXIMUM) / MAXIMUM; +} +function getValueByNames(names, properties, length) { + if (length === void 0) { + length = names.length; + } + + var value = properties; + + for (var i = 0; i < length; ++i) { + if (!utils.isObject(value) || value == null) { + return undefined; + } + + value = value[names[i]]; + } + + return value; +} +function isInProperties(roles, args, isCheckTrue) { + var length = args.length; + var role = roles; + + if (length === 0) { + return false; + } + + for (var i = 0; i < length; ++i) { + if (role === true) { + return false; + } + + role = role[args[i]]; + + if (!role || !isCheckTrue && role === true) { + return false; + } + } + + return true; +} +function isRole(args, isCheckTrue) { + return isInProperties(ROLES, args, isCheckTrue); +} +function isFixed(args) { + return isInProperties(FIXED, args, true); +} +function setPlayCSS(item, isActivate) { + item.state[PLAY_CSS] = isActivate; +} +function isPausedCSS(item) { + return item.state[PLAY_CSS] && item.isPaused(); +} +function isEndedCSS(item) { + return !item.isEnded() && item.state[PLAY_CSS]; +} +function makeId(selector) { + for (;;) { + var id = "" + Math.floor(Math.random() * 10000000); + + if (!utils.IS_WINDOW || !selector) { + return id; + } + + var checkElement = utils.$("[data-scene-id=\"" + id + "\"]"); + + if (!checkElement) { + return id; + } + } +} +function getRealId(item) { + return item.getId() || item.setId(makeId(false)).getId(); +} +function toId(text) { + return ("" + text).match(/[0-9a-zA-Z]+/g).join(""); +} +function playCSS(item, isExportCSS, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + if (!utils.ANIMATION || item.getPlayState() === RUNNING) { + return; + } + + var className = playClassName || START_ANIMATION; + + if (isPausedCSS(item)) { + item.addPlayClass(true, className, properties); + } else { + if (item.isEnded()) { + item.setTime(0); + } + + isExportCSS && item.exportCSS({ + className: className + }); + var el = item.addPlayClass(false, className, properties); + + if (!el) { + return; + } + + addAnimationEvent(item, el); + setPlayCSS(item, true); + } + + item.setPlayState(RUNNING); +} +function addAnimationEvent(item, el) { + var state = item.state; + var duration = item.getDuration(); + var isZeroDuration = !duration || !isFinite(duration); + + var animationend = function () { + setPlayCSS(item, false); + item.finish(); + }; + + var animationstart = function () { + item.trigger(PLAY); + utils.addEvent(el, "animationcancel", animationend); + utils.addEvent(el, "animationend", animationend); + utils.addEvent(el, "animationiteration", animationiteration); + }; + + item.once(ENDED, function () { + utils.removeEvent(el, "animationcancel", animationend); + utils.removeEvent(el, "animationend", animationend); + utils.removeEvent(el, "animationiteration", animationiteration); + utils.removeEvent(el, "animationstart", animationstart); + }); + + var animationiteration = function (_a) { + var elapsedTime = _a.elapsedTime; + var currentTime = elapsedTime; + var iterationCount = isZeroDuration ? 0 : currentTime / duration; + state[CURRENT_TIME] = currentTime; + item.setIteration(iterationCount); + }; + + utils.addEvent(el, "animationstart", animationstart); +} +function getEasing(curveArray) { + var easing; + + if (utils.isString(curveArray)) { + if (curveArray in EASINGS) { + easing = EASINGS[curveArray]; + } else { + var obj = toPropertyObject(curveArray); + + if (utils.isString(obj)) { + return 0; + } else { + if (obj.model === "cubic-bezier") { + curveArray = obj.value.map(function (v) { + return parseFloat(v); + }); + easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]); + } else if (obj.model === "steps") { + easing = steps(parseFloat(obj.value[0]), obj.value[1]); + } else { + return 0; + } + } + } + } else if (utils.isArray(curveArray)) { + easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]); + } else { + easing = curveArray; + } + + return easing; +} + +function GetterSetter(getter, setter, parent) { + return function (constructor) { + var prototype = constructor.prototype; + getter.forEach(function (name) { + prototype[utils.camelize("get " + name)] = function () { + return this[parent][name]; + }; + }); + setter.forEach(function (name) { + prototype[utils.camelize("set " + name)] = function (value) { + this[parent][name] = value; + return this; + }; + }); + }; +} + +function isDirectionReverse(iteration, iteraiontCount, direction) { + if (direction === REVERSE) { + return true; + } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) { + return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE); + } + + return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE); +} +/** +* @typedef {Object} AnimatorState The Animator options. Properties used in css animation. +* @property {number} [duration] The duration property defines how long an animation should take to complete one cycle. +* @property {"none"|"forwards"|"backwards"|"both"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both). +* @property {"infinite"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played. +* @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation. +* @property {number} [delay] The delay property specifies a delay for the start of an animation. +* @property {"normal"|"reverse"|"alternate"|"alternate-reverse"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles. +*/ + +var setters = ["id", ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE]; + +var getters = __spreadArrays(setters, [EASING, EASING_NAME]); +/** +* play video, animation, the others +* @extends EventTrigger +* @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation} +*/ + + +var Animator = +/*#__PURE__*/ +function (_super) { + __extends(Animator, _super); + /** + * @param - animator's options + * @example + const animator = new Animator({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.easing.EASE, + }); + */ + + + function Animator(options) { + var _this = _super.call(this) || this; + + _this.timerId = 0; + _this.state = { + id: "", + easing: 0, + easingName: "linear", + iterationCount: 1, + delay: 0, + fillMode: "forwards", + direction: NORMAL, + playSpeed: 1, + currentTime: 0, + iterationTime: -1, + iteration: 0, + tickTime: 0, + prevTime: 0, + playState: PAUSED, + duration: 0 + }; + + _this.setOptions(options); + + return _this; + } + /** + * set animator's easing. + * @param curverArray - The speed curve of an animation. + * @return {Animator} An instance itself. + * @example + animator.({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.easing.EASE, + }); + */ + + + var __proto = Animator.prototype; + + __proto.setEasing = function (curveArray) { + var easing = getEasing(curveArray); + var easingName = easing && easing[EASING_NAME] || "linear"; + var state = this.state; + state[EASING] = easing; + state[EASING_NAME] = easingName; + return this; + }; + /** + * set animator's options. + * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation} + * @param - animator's options + * @return {Animator} An instance itself. + * @example + animator.({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.eaasing.EASE, + }); + */ + + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + for (var name in options) { + var value = options[name]; + + if (name === EASING) { + this.setEasing(value); + continue; + } else if (name === DURATION) { + value && this.setDuration(value); + continue; + } + + if (OPTIONS.indexOf(name) > -1) { + this.state[name] = value; + } + } + + return this; + }; + /** + * Get the animator's total duration including delay + * @return {number} Total duration + * @example + animator.getTotalDuration(); + */ + + + __proto.getTotalDuration = function () { + return this.getActiveDuration(true); + }; + /** + * Get the animator's total duration excluding delay + * @return {number} Total duration excluding delay + * @example + animator.getActiveDuration(); + */ + + + __proto.getActiveDuration = function (delay) { + var state = this.state; + var count = state[ITERATION_COUNT]; + + if (count === INFINITE) { + return Infinity; + } + + return (delay ? state[DELAY] : 0) + this.getDuration() * count; + }; + /** + * Check if the animator has reached the end. + * @return {boolean} ended + * @example + animator.isEnded(); // true or false + */ + + + __proto.isEnded = function () { + if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) { + return true; + } else if (this.getTime() < this.getActiveDuration()) { + return false; + } + + return true; + }; + /** + *Check if the animator is paused: + * @return {boolean} paused + * @example + animator.isPaused(); // true or false + */ + + + __proto.isPaused = function () { + return this.state[PLAY_STATE] === PAUSED; + }; + + __proto.start = function (delay) { + if (delay === void 0) { + delay = this.state[DELAY]; + } + + var state = this.state; + state[PLAY_STATE] = RUNNING; + + if (state[TICK_TIME] >= delay) { + /** + * This event is fired when play animator. + * @event Animator#play + */ + this.trigger(PLAY); + return true; + } + + return false; + }; + /** + * play animator + * @return {Animator} An instance itself. + */ + + + __proto.play = function (toTime) { + var _this = this; + + var state = this.state; + var delay = state[DELAY]; + var currentTime = this.getTime(); + state[PLAY_STATE] = RUNNING; + + if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) { + this.setTime(-delay, true); + } + + this.timerId = utils.requestAnimationFrame(function (time) { + state[PREV_TIME] = time; + + _this.tick(time, toTime); + }); + this.start(); + return this; + }; + /** + * pause animator + * @return {Animator} An instance itself. + */ + + + __proto.pause = function () { + var state = this.state; + + if (state[PLAY_STATE] !== PAUSED) { + state[PLAY_STATE] = PAUSED; + /** + * This event is fired when animator is paused. + * @event Animator#paused + */ + + this.trigger(PAUSED); + } + + utils.cancelAnimationFrame(this.timerId); + return this; + }; + /** + * end animator + * @return {Animator} An instance itself. + */ + + + __proto.finish = function () { + this.setTime(0); + this.state[TICK_TIME] = 0; + this.end(); + return this; + }; + /** + * end animator + * @return {Animator} An instance itself. + */ + + + __proto.end = function () { + this.pause(); + /** + * This event is fired when animator is ended. + * @event Animator#ended + */ + + this.trigger(ENDED); + return this; + }; + /** + * set currentTime + * @param {Number|String} time - currentTime + * @return {Animator} An instance itself. + * @example + animator.setTime("from"); // 0 + animator.setTime("to"); // 100% + animator.setTime("50%"); + animator.setTime(10); + animator.getTime() // 10 + */ + + + __proto.setTime = function (time, isTick, isParent) { + var activeDuration = this.getActiveDuration(); + var state = this.state; + var prevTime = state[TICK_TIME]; + var delay = state[DELAY]; + var currentTime = isTick ? time : this.getUnitTime(time); + state[TICK_TIME] = delay + currentTime; + + if (currentTime < 0) { + currentTime = 0; + } else if (currentTime > activeDuration) { + currentTime = activeDuration; + } + + state[CURRENT_TIME] = currentTime; + this.calculate(); + + if (isTick && !isParent) { + var tickTime = state[TICK_TIME]; + + if (prevTime < delay && time >= 0) { + this.start(0); + } + + if (tickTime < prevTime || this.isEnded()) { + this.end(); + return; + } + } + + if (this.isDelay()) { + return this; + } + /** + * This event is fired when the animator updates the time. + * @event Animator#timeupdate + * @param {Object} param The object of data to be sent to an event. + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.time The iteration time during duration that the animator is running. + * @param {Number} param.iterationCount The iteration count that the animator is running. + */ + + + this.trigger(TIMEUPDATE, { + currentTime: currentTime, + time: this.getIterationTime(), + iterationCount: state[ITERATION] + }); + return this; + }; + /** + * Get the animator's current time + * @return {number} current time + * @example + animator.getTime(); + */ + + + __proto.getTime = function () { + return this.state[CURRENT_TIME]; + }; + + __proto.getUnitTime = function (time) { + if (utils.isString(time)) { + var duration = this.getDuration() || 100; + + if (time === "from") { + return 0; + } else if (time === "to") { + return duration; + } + + var _a = utils.splitUnit(time), + unit = _a.unit, + value = _a.value; + + if (unit === "%") { + !this.getDuration() && this.setDuration(duration); + return toFixed(parseFloat(time) / 100 * duration); + } else if (unit === ">") { + return value + THRESHOLD; + } else { + return value; + } + } else { + return toFixed(time); + } + }; + /** + * Check if the current state of animator is delayed. + * @return {boolean} check delay state + */ + + + __proto.isDelay = function () { + var state = this.state; + var delay = state[DELAY]; + var tickTime = state[TICK_TIME]; + return delay > 0 && tickTime < delay; + }; + + __proto.setIteration = function (iterationCount) { + var state = this.state; + var passIterationCount = Math.floor(iterationCount); + var maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT]; + + if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) { + /** + * The event is fired when an iteration of an animation ends. + * @event Animator#iteration + * @param {Object} param The object of data to be sent to an event. + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.iterationCount The iteration count that the animator is running. + */ + this.trigger("iteration", { + currentTime: state[CURRENT_TIME], + iterationCount: passIterationCount + }); + } + + state[ITERATION] = iterationCount; + return this; + }; + + __proto.calculate = function () { + var state = this.state; + var iterationCount = state[ITERATION_COUNT]; + var fillMode = state[FILL_MODE]; + var direction = state[DIRECTION]; + var duration = this.getDuration(); + var time = this.getTime(); + var iteration = duration === 0 ? 0 : time / duration; + var currentIterationTime = duration ? time % duration : 0; + + if (!duration) { + this.setIterationTime(0); + return this; + } + + this.setIteration(iteration); // direction : normal, reverse, alternate, alternate-reverse + // fillMode : forwards, backwards, both, none + + var isReverse = isDirectionReverse(iteration, iterationCount, direction); + var isFiniteDuration = isFinite(duration); + + if (isFiniteDuration && isReverse) { + currentIterationTime = duration - currentIterationTime; + } + + if (isFiniteDuration && iterationCount !== INFINITE) { + var isForwards = fillMode === "both" || fillMode === "forwards"; // fill forwards + + if (iteration >= iterationCount) { + currentIterationTime = duration * (isForwards ? iterationCount % 1 || 1 : 0); + isReverse && (currentIterationTime = duration - currentIterationTime); + } + } + + this.setIterationTime(currentIterationTime); + return this; + }; + + __proto.tick = function (now, to) { + var _this = this; + + if (this.isPaused()) { + return; + } + + var state = this.state; + var playSpeed = state[PLAY_SPEED]; + var prevTime = state[PREV_TIME]; + var delay = state[DELAY]; + var tickTime = state[TICK_TIME]; + var currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed; + state[PREV_TIME] = now; + this.setTime(currentTime - delay, true); + + if (to && to * 1000 < now) { + this.pause(); + } + + if (state[PLAY_STATE] === PAUSED) { + return; + } + + this.timerId = utils.requestAnimationFrame(function (time) { + _this.tick(time, to); + }); + }; + + Animator = __decorate([GetterSetter(getters, setters, "state")], Animator); + return Animator; +}(EventTrigger); + +function toInnerProperties(obj, orders) { + if (orders === void 0) { + orders = []; + } + + if (!obj) { + return ""; + } + + var arrObj = []; + var keys = utils.getKeys(obj); + utils.sortOrders(keys, orders); + keys.forEach(function (name) { + arrObj.push(name.replace(/\d$/g, "") + "(" + obj[name] + ")"); + }); + return arrObj.join(" "); +} +/* eslint-disable */ + + +function clone(target, toValue) { + if (toValue === void 0) { + toValue = false; + } + + return merge({}, target, toValue); +} + +function merge(to, from, toValue) { + if (toValue === void 0) { + toValue = false; + } + + for (var name in from) { + var value = from[name]; + var type = getType(value); + + if (type === utils.PROPERTY) { + to[name] = toValue ? value.toValue() : value.clone(); + } else if (type === utils.FUNCTION) { + to[name] = toValue ? getValue([name], value) : value; + } else if (type === utils.ARRAY) { + to[name] = value.slice(); + } else if (type === utils.OBJECT) { + if (utils.isObject(to[name]) && !isPropertyObject(to[name])) { + merge(to[name], value, toValue); + } else { + to[name] = clone(value, toValue); + } + } else { + to[name] = from[name]; + } + } + + return to; +} +/* eslint-enable */ + + +function getPropertyName(args) { + return args[0] in ALIAS ? ALIAS[args[0]] : args; +} + +function getValue(names, value) { + var type = getType(value); + + if (type === utils.PROPERTY) { + return value.toValue(); + } else if (type === utils.FUNCTION) { + if (names[0] !== TIMING_FUNCTION) { + return getValue(names, value()); + } + } else if (type === utils.OBJECT) { + return clone(value, true); + } + + return value; +} +/** +* Animation's Frame +*/ + + +var Frame = +/*#__PURE__*/ +function () { + /** + * @param - properties + * @example + const frame = new Scene.Frame({ + display: "none" + transform: { + translate: "50px", + scale: "5, 5", + } + }); + */ + function Frame(properties) { + if (properties === void 0) { + properties = {}; + } + + this.properties = {}; + this.orderMap = new OrderMap(NAME_SEPARATOR); + this.properties = {}; // this.orders = []; + + this.set(properties); + } + /** + * get property value + * @param {...Number|String|PropertyObject} args - property name or value + * @example + frame.get("display") // => "none", "block", .... + frame.get("transform", "translate") // => "10px,10px" + */ + + + var __proto = Frame.prototype; + + __proto.get = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var value = this.raw.apply(this, args); + return getValue(getPropertyName(args), value); + }; + /** + * get properties orders + * @param - property names + * @example + frame.getOrders(["display"]) // => [] + frame.getOrders(["transform"]) // => ["translate", "scale"] + */ + + + __proto.getOrders = function (names) { + return this.orderMap.get(names); + }; + /** + * set properties orders + * @param - property names + * @param - orders + * @example + frame.getOrders(["transform"]) // => ["translate", "scale"] + frame.setOrders(["transform"], ["scale", "tralsate"]) + */ + + + __proto.setOrders = function (names, orders) { + return this.orderMap.set(names, orders); + }; + /** + * get properties order object + * @example + console.log(frame.getOrderObject()); + */ + + + __proto.getOrderObject = function () { + return this.orderMap.getObject(); + }; + /** + * set properties orders object + * @param - properties orders object + * @example + frame.setOrderObject({ + "": ["transform"], + "transform": ["scale", "tralsate"], + }); + */ + + + __proto.setOrderObject = function (obj) { + this.orderMap.setObject(obj); + }; + /** + * get property keys + * @param - property names + * @example + frame.gets("display") // => [] + frame.gets("transform") // => ["translate"] + */ + + + __proto.getKeys = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var value = this.raw.apply(this, args); + var keys = getType(value) === utils.OBJECT ? utils.getKeys(value) : []; + utils.sortOrders(keys, this.orderMap.get(args)); + return keys; + }; + /** + * get properties array + * @param - property names + * @example + frame.gets("display") // => [] + frame.gets("transform") // => [{ key: "translate", value: "10px, 10px", children: [] }] + */ + + + __proto.gets = function () { + var _this = this; + + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var values = this.get.apply(this, args); + var keys = this.getKeys.apply(this, args); + return keys.map(function (key) { + var nextValue = values[key]; + return { + key: key, + value: nextValue, + children: _this.gets.apply(_this, __spreadArrays(args, [key])) + }; + }); + }; + + __proto.raw = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + return getValueByNames(getPropertyName(args), this.properties); + }; + /** + * remove property value + * @param {...String} args - property name + * @return {Frame} An instance itself + * @example + frame.remove("display") + */ + + + __proto.remove = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var params = getPropertyName(args); + var length = params.length; + + if (!length) { + return this; + } + + this.orderMap.remove(params); + var value = getValueByNames(params, this.properties, length - 1); + + if (utils.isObject(value)) { + delete value[params[length - 1]]; + } + + return this; + }; + /** + * set property + * @param {...Number|String|PropertyObject} args - property names or values + * @return {Frame} An instance itself + * @example + // one parameter + frame.set({ + display: "none", + transform: { + translate: "10px, 10px", + scale: "1", + }, + filter: { + brightness: "50%", + grayscale: "100%" + } + }); + // two parameters + frame.set("transform", { + translate: "10px, 10px", + scale: "1", + }); + // three parameters + frame.set("transform", "translate", "50px"); + */ + + + __proto.set = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var self = this; + var length = args.length; + var params = args.slice(0, -1); + var value = args[length - 1]; + var firstParam = params[0]; + + if (length === 1 && value instanceof Frame) { + self.merge(value); + } else if (firstParam in ALIAS) { + self._set(ALIAS[firstParam], value); + } else if (length === 2 && utils.isArray(firstParam)) { + self._set(firstParam, value); + } else if (isPropertyObject(value)) { + if (isRole(params)) { + self.set.apply(self, __spreadArrays(params, [toObject(value)])); + } else { + self._set(params, value); + } + } else if (utils.isArray(value)) { + self._set(params, value); + } else if (utils.isObject(value)) { + if (!self.has.apply(self, params) && isRole(params)) { + self._set(params, {}); + } + + for (var name in value) { + self.set.apply(self, __spreadArrays(params, [name, value[name]])); + } + } else if (utils.isString(value)) { + if (isRole(params, true)) { + if (isFixed(params) || !isRole(params)) { + this._set(params, value); + } else { + var obj = toPropertyObject(value); + + if (utils.isObject(obj)) { + self.set.apply(self, __spreadArrays(params, [obj])); + } + } + + return this; + } else { + var _a = splitStyle(value), + styles = _a.styles, + stylesLength = _a.length; + + for (var name in styles) { + self.set.apply(self, __spreadArrays(params, [name, styles[name]])); + } + + if (stylesLength) { + return this; + } + } + + self._set(params, value); + } else { + self._set(params, value); + } + + return self; + }; + /** + * Gets the names of properties. + * @return the names of properties. + * @example + // one parameter + frame.set({ + display: "none", + transform: { + translate: "10px, 10px", + scale: "1", + }, + }); + // [["display"], ["transform", "translate"], ["transform", "scale"]] + console.log(frame.getNames()); + */ + + + __proto.getNames = function () { + return getNames(this.properties, []); + }; + /** + * check that has property. + * @param {...String} args - property name + * @example + frame.has("property", "display") // => true or false + */ + + + __proto.has = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var params = getPropertyName(args); + var length = params.length; + + if (!length) { + return false; + } + + return !utils.isUndefined(getValueByNames(params, this.properties, length)); + }; + /** + * clone frame. + * @return {Frame} An instance of clone + * @example + frame.clone(); + */ + + + __proto.clone = function () { + var frame = new Frame(); + frame.setOrderObject(this.orderMap.orderMap); + return frame.merge(this); + }; + /** + * merge one frame to other frame. + * @param - target frame. + * @return {Frame} An instance itself + * @example + frame.merge(frame2); + */ + + + __proto.merge = function (frame) { + var properties = this.properties; + var frameProperties = frame.properties; + + if (frameProperties) { + merge(properties, frameProperties); + } + + return this; + }; + /** + * Specifies an css object that coverted the frame. + * @return {object} cssObject + */ + + + __proto.toCSSObject = function () { + var properties = this.get(); + var cssObject = {}; + + for (var name in properties) { + if (isRole([name], true)) { + continue; + } + + var value = properties[name]; + + if (name === TIMING_FUNCTION) { + cssObject[TIMING_FUNCTION.replace("animation", utils.ANIMATION)] = (utils.isString(value) ? value : value[EASING_NAME]) || "initial"; + } else { + cssObject[name] = value; + } + } + + var transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME])); + var filter = toInnerProperties(properties.filter, this.orderMap.get([utils.FILTER])); + utils.TRANSFORM && transform && (cssObject[utils.TRANSFORM] = transform); + utils.FILTER && filter && (cssObject[utils.FILTER] = filter); + return cssObject; + }; + /** + * Specifies an css text that coverted the frame. + * @return {string} cssText + */ + + + __proto.toCSS = function () { + var cssObject = this.toCSSObject(); + var cssArray = []; + var keys = utils.getKeys(cssObject); + utils.sortOrders(keys, this.orderMap.get([])); + keys.forEach(function (name) { + cssArray.push(name + ":" + cssObject[name] + ";"); + }); + return cssArray.join(""); + }; + /** + * Remove All Properties + * @return {Frame} An instance itself + */ + + + __proto.clear = function () { + this.properties = {}; + this.orderMap.clear(); + return this; + }; + + __proto._set = function (args, value) { + var properties = this.properties; + var length = args.length; + + for (var i = 0; i < length - 1; ++i) { + var name = args[i]; + !(name in properties) && (properties[name] = {}); + properties = properties[name]; + } + + if (!length) { + return; + } + + var lastParam = args[length - 1]; + this.orderMap.add(args); + + if (length === 1 && lastParam === TIMING_FUNCTION) { + properties[lastParam] = getEasing(value); + } else { + properties[lastParam] = utils.isString(value) && !isFixed(args) ? toPropertyObject(value, lastParam) : value; + } + }; + + return Frame; +}(); + +function dotArray(a1, a2, b1, b2) { + var length = a2.length; + return a1.map(function (v1, i) { + if (i >= length) { + return v1; + } else { + return dot(v1, a2[i], b1, b2); + } + }); +} + +function dotColor(color1, color2, b1, b2) { + // convert array to PropertyObject(type=color) + var value1 = color1.value; + var value2 = color2.value; // If the model name is not same, the inner product is impossible. + + var model1 = color1.model; + var model2 = color2.model; + + if (model1 !== model2) { + // It is recognized as a string. + return dot(color1.toValue(), color2.toValue(), b1, b2); + } + + if (value1.length === 3) { + value1[3] = 1; + } + + if (value2.length === 3) { + value2[3] = 1; + } + + var v = dotArray(value1, value2, b1, b2); + var colorModel = model1; + + for (var i = 0; i < 3; ++i) { + v[i] = parseInt(v[i], 10); + } + + var object = new PropertyObject(v, { + type: "color", + model: colorModel, + prefix: colorModel + "(", + suffix: ")" + }); + return object; +} + +function dotObject(a1, a2, b1, b2) { + var a1Type = a1.type; + + if (a1Type === "color") { + return dotColor(a1, a2, b1, b2); + } + + var value1 = a1.value; + var value2 = a2.value; + var arr = dotArray(value1, value2, b1, b2); + return new PropertyObject(arr, { + type: a1Type, + separator: a1.separator || a2.separator, + prefix: a1.prefix || a2.prefix, + suffix: a1.suffix || a2.suffix, + model: a1.model || a2.model + }); +} +/** +* The dot product of a1 and a2 for the b1 and b2. +* @memberof Dot +* @function dot +* @param {String|Number|PropertyObject} a1 value1 +* @param {String|Number|PropertyObject} a2 value2 +* @param {Number} b1 b1 ratio +* @param {Number} b2 b2 ratio +* @return {String} Not Array, Not Separator, Only Number & Unit +* @return {PropertyObject} Array with Separator. +* @example +dot(1, 3, 0.3, 0.7); +// => 1.6 +*/ + + +function dot(a1, a2, b1, b2) { + if (b2 === 0) { + return a2; + } else if (b1 === 0 || b1 + b2 === 0) { + // prevent division by zero. + return a1; + } // dot Object + + + var type1 = getType(a1); + var type2 = getType(a2); + var isFunction1 = type1 === utils.FUNCTION; + var isFunction2 = type2 === utils.FUNCTION; + + if (isFunction1 || isFunction2) { + return function () { + return dot(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2); + }; + } else if (type1 === type2) { + if (type1 === utils.PROPERTY) { + return dotObject(a1, a2, b1, b2); + } else if (type1 === utils.ARRAY) { + return dotArray(a1, a2, b1, b2); + } else if (type1 !== "value") { + return a1; + } + } else { + return a1; + } + + var v1 = utils.splitUnit("" + a1); + var v2 = utils.splitUnit("" + a2); + var v; // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환 + + if (isNaN(v1.value) || isNaN(v2.value)) { + return a1; + } else { + v = utils.dot(v1.value, v2.value, b1, b2); + } + + var prefix = v1.prefix || v2.prefix; + var unit = v1.unit || v2.unit; + + if (!prefix && !unit) { + return v; + } + + return prefix + v + unit; +} +function dotValue(time, prevTime, nextTime, prevValue, nextValue, easing) { + if (time === prevTime) { + return prevValue; + } else if (time === nextTime) { + return nextValue; + } else if (!easing) { + return dot(prevValue, nextValue, time - prevTime, nextTime - time); + } + + var ratio = easing((time - prevTime) / (nextTime - prevTime)); + var value = dot(prevValue, nextValue, ratio, 1 - ratio); + return value; +} + +function getNearTimeIndex(times, time) { + var length = times.length; + + for (var i = 0; i < length; ++i) { + if (times[i] === time) { + return [i, i]; + } else if (times[i] > time) { + return [i > 0 ? i - 1 : 0, i]; + } + } + + return [length - 1, length - 1]; +} + +function makeAnimationProperties(properties) { + var cssArray = []; + + for (var name in properties) { + cssArray.push(utils.ANIMATION + "-" + utils.decamelize(name) + ":" + properties[name] + ";"); + } + + return cssArray.join(""); +} + +function addTime(times, time) { + var length = times.length; + + for (var i = 0; i < length; ++i) { + if (time < times[i]) { + times.splice(i, 0, time); + return; + } + } + + times[length] = time; +} + +function addEntry(entries, time, keytime) { + var prevEntry = entries[entries.length - 1]; + (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) && entries.push([toFixed(time), toFixed(keytime)]); +} + +function getEntries(times, states) { + var entries = times.map(function (time) { + return [time, time]; + }); + var nextEntries = []; + states.forEach(function (state) { + var iterationCount = state[ITERATION_COUNT]; + var delay = state[DELAY]; + var playSpeed = state[PLAY_SPEED]; + var direction = state[DIRECTION]; + var intCount = Math.ceil(iterationCount); + var currentDuration = entries[entries.length - 1][0]; + var length = entries.length; + var lastTime = currentDuration * iterationCount; + + for (var i = 0; i < intCount; ++i) { + var isReverse = direction === REVERSE || direction === ALTERNATE && i % 2 || direction === ALTERNATE_REVERSE && !(i % 2); + + for (var j = 0; j < length; ++j) { + var entry = entries[isReverse ? length - j - 1 : j]; + var time = entry[1]; + var currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]); + var prevEntry = entries[isReverse ? length - j : j - 1]; + + if (currentTime > lastTime) { + if (j !== 0) { + var prevTime = currentDuration * i + (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]); + var divideTime = utils.dot(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime); + addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime); + } + + break; + } else if (currentTime === lastTime && nextEntries.length && nextEntries[nextEntries.length - 1][0] === lastTime + delay) { + break; + } + + addEntry(nextEntries, (delay + currentTime) / playSpeed, time); + } + } // delay time + + + delay && nextEntries.unshift([0, nextEntries[0][1]]); + entries = nextEntries; + nextEntries = []; + }); + return entries; +} +/** +* manage Frame Keyframes and play keyframes. +* @extends Animator +* @example +const item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } +}); +*/ + +var SceneItem = +/*#__PURE__*/ +function (_super) { + __extends(SceneItem, _super); + /** + * @param - properties + * @param - options + * @example + const item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + */ + + + function SceneItem(properties, options) { + var _this = _super.call(this) || this; + + _this.times = []; + _this.items = {}; + _this.nameMap = new OrderMap(NAME_SEPARATOR); + _this.elements = []; + _this.needUpdate = true; + + _this.load(properties, options); + + return _this; + } + + var __proto = SceneItem.prototype; + + __proto.getDuration = function () { + var times = this.times; + var length = times.length; + return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION]; + }; + /** + * get size of list + * @return {Number} length of list + */ + + + __proto.size = function () { + return this.times.length; + }; + + __proto.setDuration = function (duration) { + if (!duration) { + return this; + } + + var originalDuration = this.getDuration(); + + if (originalDuration > 0) { + var ratio_1 = duration / originalDuration; + + var _a = this, + times = _a.times, + items_1 = _a.items; + + var obj_1 = {}; + this.times = times.map(function (time) { + var time2 = toFixed(time * ratio_1); + obj_1[time2] = items_1[time]; + return time2; + }); + this.items = obj_1; + } else { + this.newFrame(duration); + } + + return this; + }; + + __proto.setId = function (id) { + var state = this.state; + var elements = this.elements; + var length = elements.length; + state.id = id || makeId(!!length); + + if (length && !state[SELECTOR]) { + var sceneId_1 = toId(this.getId()); + state[SELECTOR] = "[" + DATA_SCENE_ID + "=\"" + sceneId_1 + "\"]"; + elements.forEach(function (element) { + element.setAttribute(DATA_SCENE_ID, sceneId_1); + }); + } + + return this; + }; + /** + * Set properties to the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} [properties] - property names or values + * @return {SceneItem} An instance itself + * @example + item.set(0, "a", "b") // item.getFrame(0).set("a", "b") + console.log(item.get(0, "a")); // "b" + */ + + + __proto.set = function (time) { + var _this = this; + + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + if (time instanceof SceneItem) { + return this.set(0, time); + } else if (utils.isArray(time)) { + var length = time.length; + + for (var i = 0; i < length; ++i) { + var t = length === 1 ? 0 : this.getUnitTime(i / (length - 1) * 100 + "%"); + this.set(t, time[i]); + } + } else if (utils.isObject(time)) { + var _loop_1 = function (t) { + var value = time[t]; + utils.splitComma(t).forEach(function (eachTime) { + var realTime = _this.getUnitTime(eachTime); + + if (isNaN(realTime)) { + getNames(value, [eachTime]).forEach(function (names) { + var _a; + + var innerValue = getValueByNames(names.slice(1), value); + var arr = utils.isArray(innerValue) ? innerValue : [getValueByNames(names, _this.target), innerValue]; + var length = arr.length; + + for (var i = 0; i < length; ++i) { + (_a = _this.newFrame(i / (length - 1) * 100 + "%")).set.apply(_a, __spreadArrays(names, [arr[i]])); + } + }); + } else { + _this.set(realTime, value); + } + }); + }; + + for (var t in time) { + _loop_1(t); + } + } else if (!utils.isUndefined(time)) { + var value_1 = args[0]; + utils.splitComma(time + "").forEach(function (eachTime) { + var realTime = _this.getUnitTime(eachTime); + + if (value_1 instanceof SceneItem) { + var delay = value_1.getDelay(); + var frames = value_1.toObject(!_this.hasFrame(realTime + delay)); + var duration = value_1.getDuration(); + var direction = value_1.getDirection(); + var isReverse = direction.indexOf("reverse") > -1; + + for (var frameTime in frames) { + var nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime); + + _this.set(realTime + nextTime, frames[frameTime]); + } + } else if (args.length === 1 && utils.isArray(value_1)) { + value_1.forEach(function (item) { + _this.set(realTime, item); + }); + } else { + var frame = _this.newFrame(realTime); + + frame.set.apply(frame, args); + } + }); + } + + this.needUpdate = true; + return this; + }; + /** + * Get properties of the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} args property's name or properties + * @return {Number|String|PropertyObejct} property value + * @example + item.get(0, "a"); // item.getFrame(0).get("a"); + item.get(0, "transform", "translate"); // item.getFrame(0).get("transform", "translate"); + */ + + + __proto.get = function (time) { + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + var frame = this.getFrame(time); + return frame && frame.get.apply(frame, args); + }; + /** + * get properties orders + * @param - property names + * @example + item.getOrders(["display"]) // => [] + item.getOrders(["transform"]) // => ["translate", "scale"] + */ + + + __proto.getOrders = function (names) { + this.needUpdate && this.update(); + return this.nameMap.get(names); + }; + /** + * set properties orders + * @param - property names + * @param - orders + * @example + item.getOrders(["transform"]) // => ["translate", "scale"] + item.setOrders(["transform"], ["scale", "tralsate"]) + */ + + + __proto.setOrders = function (names, orders) { + this.needUpdate && this.update(); + var result = this.nameMap.set(names, orders); + this.updateFrameOrders(); + return result; + }; + /** + * get properties order object + * @example + console.log(item.getOrderObject()); + */ + + + __proto.getOrderObject = function () { + return this.nameMap.getObject(); + }; + /** + * set properties orders object + * @param - properties orders object + * @example + item.setOrderObject({ + "": ["transform"], + "transform": ["scale", "tralsate"], + }); + */ + + + __proto.setOrderObject = function (obj) { + this.nameMap.setObject(obj); + this.updateFrameOrders(); + }; + /** + * remove properties to the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} [properties] - property names or values + * @return {SceneItem} An instance itself + * @example + item.remove(0, "a"); + */ + + + __proto.remove = function (time) { + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + if (args.length) { + var frame = this.getFrame(time); + frame && frame.remove.apply(frame, args); + } else { + this.removeFrame(time); + } + + this.needUpdate = true; + return this; + }; + /** + * Append the item or object at the last time. + * @param - the scene item or item object + * @return An instance itself + * @example + item.append(new SceneItem({ + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + })); + item.append({ + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }); + item.set(item.getDuration(), { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }); + */ + + + __proto.append = function (item) { + if (item instanceof SceneItem) { + this.set(this.getDuration(), item); + } else { + this.append(new SceneItem(item)); + } + + return this; + }; + /** + * Push the front frames for the time and prepend the scene item or item object. + * @param - the scene item or item object + * @return An instance itself + */ + + + __proto.prepend = function (item) { + if (item instanceof SceneItem) { + var unshiftTime = item.getDuration() + item.getDelay(); + var firstFrame = this.getFrame(0); // remove first frame + + this.removeFrame(0); + this.unshift(unshiftTime); + this.set(0, item); + this.set(unshiftTime + THRESHOLD, firstFrame); + } else { + this.prepend(new SceneItem(item)); + } + + return this; + }; + /** + * Push out the amount of time. + * @param - time to push + * @example + item.get(0); // frame 0 + item.unshift(3); + item.get(3) // frame 0 + */ + + + __proto.unshift = function (time) { + var _a = this, + times = _a.times, + items = _a.items; + + var obj = {}; + this.times = times.map(function (t) { + var time2 = toFixed(time + t); + obj[time2] = items[t]; + return time2; + }); + this.items = obj; + return this; + }; + /** + * Get the frames in the item in object form. + * @return {} + * @example + item.toObject(); + // {0: {display: "none"}, 1: {display: "block"}} + */ + + + __proto.toObject = function (isStartZero) { + if (isStartZero === void 0) { + isStartZero = true; + } + + var obj = {}; + var delay = this.getDelay(); + this.forEach(function (frame, time) { + obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone(); + }); + return obj; + }; + /** + * Specifies an element to synchronize items' keyframes. + * @param {string} selectors - Selectors to find elements in items. + * @return {SceneItem} An instance itself + * @example + item.setSelector("#id.class"); + */ + + + __proto.setSelector = function (target) { + if (utils.isFunction(target)) { + this.setElement(target(this.getId())); + } else { + this.setElement(target); + } + + return this; + }; + /** + * Get the elements connected to SceneItem. + */ + + + __proto.getElements = function () { + return this.elements; + }; + /** + * Specifies an element to synchronize item's keyframes. + * @param - elements to synchronize item's keyframes. + * @param - Make sure that you have peusdo. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setElement(document.querySelectorAll(".class")); + */ + + + __proto.setElements = function (target) { + return this.setElement(target); + }; + /** + * Specifies an element to synchronize item's keyframes. + * @param - elements to synchronize item's keyframes. + * @param - Make sure that you have peusdo. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setElement(document.querySelectorAll(".class")); + */ + + + __proto.setElement = function (target) { + var state = this.state; + var elements = []; + + if (!target) { + return this; + } else if (target === true || utils.isString(target)) { + var selector = target === true ? "" + state.id : target; + var matches = /([\s\S]+)(:+[a-zA-Z]+)$/g.exec(selector); + elements = utils.toArray(utils.$(matches ? matches[1] : selector, true)); + state[SELECTOR] = selector; + } else { + elements = target instanceof Element ? [target] : utils.toArray(target); + } + + if (!elements.length) { + return this; + } + + this.elements = elements; + this.setId(this.getId()); + this.target = elements[0].style; + + this.targetFunc = function (frame) { + var attributes = frame.get("attribute"); + + if (attributes) { + var _loop_2 = function (name) { + elements.forEach(function (el) { + el.setAttribute(name, attributes[name]); + }); + }; + + for (var name in attributes) { + _loop_2(name); + } + } + + if (frame.has("html")) { + var html_1 = frame.get("html"); + elements.forEach(function (el) { + el.innerHTML = html_1; + }); + } + + var cssText = frame.toCSS(); + + if (state.cssText !== cssText) { + state.cssText = cssText; + elements.forEach(function (el) { + el.style.cssText += cssText; + }); + return frame; + } + }; + + return this; + }; + + __proto.setTarget = function (target) { + this.target = target; + + this.targetFunc = function (frame) { + var obj = frame.get(); + + for (var name in obj) { + target[name] = obj[name]; + } + }; + + return this; + }; + /** + * add css styles of items's element to the frame at that time. + * @param {Array} properties - elements to synchronize item's keyframes. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setCSS(0, ["opacity"]); + item.setCSS(0, ["opacity", "width", "height"]); + */ + + + __proto.setCSS = function (time, properties) { + this.set(time, utils.fromCSS(this.elements, properties)); + return this; + }; + + __proto.setTime = function (time, isTick, isParent, parentEasing) { + _super.prototype.setTime.call(this, time, isTick, isParent); + + var iterationTime = this.getIterationTime(); + var easing = this.getEasing() || parentEasing; + var frame = this.getNowFrame(iterationTime, easing); + var currentTime = this.getTime(); + this.temp = frame; + /** + * This event is fired when timeupdate and animate. + * @event SceneItem#animate + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.time The iteration time during duration that the animator is running. + * @param {Frame} param.frame frame of that time. + */ + + this.trigger("animate", { + frame: frame, + currentTime: currentTime, + time: iterationTime + }); + this.targetFunc && this.targetFunc(frame); + return this; + }; + /** + * update property names used in frames. + * @return {SceneItem} An instance itself + * @example + item.update(); + */ + + + __proto.update = function () { + var prevNameMap = this.nameMap; + var names = {}; + this.forEach(function (frame) { + updateFrame(names, frame.properties); + }); + var nameMap = new OrderMap(NAME_SEPARATOR); + + function pushKeys(map, stack) { + var keys = utils.getKeys(map); + utils.sortOrders(keys, prevNameMap.get(stack)); + nameMap.set(stack, keys); + keys.forEach(function (key) { + var nextMap = map[key]; + + if (utils.isObject(nextMap)) { + pushKeys(nextMap, __spreadArrays(stack, [key])); + } + }); + } + + pushKeys(names, []); + this.nameMap = nameMap; + this.forEach(function (frame) { + frame.setOrderObject(nameMap.orderMap); + }); + this.needUpdate = false; + return this; + }; + /** + * Create and add a frame to the sceneItem at that time + * @param {Number} time - frame's time + * @return {Frame} Created frame. + * @example + item.newFrame(time); + */ + + + __proto.newFrame = function (time) { + var frame = this.getFrame(time); + + if (frame) { + return frame; + } + + frame = new Frame(); + this.setFrame(time, frame); + return frame; + }; + /** + * Add a frame to the sceneItem at that time + * @param {Number} time - frame's time + * @return {SceneItem} An instance itself + * @example + item.setFrame(time, frame); + */ + + + __proto.setFrame = function (time, frame) { + var realTime = this.getUnitTime(time); + this.items[realTime] = frame; + addTime(this.times, realTime); + this.needUpdate = true; + return this; + }; + /** + * get sceneItem's frame at that time + * @param {Number} time - frame's time + * @return {Frame} sceneItem's frame at that time + * @example + const frame = item.getFrame(time); + */ + + + __proto.getFrame = function (time) { + return this.items[this.getUnitTime(time)]; + }; + /** + * remove sceneItem's frame at that time + * @param - frame's time + * @return {SceneItem} An instance itself + * @example + item.removeFrame(time); + */ + + + __proto.removeFrame = function (time) { + var realTime = this.getUnitTime(time); + var items = this.items; + var index = this.times.indexOf(realTime); + delete items[realTime]; // remove time + + if (index > -1) { + this.times.splice(index, 1); + } + + this.needUpdate = true; + return this; + }; + /** + * check if the item has a frame at that time + * @param {Number} time - frame's time + * @return {Boolean} true: the item has a frame // false: not + * @example + if (item.hasFrame(10)) { + // has + } else { + // not + } + */ + + + __proto.hasFrame = function (time) { + return this.getUnitTime(time) in this.items; + }; + /** + * Check if keyframes has propery's name + * @param - property's time + * @return {boolean} true: if has property, false: not + * @example + item.hasName(["transform", "translate"]); // true or not + */ + + + __proto.hasName = function (args) { + this.needUpdate && this.update(); + return !!this.nameMap.get(args); + }; + /** + * merge frame of the previous time at the next time. + * @param - The time of the frame to merge + * @param - The target frame + * @return {SceneItem} An instance itself + * @example + // getFrame(1) contains getFrame(0) + item.merge(0, 1); + */ + + + __proto.mergeFrame = function (time, frame) { + if (frame) { + var toFrame = this.newFrame(time); + toFrame.merge(frame); + } + + return this; + }; + /** + * Get frame of the current time + * @param {Number} time - the current time + * @param {function} easing - the speed curve of an animation + * @return {Frame} frame of the current time + * @example + let item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + // opacity: 0.7; display:"block"; + const frame = item.getNowFrame(1.7); + */ + + + __proto.getNowFrame = function (time, easing, isAccurate) { + var _this = this; + + this.needUpdate && this.update(); + var frame = new Frame(); + + var _a = getNearTimeIndex(this.times, time), + left = _a[0], + right = _a[1]; + + var realEasing = this.getEasing() || easing; + var nameMap = this.nameMap; + + if (this.hasName([TIMING_FUNCTION])) { + var nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true); + utils.isFunction(nowEasing) && (realEasing = nowEasing); + } + + if (isAccurate) { + var prevFrame_1 = this.getFrame(time); + var prevOrderMap = prevFrame_1.orderMap.filter([], function (orders) { + return prevFrame_1.has.apply(prevFrame_1, orders); + }); + + for (var name in ROLES) { + var orders = nameMap.get([name]); + + if (prevOrderMap.get([name]) && orders) { + prevOrderMap.set([name], orders); + } + } + + nameMap = prevOrderMap; + } + + var names = nameMap.gets([]); + frame.setOrderObject(nameMap.orderMap); + names.forEach(function (properties) { + var value = _this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties)); + + if (utils.isUndefined(value)) { + return; + } + + frame.set(properties, value); + }); + return frame; + }; + + __proto.load = function (properties, options) { + var _a; + + if (properties === void 0) { + properties = {}; + } + + if (options === void 0) { + options = properties.options; + } + + options && this.setOptions(options); + + if (utils.isArray(properties)) { + this.set(properties); + } else if (properties.keyframes) { + this.set(properties.keyframes); + } else { + for (var time in properties) { + if (time !== "options") { + this.set((_a = {}, _a[time] = properties[time], _a)); + } + } + } + + if (options && options[DURATION]) { + this.setDuration(options[DURATION]); + } + + return this; + }; + /** + * clone SceneItem. + * @return {SceneItem} An instance of clone + * @example + * item.clone(); + */ + + + __proto.clone = function () { + var item = new SceneItem(); + item.setOptions(this.state); + item.setOrderObject(this.nameMap.orderMap); + this.forEach(function (frame, time) { + item.setFrame(time, frame.clone()); + }); + return item; + }; + /** + * executes a provided function once for each scene item. + * @param - Function to execute for each element, taking three arguments + * @return {Keyframes} An instance itself + */ + + + __proto.forEach = function (callback) { + var times = this.times; + var items = this.items; + times.forEach(function (time) { + callback(items[time], time, items); + }); + return this; + }; + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + _super.prototype.setOptions.call(this, options); + + var id = options.id, + selector = options.selector, + elements = options.elements, + element = options.element, + target = options.target; + id && this.setId(id); + + if (target) { + this.setTarget(target); + } else if (selector) { + this.setSelector(selector); + } else if (elements || element) { + this.setElement(elements || element); + } + + return this; + }; + + __proto.toCSS = function (playCondition, parentDuration, states) { + if (playCondition === void 0) { + playCondition = { + className: START_ANIMATION + }; + } + + if (parentDuration === void 0) { + parentDuration = this.getDuration(); + } + + if (states === void 0) { + states = []; + } + + var itemState = this.state; + var selector = itemState[SELECTOR]; + + if (!selector) { + return ""; + } + + var originalDuration = this.getDuration(); + itemState[DURATION] = originalDuration; + states.push(itemState); + var reversedStates = utils.toArray(states).reverse(); + var id = toId(getRealId(this)); + var superParent = states[0]; + var infiniteIndex = utils.findIndex(reversedStates, function (state) { + return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]); + }, states.length - 1); + var finiteStates = reversedStates.slice(0, infiniteIndex); + var duration = parentDuration || finiteStates.reduce(function (prev, cur) { + return (cur[DELAY] + prev * cur[ITERATION_COUNT]) / cur[PLAY_SPEED]; + }, originalDuration); + var delay = reversedStates.slice(infiniteIndex).reduce(function (prev, cur) { + return (prev + cur[DELAY]) / cur[PLAY_SPEED]; + }, 0); + var easingName = utils.find(reversedStates, function (state) { + return state[EASING] && state[EASING_NAME]; + }, itemState)[EASING_NAME]; + var iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT]; + var fillMode = superParent[FILL_MODE]; + var direction = reversedStates[infiniteIndex][DIRECTION]; + var cssText = makeAnimationProperties({ + fillMode: fillMode, + direction: direction, + iterationCount: iterationCount, + delay: delay + "s", + name: PREFIX + "KEYFRAMES_" + id, + duration: duration / superParent[PLAY_SPEED] + "s", + timingFunction: easingName + }); + var selectors = utils.splitComma(selector).map(function (sel) { + var matches = /([\s\S]+)(:+[a-zA-Z]+)$/g.exec(sel); + + if (matches) { + return [matches[1], matches[2]]; + } else { + return [sel, ""]; + } + }); + var className = playCondition.className; + var selectorCallback = playCondition.selector; + var preselector = utils.isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback; + return "\n " + (preselector || selectors.map(function (_a) { + var sel = _a[0], + peusdo = _a[1]; + return sel + "." + className + peusdo; + })) + " {" + cssText + "}\n " + selectors.map(function (_a) { + var sel = _a[0], + peusdo = _a[1]; + return sel + "." + PAUSE_ANIMATION + peusdo; + }) + " {" + utils.ANIMATION + "-play-state: paused;}\n @" + utils.KEYFRAMES + " " + PREFIX + "KEYFRAMES_" + id + "{" + this._toKeyframes(duration, finiteStates, direction) + "}"; + }; + /** + * Export the CSS of the items to the style. + * @param - Add a selector or className to play. + * @return {SceneItem} An instance itself + */ + + + __proto.exportCSS = function (playCondition, duration, options) { + if (!this.elements.length) { + return ""; + } + + var css = this.toCSS(playCondition, duration, options); + var isParent = options && !utils.isUndefined(options[ITERATION_COUNT]); + + if (!isParent) { + if (this.styledInjector) { + this.styledInjector.destroy(); + this.styledInjector = null; + } + + this.styled = styled(css); + this.styledInjector = this.styled.inject(this.getAnimationElement(), { + original: true + }); + } + + return this; + }; + + __proto.pause = function () { + _super.prototype.pause.call(this); + + isPausedCSS(this) && this.pauseCSS(); + return this; + }; + + __proto.pauseCSS = function () { + this.elements.forEach(function (element) { + utils.addClass(element, PAUSE_ANIMATION); + }); + return this; + }; + + __proto.endCSS = function () { + this.elements.forEach(function (element) { + utils.removeClass(element, PAUSE_ANIMATION); + utils.removeClass(element, START_ANIMATION); + }); + setPlayCSS(this, false); + return this; + }; + + __proto.end = function () { + isEndedCSS(this) && this.endCSS(); + + _super.prototype.end.call(this); + + return this; + }; + /** + * Play using the css animation and keyframes. + * @param - Check if you want to export css. + * @param [playClassName="startAnimation"] - Add a class name to play. + * @param - The shorthand properties for six of the animation properties. + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp} + * @example + item.playCSS(); + item.playCSS(false, "startAnimation", { + direction: "reverse", + fillMode: "forwards", + }); + */ + + + __proto.playCSS = function (isExportCSS, playClassName, properties) { + if (isExportCSS === void 0) { + isExportCSS = true; + } + + if (properties === void 0) { + properties = {}; + } + + playCSS(this, isExportCSS, playClassName, properties); + return this; + }; + + __proto.getAnimationElement = function () { + return this.elements[0]; + }; + + __proto.addPlayClass = function (isPaused, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + var elements = this.elements; + var length = elements.length; + var cssText = makeAnimationProperties(properties); + + if (!length) { + return; + } + + if (isPaused) { + elements.forEach(function (element) { + utils.removeClass(element, PAUSE_ANIMATION); + }); + } else { + elements.forEach(function (element) { + element.style.cssText += cssText; + + if (utils.hasClass(element, START_ANIMATION)) { + utils.removeClass(element, START_ANIMATION); + } + }); + elements.forEach(function (element) { + element.clientWidth; + }); + elements.forEach(function (element) { + utils.addClass(element, START_ANIMATION); + }); + } + + return elements[0]; + }; + /** + * Clear All Frames + * @return {SceneItem} An instance itself + */ + + + __proto.clear = function () { + this.times = []; + this.items = {}; + this.nameMap = new OrderMap(NAME_SEPARATOR); + + if (this.styledInjector) { + this.styledInjector.destroy(); + } + + this.styled = null; + this.styledInjector = null; + this.temp = null; + this.needUpdate = true; + return this; + }; + + __proto.getNowValue = function (time, properties, left, right, isAccurate, easing, usePrevValue) { + var times = this.times; + var length = times.length; + var prevTime; + var nextTime; + var prevFrame; + var nextFrame; + var isUndefinedLeft = utils.isUndefined(left); + var isUndefinedRight = utils.isUndefined(right); + + if (isUndefinedLeft || isUndefinedRight) { + var indicies = getNearTimeIndex(times, time); + isUndefinedLeft && (left = indicies[0]); + isUndefinedRight && (right = indicies[1]); + } + + for (var i = left; i >= 0; --i) { + var frame = this.getFrame(times[i]); + + if (frame.has.apply(frame, properties)) { + prevTime = times[i]; + prevFrame = frame; + break; + } + } + + var prevValue = prevFrame && prevFrame.raw.apply(prevFrame, properties); + + if (isAccurate && !isRole([properties[0]])) { + return prevTime === time ? prevValue : undefined; + } + + if (usePrevValue) { + return prevValue; + } + + for (var i = right; i < length; ++i) { + var frame = this.getFrame(times[i]); + + if (frame.has.apply(frame, properties)) { + nextTime = times[i]; + nextFrame = frame; + break; + } + } + + var nextValue = nextFrame && nextFrame.raw.apply(nextFrame, properties); + + if (!prevFrame || utils.isUndefined(prevValue)) { + return nextValue; + } + + if (!nextFrame || utils.isUndefined(nextValue) || prevValue === nextValue) { + return prevValue; + } + + return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing); + }; + + __proto._toKeyframes = function (duration, states, direction) { + var _this = this; + + var frames = {}; + var times = this.times.slice(); + + if (!times.length) { + return ""; + } + + var originalDuration = this.getDuration(); + !this.getFrame(0) && times.unshift(0); + !this.getFrame(originalDuration) && times.push(originalDuration); + var entries = getEntries(times, states); + var lastEntry = entries[entries.length - 1]; // end delay time + + lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]); + var prevTime = -1; + return entries.map(function (_a) { + var time = _a[0], + keytime = _a[1]; + + if (!frames[keytime]) { + frames[keytime] = (!_this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ? _this.getNowFrame(keytime) : _this.getNowFrame(keytime, 0, true)).toCSS(); + } + + var frameTime = time / duration * 100; + + if (frameTime - prevTime < THRESHOLD) { + frameTime += THRESHOLD; + } + + prevTime = frameTime; + return Math.min(frameTime, 100) + "%{\n " + (time === 0 && !isDirectionReverse(0, 1, direction) ? "" : frames[keytime]) + "\n }"; + }).join(""); + }; + + __proto.updateFrameOrders = function () { + var nameMap = this.nameMap.orderMap; + this.forEach(function (frame) { + frame.setOrderObject(nameMap); + }); + }; + + return SceneItem; +}(Animator); + +/** + * manage sceneItems and play Scene. + * @sort 1 + */ + +var Scene = +/*#__PURE__*/ +function (_super) { + __extends(Scene, _super); + /** + * @param - properties + * @param - options + * @example + const scene = new Scene({ + item1: { + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + }, + }, + item2: { + 2: { + opacity: 1, + }, + } + }); + */ + + + function Scene(properties, options) { + var _this = _super.call(this) || this; + + _this.items = {}; + _this.orderMap = new OrderMap(NAME_SEPARATOR); + + _this.load(properties, options); + + return _this; + } + + var __proto = Scene.prototype; + + __proto.getDuration = function () { + var time = 0; + this.forEach(function (item) { + time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed()); + }); + return time || this.state[DURATION]; + }; + + __proto.setDuration = function (duration) { + var items = this.items; + var sceneDuration = this.getDuration(); + + if (duration === 0 || !isFinite(sceneDuration)) { + return this; + } + + if (sceneDuration === 0) { + this.forEach(function (item) { + item.setDuration(duration); + }); + } else { + var ratio_1 = duration / sceneDuration; + this.forEach(function (item) { + item.setDelay(item.getDelay() * ratio_1); + item.setDuration(item.getDuration() * ratio_1); + }); + } + + _super.prototype.setDuration.call(this, duration); + + return this; + }; + /** + * get item in scene by name + * @param - The item's name + * @return {Scene | SceneItem} item + * @example + const item = scene.getItem("item1") + */ + + + __proto.getItem = function (name) { + return this.items[name]; + }; + /** + * create item in scene + * @param {} name - name of item to create + * @param {} options - The option object of SceneItem + * @return {} Newly created item + * @example + const item = scene.newItem("item1") + */ + + + __proto.newItem = function (name, options) { + if (options === void 0) { + options = {}; + } + + if (this.items[name]) { + return this.items[name]; + } + + var item = new SceneItem(); + this.setItem(name, item); + item.setOptions(options); + return item; + }; + /** + * remove item in scene + * @param - name of item to remove + * @return An instance itself + * @example + const item = scene.newItem("item1") + scene.removeItem("item1"); + */ + + + __proto.removeItem = function (name) { + delete this.items[name]; + this.orderMap.remove([name]); + return this; + }; + /** + * add a sceneItem to the scene + * @param - name of item to create + * @param - sceneItem + * @example + const item = scene.newItem("item1") + */ + + + __proto.setItem = function (name, item) { + item.setId(name); + this.items[name] = item; + this.orderMap.add([name]); + return this; + }; + + __proto.setTime = function (time, isTick, isParent, parentEasing) { + _super.prototype.setTime.call(this, time, isTick, isParent); + + var iterationTime = this.getIterationTime(); + var easing = this.getEasing() || parentEasing; + var frames = {}; + this.forEach(function (item) { + item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing); + frames[item.getId()] = item.temp; + }); + this.temp = frames; + /** + * This event is fired when timeupdate and animate. + * @event Scene#animate + * @param {object} param The object of data to be sent to an event. + * @param {number} param.currentTime The total time that the animator is running. + * @param {number} param.time The iteration time during duration that the animator is running. + * @param {object} param.frames frames of that time. + * @example + const scene = new Scene({ + a: { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }, + b: { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + } + }).on("animate", e => { + console.log(e.frames); + // {a: Frame, b: Frame} + console.log(e.frames.a.get("opacity")); + }); + */ + + this.trigger("animate", { + frames: frames, + currentTime: this.getTime(), + time: iterationTime + }); + return this; + }; + /** + * executes a provided function once for each scene item. + * @param - Function to execute for each element, taking three arguments + * @return {Scene} An instance itself + */ + + + __proto.forEach = function (func) { + var items = this.items; + this.getOrders().forEach(function (id, index) { + func(items[id], id, index, items); + }); + return this; + }; + + __proto.toCSS = function (playCondition, duration, parentStates) { + if (duration === void 0) { + duration = this.getDuration(); + } + + if (parentStates === void 0) { + parentStates = []; + } + + var totalDuration = !duration || !isFinite(duration) ? 0 : duration; + var styles = []; + var state = this.state; + state[DURATION] = this.getDuration(); + this.forEach(function (item) { + styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state))); + }); + return styles.join(""); + }; + /** + * Export the CSS of the items to the style. + * @param - Add a selector or className to play. + * @return {Scene} An instance itself + */ + + + __proto.exportCSS = function (playCondition, duration, parentStates) { + var css = this.toCSS(playCondition, duration, parentStates); + + if (!parentStates || !parentStates.length) { + if (this.styledInjector) { + this.styledInjector.destroy(); + this.styledInjector = null; + } + + this.styled = styled(css); + this.styledInjector = this.styled.inject(this.getAnimationElement(), { + original: true + }); // && exportCSS(getRealId(this), css); + } + + return this; + }; + + __proto.append = function (item) { + item.setDelay(item.getDelay() + this.getDuration()); + this.setItem(getRealId(item), item); + }; + + __proto.pauseCSS = function () { + return this.forEach(function (item) { + item.pauseCSS(); + }); + }; + + __proto.pause = function () { + _super.prototype.pause.call(this); + + isPausedCSS(this) && this.pauseCSS(); + this.forEach(function (item) { + item.pause(); + }); + return this; + }; + + __proto.endCSS = function () { + this.forEach(function (item) { + item.endCSS(); + }); + setPlayCSS(this, false); + }; + + __proto.end = function () { + isEndedCSS(this) && this.endCSS(); + + _super.prototype.end.call(this); + + return this; + }; + /** + * get item orders + * @example + scene.getOrders() // => ["item1", "item2"] + */ + + + __proto.getOrders = function () { + return this.orderMap.get([]) || []; + }; + /** + * set item orders + * @param - orders + * @example + frame.setOrders(["item2", "item1"]) // => ["item2", "item1"] + */ + + + __proto.setOrders = function (orders) { + return this.orderMap.set([], orders); + }; + + __proto.getAnimationElement = function () { + var animtionElement; + this.forEach(function (item) { + var el = item.getAnimationElement(); + !animtionElement && (animtionElement = el); + }); + return animtionElement; + }; + + __proto.addPlayClass = function (isPaused, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + var animtionElement; + this.forEach(function (item) { + var el = item.addPlayClass(isPaused, playClassName, properties); + !animtionElement && (animtionElement = el); + }); + return animtionElement; + }; + /** + * Play using the css animation and keyframes. + * @param - Check if you want to export css. + * @param [playClassName="startAnimation"] - Add a class name to play. + * @param - The shorthand properties for six of the animation properties. + * @return {Scene} An instance itself + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp} + * @example + scene.playCSS(); + scene.playCSS(false, { + direction: "reverse", + fillMode: "forwards", + }); + */ + + + __proto.playCSS = function (isExportCSS, playClassName, properties) { + if (isExportCSS === void 0) { + isExportCSS = true; + } + + if (properties === void 0) { + properties = {}; + } + + playCSS(this, isExportCSS, playClassName, properties); + return this; + }; + /** + * Set properties to the Scene. + * @param - properties + * @return An instance itself + * @example + scene.set({ + ".a": { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + }, + }, + }); + // 0 + console.log(scene.getItem(".a").get(0, "opacity")); + // 1 + console.log(scene.getItem(".a").get(1, "opacity")); + */ + + + __proto.set = function (properties) { + this.load(properties); + return this; + }; + /** + * Clear All Items + * @return {Scene} An instance itself + */ + + + __proto.clear = function () { + this.finish(); + this.items = {}; + this.orderMap = new OrderMap(NAME_SEPARATOR); + + if (this.styledInjector) { + this.styledInjector.destroy(); + } + + this.styled = null; + this.styledInjector = null; + }; + + __proto.load = function (properties, options) { + if (properties === void 0) { + properties = {}; + } + + if (options === void 0) { + options = properties.options; + } + + if (!properties) { + return this; + } + + var selector = options && options[SELECTOR] || this.state[SELECTOR]; + + for (var name in properties) { + if (name === "options") { + continue; + } + + var object = properties[name]; + var item = void 0; + + if (object instanceof Scene || object instanceof SceneItem) { + this.setItem(name, object); + item = object; + } else if (utils.isFunction(object) && selector) { + var elements = utils.IS_WINDOW ? utils.$("" + (utils.isFunction(selector) ? selector(name) : name), true) : []; + var length = elements.length; + var scene = new Scene(); + + for (var i = 0; i < length; ++i) { + scene.newItem(i).setId().setElement(elements[i]).load(object(i, elements[i])); + } + + this.setItem(name, scene); + continue; + } else { + item = this.newItem(name); + item.load(object); + } + + selector && item.setSelector(selector); + } + + this.setOptions(options); + }; + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + _super.prototype.setOptions.call(this, options); + + var selector = options.selector; + + if (selector) { + this.state[SELECTOR] = selector; + } + + return this; + }; + + __proto.setSelector = function (target) { + var state = this.state; + var selector = target || state[SELECTOR]; + state[SELECTOR] = selector; + var isItFunction = utils.isFunction(target); + + if (selector) { + this.forEach(function (item, name) { + item.setSelector(isItFunction ? target(name) : selector); + }); + } + + return this; + }; + + __proto.start = function (delay) { + if (delay === void 0) { + delay = this.state[DELAY]; + } + + var result = _super.prototype.start.call(this, delay); + + if (result) { + this.forEach(function (item) { + item.start(0); + }); + } else { + this.forEach(function (item) { + item.setPlayState(RUNNING); + }); + } + + return result; + }; + /** + * version info + * @type {string} + * @example + * Scene.VERSION // 1.4.0 + */ + + + Scene.VERSION = "1.4.0"; + return Scene; +}(Animator); + +function animate(properties, options) { + return new Scene(properties, options).play(); +} +function animateItem(properties, options) { + return new SceneItem(properties, options).play(); +} + + + +var others = ({ + SceneItem: SceneItem, + Frame: Frame, + Animator: Animator, + 'default': Scene, + OPTIONS: OPTIONS, + EVENTS: EVENTS, + FIXED: FIXED, + ROLES: ROLES, + NAME_SEPARATOR: NAME_SEPARATOR, + setRole: setRole, + setAlias: setAlias, + bezier: bezier, + steps: steps, + STEP_START: STEP_START, + STEP_END: STEP_END, + LINEAR: LINEAR, + EASE: EASE, + EASE_IN: EASE_IN, + EASE_OUT: EASE_OUT, + EASE_IN_OUT: EASE_IN_OUT, + animate: animate, + animateItem: animateItem +}); + +for (var name in others) { + Scene[name] = others[name]; +} + +module.exports = Scene; +//# sourceMappingURL=scene.cjs.js.map diff --git a/dist/scene.cjs.js.map b/dist/scene.cjs.js.map new file mode 100644 index 00000000..87b6c716 --- /dev/null +++ b/dist/scene.cjs.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scene.cjs.js","sources":["../src/easing.ts","../src/consts.ts","../src/EventTrigger.ts","../src/PropertyObject.ts","../src/utils/property.ts","../src/utils.ts","../src/Animator.ts","../src/Frame.ts","../src/utils/dot.ts","../src/SceneItem.ts","../src/Scene.ts","../src/presets.ts","../src/index.umd.ts"],"sourcesContent":["import { EasingFunction } from \"./types\";\n\nfunction cubic(y1: number, y2: number, t: number) {\n const t2 = 1 - t;\n\n // Bezier Curve Formula\n return t * t * t + 3 * t * t * t2 * y2 + 3 * t * t2 * t2 * y1;\n}\nfunction solveFromX(x1: number, x2: number, x: number) {\n // x 0 ~ 1\n // t 0 ~ 1\n let t = x;\n let solveX = x;\n let dx = 1;\n\n while (Math.abs(dx) > 1 / 1000) {\n // 예상 t초에 의한 _x값\n solveX = cubic(x1, x2, t);\n dx = solveX - x;\n // 차이가 미세하면 그 값을 t로 지정\n if (Math.abs(dx) < 1 / 1000) {\n return t;\n }\n t -= dx / 2;\n }\n return t;\n}\n/**\n * @namespace easing\n */\n/**\n* Cubic Bezier curve.\n* @memberof easing\n* @func bezier\n* @param {number} [x1] - point1's x\n* @param {number} [y1] - point1's y\n* @param {number} [x2] - point2's x\n* @param {number} [y2] - point2's y\n* @return {function} the curve function\n* @example\nimport {bezier} from \"scenejs\";\nScene.bezier(0, 0, 1, 1) // LINEAR\nScene.bezier(0.25, 0.1, 0.25, 1) // EASE\n*/\nexport function bezier(x1: number, y1: number, x2: number, y2: number) {\n /*\n\t\tx = f(t)\n\t\tcalculate inverse function by x\n\t\tt = f-1(x)\n\t*/\n const func: EasingFunction = (x: number) => {\n const t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0));\n\n return cubic(y1, y2, t);\n };\n\n func.easingName = `cubic-bezier(${x1},${y1},${x2},${y2})`;\n return func;\n}\n/**\n* Specifies a stepping function\n* @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function}\n* @memberof easing\n* @func steps\n* @param {number} count - point1's x\n* @param {\"start\" | \"end\"} postion - point1's y\n* @return {function} the curve function\n* @example\nimport {steps} from \"scenejs\";\nScene.steps(1, \"start\") // Scene.STEP_START\nScene.steps(1, \"end\") // Scene.STEP_END\n*/\nexport function steps(count: number, position: \"start\" | \"end\") {\n const func: EasingFunction = (time: number) => {\n const level = 1 / count;\n\n if (time >= 1) {\n return 1;\n }\n return (position === \"start\" ? level : 0) + Math.floor(time / level) * level;\n };\n\n func.easingName = `steps(${count}, ${position})`;\n\n return func;\n}\n\n/**\n* Equivalent to steps(1, start)\n* @memberof easing\n* @name STEP_START\n* @static\n* @type {function}\n* @example\nimport {STEP_START} from \"scenejs\";\nScene.STEP_START // steps(1, start)\n*/\nexport const STEP_START = /*#__PURE__#*/steps(1, \"start\");\n/**\n* Equivalent to steps(1, end)\n* @memberof easing\n* @name STEP_END\n* @static\n* @type {function}\n* @example\nimport {STEP_END} from \"scenejs\";\nScene.STEP_END // steps(1, end)\n*/\nexport const STEP_END = /*#__PURE__#*/steps(1, \"end\");\n/**\n* Linear Speed (0, 0, 1, 1)\n* @memberof easing\n* @name LINEAR\n* @static\n* @type {function}\n* @example\nimport {LINEAR} from \"scenejs\";\nScene.LINEAR\n*/\nexport const LINEAR = /*#__PURE__#*/bezier(0, 0, 1, 1);\n/**\n* Ease Speed (0.25, 0.1, 0.25, 1)\n* @memberof easing\n* @name EASE\n* @static\n* @type {function}\n* @example\nimport {EASE} from \"scenejs\";\nScene.EASE\n*/\nexport const EASE = /*#__PURE__#*/bezier(0.25, 0.1, 0.25, 1);\n/**\n* Ease In Speed (0.42, 0, 1, 1)\n* @memberof easing\n* @name EASE_IN\n* @static\n* @type {function}\n* @example\nimport {EASE_IN} from \"scenejs\";\nScene.EASE_IN\n*/\nexport const EASE_IN = /*#__PURE__#*/bezier(0.42, 0, 1, 1);\n/**\n* Ease Out Speed (0, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_OUT} from \"scenejs\";\nScene.EASE_OUT\n*/\nexport const EASE_OUT = /*#__PURE__#*/bezier(0, 0, 0.58, 1);\n/**\n* Ease In Out Speed (0.42, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_IN_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_IN_OUT} from \"scenejs\";\nScene.EASE_IN_OUT\n*/\nexport const EASE_IN_OUT = /*#__PURE__#*/bezier(0.42, 0, 0.58, 1);\n","import { IObject } from \"@daybrush/utils\";\nimport { RoleObject, OptionType, EventType, EasingFunction } from \"./types\";\nimport { EASE, EASE_IN, EASE_IN_OUT, LINEAR, EASE_OUT, STEP_START, STEP_END } from \"./easing\";\n\nexport const PREFIX = \"__SCENEJS_\";\nexport const DATA_SCENE_ID = \"data-scene-id\";\nexport const TIMING_FUNCTION = \"animation-timing-function\";\nexport const ROLES: RoleObject = { transform: {}, filter: {}, attribute: {}, html: true };\nexport const ALIAS: IObject = { easing: [TIMING_FUNCTION] };\nexport const FIXED = { [TIMING_FUNCTION]: true, contents: true, html: true };\nexport const MAXIMUM = 1000000;\nexport const THRESHOLD = 0.000001;\n\nexport const DURATION = \"duration\";\nexport const FILL_MODE = \"fillMode\";\nexport const DIRECTION = \"direction\";\nexport const ITERATION_COUNT = \"iterationCount\";\nexport const DELAY = \"delay\";\nexport const EASING = \"easing\";\nexport const PLAY_SPEED = \"playSpeed\";\nexport const EASING_NAME = \"easingName\";\nexport const ITERATION_TIME = \"iterationTime\";\nexport const PAUSED = \"paused\";\nexport const ENDED = \"ended\";\nexport const TIMEUPDATE = \"timeupdate\";\nexport const ANIMATE = \"animate\";\nexport const PLAY = \"play\";\nexport const RUNNING = \"running\";\nexport const ITERATION = \"iteration\";\nexport const START_ANIMATION = \"startAnimation\";\nexport const PAUSE_ANIMATION = \"pauseAnimation\";\nexport const ALTERNATE = \"alternate\";\nexport const REVERSE = \"reverse\";\nexport const ALTERNATE_REVERSE = \"alternate-reverse\";\nexport const NORMAL = \"normal\";\nexport const INFINITE = \"infinite\";\nexport const PLAY_STATE = \"playState\";\nexport const PLAY_CSS = \"playCSS\";\nexport const PREV_TIME = \"prevTime\";\nexport const TICK_TIME = \"tickTime\";\nexport const CURRENT_TIME = \"currentTime\";\nexport const SELECTOR = \"selector\";\nexport const TRANSFORM_NAME = \"transform\";\nexport const EASINGS = {\n \"linear\": LINEAR,\n \"ease\": EASE,\n \"ease-in\": EASE_IN,\n \"ease-out\": EASE_OUT,\n \"ease-in-out\": EASE_IN_OUT,\n \"step-start\": STEP_START,\n \"step-end\": STEP_END,\n};\nexport const NAME_SEPARATOR = \"_///_\";\n/**\n* option name list\n* @name Scene.OPTIONS\n* @memberof Scene\n* @static\n* @type {$ts:OptionType}\n* @example\n* Scene.OPTIONS // [\"duration\", \"fillMode\", \"direction\", \"iterationCount\", \"delay\", \"easing\", \"playSpeed\"]\n*/\nexport const OPTIONS: OptionType = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED];\n\n/**\n* Event name list\n* @name Scene.EVENTS\n* @memberof Scene\n* @static\n* @type {$ts:EventType}\n* @example\n* Scene.EVENTS // [\"paused\", \"ended\", \"timeupdate\", \"animate\", \"play\", \"iteration\"];\n*/\nexport const EVENTS: EventType = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION];\n","import { isObject, isArray, toArray } from \"@daybrush/utils\";\nimport { CallbackType, EventParameter } from \"./types\";\n\n/**\n* attach and trigger event handlers.\n*/\nclass EventTrigger {\n public events: { [name: string]: CallbackType[] };\n /**\n * @example\n const et = new Scene.EventTrigger();\n const scene = new Scene();\n\n scene.on(\"call\", e => {\n console.log(e.param);\n });\n et.on(\"call\", e => {\n console.log(e.param);\n });\n scene.trigger(\"call\", {param: 1});\n et.trigger(\"call\", {param: 1});\n */\n constructor() {\n this.events = {};\n }\n public _on(name: string | EventParameter, callback?: CallbackType | CallbackType[], once?: boolean) {\n const events = this.events;\n\n if (isObject(name)) {\n for (const n in name) {\n this._on(n, name[n], once);\n }\n return;\n }\n if (!(name in events)) {\n events[name] = [];\n }\n if (!callback) {\n return;\n }\n if (isArray(callback)) {\n callback.forEach(func => this._on(name, func, once));\n return;\n }\n events[name].push(once ? function callback2(...args) {\n callback(...args);\n this.off(name, callback2);\n } : callback);\n }\n /**\n * Attach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function() {\n console.log(\"animate\");\n });\n\n target.trigger(\"animate\");\n\n */\n public on(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback);\n return this;\n }\n /**\n * Dettach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n const callback = function() {\n console.log(\"animate\");\n };\n target.on(\"animate\", callback);\n\n target.off(\"animate\", callback);\n target.off(\"animate\");\n\n */\n public off(name?: string, callback?: CallbackType) {\n if (!name) {\n this.events = {};\n } else if (!callback) {\n this.events[name] = [];\n } else {\n const callbacks = this.events[name];\n\n if (!callbacks) {\n return this;\n }\n const index = callbacks.indexOf(callback);\n\n if (index !== -1) {\n callbacks.splice(index, 1);\n }\n }\n return this;\n }\n /**\n * execute event handler\n * @param - event's name\n * @param - event handler's additional parameter\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function(a1, a2) {\n console.log(\"animate\", a1, a2);\n });\n\n target.trigger(\"animate\", [1, 2]); // log => \"animate\", 1, 2\n\n */\n public trigger(name: string, ...data: any[]) {\n const events = this.events;\n\n if (!(name in events)) {\n return this;\n }\n\n const args = data || [];\n\n !args[0] && (args[0] = {});\n const event = events[name];\n const target = args[0];\n\n target.type = name;\n target.currentTarget = this;\n !target.target && (target.target = this);\n toArray(events[name]).forEach(callback => {\n callback.apply(this, data);\n });\n\n return this;\n }\n public once(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback, true);\n return this;\n }\n}\nexport default EventTrigger;\n","import { isString } from \"@daybrush/utils\";\nimport { PropertyObjectState } from \"./types\";\n\n/**\n* Make string, array to PropertyObject for the dot product\n*/\nclass PropertyObject implements PropertyObjectState {\n public value: any[];\n public prefix: string = \"\";\n public suffix: string = \"\";\n public model: string = \"\";\n public type: string = \"\";\n public separator: string = \",\";\n\n /**\n * @param - This value is in the array format.\n * @param - options\n * @example\n var obj = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n */\n constructor(value: string | any[], options?: Partial) {\n options && this.setOptions(options);\n this.value = isString(value) ? value.split(this.separator) : value;\n }\n public setOptions(newOptions: Partial) {\n for (const name in newOptions) {\n this[name as keyof PropertyObjectState] = newOptions[name as keyof PropertyObjectState];\n }\n return this;\n }\n /**\n * the number of values.\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.length);\n // 3\n */\n public size() {\n return this.value.length;\n }\n /**\n * retrieve one of values at the index\n * @param {Number} index - index\n * @return {Object} one of values at the index\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.get(0));\n // 1\n */\n public get(index: number) {\n return this.value[index];\n }\n /**\n * Set the value at that index\n * @param {Number} index - index\n * @param {Object} value - text, a number, object to set\n * @return {PropertyObject} An instance itself\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n obj1.set(0, 2);\n console.log(obj1.toValue());\n // 2,2,3\n */\n public set(index: number, value: any) {\n this.value[index] = value;\n return this;\n }\n /**\n * create a copy of an instance itself.\n * @return {PropertyObject} clone\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n const obj2 = obj1.clone();\n */\n public clone(): PropertyObject {\n const {\n separator,\n prefix,\n suffix,\n model,\n type,\n } = this;\n const arr = this.value.map(v => ((v instanceof PropertyObject) ? v.clone() : v));\n return new PropertyObject(arr, {\n separator,\n prefix,\n suffix,\n model,\n type,\n });\n }\n /**\n * Make Property Object to String\n * @return {String} Make Property Object to String\n * @example\n //rgba(100, 100, 100, 0.5)\n const obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\",\n });\n console.log(obj4.toValue());\n // \"rgba(100,100,100,0.5)\"\n */\n public toValue(): string {\n return this.prefix + this.join() + this.suffix;\n }\n /**\n * Make Property Object's array to String\n * @return {String} Join the elements of an array into a string\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n obj4.join(); // => \"100,100,100,0.5\"\n */\n public join() {\n return this.value.map(v => ((v instanceof PropertyObject) ? v.toValue() : v)).join(this.separator);\n }\n /**\n * executes a provided function once per array element.\n * @param {Function} callback - Function to execute for each element, taking three arguments\n * @param {All} [callback.currentValue] The current element being processed in the array.\n * @param {Number} [callback.index] The index of the current element being processed in the array.\n * @param {Array} [callback.array] the array.\n * @return {PropertyObject} An instance itself\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document.\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n\n obj4.forEach(t => {\n console.log(t);\n }); // => \"100,100,100,0.5\"\n */\n public forEach(func: (value?: any, index?: number, array?: any[]) => void) {\n this.value.forEach(func);\n return this;\n }\n}\nexport default PropertyObject;\n","/**\n* @namespace\n* @name Property\n*/\n\nimport PropertyObject from \"../PropertyObject\";\nimport {\n COLOR_MODELS, isString,\n splitComma, splitSpace, stringToRGBA,\n RGBA, splitBracket, IObject, isArray, splitText\n} from \"@daybrush/utils\";\nimport { NameType } from \"../types\";\n\nexport function splitStyle(str: string) {\n\n const properties = splitText(str, \";\");\n const obj: IObject = {};\n const totalLength = properties.length;\n let length = totalLength;\n\n for (let i = 0; i < totalLength; ++i) {\n const matches = splitText(properties[i], \":\");\n\n if (matches.length < 2 || !matches[1]) {\n --length;\n continue;\n }\n obj[matches[0].trim()] = toPropertyObject(matches[1].trim());\n }\n return { styles: obj, length };\n}\n/**\n* convert array to PropertyObject[type=color].\n* default model \"rgba\"\n* @memberof Property\n* @function arrayToColorObject\n* @param {Array|PropertyObject} value ex) [0, 0, 0, 1]\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\narrayToColorObject([0, 0, 0])\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0, 1], separator=\",\")\n*/\nexport function arrayToColorObject(arr: number[]) {\n const model = RGBA;\n\n if (arr.length === 3) {\n arr[3] = 1;\n }\n return new PropertyObject(arr, {\n model,\n separator: \",\",\n type: \"color\",\n prefix: `${model}(`,\n suffix: \")\",\n });\n}\n/**\n* convert text with parentheses to object.\n* @memberof Property\n* @function stringToBracketObject\n* @param {String} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject\n* @example\nstringToBracketObject(\"abcde(0, 0, 0,1)\")\n// => PropertyObject(model=\"abcde\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToBracketObject(text: string) {\n // [prefix, value, other]\n const { prefix: model, value, suffix: afterModel } = splitBracket(text);\n\n if (typeof value === \"undefined\") {\n return text;\n }\n if (COLOR_MODELS.indexOf(model) > -1) {\n return arrayToColorObject(stringToRGBA(text));\n }\n // divide comma(,)\n const obj = toPropertyObject(value, model);\n\n let arr = [value];\n let separator = \",\";\n let prefix = `${model}(`;\n let suffix = `)${afterModel}`;\n\n if (obj instanceof PropertyObject) {\n separator = obj.separator;\n arr = obj.value;\n prefix += obj.prefix;\n suffix = obj.suffix + suffix;\n }\n return new PropertyObject(arr, {\n separator,\n model,\n prefix,\n suffix,\n });\n}\n\nexport function arrayToPropertyObject(arr: any[], separator: string) {\n return new PropertyObject(arr, {\n type: \"array\",\n separator,\n });\n}\n\n/**\n* convert text with parentheses to PropertyObject[type=color].\n* If the values are not RGBA model, change them RGBA mdoel.\n* @memberof Property\n* @function stringToColorObject\n* @param {String|PropertyObject} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\nstringToColorObject(\"rgba(0, 0, 0,1)\")\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToColorObject(value: string): string | PropertyObject {\n const result = stringToRGBA(value);\n\n return result ? arrayToColorObject(result) : value;\n}\n/**\n* convert CSS Value to PropertyObject\n* @memberof Property\n* @function toPropertyObject\n* @param {String} value it's text contains the array.\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @see referenced regular expression {@link http://stackoverflow.com/questions/20215440/parse-css-gradient-rule-with-javascript-regex}\n* @example\ntoPropertyObject(\"1px solid #000\");\n// => PropertyObject([\"1px\", \"solid\", rgba(0, 0, 0, 1)])\n*/\nexport function toPropertyObject(value: any[], model?: NameType): PropertyObject;\nexport function toPropertyObject(value: IObject, model?: NameType): IObject;\nexport function toPropertyObject(value: string, model?: NameType): PropertyObject | string;\nexport function toPropertyObject(value: string | IObject | any[], model?: NameType) {\n if (!isString(value)) {\n if (isArray(value)) {\n return arrayToPropertyObject(value, \",\");\n }\n return value;\n }\n let values: any = splitComma(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \",\");\n }\n values = splitSpace(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \" \");\n }\n values = /^(['\"])([^'\"]*)(['\"])$/g.exec(value);\n\n if (values && values[1] === values[3]) {\n // Quotes\n return new PropertyObject([toPropertyObject(values[2])], {\n prefix: values[1],\n suffix: values[1],\n });\n } else if (value.indexOf(\"(\") !== -1) {\n // color\n return stringToBracketObject(value);\n } else if (value.charAt(0) === \"#\" && model !== \"url\") {\n return stringToColorObject(value);\n }\n return value;\n}\nexport function toObject(object: PropertyObject, result: IObject = {}) {\n const model = object.model;\n\n if (model) {\n object.setOptions({\n model: \"\",\n suffix: \"\",\n prefix: \"\",\n });\n const value = object.size() > 1 ? object : object.get(0);\n\n result[model] = value;\n } else {\n object.forEach(obj => {\n toObject(obj, result);\n });\n }\n return result;\n}\n","import {\n ROLES, MAXIMUM, FIXED, ALIAS,\n PAUSED, RUNNING, PLAY, ENDED, PREFIX, PLAY_CSS, CURRENT_TIME, START_ANIMATION, EASINGS, NAME_SEPARATOR\n} from \"./consts\";\nimport PropertyObject from \"./PropertyObject\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport {\n isArray, ANIMATION, ARRAY, OBJECT,\n PROPERTY, STRING, NUMBER, IS_WINDOW, IObject, $, document, isObject, addEvent, removeEvent, isString,\n} from \"@daybrush/utils\";\nimport { EasingType, EasingFunction, NameType } from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\nimport { bezier, steps } from \"./easing\";\n\nexport function isPropertyObject(value: any): value is PropertyObject {\n return value instanceof PropertyObject;\n}\nexport function setAlias(name: string, alias: string[]) {\n ALIAS[name] = alias;\n}\nexport function setRole(names: string[], isProperty?: boolean, isFixedProperty?: boolean) {\n const length = names.length;\n let roles: any = ROLES;\n let fixed: any = FIXED;\n\n for (let i = 0; i < length - 1; ++i) {\n !roles[names[i]] && (roles[names[i]] = {});\n roles = roles[names[i]];\n if (isFixedProperty) {\n !fixed[names[i]] && (fixed[names[i]] = {});\n fixed = fixed[names[i]];\n }\n }\n isFixedProperty && (fixed[names[length - 1]] = true);\n roles[names[length - 1]] = isProperty ? true : {};\n}\nexport function getType(value: any) {\n const type = typeof value;\n\n if (type === OBJECT) {\n if (isArray(value)) {\n return ARRAY;\n } else if (isPropertyObject(value)) {\n return PROPERTY;\n }\n } else if (type === STRING || type === NUMBER) {\n return \"value\";\n }\n return type;\n}\nexport function isPureObject(obj: any): obj is object {\n return isObject(obj) && obj.constructor === Object;\n}\nexport function getNames(names: IObject, stack: string[]) {\n let arr: string[][] = [];\n\n if (isPureObject(names)) {\n for (const name in names) {\n stack.push(name);\n arr = arr.concat(getNames(names[name], stack));\n stack.pop();\n }\n } else {\n arr.push(stack.slice());\n }\n return arr;\n}\nexport function updateFrame(names: IObject, properties: IObject) {\n for (const name in properties) {\n const value = properties[name];\n\n if (!isPureObject(value)) {\n names[name] = true;\n continue;\n }\n if (!isObject(names[name])) {\n names[name] = {};\n }\n updateFrame(names[name], properties[name]);\n }\n return names;\n}\nexport function toFixed(num: number) {\n return Math.round(num * MAXIMUM) / MAXIMUM;\n}\nexport function getValueByNames(\n names: Array,\n properties: IObject, length: number = names.length) {\n let value = properties;\n\n for (let i = 0; i < length; ++i) {\n if (!isObject(value) || value == null) {\n return undefined;\n }\n value = value[names[i]];\n }\n return value;\n}\nexport function isInProperties(roles: IObject, args: NameType[], isCheckTrue?: boolean) {\n const length = args.length;\n let role: any = roles;\n\n if (length === 0) {\n return false;\n }\n for (let i = 0; i < length; ++i) {\n if (role === true) {\n return false;\n }\n role = role[args[i]];\n if (!role || (!isCheckTrue && role === true)) {\n return false;\n }\n }\n return true;\n}\nexport function isRole(args: NameType[], isCheckTrue?: boolean) {\n return isInProperties(ROLES, args, isCheckTrue);\n}\nexport function isFixed(args: NameType[]) {\n return isInProperties(FIXED, args, true);\n}\n\nexport interface IterationInterface {\n currentTime: number;\n iterationCount: number;\n elapsedTime: number;\n}\nexport function setPlayCSS(item: Scene | SceneItem, isActivate: boolean) {\n item.state[PLAY_CSS] = isActivate;\n}\nexport function isPausedCSS(item: Scene | SceneItem) {\n return item.state[PLAY_CSS] && item.isPaused();\n}\nexport function isEndedCSS(item: Scene | SceneItem) {\n return !item.isEnded() && item.state[PLAY_CSS];\n}\n\nexport function makeId(selector?: boolean) {\n for (; ;) {\n const id = `${Math.floor(Math.random() * 10000000)}`;\n\n if (!IS_WINDOW || !selector) {\n return id;\n }\n const checkElement = $(`[data-scene-id=\"${id}\"]`);\n\n if (!checkElement) {\n return id;\n }\n }\n}\nexport function getRealId(item: Scene | SceneItem) {\n return item.getId() || item.setId(makeId(false)).getId();\n}\nexport function toId(text: number | string) {\n return `${text}`.match(/[0-9a-zA-Z]+/g).join(\"\");\n}\nexport function playCSS(\n item: Scene | SceneItem, isExportCSS?: boolean,\n playClassName?: string, properties: object = {}) {\n if (!ANIMATION || item.getPlayState() === RUNNING) {\n return;\n }\n const className = playClassName || START_ANIMATION;\n\n if (isPausedCSS(item)) {\n item.addPlayClass(true, className, properties);\n } else {\n if (item.isEnded()) {\n item.setTime(0);\n }\n isExportCSS && item.exportCSS({ className });\n const el = item.addPlayClass(false, className, properties);\n\n if (!el) {\n return;\n }\n addAnimationEvent(item, el);\n setPlayCSS(item, true);\n }\n item.setPlayState(RUNNING);\n}\n\nexport function addAnimationEvent(item: Scene | SceneItem, el: Element) {\n const state = item.state;\n const duration = item.getDuration();\n const isZeroDuration = !duration || !isFinite(duration);\n const animationend = () => {\n setPlayCSS(item, false);\n item.finish();\n };\n const animationstart = () => {\n item.trigger(PLAY);\n\n addEvent(el, \"animationcancel\", animationend);\n addEvent(el, \"animationend\", animationend);\n addEvent(el, \"animationiteration\", animationiteration);\n };\n item.once(ENDED, () => {\n removeEvent(el, \"animationcancel\", animationend);\n removeEvent(el, \"animationend\", animationend);\n removeEvent(el, \"animationiteration\", animationiteration);\n removeEvent(el, \"animationstart\", animationstart);\n });\n const animationiteration = ({ elapsedTime }: any) => {\n const currentTime = elapsedTime;\n const iterationCount = isZeroDuration ? 0 : (currentTime / duration);\n\n state[CURRENT_TIME] = currentTime;\n item.setIteration(iterationCount);\n };\n addEvent(el, \"animationstart\", animationstart);\n}\n\nexport function getEasing(curveArray: string | number[] | EasingFunction): EasingType {\n let easing: EasingType;\n\n if (isString(curveArray)) {\n if (curveArray in EASINGS) {\n easing = EASINGS[curveArray];\n } else {\n const obj = toPropertyObject(curveArray);\n\n if (isString(obj)) {\n return 0;\n } else {\n if (obj.model === \"cubic-bezier\") {\n curveArray = obj.value.map(v => parseFloat(v));\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else if (obj.model === \"steps\") {\n easing = steps(parseFloat(obj.value[0]), obj.value[1]);\n } else {\n return 0;\n }\n }\n }\n } else if (isArray(curveArray)) {\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else {\n easing = curveArray;\n }\n\n return easing;\n}\n\nexport function getFullName(names: NameType[]) {\n return names.join(NAME_SEPARATOR);\n}\n","import {\n THRESHOLD,\n ALTERNATE, ALTERNATE_REVERSE, REVERSE, INFINITE, NORMAL,\n ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED,\n DURATION, EASING, ITERATION_TIME, EASING_NAME, PAUSED,\n RUNNING, PLAY, TIMEUPDATE, ENDED, PLAY_STATE, PREV_TIME, TICK_TIME, CURRENT_TIME, ITERATION, OPTIONS, EASINGS\n} from \"./consts\";\nimport EventTrigger from \"./EventTrigger\";\nimport { bezier, steps } from \"./easing\";\nimport { toFixed, getEasing } from \"./utils\";\nimport { splitUnit, isString, camelize, requestAnimationFrame, isArray, cancelAnimationFrame } from \"@daybrush/utils\";\nimport {\n IterationCountType, DirectionType, AnimatorState,\n EasingFunction, FillModeType, PlayStateType, EasingType, AnimatorOptions,\n} from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\n\nfunction GetterSetter {}>(\n getter: string[], setter: string[], parent: string) {\n return (constructor: T) => {\n const prototype = constructor.prototype;\n\n getter.forEach(name => {\n prototype[camelize(`get ${name}`)] = function() {\n return this[parent][name];\n };\n });\n setter.forEach(name => {\n prototype[camelize(`set ${name}`)] = function(value: any) {\n this[parent][name] = value;\n return this;\n };\n });\n };\n}\nexport function isDirectionReverse(iteration: number, iteraiontCount: IterationCountType, direction: DirectionType) {\n if (direction === REVERSE) {\n return true;\n } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) {\n return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE);\n }\n return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE);\n}\n/**\n* @typedef {Object} AnimatorState The Animator options. Properties used in css animation.\n* @property {number} [duration] The duration property defines how long an animation should take to complete one cycle.\n* @property {\"none\"|\"forwards\"|\"backwards\"|\"both\"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both).\n* @property {\"infinite\"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played.\n* @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation.\n* @property {number} [delay] The delay property specifies a delay for the start of an animation.\n* @property {\"normal\"|\"reverse\"|\"alternate\"|\"alternate-reverse\"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles.\n*/\n\nconst setters = [\"id\", ITERATION_COUNT, DELAY, FILL_MODE,\n DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE];\nconst getters = [...setters, EASING, EASING_NAME];\n\n/**\n* play video, animation, the others\n* @extends EventTrigger\n* @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n*/\n@GetterSetter(getters, setters, \"state\")\nclass Animator\n extends EventTrigger {\n public state: U;\n private timerId: number = 0;\n\n /**\n * @param - animator's options\n * @example\n const animator = new Animator({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n constructor(options?: Partial) {\n super();\n this.state = {\n id: \"\",\n easing: 0,\n easingName: \"linear\",\n iterationCount: 1,\n delay: 0,\n fillMode: \"forwards\",\n direction: NORMAL,\n playSpeed: 1,\n currentTime: 0,\n iterationTime: -1,\n iteration: 0,\n tickTime: 0,\n prevTime: 0,\n playState: PAUSED,\n duration: 0,\n } as U;\n this.setOptions(options);\n }\n /**\n * set animator's easing.\n * @param curverArray - The speed curve of an animation.\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n public setEasing(curveArray: string | number[] | EasingFunction): this {\n const easing: EasingType = getEasing(curveArray);\n const easingName = easing && easing[EASING_NAME] || \"linear\";\n const state = this.state;\n\n state[EASING] = easing;\n state[EASING_NAME] = easingName;\n return this;\n }\n /**\n * set animator's options.\n * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n * @param - animator's options\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.eaasing.EASE,\n });\n */\n public setOptions(options: Partial = {}): this {\n for (const name in options) {\n const value = options[name];\n\n if (name === EASING) {\n this.setEasing(value);\n continue;\n } else if (name === DURATION) {\n value && this.setDuration(value);\n continue;\n }\n if (OPTIONS.indexOf(name as any) > -1) {\n this.state[name] = value;\n }\n }\n\n return this;\n }\n /**\n * Get the animator's total duration including delay\n * @return {number} Total duration\n * @example\n animator.getTotalDuration();\n */\n public getTotalDuration(): number {\n return this.getActiveDuration(true);\n }\n /**\n * Get the animator's total duration excluding delay\n * @return {number} Total duration excluding delay\n * @example\n animator.getActiveDuration();\n */\n public getActiveDuration(delay?: boolean): number {\n const state = this.state;\n const count = state[ITERATION_COUNT];\n if (count === INFINITE) {\n return Infinity;\n }\n return (delay ? state[DELAY] : 0) + this.getDuration() * count;\n }\n /**\n * Check if the animator has reached the end.\n * @return {boolean} ended\n * @example\n animator.isEnded(); // true or false\n */\n public isEnded(): boolean {\n if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) {\n return true;\n } else if (this.getTime() < this.getActiveDuration()) {\n return false;\n }\n return true;\n }\n /**\n *Check if the animator is paused:\n * @return {boolean} paused\n * @example\n animator.isPaused(); // true or false\n */\n public isPaused(): boolean {\n return this.state[PLAY_STATE] === PAUSED;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const state = this.state;\n\n state[PLAY_STATE] = RUNNING;\n if (state[TICK_TIME] >= delay) {\n /**\n * This event is fired when play animator.\n * @event Animator#play\n */\n this.trigger(PLAY);\n return true;\n }\n return false;\n }\n /**\n * play animator\n * @return {Animator} An instance itself.\n */\n public play(toTime?: number) {\n const state = this.state;\n const delay = state[DELAY];\n const currentTime = this.getTime();\n\n state[PLAY_STATE] = RUNNING;\n\n if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) {\n this.setTime(-delay, true);\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n state[PREV_TIME] = time;\n this.tick(time, toTime);\n });\n this.start();\n return this;\n }\n /**\n * pause animator\n * @return {Animator} An instance itself.\n */\n public pause(): this {\n const state = this.state;\n\n if (state[PLAY_STATE] !== PAUSED) {\n state[PLAY_STATE] = PAUSED;\n /**\n * This event is fired when animator is paused.\n * @event Animator#paused\n */\n this.trigger(PAUSED);\n }\n cancelAnimationFrame(this.timerId);\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public finish() {\n this.setTime(0);\n this.state[TICK_TIME] = 0;\n this.end();\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public end() {\n this.pause();\n /**\n * This event is fired when animator is ended.\n * @event Animator#ended\n */\n this.trigger(ENDED);\n return this;\n }\n /**\n * set currentTime\n * @param {Number|String} time - currentTime\n * @return {Animator} An instance itself.\n * @example\n\n animator.setTime(\"from\"); // 0\n animator.setTime(\"to\"); // 100%\n animator.setTime(\"50%\");\n animator.setTime(10);\n animator.getTime() // 10\n */\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean) {\n const activeDuration = this.getActiveDuration();\n const state = this.state;\n const prevTime = state[TICK_TIME];\n const delay = state[DELAY];\n let currentTime = isTick ? (time as number) : this.getUnitTime(time);\n\n state[TICK_TIME] = delay + currentTime;\n if (currentTime < 0) {\n currentTime = 0;\n } else if (currentTime > activeDuration) {\n currentTime = activeDuration;\n }\n state[CURRENT_TIME] = currentTime;\n this.calculate();\n\n if (isTick && !isParent) {\n const tickTime = state[TICK_TIME];\n\n if (prevTime < delay && time >= 0) {\n this.start(0);\n }\n if (tickTime < prevTime || this.isEnded()) {\n this.end();\n return;\n }\n }\n if (this.isDelay()) {\n return this;\n }\n /**\n * This event is fired when the animator updates the time.\n * @event Animator#timeupdate\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(TIMEUPDATE, {\n currentTime,\n time: this.getIterationTime(),\n iterationCount: state[ITERATION],\n });\n\n return this;\n }\n /**\n * Get the animator's current time\n * @return {number} current time\n * @example\n animator.getTime();\n */\n public getTime(): number {\n return this.state[CURRENT_TIME];\n }\n public getUnitTime(time: string | number) {\n if (isString(time)) {\n const duration = this.getDuration() || 100;\n\n if (time === \"from\") {\n return 0;\n } else if (time === \"to\") {\n return duration;\n }\n const { unit, value } = splitUnit(time);\n\n if (unit === \"%\") {\n !this.getDuration() && (this.setDuration(duration));\n return toFixed(parseFloat(time) / 100 * duration);\n } else if (unit === \">\") {\n return value + THRESHOLD;\n } else {\n return value;\n }\n } else {\n return toFixed(time);\n }\n }\n /**\n * Check if the current state of animator is delayed.\n * @return {boolean} check delay state\n */\n public isDelay() {\n const state = this.state;\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n\n return delay > 0 && (tickTime < delay);\n }\n public setIteration(iterationCount: number): this {\n const state = this.state;\n const passIterationCount = Math.floor(iterationCount);\n const maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT];\n\n if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) {\n /**\n * The event is fired when an iteration of an animation ends.\n * @event Animator#iteration\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(\"iteration\", {\n currentTime: state[CURRENT_TIME],\n iterationCount: passIterationCount,\n });\n }\n state[ITERATION] = iterationCount;\n return this;\n }\n protected calculate() {\n const state = this.state;\n const iterationCount = state[ITERATION_COUNT];\n const fillMode = state[FILL_MODE];\n const direction = state[DIRECTION];\n const duration = this.getDuration();\n const time = this.getTime();\n const iteration = duration === 0 ? 0 : time / duration;\n let currentIterationTime = duration ? time % duration : 0;\n\n if (!duration) {\n this.setIterationTime(0);\n return this;\n }\n this.setIteration(iteration);\n\n // direction : normal, reverse, alternate, alternate-reverse\n // fillMode : forwards, backwards, both, none\n const isReverse = isDirectionReverse(iteration, iterationCount, direction);\n\n const isFiniteDuration = isFinite(duration);\n if (isFiniteDuration && isReverse) {\n currentIterationTime = duration - currentIterationTime;\n }\n if (isFiniteDuration && iterationCount !== INFINITE) {\n const isForwards = fillMode === \"both\" || fillMode === \"forwards\";\n\n // fill forwards\n if (iteration >= iterationCount) {\n currentIterationTime = duration * (isForwards ? (iterationCount % 1) || 1 : 0);\n isReverse && (currentIterationTime = duration - currentIterationTime);\n }\n }\n this.setIterationTime(currentIterationTime);\n return this;\n }\n private tick(now: number, to?: number) {\n if (this.isPaused()) {\n return;\n }\n const state = this.state;\n const playSpeed = state[PLAY_SPEED];\n const prevTime = state[PREV_TIME];\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n const currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed;\n\n state[PREV_TIME] = now;\n this.setTime(currentTime - delay, true);\n if (to && to * 1000 < now) {\n this.pause();\n }\n if (state[PLAY_STATE] === PAUSED) {\n return;\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n this.tick(time, to);\n });\n }\n}\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#setId\n * @param {number | string} - String or number of id to be set in the animator\n * @return {Animator} An instance itself.\n */\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#getId\n * @return {number | string} the indicator of the item.\n */\n/**\n * Get a delay for the start of an animation.\n * @method Animator#getDelay\n * @return {number} delay\n */\n/**\n * Set a delay for the start of an animation.\n * @method Animator#setDelay\n * @param {number} delay - delay\n * @return {Animator} An instance itself.\n */\n/**\n * Get fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#getFillMode\n * @return {FillModeType} fillMode\n */\n/**\n * Set fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#setFillMode\n * @param {FillModeType} fillMode - fillMode\n * @return {Animator} An instance itself.\n */\n/**\n * Get the number of times an animation should be played.\n * @method Animator#getIterationCount\n * @return {IterationCountType} iterationCount\n */\n/**\n * Set the number of times an animation should be played.\n * @method Animator#setIterationCount\n * @param {IterationCountType} iterationCount - iterationCount\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#getDirection\n * @return {DirectionType} direction\n */\n/**\n * Set whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#setDirection\n * @param {DirectionType} direction - direction\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether the animation is running or paused.\n * @method Animator#getPlayState\n * @return {PlayStateType} playState\n */\n/**\n * Set whether the animation is running or paused.\n * @method Animator#setPlayState\n * @param {PlayStateType} playState - playState\n * @return {Animator} An instance itself.\n */\n/**\n * Get the animator's play speed\n * @method Animator#getPlaySpeed\n * @return {number} playSpeed\n */\n/**\n * Set the animator's play speed\n * @method Animator#setPlaySpeed\n * @param {number} playSpeed - playSpeed\n * @return {Animator} An instance itself.\n */\n/**\n * Get how long an animation should take to complete one cycle.\n * @method Animator#getDuration\n * @return {number} duration\n */\n/**\n * Set how long an animation should take to complete one cycle.\n * @method Animator#setDuration\n * @param {number} duration - duration\n * @return {Animator} An instance itself.\n */\n/**\n * Get the speed curve of an animation.\n * @method Animator#getEasing\n * @return {EasingType} easing\n */\n/**\n * Get the speed curve's name\n * @method Animator#getEasingName\n * @return {string} the curve's name.\n */\n/**\n\t* Get the animator's current iteration time\n\t* @method Animator#getIterationTime\n\t* @return {number} current iteration time\n\t* @example\nanimator.getIterationTime();\n\t*/\n\n// tslint:disable-next-line:interface-name\ninterface Animator {\n setId(id: number | string): this;\n getId(): number | string;\n getIterationTime(): number;\n setIterationTime(time: number): this;\n setDelay(delay: number): this;\n getDelay(): number;\n setFillMode(fillMode: FillModeType): this;\n getFillMode(): FillModeType;\n setIterationCount(iterationCount: IterationCountType): this;\n getIterationCount(): IterationCountType;\n setDirection(direction: DirectionType): this;\n getDirection(): DirectionType;\n setPlayState(playState: PlayStateType): this;\n getPlayState(): PlayStateType;\n setPlaySpeed(playSpeed: number): this;\n getPlaySpeed(): number;\n setDuration(duration: number): this;\n getDuration(): number;\n getEasing(): EasingType;\n getEasingName(): string;\n}\nexport default Animator;\n","import {\n ALIAS, TIMING_FUNCTION, TRANSFORM_NAME, EASING_NAME, NAME_SEPARATOR\n} from \"./consts\";\nimport { isRole, getType, isPropertyObject, getValueByNames, isFixed, getNames, getEasing, getFullName } from \"./utils\";\nimport { toPropertyObject, splitStyle, toObject } from \"./utils/property\";\nimport {\n isObject, isArray, isString, getKeys,\n ANIMATION, TRANSFORM, FILTER, PROPERTY, FUNCTION, ARRAY, OBJECT, IObject, isUndefined,\n sortOrders,\n} from \"@daybrush/utils\";\nimport { NameType, KeyValueChildren } from \"./types\";\nimport OrderMap from \"order-map\";\n\nfunction toInnerProperties(obj: IObject, orders: NameType[] = []) {\n if (!obj) {\n return \"\";\n }\n const arrObj = [];\n\n const keys = getKeys(obj);\n\n sortOrders(keys, orders);\n\n keys.forEach(name => {\n arrObj.push(`${name.replace(/\\d$/g, \"\")}(${obj[name]})`);\n });\n\n return arrObj.join(\" \");\n}\n\n/* eslint-disable */\nfunction clone(target: IObject, toValue = false) {\n return merge({}, target, toValue);\n}\nfunction merge(to: IObject, from: IObject, toValue = false) {\n for (const name in from) {\n const value = from[name];\n const type = getType(value);\n\n if (type === PROPERTY) {\n to[name] = toValue ? value.toValue() : value.clone();\n } else if (type === FUNCTION) {\n to[name] = toValue ? getValue([name], value) : value;\n } else if (type === ARRAY) {\n to[name] = value.slice();\n } else if (type === OBJECT) {\n if (isObject(to[name]) && !isPropertyObject(to[name])) {\n merge(to[name], value, toValue);\n } else {\n to[name] = clone(value, toValue);\n }\n } else {\n to[name] = from[name];\n }\n }\n return to;\n}\n/* eslint-enable */\n\nfunction getPropertyName(args: NameType[]) {\n return args[0] in ALIAS ? ALIAS[args[0]] : args;\n}\nfunction getValue(names: NameType[], value: any): any {\n const type = getType(value);\n\n if (type === PROPERTY) {\n return value.toValue();\n } else if (type === FUNCTION) {\n if (names[0] !== TIMING_FUNCTION) {\n return getValue(names, value());\n }\n } else if (type === OBJECT) {\n return clone(value, true);\n }\n return value;\n}\n/**\n* Animation's Frame\n*/\nclass Frame {\n public properties: IObject = {};\n public orderMap: OrderMap = new OrderMap(NAME_SEPARATOR);\n /**\n * @param - properties\n * @example\n const frame = new Scene.Frame({\n display: \"none\"\n transform: {\n translate: \"50px\",\n scale: \"5, 5\",\n }\n });\n */\n constructor(properties: any = {}) {\n this.properties = {};\n // this.orders = [];\n this.set(properties);\n }\n /**\n * get property value\n * @param {...Number|String|PropertyObject} args - property name or value\n * @example\n frame.get(\"display\") // => \"none\", \"block\", ....\n frame.get(\"transform\", \"translate\") // => \"10px,10px\"\n */\n public get(...args: NameType[]) {\n const value = this.raw(...args);\n\n return getValue(getPropertyName(args), value);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n frame.getOrders([\"display\"]) // => []\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n return this.orderMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n frame.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n return this.orderMap.set(names, orders);\n }\n /**\n * get properties order object\n * @example\n console.log(frame.getOrderObject());\n */\n public getOrderObject() {\n return this.orderMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n frame.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.orderMap.setObject(obj);\n }\n\n /**\n * get property keys\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [\"translate\"]\n */\n public getKeys(...args: NameType[]): string[] {\n const value = this.raw(...args);\n const keys = getType(value) === OBJECT ? getKeys(value) : [];\n\n sortOrders(keys, this.orderMap.get(args));\n return keys;\n }\n /**\n * get properties array\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [{ key: \"translate\", value: \"10px, 10px\", children: [] }]\n */\n public gets(...args: NameType[]): KeyValueChildren[] {\n const values = this.get(...args);\n const keys = this.getKeys(...args);\n\n return keys.map(key => {\n const nextValue = values[key];\n return { key, value: nextValue, children: this.gets(...args, key) };\n });\n }\n\n public raw(...args: NameType[]) {\n return getValueByNames(getPropertyName(args), this.properties);\n }\n /**\n * remove property value\n * @param {...String} args - property name\n * @return {Frame} An instance itself\n * @example\n frame.remove(\"display\")\n */\n public remove(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return this;\n }\n this.orderMap.remove(params);\n const value = getValueByNames(params, this.properties, length - 1);\n\n if (isObject(value)) {\n delete value[params[length - 1]];\n }\n return this;\n }\n /**\n * set property\n * @param {...Number|String|PropertyObject} args - property names or values\n * @return {Frame} An instance itself\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n filter: {\n brightness: \"50%\",\n grayscale: \"100%\"\n }\n });\n\n // two parameters\n frame.set(\"transform\", {\n translate: \"10px, 10px\",\n scale: \"1\",\n });\n\n // three parameters\n frame.set(\"transform\", \"translate\", \"50px\");\n */\n public set(...args: any[]) {\n const self = this;\n const length = args.length;\n const params = args.slice(0, -1);\n const value = args[length - 1];\n const firstParam = params[0];\n\n if (length === 1 && value instanceof Frame) {\n self.merge(value);\n } else if (firstParam in ALIAS) {\n self._set(ALIAS[firstParam], value);\n } else if (length === 2 && isArray(firstParam)) {\n self._set(firstParam, value);\n } else if (isPropertyObject(value)) {\n if (isRole(params)) {\n self.set(...params, toObject(value));\n } else {\n self._set(params, value);\n }\n } else if (isArray(value)) {\n self._set(params, value);\n } else if (isObject(value)) {\n if (!self.has(...params) && isRole(params)) {\n self._set(params, {});\n }\n for (const name in value) {\n self.set(...params, name, value[name]);\n }\n } else if (isString(value)) {\n if (isRole(params, true)) {\n if (isFixed(params) || !isRole(params)) {\n this._set(params, value);\n } else {\n const obj = toPropertyObject(value);\n\n if (isObject(obj)) {\n self.set(...params, obj);\n }\n }\n return this;\n } else {\n const { styles, length: stylesLength } = splitStyle(value);\n\n for (const name in styles) {\n self.set(...params, name, styles[name]);\n }\n if (stylesLength) {\n return this;\n }\n }\n self._set(params, value);\n } else {\n self._set(params, value);\n }\n return self;\n }\n /**\n * Gets the names of properties.\n * @return the names of properties.\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n });\n\n // [[\"display\"], [\"transform\", \"translate\"], [\"transform\", \"scale\"]]\n console.log(frame.getNames());\n */\n public getNames(): string[][] {\n return getNames(this.properties, []);\n }\n /**\n * check that has property.\n * @param {...String} args - property name\n * @example\n frame.has(\"property\", \"display\") // => true or false\n */\n public has(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return false;\n }\n return !isUndefined(getValueByNames(params, this.properties, length));\n }\n /**\n * clone frame.\n * @return {Frame} An instance of clone\n * @example\n frame.clone();\n */\n public clone() {\n const frame = new Frame();\n\n frame.setOrderObject(this.orderMap.orderMap);\n return frame.merge(this);\n }\n /**\n * merge one frame to other frame.\n * @param - target frame.\n * @return {Frame} An instance itself\n * @example\n frame.merge(frame2);\n */\n public merge(frame: Frame) {\n const properties = this.properties;\n const frameProperties = frame.properties;\n\n if (frameProperties) {\n merge(properties, frameProperties);\n }\n return this;\n }\n /**\n * Specifies an css object that coverted the frame.\n * @return {object} cssObject\n */\n public toCSSObject() {\n const properties = this.get();\n const cssObject: IObject = {};\n\n for (const name in properties) {\n if (isRole([name], true)) {\n continue;\n }\n const value = properties[name];\n\n if (name === TIMING_FUNCTION) {\n cssObject[TIMING_FUNCTION.replace(\"animation\", ANIMATION)] =\n (isString(value) ? value : value[EASING_NAME]) || \"initial\";\n } else {\n cssObject[name] = value;\n }\n }\n const transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME]));\n const filter = toInnerProperties(properties.filter, this.orderMap.get([FILTER]));\n\n TRANSFORM && transform && (cssObject[TRANSFORM] = transform);\n FILTER && filter && (cssObject[FILTER] = filter);\n return cssObject;\n }\n /**\n * Specifies an css text that coverted the frame.\n * @return {string} cssText\n */\n public toCSS() {\n const cssObject = this.toCSSObject();\n const cssArray = [];\n const keys = getKeys(cssObject);\n\n sortOrders(keys, this.orderMap.get([]));\n keys.forEach(name => {\n cssArray.push(`${name}:${cssObject[name]};`);\n });\n return cssArray.join(\"\");\n }\n /**\n * Remove All Properties\n * @return {Frame} An instance itself\n */\n public clear() {\n this.properties = {};\n this.orderMap.clear();\n return this;\n }\n private _set(args: NameType[], value: any) {\n let properties = this.properties;\n const length = args.length;\n\n for (let i = 0; i < length - 1; ++i) {\n const name = args[i];\n\n !(name in properties) && (properties[name] = {});\n properties = properties[name];\n }\n if (!length) {\n return;\n }\n const lastParam = args[length - 1];\n\n this.orderMap.add(args);\n if (length === 1 && lastParam === TIMING_FUNCTION) {\n properties[lastParam] = getEasing(value);\n } else {\n properties[lastParam] = isString(value) && !isFixed(args)\n ? toPropertyObject(value, lastParam)\n : value;\n }\n }\n}\nexport default Frame;\n","\nimport PropertyObject from \"../PropertyObject\";\nimport { getType } from \"../utils\";\nimport { toPropertyObject } from \"./property\";\nimport { splitUnit, PROPERTY, FUNCTION, ARRAY, dot as dotNumber } from \"@daybrush/utils\";\nimport { EasingType } from \"../types\";\n\nfunction dotArray(a1: any[], a2: any, b1: number, b2: number): any {\n const length = a2.length;\n\n return a1.map((v1, i) => {\n if (i >= length) {\n return v1;\n } else {\n return dot(v1, a2[i], b1, b2);\n }\n });\n}\n\nfunction dotColor(color1: PropertyObject, color2: PropertyObject, b1: number, b2: number) {\n // convert array to PropertyObject(type=color)\n const value1 = color1.value;\n const value2 = color2.value;\n // If the model name is not same, the inner product is impossible.\n const model1 = color1.model;\n const model2 = color2.model;\n\n if (model1 !== model2) {\n // It is recognized as a string.\n return dot(color1.toValue(), color2.toValue(), b1, b2);\n }\n if (value1.length === 3) {\n value1[3] = 1;\n }\n if (value2.length === 3) {\n value2[3] = 1;\n }\n const v = dotArray(value1, value2, b1, b2);\n const colorModel = model1;\n\n for (let i = 0; i < 3; ++i) {\n v[i] = parseInt(v[i], 10);\n }\n const object = new PropertyObject(v, {\n type: \"color\",\n model: colorModel,\n prefix: `${colorModel}(`,\n suffix: \")\",\n });\n\n return object;\n}\n\nfunction dotObject(a1: PropertyObject, a2: PropertyObject, b1: number, b2: number) {\n const a1Type = a1.type;\n\n if (a1Type === \"color\") {\n return dotColor(a1, a2, b1, b2);\n }\n const value1 = a1.value;\n const value2 = a2.value;\n const arr = dotArray(value1, value2, b1, b2);\n\n return new PropertyObject(arr, {\n type: a1Type,\n separator: a1.separator || a2.separator,\n prefix: a1.prefix || a2.prefix,\n suffix: a1.suffix || a2.suffix,\n model: a1.model || a2.model,\n });\n}\n/**\n* The dot product of a1 and a2 for the b1 and b2.\n* @memberof Dot\n* @function dot\n* @param {String|Number|PropertyObject} a1 value1\n* @param {String|Number|PropertyObject} a2 value2\n* @param {Number} b1 b1 ratio\n* @param {Number} b2 b2 ratio\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @example\ndot(1, 3, 0.3, 0.7);\n// => 1.6\n*/\nexport function dot(a1: any, a2: any, b1: number, b2: number): any {\n if (b2 === 0) {\n return a2;\n } else if (b1 === 0 || b1 + b2 === 0) {\n // prevent division by zero.\n return a1;\n }\n // dot Object\n\n const type1 = getType(a1);\n const type2 = getType(a2);\n const isFunction1 = type1 === FUNCTION;\n const isFunction2 = type2 === FUNCTION;\n\n if (isFunction1 || isFunction2) {\n return () => {\n return dot(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2);\n };\n } else if (type1 === type2) {\n if (type1 === PROPERTY) {\n return dotObject(a1, a2, b1, b2);\n } else if (type1 === ARRAY) {\n return dotArray(a1, a2, b1, b2);\n } else if (type1 !== \"value\") {\n return a1;\n }\n } else {\n return a1;\n }\n const v1 = splitUnit(`${a1}`);\n const v2 = splitUnit(`${a2}`);\n let v;\n\n // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환\n if (isNaN(v1.value) || isNaN(v2.value)) {\n return a1;\n } else {\n v = dotNumber(v1.value, v2.value, b1, b2);\n }\n const prefix = v1.prefix || v2.prefix;\n const unit = v1.unit || v2.unit;\n\n if (!prefix && !unit) {\n return v;\n }\n return prefix + v + unit;\n}\n\nexport function dotValue(\n time: number,\n prevTime: number,\n nextTime: number,\n prevValue: any,\n nextValue: any,\n easing?: EasingType) {\n if (time === prevTime) {\n return prevValue;\n } else if (time === nextTime) {\n return nextValue;\n } else if (!easing) {\n return dot(prevValue, nextValue, time - prevTime, nextTime - time);\n }\n const ratio = easing((time - prevTime) / (nextTime - prevTime));\n const value = dot(prevValue, nextValue, ratio, 1 - ratio);\n\n return value;\n}\n","import Animator, { isDirectionReverse } from \"./Animator\";\nimport Frame from \"./Frame\";\nimport {\n toFixed,\n isFixed,\n playCSS,\n toId,\n getRealId,\n makeId,\n isPausedCSS,\n isRole,\n getValueByNames,\n isEndedCSS,\n setPlayCSS,\n getNames,\n updateFrame,\n} from \"./utils\";\nimport { dotValue } from \"./utils/dot\";\nimport {\n START_ANIMATION,\n PREFIX, THRESHOLD,\n TIMING_FUNCTION, ALTERNATE, ALTERNATE_REVERSE, INFINITE,\n REVERSE, EASING, FILL_MODE, DIRECTION, ITERATION_COUNT,\n EASING_NAME, DELAY, PLAY_SPEED, DURATION, PAUSE_ANIMATION,\n DATA_SCENE_ID, SELECTOR, ROLES, NAME_SEPARATOR\n} from \"./consts\";\nimport {\n isObject, isArray, isUndefined, decamelize,\n ANIMATION, fromCSS, addClass, removeClass, hasClass,\n KEYFRAMES, isFunction,\n IObject, $, splitComma, toArray, isString, IArrayFormat,\n dot as dotNumber,\n find,\n findIndex,\n getKeys,\n sortOrders,\n} from \"@daybrush/utils\";\nimport {\n NameType, AnimateElement, AnimatorState,\n SceneItemState, SceneItemOptions, EasingType, PlayCondition, DirectionType\n} from \"./types\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n\nfunction getNearTimeIndex(times: number[], time: number) {\n const length = times.length;\n\n for (let i = 0; i < length; ++i) {\n if (times[i] === time) {\n return [i, i];\n } else if (times[i] > time) {\n return [i > 0 ? i - 1 : 0, i];\n }\n }\n return [length - 1, length - 1];\n}\nfunction makeAnimationProperties(properties: object) {\n const cssArray = [];\n\n for (const name in properties) {\n cssArray.push(`${ANIMATION}-${decamelize(name)}:${properties[name]};`);\n }\n return cssArray.join(\"\");\n}\nfunction addTime(times: number[], time: number) {\n const length = times.length;\n for (let i = 0; i < length; ++i) {\n if (time < times[i]) {\n times.splice(i, 0, time);\n return;\n }\n }\n times[length] = time;\n}\nfunction addEntry(entries: number[][], time: number, keytime: number) {\n const prevEntry = entries[entries.length - 1];\n\n (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) &&\n entries.push([toFixed(time), toFixed(keytime)]);\n}\nexport function getEntries(times: number[], states: AnimatorState[]) {\n let entries = times.map(time => ([time, time]));\n let nextEntries = [];\n\n states.forEach(state => {\n const iterationCount = state[ITERATION_COUNT] as number;\n const delay = state[DELAY];\n const playSpeed = state[PLAY_SPEED];\n const direction = state[DIRECTION];\n const intCount = Math.ceil(iterationCount);\n const currentDuration = entries[entries.length - 1][0];\n const length = entries.length;\n const lastTime = currentDuration * iterationCount;\n\n for (let i = 0; i < intCount; ++i) {\n const isReverse =\n direction === REVERSE ||\n direction === ALTERNATE && i % 2 ||\n direction === ALTERNATE_REVERSE && !(i % 2);\n\n for (let j = 0; j < length; ++j) {\n const entry = entries[isReverse ? length - j - 1 : j];\n const time = entry[1];\n const currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]);\n const prevEntry = entries[isReverse ? length - j : j - 1];\n\n if (currentTime > lastTime) {\n if (j !== 0) {\n const prevTime = currentDuration * i +\n (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]);\n const divideTime = dotNumber(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime);\n\n addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime);\n }\n break;\n } else if (\n currentTime === lastTime\n && nextEntries.length\n && nextEntries[nextEntries.length - 1][0] === lastTime + delay\n ) {\n break;\n }\n addEntry(nextEntries, (delay + currentTime) / playSpeed, time);\n }\n }\n // delay time\n delay && nextEntries.unshift([0, nextEntries[0][1]]);\n\n entries = nextEntries;\n nextEntries = [];\n });\n\n return entries;\n}\n/**\n* manage Frame Keyframes and play keyframes.\n* @extends Animator\n* @example\nconst item = new SceneItem({\n\t0: {\n\t\tdisplay: \"none\",\n\t},\n\t1: {\n\t\tdisplay: \"block\",\n\t\topacity: 0,\n\t},\n\t2: {\n\t\topacity: 1,\n\t}\n});\n*/\nclass SceneItem extends Animator {\n public times: number[] = [];\n public items: IObject = {};\n public nameMap = new OrderMap(NAME_SEPARATOR);\n public elements: AnimateElement[] = [];\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: Frame;\n private needUpdate: boolean = true;\n private target: any;\n private targetFunc: (frame: Frame) => void;\n\n /**\n * @param - properties\n * @param - options\n * @example\n const item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n */\n constructor(properties?: any, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n const times = this.times;\n const length = times.length;\n\n return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION];\n }\n /**\n * get size of list\n * @return {Number} length of list\n */\n public size() {\n return this.times.length;\n }\n public setDuration(duration: number) {\n if (!duration) {\n return this;\n }\n const originalDuration = this.getDuration();\n\n if (originalDuration > 0) {\n const ratio = duration / originalDuration;\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(time => {\n const time2 = toFixed(time * ratio);\n\n obj[time2] = items[time];\n\n return time2;\n });\n this.items = obj;\n } else {\n this.newFrame(duration);\n }\n return this;\n }\n public setId(id?: number | string) {\n const state = this.state;\n const elements = this.elements;\n const length = elements.length;\n\n state.id = id || makeId(!!length);\n\n if (length && !state[SELECTOR]) {\n const sceneId = toId(this.getId());\n\n state[SELECTOR] = `[${DATA_SCENE_ID}=\"${sceneId}\"]`;\n elements.forEach(element => {\n element.setAttribute(DATA_SCENE_ID, sceneId);\n });\n }\n return this;\n }\n\n /**\n * Set properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.set(0, \"a\", \"b\") // item.getFrame(0).set(\"a\", \"b\")\n console.log(item.get(0, \"a\")); // \"b\"\n */\n public set(time: any, ...args: any[]) {\n if (time instanceof SceneItem) {\n return this.set(0, time);\n } else if (isArray(time)) {\n const length = time.length;\n\n for (let i = 0; i < length; ++i) {\n const t = length === 1 ? 0 : this.getUnitTime(`${i / (length - 1) * 100}%`);\n\n this.set(t, time[i]);\n }\n } else if (isObject(time)) {\n for (const t in time) {\n const value = time[t];\n\n splitComma(t).forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (isNaN(realTime)) {\n getNames(value, [eachTime]).forEach(names => {\n const innerValue = getValueByNames(names.slice(1), value);\n const arr = isArray(innerValue) ?\n innerValue : [getValueByNames(names, this.target), innerValue];\n const length = arr.length;\n\n for (let i = 0; i < length; ++i) {\n this.newFrame(`${i / (length - 1) * 100}%`).set(...names, arr[i]);\n }\n });\n } else {\n this.set(realTime, value);\n }\n });\n }\n } else if (!isUndefined(time)) {\n const value = args[0];\n\n splitComma(time + \"\").forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (value instanceof SceneItem) {\n const delay = value.getDelay();\n const frames = value.toObject(!this.hasFrame(realTime + delay));\n const duration = value.getDuration();\n const direction = value.getDirection();\n const isReverse = direction.indexOf(\"reverse\") > -1;\n\n for (const frameTime in frames) {\n const nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime);\n this.set(realTime + nextTime, frames[frameTime]);\n }\n } else if (args.length === 1 && isArray(value)) {\n value.forEach((item: any) => {\n this.set(realTime, item);\n });\n } else {\n const frame = this.newFrame(realTime);\n\n frame.set(...args);\n }\n });\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Get properties of the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} args property's name or properties\n * @return {Number|String|PropertyObejct} property value\n * @example\n item.get(0, \"a\"); // item.getFrame(0).get(\"a\");\n item.get(0, \"transform\", \"translate\"); // item.getFrame(0).get(\"transform\", \"translate\");\n */\n public get(time: string | number, ...args: NameType[]) {\n const frame = this.getFrame(time);\n\n return frame && frame.get(...args);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n item.getOrders([\"display\"]) // => []\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n this.needUpdate && this.update();\n\n return this.nameMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n item.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n this.needUpdate && this.update();\n\n const result = this.nameMap.set(names, orders);\n\n this.updateFrameOrders();\n\n return result;\n }\n /**\n * get properties order object\n * @example\n console.log(item.getOrderObject());\n */\n public getOrderObject() {\n return this.nameMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n item.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.nameMap.setObject(obj);\n\n this.updateFrameOrders();\n }\n public remove(time: string | number, ...args: any[]): this;\n /**\n * remove properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.remove(0, \"a\");\n */\n public remove(time: string | number, ...args: NameType[]) {\n if (args.length) {\n const frame = this.getFrame(time);\n\n frame && frame.remove(...args);\n } else {\n this.removeFrame(time);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Append the item or object at the last time.\n * @param - the scene item or item object\n * @return An instance itself\n * @example\n item.append(new SceneItem({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }));\n item.append({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n item.set(item.getDuration(), {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n */\n public append(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n this.set(this.getDuration(), item);\n } else {\n this.append(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push the front frames for the time and prepend the scene item or item object.\n * @param - the scene item or item object\n * @return An instance itself\n */\n public prepend(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n const unshiftTime = item.getDuration() + item.getDelay();\n const firstFrame = this.getFrame(0);\n // remove first frame\n this.removeFrame(0);\n this.unshift(unshiftTime);\n this.set(0, item);\n this.set(unshiftTime + THRESHOLD, firstFrame);\n } else {\n this.prepend(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push out the amount of time.\n * @param - time to push\n * @example\n item.get(0); // frame 0\n item.unshift(3);\n item.get(3) // frame 0\n */\n public unshift(time: number) {\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(t => {\n const time2 = toFixed(time + t);\n\n obj[time2] = items[t];\n return time2;\n });\n this.items = obj;\n return this;\n }\n /**\n * Get the frames in the item in object form.\n * @return {}\n * @example\n item.toObject();\n // {0: {display: \"none\"}, 1: {display: \"block\"}}\n */\n public toObject(isStartZero = true): IObject {\n const obj: IObject = {};\n const delay = this.getDelay();\n\n this.forEach((frame: Frame, time: number) => {\n obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone();\n });\n return obj;\n }\n /**\n * Specifies an element to synchronize items' keyframes.\n * @param {string} selectors - Selectors to find elements in items.\n * @return {SceneItem} An instance itself\n * @example\nitem.setSelector(\"#id.class\");\n */\n public setSelector(target: string | boolean | ((id: number | string) => string)) {\n if (isFunction(target)) {\n this.setElement(target(this.getId()));\n } else {\n this.setElement(target);\n }\n return this;\n }\n /**\n * Get the elements connected to SceneItem.\n */\n public getElements(): AnimateElement[] {\n return this.elements;\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElements(target: boolean | string | AnimateElement | IArrayFormat): this {\n return this.setElement(target);\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElement(target: boolean | string | AnimateElement | IArrayFormat) {\n const state = this.state;\n let elements: AnimateElement[] = [];\n\n if (!target) {\n return this;\n } else if (target === true || isString(target)) {\n const selector = target === true ? `${state.id}` : target;\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(selector);\n\n elements = toArray($(matches ? matches[1] : selector, true));\n state[SELECTOR] = selector;\n } else {\n elements = (target instanceof Element) ? [target] : toArray(target);\n }\n if (!elements.length) {\n return this;\n }\n this.elements = elements;\n this.setId(this.getId());\n this.target = elements[0].style;\n this.targetFunc = (frame: Frame) => {\n const attributes = frame.get(\"attribute\");\n\n if (attributes) {\n for (const name in attributes) {\n elements.forEach(el => {\n el.setAttribute(name, attributes[name]);\n });\n }\n }\n if (frame.has(\"html\")) {\n const html = frame.get(\"html\");\n\n elements.forEach(el => {\n el.innerHTML = html;\n });\n }\n const cssText = frame.toCSS();\n\n if (state.cssText !== cssText) {\n state.cssText = cssText;\n\n elements.forEach(el => {\n el.style.cssText += cssText;\n });\n return frame;\n }\n };\n return this;\n }\n public setTarget(target: any): this {\n this.target = target;\n this.targetFunc = (frame: Frame) => {\n const obj = frame.get();\n\n for (const name in obj) {\n target[name] = obj[name];\n }\n };\n return this;\n }\n /**\n * add css styles of items's element to the frame at that time.\n * @param {Array} properties - elements to synchronize item's keyframes.\n * @return {SceneItem} An instance itself\n * @example\n item.setElement(document.querySelector(\"#id.class\"));\n item.setCSS(0, [\"opacity\"]);\n item.setCSS(0, [\"opacity\", \"width\", \"height\"]);\n */\n public setCSS(time: number, properties: string[]) {\n this.set(time, fromCSS(this.elements, properties));\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frame = this.getNowFrame(iterationTime, easing);\n const currentTime = this.getTime();\n\n this.temp = frame;\n /**\n * This event is fired when timeupdate and animate.\n * @event SceneItem#animate\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Frame} param.frame frame of that time.\n */\n this.trigger(\"animate\", {\n frame,\n currentTime,\n time: iterationTime,\n });\n this.targetFunc && this.targetFunc(frame);\n return this;\n }\n /**\n * update property names used in frames.\n * @return {SceneItem} An instance itself\n * @example\n item.update();\n */\n public update() {\n const prevNameMap = this.nameMap;\n const names = {};\n this.forEach(frame => {\n updateFrame(names, frame.properties);\n });\n\n const nameMap = new OrderMap(NAME_SEPARATOR);\n\n function pushKeys(map: IObject, stack: NameType[]) {\n const keys = getKeys(map);\n\n sortOrders(keys, prevNameMap.get(stack));\n\n nameMap.set(stack, keys);\n keys.forEach(key => {\n const nextMap = map[key];\n if (isObject(nextMap)) {\n pushKeys(nextMap, [...stack, key]);\n }\n });\n }\n pushKeys(names, []);\n\n this.nameMap = nameMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap.orderMap);\n });\n this.needUpdate = false;\n return this;\n }\n /**\n * Create and add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {Frame} Created frame.\n * @example\n item.newFrame(time);\n */\n public newFrame(time: string | number) {\n let frame = this.getFrame(time);\n\n if (frame) {\n return frame;\n }\n frame = new Frame();\n\n this.setFrame(time, frame);\n return frame;\n }\n /**\n * Add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.setFrame(time, frame);\n */\n public setFrame(time: string | number, frame: Frame) {\n const realTime = this.getUnitTime(time);\n\n this.items[realTime] = frame;\n addTime(this.times, realTime);\n this.needUpdate = true;\n return this;\n }\n public getFrame(time: number | string, ...names: any[]): Frame;\n /**\n * get sceneItem's frame at that time\n * @param {Number} time - frame's time\n * @return {Frame} sceneItem's frame at that time\n * @example\n const frame = item.getFrame(time);\n */\n public getFrame(time: number | string) {\n return this.items[this.getUnitTime(time)];\n }\n public removeFrame(time: number | string, ...names: any[]): this;\n /**\n * remove sceneItem's frame at that time\n * @param - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.removeFrame(time);\n */\n public removeFrame(time: number | string) {\n const realTime = this.getUnitTime(time);\n const items = this.items;\n const index = this.times.indexOf(realTime);\n\n delete items[realTime];\n\n // remove time\n if (index > -1) {\n this.times.splice(index, 1);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * check if the item has a frame at that time\n * @param {Number} time - frame's time\n * @return {Boolean} true: the item has a frame // false: not\n * @example\n if (item.hasFrame(10)) {\n // has\n } else {\n // not\n }\n */\n public hasFrame(time: number | string) {\n return this.getUnitTime(time) in this.items;\n }\n /**\n * Check if keyframes has propery's name\n * @param - property's time\n * @return {boolean} true: if has property, false: not\n * @example\n item.hasName([\"transform\", \"translate\"]); // true or not\n */\n public hasName(args: string[]) {\n this.needUpdate && this.update();\n return !!this.nameMap.get(args);\n }\n /**\n * merge frame of the previous time at the next time.\n * @param - The time of the frame to merge\n * @param - The target frame\n * @return {SceneItem} An instance itself\n * @example\n // getFrame(1) contains getFrame(0)\n item.merge(0, 1);\n */\n public mergeFrame(time: number | string, frame: Frame) {\n if (frame) {\n const toFrame = this.newFrame(time);\n\n toFrame.merge(frame);\n }\n return this;\n }\n /**\n * Get frame of the current time\n * @param {Number} time - the current time\n * @param {function} easing - the speed curve of an animation\n * @return {Frame} frame of the current time\n * @example\n let item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n // opacity: 0.7; display:\"block\";\n const frame = item.getNowFrame(1.7);\n */\n public getNowFrame(time: number, easing?: EasingType, isAccurate?: boolean) {\n this.needUpdate && this.update();\n const frame = new Frame();\n const [left, right] = getNearTimeIndex(this.times, time);\n let realEasing = this.getEasing() || easing;\n let nameMap = this.nameMap;\n\n if (this.hasName([TIMING_FUNCTION])) {\n const nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true);\n\n isFunction(nowEasing) && (realEasing = nowEasing);\n }\n if (isAccurate) {\n const prevFrame = this.getFrame(time);\n const prevOrderMap = prevFrame.orderMap.filter([], orders => {\n return prevFrame.has(...orders);\n });\n\n for (const name in ROLES) {\n const orders = nameMap.get([name]);\n if (prevOrderMap.get([name]) && orders) {\n prevOrderMap.set([name], orders);\n }\n }\n nameMap = prevOrderMap;\n }\n const names = nameMap.gets([]);\n\n frame.setOrderObject(nameMap.orderMap);\n names.forEach(properties => {\n const value = this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties));\n\n if (isUndefined(value)) {\n return;\n }\n frame.set(properties, value);\n });\n return frame;\n }\n public load(properties: any = {}, options = properties.options) {\n options && this.setOptions(options);\n\n if (isArray(properties)) {\n this.set(properties);\n } else if (properties.keyframes) {\n this.set(properties.keyframes);\n } else {\n for (const time in properties) {\n if (time !== \"options\") {\n this.set({\n [time]: properties[time],\n });\n }\n }\n }\n if (options && options[DURATION]) {\n this.setDuration(options[DURATION]);\n }\n return this;\n }\n /**\n * clone SceneItem.\n * @return {SceneItem} An instance of clone\n * @example\n * item.clone();\n */\n public clone() {\n const item = new SceneItem();\n\n item.setOptions(this.state);\n item.setOrderObject(this.nameMap.orderMap);\n\n this.forEach((frame: Frame, time: number) => {\n item.setFrame(time, frame.clone());\n });\n return item;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Keyframes} An instance itself\n */\n public forEach(callback: (item: Frame, time: number, items: IObject) => void) {\n const times = this.times;\n const items = this.items;\n\n times.forEach(time => {\n callback(items[time], time, items);\n });\n return this;\n }\n public setOptions(options: Partial = {}) {\n super.setOptions(options);\n const { id, selector, elements, element, target } = options;\n\n id && this.setId(id);\n if (target) {\n this.setTarget(target);\n } else if (selector) {\n this.setSelector(selector);\n } else if (elements || element) {\n this.setElement(elements || element);\n }\n return this;\n }\n public toCSS(\n playCondition: PlayCondition = { className: START_ANIMATION },\n parentDuration = this.getDuration(), states: AnimatorState[] = []) {\n const itemState = this.state;\n const selector = itemState[SELECTOR];\n\n if (!selector) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n itemState[DURATION] = originalDuration;\n states.push(itemState);\n\n const reversedStates = toArray(states).reverse();\n const id = toId(getRealId(this));\n const superParent = states[0];\n const infiniteIndex = findIndex(reversedStates, state => {\n return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]);\n }, states.length - 1);\n const finiteStates = reversedStates.slice(0, infiniteIndex);\n const duration = parentDuration || finiteStates.reduce((prev, cur) => {\n return (cur[DELAY] + prev * (cur[ITERATION_COUNT] as number)) / cur[PLAY_SPEED];\n }, originalDuration);\n const delay = reversedStates.slice(infiniteIndex).reduce((prev, cur) => {\n return (prev + cur[DELAY]) / cur[PLAY_SPEED];\n }, 0);\n const easingName = find(reversedStates, state => (state[EASING] && state[EASING_NAME]), itemState)[EASING_NAME];\n const iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT];\n const fillMode = superParent[FILL_MODE];\n const direction = reversedStates[infiniteIndex][DIRECTION];\n const cssText = makeAnimationProperties({\n fillMode,\n direction,\n iterationCount,\n delay: `${delay}s`,\n name: `${PREFIX}KEYFRAMES_${id}`,\n duration: `${duration / superParent[PLAY_SPEED]}s`,\n timingFunction: easingName,\n });\n const selectors = splitComma(selector).map(sel => {\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(sel);\n\n if (matches) {\n return [matches[1], matches[2]];\n } else {\n return [sel, \"\"];\n }\n });\n const className = playCondition.className;\n const selectorCallback = playCondition.selector;\n const preselector = isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback;\n\n return `\n ${preselector || selectors.map(([sel, peusdo]) => `${sel}.${className}${peusdo}`)} {${cssText}}\n ${selectors.map(([sel, peusdo]) => `${sel}.${PAUSE_ANIMATION}${peusdo}`)} {${ANIMATION}-play-state: paused;}\n @${KEYFRAMES} ${PREFIX}KEYFRAMES_${id}{${this._toKeyframes(duration, finiteStates, direction)}}`;\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {SceneItem} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition,\n duration?: number, options?: AnimatorState[]) {\n if (!this.elements.length) {\n return \"\";\n }\n const css = this.toCSS(playCondition, duration, options);\n const isParent = options && !isUndefined(options[ITERATION_COUNT]);\n\n if (!isParent) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n }\n return this;\n }\n public pause() {\n super.pause();\n isPausedCSS(this) && this.pauseCSS();\n return this;\n }\n public pauseCSS() {\n this.elements.forEach(element => {\n addClass(element, PAUSE_ANIMATION);\n });\n return this;\n }\n public endCSS() {\n this.elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n removeClass(element, START_ANIMATION);\n });\n setPlayCSS(this, false);\n return this;\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n item.playCSS();\n item.playCSS(false, \"startAnimation\", {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: object = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public getAnimationElement(): AnimateElement {\n return this.elements[0];\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n const elements = this.elements;\n const length = elements.length;\n const cssText = makeAnimationProperties(properties);\n\n if (!length) {\n return;\n }\n if (isPaused) {\n elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n });\n } else {\n elements.forEach(element => {\n element.style.cssText += cssText;\n\n if (hasClass(element, START_ANIMATION)) {\n removeClass(element, START_ANIMATION);\n }\n });\n elements.forEach(element => {\n element.clientWidth;\n });\n elements.forEach(element => {\n addClass(element, START_ANIMATION);\n });\n }\n return elements[0];\n }\n /**\n * Clear All Frames\n * @return {SceneItem} An instance itself\n */\n public clear() {\n this.times = [];\n this.items = {};\n this.nameMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n this.temp = null;\n this.needUpdate = true;\n return this;\n }\n public getNowValue(\n time: number,\n properties: NameType[],\n left?: number,\n right?: number,\n isAccurate?: boolean,\n easing?: EasingType,\n usePrevValue?: boolean,\n ) {\n const times = this.times;\n const length = times.length;\n\n let prevTime: number;\n let nextTime: number;\n let prevFrame: Frame;\n let nextFrame: Frame;\n const isUndefinedLeft = isUndefined(left);\n const isUndefinedRight = isUndefined(right);\n if (isUndefinedLeft || isUndefinedRight) {\n const indicies = getNearTimeIndex(times, time);\n isUndefinedLeft && (left = indicies[0]);\n isUndefinedRight && (right = indicies[1]);\n }\n\n for (let i = left; i >= 0; --i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n prevTime = times[i];\n prevFrame = frame;\n break;\n }\n }\n const prevValue = prevFrame && prevFrame.raw(...properties);\n\n if (isAccurate && !isRole([properties[0]])) {\n return prevTime === time ? prevValue : undefined;\n }\n if (usePrevValue) {\n return prevValue;\n }\n for (let i = right; i < length; ++i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n nextTime = times[i];\n nextFrame = frame;\n break;\n }\n }\n const nextValue = nextFrame && nextFrame.raw(...properties);\n\n if (!prevFrame || isUndefined(prevValue)) {\n return nextValue;\n }\n if (!nextFrame || isUndefined(nextValue) || prevValue === nextValue) {\n return prevValue;\n }\n return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing);\n }\n private _toKeyframes(duration: number, states: AnimatorState[], direction: DirectionType) {\n const frames: IObject = {};\n const times = this.times.slice();\n\n if (!times.length) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n (!this.getFrame(0)) && times.unshift(0);\n (!this.getFrame(originalDuration)) && times.push(originalDuration);\n const entries = getEntries(times, states);\n const lastEntry = entries[entries.length - 1];\n\n // end delay time\n lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]);\n let prevTime = -1;\n\n return entries.map(([time, keytime]) => {\n if (!frames[keytime]) {\n frames[keytime] =\n (!this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ?\n this.getNowFrame(keytime) : this.getNowFrame(keytime, 0, true)).toCSS();\n }\n\n let frameTime = time / duration * 100;\n\n if (frameTime - prevTime < THRESHOLD) {\n frameTime += THRESHOLD;\n }\n prevTime = frameTime;\n return `${Math.min(frameTime, 100)}%{\n ${time === 0 && !isDirectionReverse(0, 1, direction) ? \"\" : frames[keytime]}\n }`;\n }).join(\"\");\n }\n private updateFrameOrders() {\n const nameMap = this.nameMap.orderMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap);\n });\n }\n}\n\nexport default SceneItem;\n","import Animator from \"./Animator\";\nimport SceneItem from \"./SceneItem\";\nimport { SELECTOR, DURATION, DELAY, RUNNING, NAME_SEPARATOR } from \"./consts\";\nimport { playCSS, getRealId, isPausedCSS, isEndedCSS, setPlayCSS } from \"./utils\";\nimport { isFunction, IS_WINDOW, IObject, $, IArrayFormat } from \"@daybrush/utils\";\nimport {\n AnimateElement, SceneState, SceneOptions, EasingType,\n AnimatorState, SceneItemOptions, PlayCondition, NameType\n} from \"./types\";\nimport Frame from \"./Frame\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n/**\n * manage sceneItems and play Scene.\n * @sort 1\n */\nclass Scene extends Animator {\n /**\n * version info\n * @type {string}\n * @example\n * Scene.VERSION // #__VERSION__#\n */\n public static VERSION: string = \"#__VERSION__#\";\n public items: IObject = {};\n public orderMap = new OrderMap(NAME_SEPARATOR);\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: IObject;\n /**\n * @param - properties\n * @param - options\n * @example\n const scene = new Scene({\n item1: {\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n },\n },\n item2: {\n 2: {\n opacity: 1,\n },\n }\n });\n */\n constructor(properties?: { options?: Partial } & IObject, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n let time = 0;\n\n this.forEach(item => {\n time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed());\n });\n return time || this.state[DURATION];\n }\n public setDuration(duration: number) {\n const items = this.items;\n const sceneDuration = this.getDuration();\n\n if (duration === 0 || !isFinite(sceneDuration)) {\n return this;\n }\n if (sceneDuration === 0) {\n this.forEach(item => {\n item.setDuration(duration);\n });\n } else {\n const ratio = duration / sceneDuration;\n\n this.forEach(item => {\n item.setDelay(item.getDelay() * ratio);\n item.setDuration(item.getDuration() * ratio);\n });\n }\n super.setDuration(duration);\n return this;\n }\n public getItem(name: number | string): T;\n /**\n * get item in scene by name\n * @param - The item's name\n * @return {Scene | SceneItem} item\n * @example\n const item = scene.getItem(\"item1\")\n */\n public getItem(name: number | string) {\n return this.items[name];\n }\n /**\n * create item in scene\n * @param {} name - name of item to create\n * @param {} options - The option object of SceneItem\n * @return {} Newly created item\n * @example\n const item = scene.newItem(\"item1\")\n */\n public newItem(name: number | string, options: Partial = {}): Scene | SceneItem {\n if (this.items[name]) {\n return this.items[name];\n }\n const item = new SceneItem();\n\n this.setItem(name, item);\n item.setOptions(options);\n\n return item;\n }\n /**\n * remove item in scene\n * @param - name of item to remove\n * @return An instance itself\n * @example\n const item = scene.newItem(\"item1\")\n\n scene.removeItem(\"item1\");\n */\n public removeItem(name: number | string): this {\n delete this.items[name];\n\n this.orderMap.remove([name]);\n return this;\n }\n /**\n * add a sceneItem to the scene\n * @param - name of item to create\n * @param - sceneItem\n * @example\n const item = scene.newItem(\"item1\")\n */\n public setItem(name: number | string, item: Scene | SceneItem) {\n item.setId(name);\n this.items[name] = item;\n\n this.orderMap.add([name]);\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frames: IObject = {};\n\n this.forEach(item => {\n item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing);\n\n frames[item.getId()] = item.temp;\n });\n this.temp = frames;\n\n /**\n * This event is fired when timeupdate and animate.\n * @event Scene#animate\n * @param {object} param The object of data to be sent to an event.\n * @param {number} param.currentTime The total time that the animator is running.\n * @param {number} param.time The iteration time during duration that the animator is running.\n * @param {object} param.frames frames of that time.\n * @example\nconst scene = new Scene({\n a: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n },\n b: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }\n}).on(\"animate\", e => {\n console.log(e.frames);\n // {a: Frame, b: Frame}\n console.log(e.frames.a.get(\"opacity\"));\n});\n */\n this.trigger(\"animate\", {\n frames,\n currentTime: this.getTime(),\n time: iterationTime,\n });\n\n return this;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Scene} An instance itself\n */\n public forEach(\n func: (\n item: Scene | SceneItem,\n id: string | number,\n index: number,\n items: IObject,\n ) => void,\n ) {\n const items = this.items;\n this.getOrders().forEach((id, index) => {\n func(items[id], id, index, items);\n });\n return this;\n }\n public toCSS(\n playCondition?: PlayCondition,\n duration: number = this.getDuration(), parentStates: AnimatorState[] = []) {\n const totalDuration = !duration || !isFinite(duration) ? 0 : duration;\n const styles: string[] = [];\n const state = this.state;\n\n state[DURATION] = this.getDuration();\n\n this.forEach(item => {\n styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state)));\n });\n return styles.join(\"\");\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {Scene} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition, duration?: number, parentStates?: AnimatorState[]) {\n const css = this.toCSS(playCondition, duration, parentStates);\n\n if (!parentStates || !parentStates.length) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n // && exportCSS(getRealId(this), css);\n }\n return this;\n }\n public append(item: SceneItem | Scene) {\n item.setDelay(item.getDelay() + this.getDuration());\n this.setItem(getRealId(item), item);\n }\n public pauseCSS() {\n return this.forEach(item => {\n item.pauseCSS();\n });\n }\n public pause() {\n super.pause();\n\n isPausedCSS(this) && this.pauseCSS();\n this.forEach(item => {\n item.pause();\n });\n return this;\n }\n public endCSS() {\n this.forEach(item => {\n item.endCSS();\n });\n setPlayCSS(this, false);\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * get item orders\n * @example\n scene.getOrders() // => [\"item1\", \"item2\"]\n */\n public getOrders(): NameType[] {\n return this.orderMap.get([]) || [];\n }\n /**\n * set item orders\n * @param - orders\n * @example\n frame.setOrders([\"item2\", \"item1\"]) // => [\"item2\", \"item1\"]\n */\n public setOrders(orders: NameType[]): NameType[] {\n return this.orderMap.set([], orders);\n }\n public getAnimationElement() {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.getAnimationElement();\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.addPlayClass(isPaused, playClassName, properties);\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @return {Scene} An instance itself\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n scene.playCSS();\n scene.playCSS(false, {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: Partial = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public set(properties: any, ...args: any[]): this;\n /**\n * Set properties to the Scene.\n * @param - properties\n * @return An instance itself\n * @example\nscene.set({\n \".a\": {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n },\n },\n});\n// 0\nconsole.log(scene.getItem(\".a\").get(0, \"opacity\"));\n// 1\nconsole.log(scene.getItem(\".a\").get(1, \"opacity\"));\n */\n public set(properties: any) {\n this.load(properties);\n return this;\n }\n /**\n * Clear All Items\n * @return {Scene} An instance itself\n */\n public clear() {\n this.finish();\n this.items = {};\n this.orderMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n }\n public load(properties: any = {}, options = properties.options) {\n if (!properties) {\n return this;\n }\n const selector = options && options[SELECTOR] || this.state[SELECTOR];\n for (const name in properties) {\n if (name === \"options\") {\n continue;\n }\n const object = properties[name];\n let item;\n\n if (object instanceof Scene || object instanceof SceneItem) {\n this.setItem(name, object);\n item = object;\n } else if (isFunction(object) && selector) {\n const elements =\n IS_WINDOW\n ? $(`${isFunction(selector) ? selector(name) : name}`, true) as IArrayFormat\n : ([] as AnimateElement[]);\n const length = elements.length;\n const scene = new Scene();\n\n for (let i = 0; i < length; ++i) {\n (scene.newItem(i) as SceneItem).setId().setElement(elements[i]).load(object(i, elements[i]));\n }\n this.setItem(name, scene);\n continue;\n } else {\n item = this.newItem(name);\n item.load(object);\n }\n selector && item.setSelector(selector);\n }\n this.setOptions(options);\n }\n public setOptions(options: Partial = {}): this {\n super.setOptions(options);\n\n const selector = options.selector;\n\n if (selector) {\n this.state[SELECTOR] = selector;\n }\n return this;\n }\n public setSelector(target?: string | boolean | ((id: number | string) => string)) {\n const state = this.state;\n const selector = target || state[SELECTOR];\n\n state[SELECTOR] = selector;\n const isItFunction = isFunction(target);\n if (selector) {\n this.forEach((item, name) => {\n item.setSelector(isItFunction ? (target as (id: number | string) => string)(name) : selector);\n });\n }\n return this;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const result = super.start(delay);\n\n if (result) {\n this.forEach(item => {\n item.start(0);\n });\n } else {\n this.forEach(item => {\n item.setPlayState(RUNNING);\n });\n }\n return result;\n }\n}\n\nexport default Scene;\n","import { IObject } from \"@daybrush/utils\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport { SceneOptions, SceneItemOptions } from \"./types\";\n\nexport function animate(properties?: IObject, options?: Partial) {\n return new Scene(properties, options).play();\n}\nexport function animateItem(properties?: IObject, options?: Partial) {\n return new SceneItem(properties, options).play();\n}\n","import Scene, * as others from \"./index\";\n\nfor (const name in others) {\n (Scene as any)[name] = (others as any)[name];\n}\n\nexport default Scene;\n"],"names":["cubic","y1","y2","t","t2","solveFromX","x1","x2","x","solveX","dx","Math","abs","bezier","func","max","min","easingName","steps","count","position","time","level","floor","STEP_START","STEP_END","LINEAR","EASE","EASE_IN","EASE_OUT","EASE_IN_OUT","PREFIX","DATA_SCENE_ID","TIMING_FUNCTION","ROLES","transform","filter","attribute","html","ALIAS","easing","FIXED","_a","MAXIMUM","THRESHOLD","DURATION","FILL_MODE","DIRECTION","ITERATION_COUNT","DELAY","EASING","PLAY_SPEED","EASING_NAME","ITERATION_TIME","PAUSED","ENDED","TIMEUPDATE","ANIMATE","PLAY","RUNNING","ITERATION","START_ANIMATION","PAUSE_ANIMATION","ALTERNATE","REVERSE","ALTERNATE_REVERSE","NORMAL","INFINITE","PLAY_STATE","PLAY_CSS","PREV_TIME","TICK_TIME","CURRENT_TIME","SELECTOR","TRANSFORM_NAME","EASINGS","NAME_SEPARATOR","OPTIONS","EVENTS","events","name","callback","once","isObject","n","_on","isArray","forEach","_this","push","callback2","_i","args","off","callbacks","index","indexOf","splice","data","event","target","type","currentTarget","toArray","apply","value","options","setOptions","isString","split","separator","newOptions","length","prefix","suffix","model","arr","map","v","PropertyObject","clone","join","toValue","splitStyle","str","properties","splitText","obj","totalLength","i","matches","trim","toPropertyObject","styles","arrayToColorObject","RGBA","stringToBracketObject","text","splitBracket","afterModel","COLOR_MODELS","stringToRGBA","arrayToPropertyObject","stringToColorObject","result","values","splitComma","splitSpace","exec","charAt","toObject","object","size","get","isPropertyObject","setAlias","alias","setRole","names","isProperty","isFixedProperty","roles","fixed","getType","OBJECT","ARRAY","PROPERTY","STRING","NUMBER","isPureObject","constructor","Object","getNames","stack","concat","pop","slice","updateFrame","toFixed","num","round","getValueByNames","undefined","isInProperties","isCheckTrue","role","isRole","isFixed","setPlayCSS","item","isActivate","state","isPausedCSS","isPaused","isEndedCSS","isEnded","makeId","selector","id","random","IS_WINDOW","checkElement","$","getRealId","getId","setId","toId","match","playCSS","isExportCSS","playClassName","ANIMATION","getPlayState","className","addPlayClass","setTime","exportCSS","el","addAnimationEvent","setPlayState","duration","getDuration","isZeroDuration","isFinite","animationend","finish","animationstart","trigger","addEvent","animationiteration","removeEvent","elapsedTime","currentTime","iterationCount","setIteration","getEasing","curveArray","parseFloat","GetterSetter","getter","setter","parent","prototype","camelize","isDirectionReverse","iteration","iteraiontCount","direction","setters","getters","__extends","_super","delay","fillMode","playSpeed","iterationTime","tickTime","prevTime","playState","setEasing","setDuration","getActiveDuration","Infinity","getTime","toTime","timerId","requestAnimationFrame","tick","start","cancelAnimationFrame","end","pause","isTick","isParent","activeDuration","getUnitTime","calculate","isDelay","getIterationTime","splitUnit","unit","passIterationCount","maxIterationCount","currentIterationTime","setIterationTime","isReverse","isFiniteDuration","isForwards","now","to","Animator","EventTrigger","toInnerProperties","orders","arrObj","keys","getKeys","sortOrders","replace","merge","from","FUNCTION","getValue","getPropertyName","OrderMap","set","raw","orderMap","getObject","setObject","key","nextValue","children","gets","params","remove","self","firstParam","Frame","_set","has","stylesLength","isUndefined","frame","setOrderObject","frameProperties","cssObject","FILTER","TRANSFORM","toCSSObject","cssArray","clear","lastParam","add","dotArray","a1","a2","b1","b2","v1","dot","dotColor","color1","color2","value1","value2","model1","model2","colorModel","parseInt","dotObject","a1Type","type1","type2","isFunction1","isFunction2","v2","isNaN","dotNumber","dotValue","nextTime","prevValue","ratio","getNearTimeIndex","times","makeAnimationProperties","decamelize","addTime","addEntry","entries","keytime","prevEntry","getEntries","states","nextEntries","intCount","ceil","currentDuration","lastTime","j","entry","divideTime","unshift","load","originalDuration","ratio_1","items_1","obj_1","time2","items","newFrame","elements","sceneId_1","element","setAttribute","SceneItem","eachTime","realTime","innerValue","value_1","getDelay","frames","hasFrame","getDirection","frameTime","needUpdate","getFrame","update","nameMap","updateFrameOrders","removeFrame","append","unshiftTime","firstFrame","prepend","isStartZero","isFunction","setElement","Element","style","targetFunc","attributes","html_1","innerHTML","cssText","toCSS","fromCSS","parentEasing","getNowFrame","temp","prevNameMap","pushKeys","nextMap","setFrame","toFrame","isAccurate","left","right","realEasing","hasName","nowEasing","getNowValue","prevFrame_1","prevOrderMap","keyframes","setTarget","setSelector","playCondition","parentDuration","itemState","reversedStates","reverse","superParent","infiniteIndex","findIndex","finiteStates","reduce","prev","cur","find","timingFunction","selectors","sel","selectorCallback","preselector","peusdo","KEYFRAMES","_toKeyframes","css","styledInjector","destroy","styled","inject","getAnimationElement","original","pauseCSS","addClass","removeClass","endCSS","hasClass","clientWidth","usePrevValue","prevFrame","nextFrame","isUndefinedLeft","isUndefinedRight","indicies","lastEntry","getTotalDuration","getPlaySpeed","sceneDuration","setDelay","setItem","getOrders","parentStates","totalDuration","animtionElement","Scene","scene","newItem","isItFunction","animate","play","animateItem","others"],"mappings":"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"} \ No newline at end of file diff --git a/dist/scene.esm.js b/dist/scene.esm.js new file mode 100644 index 00000000..047b0250 --- /dev/null +++ b/dist/scene.esm.js @@ -0,0 +1,4141 @@ +/* +Copyright (c) 2016 Daybrush +name: scenejs +license: MIT +author: Daybrush +repository: https://github.com/daybrush/scenejs.git +version: 1.4.0 +*/ +import { isObject, isArray, toArray, isString, splitText, splitComma, splitSpace, RGBA, splitBracket, COLOR_MODELS, stringToRGBA, OBJECT, ARRAY, PROPERTY, STRING, NUMBER, IS_WINDOW, $, ANIMATION, removeEvent, addEvent, requestAnimationFrame, cancelAnimationFrame, splitUnit, camelize, getKeys, sortOrders, isUndefined, FILTER, TRANSFORM, FUNCTION, dot as dot$1, isFunction, fromCSS, findIndex, find, KEYFRAMES, addClass, removeClass, hasClass, decamelize } from '@daybrush/utils'; +import OrderMap from 'order-map'; +import styled from 'css-styled'; + +/*! ***************************************************************************** +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. +***************************************************************************** */ + +/* global Reflect, Promise */ +var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || { + __proto__: [] + } instanceof Array && function (d, b) { + d.__proto__ = b; + } || function (d, b) { + for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; + }; + + return extendStatics(d, b); +}; + +function __extends(d, b) { + extendStatics(d, b); + + function __() { + this.constructor = d; + } + + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); +} +function __decorate(decorators, target, key, desc) { + var c = arguments.length, + r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, + d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +} +function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + + for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j]; + + return r; +} + +function cubic(y1, y2, t) { + var t2 = 1 - t; // Bezier Curve Formula + + return t * t * t + 3 * t * t * t2 * y2 + 3 * t * t2 * t2 * y1; +} + +function solveFromX(x1, x2, x) { + // x 0 ~ 1 + // t 0 ~ 1 + var t = x; + var solveX = x; + var dx = 1; + + while (Math.abs(dx) > 1 / 1000) { + // 예상 t초에 의한 _x값 + solveX = cubic(x1, x2, t); + dx = solveX - x; // 차이가 미세하면 그 값을 t로 지정 + + if (Math.abs(dx) < 1 / 1000) { + return t; + } + + t -= dx / 2; + } + + return t; +} +/** + * @namespace easing + */ + +/** +* Cubic Bezier curve. +* @memberof easing +* @func bezier +* @param {number} [x1] - point1's x +* @param {number} [y1] - point1's y +* @param {number} [x2] - point2's x +* @param {number} [y2] - point2's y +* @return {function} the curve function +* @example +import {bezier} from "scenejs"; +Scene.bezier(0, 0, 1, 1) // LINEAR +Scene.bezier(0.25, 0.1, 0.25, 1) // EASE +*/ + + +function bezier(x1, y1, x2, y2) { + /* + x = f(t) + calculate inverse function by x + t = f-1(x) + */ + var func = function (x) { + var t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0)); + return cubic(y1, y2, t); + }; + + func.easingName = "cubic-bezier(" + x1 + "," + y1 + "," + x2 + "," + y2 + ")"; + return func; +} +/** +* Specifies a stepping function +* @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function} +* @memberof easing +* @func steps +* @param {number} count - point1's x +* @param {"start" | "end"} postion - point1's y +* @return {function} the curve function +* @example +import {steps} from "scenejs"; +Scene.steps(1, "start") // Scene.STEP_START +Scene.steps(1, "end") // Scene.STEP_END +*/ + +function steps(count, position) { + var func = function (time) { + var level = 1 / count; + + if (time >= 1) { + return 1; + } + + return (position === "start" ? level : 0) + Math.floor(time / level) * level; + }; + + func.easingName = "steps(" + count + ", " + position + ")"; + return func; +} +/** +* Equivalent to steps(1, start) +* @memberof easing +* @name STEP_START +* @static +* @type {function} +* @example +import {STEP_START} from "scenejs"; +Scene.STEP_START // steps(1, start) +*/ + +var STEP_START = +/*#__PURE__#*/ +steps(1, "start"); +/** +* Equivalent to steps(1, end) +* @memberof easing +* @name STEP_END +* @static +* @type {function} +* @example +import {STEP_END} from "scenejs"; +Scene.STEP_END // steps(1, end) +*/ + +var STEP_END = +/*#__PURE__#*/ +steps(1, "end"); +/** +* Linear Speed (0, 0, 1, 1) +* @memberof easing +* @name LINEAR +* @static +* @type {function} +* @example +import {LINEAR} from "scenejs"; +Scene.LINEAR +*/ + +var LINEAR = +/*#__PURE__#*/ +bezier(0, 0, 1, 1); +/** +* Ease Speed (0.25, 0.1, 0.25, 1) +* @memberof easing +* @name EASE +* @static +* @type {function} +* @example +import {EASE} from "scenejs"; +Scene.EASE +*/ + +var EASE = +/*#__PURE__#*/ +bezier(0.25, 0.1, 0.25, 1); +/** +* Ease In Speed (0.42, 0, 1, 1) +* @memberof easing +* @name EASE_IN +* @static +* @type {function} +* @example +import {EASE_IN} from "scenejs"; +Scene.EASE_IN +*/ + +var EASE_IN = +/*#__PURE__#*/ +bezier(0.42, 0, 1, 1); +/** +* Ease Out Speed (0, 0, 0.58, 1) +* @memberof easing +* @name EASE_OUT +* @static +* @type {function} +* @example +import {EASE_OUT} from "scenejs"; +Scene.EASE_OUT +*/ + +var EASE_OUT = +/*#__PURE__#*/ +bezier(0, 0, 0.58, 1); +/** +* Ease In Out Speed (0.42, 0, 0.58, 1) +* @memberof easing +* @name EASE_IN_OUT +* @static +* @type {function} +* @example +import {EASE_IN_OUT} from "scenejs"; +Scene.EASE_IN_OUT +*/ + +var EASE_IN_OUT = +/*#__PURE__#*/ +bezier(0.42, 0, 0.58, 1); + +var _a; +var PREFIX = "__SCENEJS_"; +var DATA_SCENE_ID = "data-scene-id"; +var TIMING_FUNCTION = "animation-timing-function"; +var ROLES = { + transform: {}, + filter: {}, + attribute: {}, + html: true +}; +var ALIAS = { + easing: [TIMING_FUNCTION] +}; +var FIXED = (_a = {}, _a[TIMING_FUNCTION] = true, _a.contents = true, _a.html = true, _a); +var MAXIMUM = 1000000; +var THRESHOLD = 0.000001; +var DURATION = "duration"; +var FILL_MODE = "fillMode"; +var DIRECTION = "direction"; +var ITERATION_COUNT = "iterationCount"; +var DELAY = "delay"; +var EASING = "easing"; +var PLAY_SPEED = "playSpeed"; +var EASING_NAME = "easingName"; +var ITERATION_TIME = "iterationTime"; +var PAUSED = "paused"; +var ENDED = "ended"; +var TIMEUPDATE = "timeupdate"; +var ANIMATE = "animate"; +var PLAY = "play"; +var RUNNING = "running"; +var ITERATION = "iteration"; +var START_ANIMATION = "startAnimation"; +var PAUSE_ANIMATION = "pauseAnimation"; +var ALTERNATE = "alternate"; +var REVERSE = "reverse"; +var ALTERNATE_REVERSE = "alternate-reverse"; +var NORMAL = "normal"; +var INFINITE = "infinite"; +var PLAY_STATE = "playState"; +var PLAY_CSS = "playCSS"; +var PREV_TIME = "prevTime"; +var TICK_TIME = "tickTime"; +var CURRENT_TIME = "currentTime"; +var SELECTOR = "selector"; +var TRANSFORM_NAME = "transform"; +var EASINGS = { + "linear": LINEAR, + "ease": EASE, + "ease-in": EASE_IN, + "ease-out": EASE_OUT, + "ease-in-out": EASE_IN_OUT, + "step-start": STEP_START, + "step-end": STEP_END +}; +var NAME_SEPARATOR = "_///_"; +/** +* option name list +* @name Scene.OPTIONS +* @memberof Scene +* @static +* @type {$ts:OptionType} +* @example +* Scene.OPTIONS // ["duration", "fillMode", "direction", "iterationCount", "delay", "easing", "playSpeed"] +*/ + +var OPTIONS = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED]; +/** +* Event name list +* @name Scene.EVENTS +* @memberof Scene +* @static +* @type {$ts:EventType} +* @example +* Scene.EVENTS // ["paused", "ended", "timeupdate", "animate", "play", "iteration"]; +*/ + +var EVENTS = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION]; + +/** +* attach and trigger event handlers. +*/ + +var EventTrigger = +/*#__PURE__*/ +function () { + /** + * @example + const et = new Scene.EventTrigger(); + const scene = new Scene(); + scene.on("call", e => { + console.log(e.param); + }); + et.on("call", e => { + console.log(e.param); + }); + scene.trigger("call", {param: 1}); + et.trigger("call", {param: 1}); + */ + function EventTrigger() { + this.events = {}; + } + + var __proto = EventTrigger.prototype; + + __proto._on = function (name, callback, once) { + var _this = this; + + var events = this.events; + + if (isObject(name)) { + for (var n in name) { + this._on(n, name[n], once); + } + + return; + } + + if (!(name in events)) { + events[name] = []; + } + + if (!callback) { + return; + } + + if (isArray(callback)) { + callback.forEach(function (func) { + return _this._on(name, func, once); + }); + return; + } + + events[name].push(once ? function callback2() { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + callback.apply(void 0, args); + this.off(name, callback2); + } : callback); + }; + /** + * Attach an event handler function for one or more events to target + * @param - event's name + * @param - function to execute when the event is triggered. + * @return {EventTrigger} An Instance itself. + * @example + target.on("animate", function() { + console.log("animate"); + }); + target.trigger("animate"); + */ + + + __proto.on = function (name, callback) { + this._on(name, callback); + + return this; + }; + /** + * Dettach an event handler function for one or more events to target + * @param - event's name + * @param - function to execute when the event is triggered. + * @return {EventTrigger} An Instance itself. + * @example + const callback = function() { + console.log("animate"); + }; + target.on("animate", callback); + target.off("animate", callback); + target.off("animate"); + */ + + + __proto.off = function (name, callback) { + if (!name) { + this.events = {}; + } else if (!callback) { + this.events[name] = []; + } else { + var callbacks = this.events[name]; + + if (!callbacks) { + return this; + } + + var index = callbacks.indexOf(callback); + + if (index !== -1) { + callbacks.splice(index, 1); + } + } + + return this; + }; + /** + * execute event handler + * @param - event's name + * @param - event handler's additional parameter + * @return {EventTrigger} An Instance itself. + * @example + target.on("animate", function(a1, a2) { + console.log("animate", a1, a2); + }); + target.trigger("animate", [1, 2]); // log => "animate", 1, 2 + */ + + + __proto.trigger = function (name) { + var _this = this; + + var data = []; + + for (var _i = 1; _i < arguments.length; _i++) { + data[_i - 1] = arguments[_i]; + } + + var events = this.events; + + if (!(name in events)) { + return this; + } + + var args = data || []; + !args[0] && (args[0] = {}); + var event = events[name]; + var target = args[0]; + target.type = name; + target.currentTarget = this; + !target.target && (target.target = this); + toArray(events[name]).forEach(function (callback) { + callback.apply(_this, data); + }); + return this; + }; + + __proto.once = function (name, callback) { + this._on(name, callback, true); + + return this; + }; + + return EventTrigger; +}(); + +/** +* Make string, array to PropertyObject for the dot product +*/ + +var PropertyObject = +/*#__PURE__*/ +function () { + /** + * @param - This value is in the array format. + * @param - options + * @example + var obj = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + */ + function PropertyObject(value, options) { + this.prefix = ""; + this.suffix = ""; + this.model = ""; + this.type = ""; + this.separator = ","; + options && this.setOptions(options); + this.value = isString(value) ? value.split(this.separator) : value; + } + + var __proto = PropertyObject.prototype; + + __proto.setOptions = function (newOptions) { + for (var name in newOptions) { + this[name] = newOptions[name]; + } + + return this; + }; + /** + * the number of values. + * @example + const obj1 = new PropertyObject("1,2,3", ","); + console.log(obj1.length); + // 3 + */ + + + __proto.size = function () { + return this.value.length; + }; + /** + * retrieve one of values at the index + * @param {Number} index - index + * @return {Object} one of values at the index + * @example + const obj1 = new PropertyObject("1,2,3", ","); + console.log(obj1.get(0)); + // 1 + */ + + + __proto.get = function (index) { + return this.value[index]; + }; + /** + * Set the value at that index + * @param {Number} index - index + * @param {Object} value - text, a number, object to set + * @return {PropertyObject} An instance itself + * @example + const obj1 = new PropertyObject("1,2,3", ","); + obj1.set(0, 2); + console.log(obj1.toValue()); + // 2,2,3 + */ + + + __proto.set = function (index, value) { + this.value[index] = value; + return this; + }; + /** + * create a copy of an instance itself. + * @return {PropertyObject} clone + * @example + const obj1 = new PropertyObject("1,2,3", ","); + const obj2 = obj1.clone(); + */ + + + __proto.clone = function () { + var _a = this, + separator = _a.separator, + prefix = _a.prefix, + suffix = _a.suffix, + model = _a.model, + type = _a.type; + + var arr = this.value.map(function (v) { + return v instanceof PropertyObject ? v.clone() : v; + }); + return new PropertyObject(arr, { + separator: separator, + prefix: prefix, + suffix: suffix, + model: model, + type: type + }); + }; + /** + * Make Property Object to String + * @return {String} Make Property Object to String + * @example + //rgba(100, 100, 100, 0.5) + const obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")", + }); + console.log(obj4.toValue()); + // "rgba(100,100,100,0.5)" + */ + + + __proto.toValue = function () { + return this.prefix + this.join() + this.suffix; + }; + /** + * Make Property Object's array to String + * @return {String} Join the elements of an array into a string + * @example + //rgba(100, 100, 100, 0.5) + var obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + obj4.join(); // => "100,100,100,0.5" + */ + + + __proto.join = function () { + return this.value.map(function (v) { + return v instanceof PropertyObject ? v.toValue() : v; + }).join(this.separator); + }; + /** + * executes a provided function once per array element. + * @param {Function} callback - Function to execute for each element, taking three arguments + * @param {All} [callback.currentValue] The current element being processed in the array. + * @param {Number} [callback.index] The index of the current element being processed in the array. + * @param {Array} [callback.array] the array. + * @return {PropertyObject} An instance itself + * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document. + * @example + //rgba(100, 100, 100, 0.5) + var obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + obj4.forEach(t => { + console.log(t); + }); // => "100,100,100,0.5" + */ + + + __proto.forEach = function (func) { + this.value.forEach(func); + return this; + }; + + return PropertyObject; +}(); + +/** +* @namespace +* @name Property +*/ +function splitStyle(str) { + var properties = splitText(str, ";"); + var obj = {}; + var totalLength = properties.length; + var length = totalLength; + + for (var i = 0; i < totalLength; ++i) { + var matches = splitText(properties[i], ":"); + + if (matches.length < 2 || !matches[1]) { + --length; + continue; + } + + obj[matches[0].trim()] = toPropertyObject(matches[1].trim()); + } + + return { + styles: obj, + length: length + }; +} +/** +* convert array to PropertyObject[type=color]. +* default model "rgba" +* @memberof Property +* @function arrayToColorObject +* @param {Array|PropertyObject} value ex) [0, 0, 0, 1] +* @return {PropertyObject} PropertyObject[type=color] +* @example +arrayToColorObject([0, 0, 0]) +// => PropertyObject(type="color", model="rgba", value=[0, 0, 0, 1], separator=",") +*/ + +function arrayToColorObject(arr) { + var model = RGBA; + + if (arr.length === 3) { + arr[3] = 1; + } + + return new PropertyObject(arr, { + model: model, + separator: ",", + type: "color", + prefix: model + "(", + suffix: ")" + }); +} +/** +* convert text with parentheses to object. +* @memberof Property +* @function stringToBracketObject +* @param {String} value ex) "rgba(0,0,0,1)" +* @return {PropertyObject} PropertyObject +* @example +stringToBracketObject("abcde(0, 0, 0,1)") +// => PropertyObject(model="abcde", value=[0, 0, 0,1], separator=",") +*/ + +function stringToBracketObject(text) { + // [prefix, value, other] + var _a = splitBracket(text), + model = _a.prefix, + value = _a.value, + afterModel = _a.suffix; + + if (typeof value === "undefined") { + return text; + } + + if (COLOR_MODELS.indexOf(model) > -1) { + return arrayToColorObject(stringToRGBA(text)); + } // divide comma(,) + + + var obj = toPropertyObject(value, model); + var arr = [value]; + var separator = ","; + var prefix = model + "("; + var suffix = ")" + afterModel; + + if (obj instanceof PropertyObject) { + separator = obj.separator; + arr = obj.value; + prefix += obj.prefix; + suffix = obj.suffix + suffix; + } + + return new PropertyObject(arr, { + separator: separator, + model: model, + prefix: prefix, + suffix: suffix + }); +} +function arrayToPropertyObject(arr, separator) { + return new PropertyObject(arr, { + type: "array", + separator: separator + }); +} +/** +* convert text with parentheses to PropertyObject[type=color]. +* If the values are not RGBA model, change them RGBA mdoel. +* @memberof Property +* @function stringToColorObject +* @param {String|PropertyObject} value ex) "rgba(0,0,0,1)" +* @return {PropertyObject} PropertyObject[type=color] +* @example +stringToColorObject("rgba(0, 0, 0,1)") +// => PropertyObject(type="color", model="rgba", value=[0, 0, 0,1], separator=",") +*/ + +function stringToColorObject(value) { + var result = stringToRGBA(value); + return result ? arrayToColorObject(result) : value; +} +function toPropertyObject(value, model) { + if (!isString(value)) { + if (isArray(value)) { + return arrayToPropertyObject(value, ","); + } + + return value; + } + + var values = splitComma(value); + + if (values.length > 1) { + return arrayToPropertyObject(values.map(function (v) { + return toPropertyObject(v); + }), ","); + } + + values = splitSpace(value); + + if (values.length > 1) { + return arrayToPropertyObject(values.map(function (v) { + return toPropertyObject(v); + }), " "); + } + + values = /^(['"])([^'"]*)(['"])$/g.exec(value); + + if (values && values[1] === values[3]) { + // Quotes + return new PropertyObject([toPropertyObject(values[2])], { + prefix: values[1], + suffix: values[1] + }); + } else if (value.indexOf("(") !== -1) { + // color + return stringToBracketObject(value); + } else if (value.charAt(0) === "#" && model !== "url") { + return stringToColorObject(value); + } + + return value; +} +function toObject(object, result) { + if (result === void 0) { + result = {}; + } + + var model = object.model; + + if (model) { + object.setOptions({ + model: "", + suffix: "", + prefix: "" + }); + var value = object.size() > 1 ? object : object.get(0); + result[model] = value; + } else { + object.forEach(function (obj) { + toObject(obj, result); + }); + } + + return result; +} + +function isPropertyObject(value) { + return value instanceof PropertyObject; +} +function setAlias(name, alias) { + ALIAS[name] = alias; +} +function setRole(names, isProperty, isFixedProperty) { + var length = names.length; + var roles = ROLES; + var fixed = FIXED; + + for (var i = 0; i < length - 1; ++i) { + !roles[names[i]] && (roles[names[i]] = {}); + roles = roles[names[i]]; + + if (isFixedProperty) { + !fixed[names[i]] && (fixed[names[i]] = {}); + fixed = fixed[names[i]]; + } + } + + isFixedProperty && (fixed[names[length - 1]] = true); + roles[names[length - 1]] = isProperty ? true : {}; +} +function getType(value) { + var type = typeof value; + + if (type === OBJECT) { + if (isArray(value)) { + return ARRAY; + } else if (isPropertyObject(value)) { + return PROPERTY; + } + } else if (type === STRING || type === NUMBER) { + return "value"; + } + + return type; +} +function isPureObject(obj) { + return isObject(obj) && obj.constructor === Object; +} +function getNames(names, stack) { + var arr = []; + + if (isPureObject(names)) { + for (var name in names) { + stack.push(name); + arr = arr.concat(getNames(names[name], stack)); + stack.pop(); + } + } else { + arr.push(stack.slice()); + } + + return arr; +} +function updateFrame(names, properties) { + for (var name in properties) { + var value = properties[name]; + + if (!isPureObject(value)) { + names[name] = true; + continue; + } + + if (!isObject(names[name])) { + names[name] = {}; + } + + updateFrame(names[name], properties[name]); + } + + return names; +} +function toFixed(num) { + return Math.round(num * MAXIMUM) / MAXIMUM; +} +function getValueByNames(names, properties, length) { + if (length === void 0) { + length = names.length; + } + + var value = properties; + + for (var i = 0; i < length; ++i) { + if (!isObject(value) || value == null) { + return undefined; + } + + value = value[names[i]]; + } + + return value; +} +function isInProperties(roles, args, isCheckTrue) { + var length = args.length; + var role = roles; + + if (length === 0) { + return false; + } + + for (var i = 0; i < length; ++i) { + if (role === true) { + return false; + } + + role = role[args[i]]; + + if (!role || !isCheckTrue && role === true) { + return false; + } + } + + return true; +} +function isRole(args, isCheckTrue) { + return isInProperties(ROLES, args, isCheckTrue); +} +function isFixed(args) { + return isInProperties(FIXED, args, true); +} +function setPlayCSS(item, isActivate) { + item.state[PLAY_CSS] = isActivate; +} +function isPausedCSS(item) { + return item.state[PLAY_CSS] && item.isPaused(); +} +function isEndedCSS(item) { + return !item.isEnded() && item.state[PLAY_CSS]; +} +function makeId(selector) { + for (;;) { + var id = "" + Math.floor(Math.random() * 10000000); + + if (!IS_WINDOW || !selector) { + return id; + } + + var checkElement = $("[data-scene-id=\"" + id + "\"]"); + + if (!checkElement) { + return id; + } + } +} +function getRealId(item) { + return item.getId() || item.setId(makeId(false)).getId(); +} +function toId(text) { + return ("" + text).match(/[0-9a-zA-Z]+/g).join(""); +} +function playCSS(item, isExportCSS, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + if (!ANIMATION || item.getPlayState() === RUNNING) { + return; + } + + var className = playClassName || START_ANIMATION; + + if (isPausedCSS(item)) { + item.addPlayClass(true, className, properties); + } else { + if (item.isEnded()) { + item.setTime(0); + } + + isExportCSS && item.exportCSS({ + className: className + }); + var el = item.addPlayClass(false, className, properties); + + if (!el) { + return; + } + + addAnimationEvent(item, el); + setPlayCSS(item, true); + } + + item.setPlayState(RUNNING); +} +function addAnimationEvent(item, el) { + var state = item.state; + var duration = item.getDuration(); + var isZeroDuration = !duration || !isFinite(duration); + + var animationend = function () { + setPlayCSS(item, false); + item.finish(); + }; + + var animationstart = function () { + item.trigger(PLAY); + addEvent(el, "animationcancel", animationend); + addEvent(el, "animationend", animationend); + addEvent(el, "animationiteration", animationiteration); + }; + + item.once(ENDED, function () { + removeEvent(el, "animationcancel", animationend); + removeEvent(el, "animationend", animationend); + removeEvent(el, "animationiteration", animationiteration); + removeEvent(el, "animationstart", animationstart); + }); + + var animationiteration = function (_a) { + var elapsedTime = _a.elapsedTime; + var currentTime = elapsedTime; + var iterationCount = isZeroDuration ? 0 : currentTime / duration; + state[CURRENT_TIME] = currentTime; + item.setIteration(iterationCount); + }; + + addEvent(el, "animationstart", animationstart); +} +function getEasing(curveArray) { + var easing; + + if (isString(curveArray)) { + if (curveArray in EASINGS) { + easing = EASINGS[curveArray]; + } else { + var obj = toPropertyObject(curveArray); + + if (isString(obj)) { + return 0; + } else { + if (obj.model === "cubic-bezier") { + curveArray = obj.value.map(function (v) { + return parseFloat(v); + }); + easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]); + } else if (obj.model === "steps") { + easing = steps(parseFloat(obj.value[0]), obj.value[1]); + } else { + return 0; + } + } + } + } else if (isArray(curveArray)) { + easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]); + } else { + easing = curveArray; + } + + return easing; +} + +function GetterSetter(getter, setter, parent) { + return function (constructor) { + var prototype = constructor.prototype; + getter.forEach(function (name) { + prototype[camelize("get " + name)] = function () { + return this[parent][name]; + }; + }); + setter.forEach(function (name) { + prototype[camelize("set " + name)] = function (value) { + this[parent][name] = value; + return this; + }; + }); + }; +} + +function isDirectionReverse(iteration, iteraiontCount, direction) { + if (direction === REVERSE) { + return true; + } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) { + return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE); + } + + return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE); +} +/** +* @typedef {Object} AnimatorState The Animator options. Properties used in css animation. +* @property {number} [duration] The duration property defines how long an animation should take to complete one cycle. +* @property {"none"|"forwards"|"backwards"|"both"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both). +* @property {"infinite"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played. +* @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation. +* @property {number} [delay] The delay property specifies a delay for the start of an animation. +* @property {"normal"|"reverse"|"alternate"|"alternate-reverse"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles. +*/ + +var setters = ["id", ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE]; + +var getters = __spreadArrays(setters, [EASING, EASING_NAME]); +/** +* play video, animation, the others +* @extends EventTrigger +* @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation} +*/ + + +var Animator = +/*#__PURE__*/ +function (_super) { + __extends(Animator, _super); + /** + * @param - animator's options + * @example + const animator = new Animator({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.easing.EASE, + }); + */ + + + function Animator(options) { + var _this = _super.call(this) || this; + + _this.timerId = 0; + _this.state = { + id: "", + easing: 0, + easingName: "linear", + iterationCount: 1, + delay: 0, + fillMode: "forwards", + direction: NORMAL, + playSpeed: 1, + currentTime: 0, + iterationTime: -1, + iteration: 0, + tickTime: 0, + prevTime: 0, + playState: PAUSED, + duration: 0 + }; + + _this.setOptions(options); + + return _this; + } + /** + * set animator's easing. + * @param curverArray - The speed curve of an animation. + * @return {Animator} An instance itself. + * @example + animator.({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.easing.EASE, + }); + */ + + + var __proto = Animator.prototype; + + __proto.setEasing = function (curveArray) { + var easing = getEasing(curveArray); + var easingName = easing && easing[EASING_NAME] || "linear"; + var state = this.state; + state[EASING] = easing; + state[EASING_NAME] = easingName; + return this; + }; + /** + * set animator's options. + * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation} + * @param - animator's options + * @return {Animator} An instance itself. + * @example + animator.({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.eaasing.EASE, + }); + */ + + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + for (var name in options) { + var value = options[name]; + + if (name === EASING) { + this.setEasing(value); + continue; + } else if (name === DURATION) { + value && this.setDuration(value); + continue; + } + + if (OPTIONS.indexOf(name) > -1) { + this.state[name] = value; + } + } + + return this; + }; + /** + * Get the animator's total duration including delay + * @return {number} Total duration + * @example + animator.getTotalDuration(); + */ + + + __proto.getTotalDuration = function () { + return this.getActiveDuration(true); + }; + /** + * Get the animator's total duration excluding delay + * @return {number} Total duration excluding delay + * @example + animator.getActiveDuration(); + */ + + + __proto.getActiveDuration = function (delay) { + var state = this.state; + var count = state[ITERATION_COUNT]; + + if (count === INFINITE) { + return Infinity; + } + + return (delay ? state[DELAY] : 0) + this.getDuration() * count; + }; + /** + * Check if the animator has reached the end. + * @return {boolean} ended + * @example + animator.isEnded(); // true or false + */ + + + __proto.isEnded = function () { + if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) { + return true; + } else if (this.getTime() < this.getActiveDuration()) { + return false; + } + + return true; + }; + /** + *Check if the animator is paused: + * @return {boolean} paused + * @example + animator.isPaused(); // true or false + */ + + + __proto.isPaused = function () { + return this.state[PLAY_STATE] === PAUSED; + }; + + __proto.start = function (delay) { + if (delay === void 0) { + delay = this.state[DELAY]; + } + + var state = this.state; + state[PLAY_STATE] = RUNNING; + + if (state[TICK_TIME] >= delay) { + /** + * This event is fired when play animator. + * @event Animator#play + */ + this.trigger(PLAY); + return true; + } + + return false; + }; + /** + * play animator + * @return {Animator} An instance itself. + */ + + + __proto.play = function (toTime) { + var _this = this; + + var state = this.state; + var delay = state[DELAY]; + var currentTime = this.getTime(); + state[PLAY_STATE] = RUNNING; + + if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) { + this.setTime(-delay, true); + } + + this.timerId = requestAnimationFrame(function (time) { + state[PREV_TIME] = time; + + _this.tick(time, toTime); + }); + this.start(); + return this; + }; + /** + * pause animator + * @return {Animator} An instance itself. + */ + + + __proto.pause = function () { + var state = this.state; + + if (state[PLAY_STATE] !== PAUSED) { + state[PLAY_STATE] = PAUSED; + /** + * This event is fired when animator is paused. + * @event Animator#paused + */ + + this.trigger(PAUSED); + } + + cancelAnimationFrame(this.timerId); + return this; + }; + /** + * end animator + * @return {Animator} An instance itself. + */ + + + __proto.finish = function () { + this.setTime(0); + this.state[TICK_TIME] = 0; + this.end(); + return this; + }; + /** + * end animator + * @return {Animator} An instance itself. + */ + + + __proto.end = function () { + this.pause(); + /** + * This event is fired when animator is ended. + * @event Animator#ended + */ + + this.trigger(ENDED); + return this; + }; + /** + * set currentTime + * @param {Number|String} time - currentTime + * @return {Animator} An instance itself. + * @example + animator.setTime("from"); // 0 + animator.setTime("to"); // 100% + animator.setTime("50%"); + animator.setTime(10); + animator.getTime() // 10 + */ + + + __proto.setTime = function (time, isTick, isParent) { + var activeDuration = this.getActiveDuration(); + var state = this.state; + var prevTime = state[TICK_TIME]; + var delay = state[DELAY]; + var currentTime = isTick ? time : this.getUnitTime(time); + state[TICK_TIME] = delay + currentTime; + + if (currentTime < 0) { + currentTime = 0; + } else if (currentTime > activeDuration) { + currentTime = activeDuration; + } + + state[CURRENT_TIME] = currentTime; + this.calculate(); + + if (isTick && !isParent) { + var tickTime = state[TICK_TIME]; + + if (prevTime < delay && time >= 0) { + this.start(0); + } + + if (tickTime < prevTime || this.isEnded()) { + this.end(); + return; + } + } + + if (this.isDelay()) { + return this; + } + /** + * This event is fired when the animator updates the time. + * @event Animator#timeupdate + * @param {Object} param The object of data to be sent to an event. + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.time The iteration time during duration that the animator is running. + * @param {Number} param.iterationCount The iteration count that the animator is running. + */ + + + this.trigger(TIMEUPDATE, { + currentTime: currentTime, + time: this.getIterationTime(), + iterationCount: state[ITERATION] + }); + return this; + }; + /** + * Get the animator's current time + * @return {number} current time + * @example + animator.getTime(); + */ + + + __proto.getTime = function () { + return this.state[CURRENT_TIME]; + }; + + __proto.getUnitTime = function (time) { + if (isString(time)) { + var duration = this.getDuration() || 100; + + if (time === "from") { + return 0; + } else if (time === "to") { + return duration; + } + + var _a = splitUnit(time), + unit = _a.unit, + value = _a.value; + + if (unit === "%") { + !this.getDuration() && this.setDuration(duration); + return toFixed(parseFloat(time) / 100 * duration); + } else if (unit === ">") { + return value + THRESHOLD; + } else { + return value; + } + } else { + return toFixed(time); + } + }; + /** + * Check if the current state of animator is delayed. + * @return {boolean} check delay state + */ + + + __proto.isDelay = function () { + var state = this.state; + var delay = state[DELAY]; + var tickTime = state[TICK_TIME]; + return delay > 0 && tickTime < delay; + }; + + __proto.setIteration = function (iterationCount) { + var state = this.state; + var passIterationCount = Math.floor(iterationCount); + var maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT]; + + if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) { + /** + * The event is fired when an iteration of an animation ends. + * @event Animator#iteration + * @param {Object} param The object of data to be sent to an event. + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.iterationCount The iteration count that the animator is running. + */ + this.trigger("iteration", { + currentTime: state[CURRENT_TIME], + iterationCount: passIterationCount + }); + } + + state[ITERATION] = iterationCount; + return this; + }; + + __proto.calculate = function () { + var state = this.state; + var iterationCount = state[ITERATION_COUNT]; + var fillMode = state[FILL_MODE]; + var direction = state[DIRECTION]; + var duration = this.getDuration(); + var time = this.getTime(); + var iteration = duration === 0 ? 0 : time / duration; + var currentIterationTime = duration ? time % duration : 0; + + if (!duration) { + this.setIterationTime(0); + return this; + } + + this.setIteration(iteration); // direction : normal, reverse, alternate, alternate-reverse + // fillMode : forwards, backwards, both, none + + var isReverse = isDirectionReverse(iteration, iterationCount, direction); + var isFiniteDuration = isFinite(duration); + + if (isFiniteDuration && isReverse) { + currentIterationTime = duration - currentIterationTime; + } + + if (isFiniteDuration && iterationCount !== INFINITE) { + var isForwards = fillMode === "both" || fillMode === "forwards"; // fill forwards + + if (iteration >= iterationCount) { + currentIterationTime = duration * (isForwards ? iterationCount % 1 || 1 : 0); + isReverse && (currentIterationTime = duration - currentIterationTime); + } + } + + this.setIterationTime(currentIterationTime); + return this; + }; + + __proto.tick = function (now, to) { + var _this = this; + + if (this.isPaused()) { + return; + } + + var state = this.state; + var playSpeed = state[PLAY_SPEED]; + var prevTime = state[PREV_TIME]; + var delay = state[DELAY]; + var tickTime = state[TICK_TIME]; + var currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed; + state[PREV_TIME] = now; + this.setTime(currentTime - delay, true); + + if (to && to * 1000 < now) { + this.pause(); + } + + if (state[PLAY_STATE] === PAUSED) { + return; + } + + this.timerId = requestAnimationFrame(function (time) { + _this.tick(time, to); + }); + }; + + Animator = __decorate([GetterSetter(getters, setters, "state")], Animator); + return Animator; +}(EventTrigger); + +function toInnerProperties(obj, orders) { + if (orders === void 0) { + orders = []; + } + + if (!obj) { + return ""; + } + + var arrObj = []; + var keys = getKeys(obj); + sortOrders(keys, orders); + keys.forEach(function (name) { + arrObj.push(name.replace(/\d$/g, "") + "(" + obj[name] + ")"); + }); + return arrObj.join(" "); +} +/* eslint-disable */ + + +function clone(target, toValue) { + if (toValue === void 0) { + toValue = false; + } + + return merge({}, target, toValue); +} + +function merge(to, from, toValue) { + if (toValue === void 0) { + toValue = false; + } + + for (var name in from) { + var value = from[name]; + var type = getType(value); + + if (type === PROPERTY) { + to[name] = toValue ? value.toValue() : value.clone(); + } else if (type === FUNCTION) { + to[name] = toValue ? getValue([name], value) : value; + } else if (type === ARRAY) { + to[name] = value.slice(); + } else if (type === OBJECT) { + if (isObject(to[name]) && !isPropertyObject(to[name])) { + merge(to[name], value, toValue); + } else { + to[name] = clone(value, toValue); + } + } else { + to[name] = from[name]; + } + } + + return to; +} +/* eslint-enable */ + + +function getPropertyName(args) { + return args[0] in ALIAS ? ALIAS[args[0]] : args; +} + +function getValue(names, value) { + var type = getType(value); + + if (type === PROPERTY) { + return value.toValue(); + } else if (type === FUNCTION) { + if (names[0] !== TIMING_FUNCTION) { + return getValue(names, value()); + } + } else if (type === OBJECT) { + return clone(value, true); + } + + return value; +} +/** +* Animation's Frame +*/ + + +var Frame = +/*#__PURE__*/ +function () { + /** + * @param - properties + * @example + const frame = new Scene.Frame({ + display: "none" + transform: { + translate: "50px", + scale: "5, 5", + } + }); + */ + function Frame(properties) { + if (properties === void 0) { + properties = {}; + } + + this.properties = {}; + this.orderMap = new OrderMap(NAME_SEPARATOR); + this.properties = {}; // this.orders = []; + + this.set(properties); + } + /** + * get property value + * @param {...Number|String|PropertyObject} args - property name or value + * @example + frame.get("display") // => "none", "block", .... + frame.get("transform", "translate") // => "10px,10px" + */ + + + var __proto = Frame.prototype; + + __proto.get = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var value = this.raw.apply(this, args); + return getValue(getPropertyName(args), value); + }; + /** + * get properties orders + * @param - property names + * @example + frame.getOrders(["display"]) // => [] + frame.getOrders(["transform"]) // => ["translate", "scale"] + */ + + + __proto.getOrders = function (names) { + return this.orderMap.get(names); + }; + /** + * set properties orders + * @param - property names + * @param - orders + * @example + frame.getOrders(["transform"]) // => ["translate", "scale"] + frame.setOrders(["transform"], ["scale", "tralsate"]) + */ + + + __proto.setOrders = function (names, orders) { + return this.orderMap.set(names, orders); + }; + /** + * get properties order object + * @example + console.log(frame.getOrderObject()); + */ + + + __proto.getOrderObject = function () { + return this.orderMap.getObject(); + }; + /** + * set properties orders object + * @param - properties orders object + * @example + frame.setOrderObject({ + "": ["transform"], + "transform": ["scale", "tralsate"], + }); + */ + + + __proto.setOrderObject = function (obj) { + this.orderMap.setObject(obj); + }; + /** + * get property keys + * @param - property names + * @example + frame.gets("display") // => [] + frame.gets("transform") // => ["translate"] + */ + + + __proto.getKeys = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var value = this.raw.apply(this, args); + var keys = getType(value) === OBJECT ? getKeys(value) : []; + sortOrders(keys, this.orderMap.get(args)); + return keys; + }; + /** + * get properties array + * @param - property names + * @example + frame.gets("display") // => [] + frame.gets("transform") // => [{ key: "translate", value: "10px, 10px", children: [] }] + */ + + + __proto.gets = function () { + var _this = this; + + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var values = this.get.apply(this, args); + var keys = this.getKeys.apply(this, args); + return keys.map(function (key) { + var nextValue = values[key]; + return { + key: key, + value: nextValue, + children: _this.gets.apply(_this, __spreadArrays(args, [key])) + }; + }); + }; + + __proto.raw = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + return getValueByNames(getPropertyName(args), this.properties); + }; + /** + * remove property value + * @param {...String} args - property name + * @return {Frame} An instance itself + * @example + frame.remove("display") + */ + + + __proto.remove = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var params = getPropertyName(args); + var length = params.length; + + if (!length) { + return this; + } + + this.orderMap.remove(params); + var value = getValueByNames(params, this.properties, length - 1); + + if (isObject(value)) { + delete value[params[length - 1]]; + } + + return this; + }; + /** + * set property + * @param {...Number|String|PropertyObject} args - property names or values + * @return {Frame} An instance itself + * @example + // one parameter + frame.set({ + display: "none", + transform: { + translate: "10px, 10px", + scale: "1", + }, + filter: { + brightness: "50%", + grayscale: "100%" + } + }); + // two parameters + frame.set("transform", { + translate: "10px, 10px", + scale: "1", + }); + // three parameters + frame.set("transform", "translate", "50px"); + */ + + + __proto.set = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var self = this; + var length = args.length; + var params = args.slice(0, -1); + var value = args[length - 1]; + var firstParam = params[0]; + + if (length === 1 && value instanceof Frame) { + self.merge(value); + } else if (firstParam in ALIAS) { + self._set(ALIAS[firstParam], value); + } else if (length === 2 && isArray(firstParam)) { + self._set(firstParam, value); + } else if (isPropertyObject(value)) { + if (isRole(params)) { + self.set.apply(self, __spreadArrays(params, [toObject(value)])); + } else { + self._set(params, value); + } + } else if (isArray(value)) { + self._set(params, value); + } else if (isObject(value)) { + if (!self.has.apply(self, params) && isRole(params)) { + self._set(params, {}); + } + + for (var name in value) { + self.set.apply(self, __spreadArrays(params, [name, value[name]])); + } + } else if (isString(value)) { + if (isRole(params, true)) { + if (isFixed(params) || !isRole(params)) { + this._set(params, value); + } else { + var obj = toPropertyObject(value); + + if (isObject(obj)) { + self.set.apply(self, __spreadArrays(params, [obj])); + } + } + + return this; + } else { + var _a = splitStyle(value), + styles = _a.styles, + stylesLength = _a.length; + + for (var name in styles) { + self.set.apply(self, __spreadArrays(params, [name, styles[name]])); + } + + if (stylesLength) { + return this; + } + } + + self._set(params, value); + } else { + self._set(params, value); + } + + return self; + }; + /** + * Gets the names of properties. + * @return the names of properties. + * @example + // one parameter + frame.set({ + display: "none", + transform: { + translate: "10px, 10px", + scale: "1", + }, + }); + // [["display"], ["transform", "translate"], ["transform", "scale"]] + console.log(frame.getNames()); + */ + + + __proto.getNames = function () { + return getNames(this.properties, []); + }; + /** + * check that has property. + * @param {...String} args - property name + * @example + frame.has("property", "display") // => true or false + */ + + + __proto.has = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var params = getPropertyName(args); + var length = params.length; + + if (!length) { + return false; + } + + return !isUndefined(getValueByNames(params, this.properties, length)); + }; + /** + * clone frame. + * @return {Frame} An instance of clone + * @example + frame.clone(); + */ + + + __proto.clone = function () { + var frame = new Frame(); + frame.setOrderObject(this.orderMap.orderMap); + return frame.merge(this); + }; + /** + * merge one frame to other frame. + * @param - target frame. + * @return {Frame} An instance itself + * @example + frame.merge(frame2); + */ + + + __proto.merge = function (frame) { + var properties = this.properties; + var frameProperties = frame.properties; + + if (frameProperties) { + merge(properties, frameProperties); + } + + return this; + }; + /** + * Specifies an css object that coverted the frame. + * @return {object} cssObject + */ + + + __proto.toCSSObject = function () { + var properties = this.get(); + var cssObject = {}; + + for (var name in properties) { + if (isRole([name], true)) { + continue; + } + + var value = properties[name]; + + if (name === TIMING_FUNCTION) { + cssObject[TIMING_FUNCTION.replace("animation", ANIMATION)] = (isString(value) ? value : value[EASING_NAME]) || "initial"; + } else { + cssObject[name] = value; + } + } + + var transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME])); + var filter = toInnerProperties(properties.filter, this.orderMap.get([FILTER])); + TRANSFORM && transform && (cssObject[TRANSFORM] = transform); + FILTER && filter && (cssObject[FILTER] = filter); + return cssObject; + }; + /** + * Specifies an css text that coverted the frame. + * @return {string} cssText + */ + + + __proto.toCSS = function () { + var cssObject = this.toCSSObject(); + var cssArray = []; + var keys = getKeys(cssObject); + sortOrders(keys, this.orderMap.get([])); + keys.forEach(function (name) { + cssArray.push(name + ":" + cssObject[name] + ";"); + }); + return cssArray.join(""); + }; + /** + * Remove All Properties + * @return {Frame} An instance itself + */ + + + __proto.clear = function () { + this.properties = {}; + this.orderMap.clear(); + return this; + }; + + __proto._set = function (args, value) { + var properties = this.properties; + var length = args.length; + + for (var i = 0; i < length - 1; ++i) { + var name = args[i]; + !(name in properties) && (properties[name] = {}); + properties = properties[name]; + } + + if (!length) { + return; + } + + var lastParam = args[length - 1]; + this.orderMap.add(args); + + if (length === 1 && lastParam === TIMING_FUNCTION) { + properties[lastParam] = getEasing(value); + } else { + properties[lastParam] = isString(value) && !isFixed(args) ? toPropertyObject(value, lastParam) : value; + } + }; + + return Frame; +}(); + +function dotArray(a1, a2, b1, b2) { + var length = a2.length; + return a1.map(function (v1, i) { + if (i >= length) { + return v1; + } else { + return dot(v1, a2[i], b1, b2); + } + }); +} + +function dotColor(color1, color2, b1, b2) { + // convert array to PropertyObject(type=color) + var value1 = color1.value; + var value2 = color2.value; // If the model name is not same, the inner product is impossible. + + var model1 = color1.model; + var model2 = color2.model; + + if (model1 !== model2) { + // It is recognized as a string. + return dot(color1.toValue(), color2.toValue(), b1, b2); + } + + if (value1.length === 3) { + value1[3] = 1; + } + + if (value2.length === 3) { + value2[3] = 1; + } + + var v = dotArray(value1, value2, b1, b2); + var colorModel = model1; + + for (var i = 0; i < 3; ++i) { + v[i] = parseInt(v[i], 10); + } + + var object = new PropertyObject(v, { + type: "color", + model: colorModel, + prefix: colorModel + "(", + suffix: ")" + }); + return object; +} + +function dotObject(a1, a2, b1, b2) { + var a1Type = a1.type; + + if (a1Type === "color") { + return dotColor(a1, a2, b1, b2); + } + + var value1 = a1.value; + var value2 = a2.value; + var arr = dotArray(value1, value2, b1, b2); + return new PropertyObject(arr, { + type: a1Type, + separator: a1.separator || a2.separator, + prefix: a1.prefix || a2.prefix, + suffix: a1.suffix || a2.suffix, + model: a1.model || a2.model + }); +} +/** +* The dot product of a1 and a2 for the b1 and b2. +* @memberof Dot +* @function dot +* @param {String|Number|PropertyObject} a1 value1 +* @param {String|Number|PropertyObject} a2 value2 +* @param {Number} b1 b1 ratio +* @param {Number} b2 b2 ratio +* @return {String} Not Array, Not Separator, Only Number & Unit +* @return {PropertyObject} Array with Separator. +* @example +dot(1, 3, 0.3, 0.7); +// => 1.6 +*/ + + +function dot(a1, a2, b1, b2) { + if (b2 === 0) { + return a2; + } else if (b1 === 0 || b1 + b2 === 0) { + // prevent division by zero. + return a1; + } // dot Object + + + var type1 = getType(a1); + var type2 = getType(a2); + var isFunction1 = type1 === FUNCTION; + var isFunction2 = type2 === FUNCTION; + + if (isFunction1 || isFunction2) { + return function () { + return dot(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2); + }; + } else if (type1 === type2) { + if (type1 === PROPERTY) { + return dotObject(a1, a2, b1, b2); + } else if (type1 === ARRAY) { + return dotArray(a1, a2, b1, b2); + } else if (type1 !== "value") { + return a1; + } + } else { + return a1; + } + + var v1 = splitUnit("" + a1); + var v2 = splitUnit("" + a2); + var v; // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환 + + if (isNaN(v1.value) || isNaN(v2.value)) { + return a1; + } else { + v = dot$1(v1.value, v2.value, b1, b2); + } + + var prefix = v1.prefix || v2.prefix; + var unit = v1.unit || v2.unit; + + if (!prefix && !unit) { + return v; + } + + return prefix + v + unit; +} +function dotValue(time, prevTime, nextTime, prevValue, nextValue, easing) { + if (time === prevTime) { + return prevValue; + } else if (time === nextTime) { + return nextValue; + } else if (!easing) { + return dot(prevValue, nextValue, time - prevTime, nextTime - time); + } + + var ratio = easing((time - prevTime) / (nextTime - prevTime)); + var value = dot(prevValue, nextValue, ratio, 1 - ratio); + return value; +} + +function getNearTimeIndex(times, time) { + var length = times.length; + + for (var i = 0; i < length; ++i) { + if (times[i] === time) { + return [i, i]; + } else if (times[i] > time) { + return [i > 0 ? i - 1 : 0, i]; + } + } + + return [length - 1, length - 1]; +} + +function makeAnimationProperties(properties) { + var cssArray = []; + + for (var name in properties) { + cssArray.push(ANIMATION + "-" + decamelize(name) + ":" + properties[name] + ";"); + } + + return cssArray.join(""); +} + +function addTime(times, time) { + var length = times.length; + + for (var i = 0; i < length; ++i) { + if (time < times[i]) { + times.splice(i, 0, time); + return; + } + } + + times[length] = time; +} + +function addEntry(entries, time, keytime) { + var prevEntry = entries[entries.length - 1]; + (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) && entries.push([toFixed(time), toFixed(keytime)]); +} + +function getEntries(times, states) { + var entries = times.map(function (time) { + return [time, time]; + }); + var nextEntries = []; + states.forEach(function (state) { + var iterationCount = state[ITERATION_COUNT]; + var delay = state[DELAY]; + var playSpeed = state[PLAY_SPEED]; + var direction = state[DIRECTION]; + var intCount = Math.ceil(iterationCount); + var currentDuration = entries[entries.length - 1][0]; + var length = entries.length; + var lastTime = currentDuration * iterationCount; + + for (var i = 0; i < intCount; ++i) { + var isReverse = direction === REVERSE || direction === ALTERNATE && i % 2 || direction === ALTERNATE_REVERSE && !(i % 2); + + for (var j = 0; j < length; ++j) { + var entry = entries[isReverse ? length - j - 1 : j]; + var time = entry[1]; + var currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]); + var prevEntry = entries[isReverse ? length - j : j - 1]; + + if (currentTime > lastTime) { + if (j !== 0) { + var prevTime = currentDuration * i + (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]); + var divideTime = dot$1(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime); + addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime); + } + + break; + } else if (currentTime === lastTime && nextEntries.length && nextEntries[nextEntries.length - 1][0] === lastTime + delay) { + break; + } + + addEntry(nextEntries, (delay + currentTime) / playSpeed, time); + } + } // delay time + + + delay && nextEntries.unshift([0, nextEntries[0][1]]); + entries = nextEntries; + nextEntries = []; + }); + return entries; +} +/** +* manage Frame Keyframes and play keyframes. +* @extends Animator +* @example +const item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } +}); +*/ + +var SceneItem = +/*#__PURE__*/ +function (_super) { + __extends(SceneItem, _super); + /** + * @param - properties + * @param - options + * @example + const item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + */ + + + function SceneItem(properties, options) { + var _this = _super.call(this) || this; + + _this.times = []; + _this.items = {}; + _this.nameMap = new OrderMap(NAME_SEPARATOR); + _this.elements = []; + _this.needUpdate = true; + + _this.load(properties, options); + + return _this; + } + + var __proto = SceneItem.prototype; + + __proto.getDuration = function () { + var times = this.times; + var length = times.length; + return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION]; + }; + /** + * get size of list + * @return {Number} length of list + */ + + + __proto.size = function () { + return this.times.length; + }; + + __proto.setDuration = function (duration) { + if (!duration) { + return this; + } + + var originalDuration = this.getDuration(); + + if (originalDuration > 0) { + var ratio_1 = duration / originalDuration; + + var _a = this, + times = _a.times, + items_1 = _a.items; + + var obj_1 = {}; + this.times = times.map(function (time) { + var time2 = toFixed(time * ratio_1); + obj_1[time2] = items_1[time]; + return time2; + }); + this.items = obj_1; + } else { + this.newFrame(duration); + } + + return this; + }; + + __proto.setId = function (id) { + var state = this.state; + var elements = this.elements; + var length = elements.length; + state.id = id || makeId(!!length); + + if (length && !state[SELECTOR]) { + var sceneId_1 = toId(this.getId()); + state[SELECTOR] = "[" + DATA_SCENE_ID + "=\"" + sceneId_1 + "\"]"; + elements.forEach(function (element) { + element.setAttribute(DATA_SCENE_ID, sceneId_1); + }); + } + + return this; + }; + /** + * Set properties to the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} [properties] - property names or values + * @return {SceneItem} An instance itself + * @example + item.set(0, "a", "b") // item.getFrame(0).set("a", "b") + console.log(item.get(0, "a")); // "b" + */ + + + __proto.set = function (time) { + var _this = this; + + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + if (time instanceof SceneItem) { + return this.set(0, time); + } else if (isArray(time)) { + var length = time.length; + + for (var i = 0; i < length; ++i) { + var t = length === 1 ? 0 : this.getUnitTime(i / (length - 1) * 100 + "%"); + this.set(t, time[i]); + } + } else if (isObject(time)) { + var _loop_1 = function (t) { + var value = time[t]; + splitComma(t).forEach(function (eachTime) { + var realTime = _this.getUnitTime(eachTime); + + if (isNaN(realTime)) { + getNames(value, [eachTime]).forEach(function (names) { + var _a; + + var innerValue = getValueByNames(names.slice(1), value); + var arr = isArray(innerValue) ? innerValue : [getValueByNames(names, _this.target), innerValue]; + var length = arr.length; + + for (var i = 0; i < length; ++i) { + (_a = _this.newFrame(i / (length - 1) * 100 + "%")).set.apply(_a, __spreadArrays(names, [arr[i]])); + } + }); + } else { + _this.set(realTime, value); + } + }); + }; + + for (var t in time) { + _loop_1(t); + } + } else if (!isUndefined(time)) { + var value_1 = args[0]; + splitComma(time + "").forEach(function (eachTime) { + var realTime = _this.getUnitTime(eachTime); + + if (value_1 instanceof SceneItem) { + var delay = value_1.getDelay(); + var frames = value_1.toObject(!_this.hasFrame(realTime + delay)); + var duration = value_1.getDuration(); + var direction = value_1.getDirection(); + var isReverse = direction.indexOf("reverse") > -1; + + for (var frameTime in frames) { + var nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime); + + _this.set(realTime + nextTime, frames[frameTime]); + } + } else if (args.length === 1 && isArray(value_1)) { + value_1.forEach(function (item) { + _this.set(realTime, item); + }); + } else { + var frame = _this.newFrame(realTime); + + frame.set.apply(frame, args); + } + }); + } + + this.needUpdate = true; + return this; + }; + /** + * Get properties of the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} args property's name or properties + * @return {Number|String|PropertyObejct} property value + * @example + item.get(0, "a"); // item.getFrame(0).get("a"); + item.get(0, "transform", "translate"); // item.getFrame(0).get("transform", "translate"); + */ + + + __proto.get = function (time) { + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + var frame = this.getFrame(time); + return frame && frame.get.apply(frame, args); + }; + /** + * get properties orders + * @param - property names + * @example + item.getOrders(["display"]) // => [] + item.getOrders(["transform"]) // => ["translate", "scale"] + */ + + + __proto.getOrders = function (names) { + this.needUpdate && this.update(); + return this.nameMap.get(names); + }; + /** + * set properties orders + * @param - property names + * @param - orders + * @example + item.getOrders(["transform"]) // => ["translate", "scale"] + item.setOrders(["transform"], ["scale", "tralsate"]) + */ + + + __proto.setOrders = function (names, orders) { + this.needUpdate && this.update(); + var result = this.nameMap.set(names, orders); + this.updateFrameOrders(); + return result; + }; + /** + * get properties order object + * @example + console.log(item.getOrderObject()); + */ + + + __proto.getOrderObject = function () { + return this.nameMap.getObject(); + }; + /** + * set properties orders object + * @param - properties orders object + * @example + item.setOrderObject({ + "": ["transform"], + "transform": ["scale", "tralsate"], + }); + */ + + + __proto.setOrderObject = function (obj) { + this.nameMap.setObject(obj); + this.updateFrameOrders(); + }; + /** + * remove properties to the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} [properties] - property names or values + * @return {SceneItem} An instance itself + * @example + item.remove(0, "a"); + */ + + + __proto.remove = function (time) { + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + if (args.length) { + var frame = this.getFrame(time); + frame && frame.remove.apply(frame, args); + } else { + this.removeFrame(time); + } + + this.needUpdate = true; + return this; + }; + /** + * Append the item or object at the last time. + * @param - the scene item or item object + * @return An instance itself + * @example + item.append(new SceneItem({ + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + })); + item.append({ + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }); + item.set(item.getDuration(), { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }); + */ + + + __proto.append = function (item) { + if (item instanceof SceneItem) { + this.set(this.getDuration(), item); + } else { + this.append(new SceneItem(item)); + } + + return this; + }; + /** + * Push the front frames for the time and prepend the scene item or item object. + * @param - the scene item or item object + * @return An instance itself + */ + + + __proto.prepend = function (item) { + if (item instanceof SceneItem) { + var unshiftTime = item.getDuration() + item.getDelay(); + var firstFrame = this.getFrame(0); // remove first frame + + this.removeFrame(0); + this.unshift(unshiftTime); + this.set(0, item); + this.set(unshiftTime + THRESHOLD, firstFrame); + } else { + this.prepend(new SceneItem(item)); + } + + return this; + }; + /** + * Push out the amount of time. + * @param - time to push + * @example + item.get(0); // frame 0 + item.unshift(3); + item.get(3) // frame 0 + */ + + + __proto.unshift = function (time) { + var _a = this, + times = _a.times, + items = _a.items; + + var obj = {}; + this.times = times.map(function (t) { + var time2 = toFixed(time + t); + obj[time2] = items[t]; + return time2; + }); + this.items = obj; + return this; + }; + /** + * Get the frames in the item in object form. + * @return {} + * @example + item.toObject(); + // {0: {display: "none"}, 1: {display: "block"}} + */ + + + __proto.toObject = function (isStartZero) { + if (isStartZero === void 0) { + isStartZero = true; + } + + var obj = {}; + var delay = this.getDelay(); + this.forEach(function (frame, time) { + obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone(); + }); + return obj; + }; + /** + * Specifies an element to synchronize items' keyframes. + * @param {string} selectors - Selectors to find elements in items. + * @return {SceneItem} An instance itself + * @example + item.setSelector("#id.class"); + */ + + + __proto.setSelector = function (target) { + if (isFunction(target)) { + this.setElement(target(this.getId())); + } else { + this.setElement(target); + } + + return this; + }; + /** + * Get the elements connected to SceneItem. + */ + + + __proto.getElements = function () { + return this.elements; + }; + /** + * Specifies an element to synchronize item's keyframes. + * @param - elements to synchronize item's keyframes. + * @param - Make sure that you have peusdo. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setElement(document.querySelectorAll(".class")); + */ + + + __proto.setElements = function (target) { + return this.setElement(target); + }; + /** + * Specifies an element to synchronize item's keyframes. + * @param - elements to synchronize item's keyframes. + * @param - Make sure that you have peusdo. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setElement(document.querySelectorAll(".class")); + */ + + + __proto.setElement = function (target) { + var state = this.state; + var elements = []; + + if (!target) { + return this; + } else if (target === true || isString(target)) { + var selector = target === true ? "" + state.id : target; + var matches = /([\s\S]+)(:+[a-zA-Z]+)$/g.exec(selector); + elements = toArray($(matches ? matches[1] : selector, true)); + state[SELECTOR] = selector; + } else { + elements = target instanceof Element ? [target] : toArray(target); + } + + if (!elements.length) { + return this; + } + + this.elements = elements; + this.setId(this.getId()); + this.target = elements[0].style; + + this.targetFunc = function (frame) { + var attributes = frame.get("attribute"); + + if (attributes) { + var _loop_2 = function (name) { + elements.forEach(function (el) { + el.setAttribute(name, attributes[name]); + }); + }; + + for (var name in attributes) { + _loop_2(name); + } + } + + if (frame.has("html")) { + var html_1 = frame.get("html"); + elements.forEach(function (el) { + el.innerHTML = html_1; + }); + } + + var cssText = frame.toCSS(); + + if (state.cssText !== cssText) { + state.cssText = cssText; + elements.forEach(function (el) { + el.style.cssText += cssText; + }); + return frame; + } + }; + + return this; + }; + + __proto.setTarget = function (target) { + this.target = target; + + this.targetFunc = function (frame) { + var obj = frame.get(); + + for (var name in obj) { + target[name] = obj[name]; + } + }; + + return this; + }; + /** + * add css styles of items's element to the frame at that time. + * @param {Array} properties - elements to synchronize item's keyframes. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setCSS(0, ["opacity"]); + item.setCSS(0, ["opacity", "width", "height"]); + */ + + + __proto.setCSS = function (time, properties) { + this.set(time, fromCSS(this.elements, properties)); + return this; + }; + + __proto.setTime = function (time, isTick, isParent, parentEasing) { + _super.prototype.setTime.call(this, time, isTick, isParent); + + var iterationTime = this.getIterationTime(); + var easing = this.getEasing() || parentEasing; + var frame = this.getNowFrame(iterationTime, easing); + var currentTime = this.getTime(); + this.temp = frame; + /** + * This event is fired when timeupdate and animate. + * @event SceneItem#animate + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.time The iteration time during duration that the animator is running. + * @param {Frame} param.frame frame of that time. + */ + + this.trigger("animate", { + frame: frame, + currentTime: currentTime, + time: iterationTime + }); + this.targetFunc && this.targetFunc(frame); + return this; + }; + /** + * update property names used in frames. + * @return {SceneItem} An instance itself + * @example + item.update(); + */ + + + __proto.update = function () { + var prevNameMap = this.nameMap; + var names = {}; + this.forEach(function (frame) { + updateFrame(names, frame.properties); + }); + var nameMap = new OrderMap(NAME_SEPARATOR); + + function pushKeys(map, stack) { + var keys = getKeys(map); + sortOrders(keys, prevNameMap.get(stack)); + nameMap.set(stack, keys); + keys.forEach(function (key) { + var nextMap = map[key]; + + if (isObject(nextMap)) { + pushKeys(nextMap, __spreadArrays(stack, [key])); + } + }); + } + + pushKeys(names, []); + this.nameMap = nameMap; + this.forEach(function (frame) { + frame.setOrderObject(nameMap.orderMap); + }); + this.needUpdate = false; + return this; + }; + /** + * Create and add a frame to the sceneItem at that time + * @param {Number} time - frame's time + * @return {Frame} Created frame. + * @example + item.newFrame(time); + */ + + + __proto.newFrame = function (time) { + var frame = this.getFrame(time); + + if (frame) { + return frame; + } + + frame = new Frame(); + this.setFrame(time, frame); + return frame; + }; + /** + * Add a frame to the sceneItem at that time + * @param {Number} time - frame's time + * @return {SceneItem} An instance itself + * @example + item.setFrame(time, frame); + */ + + + __proto.setFrame = function (time, frame) { + var realTime = this.getUnitTime(time); + this.items[realTime] = frame; + addTime(this.times, realTime); + this.needUpdate = true; + return this; + }; + /** + * get sceneItem's frame at that time + * @param {Number} time - frame's time + * @return {Frame} sceneItem's frame at that time + * @example + const frame = item.getFrame(time); + */ + + + __proto.getFrame = function (time) { + return this.items[this.getUnitTime(time)]; + }; + /** + * remove sceneItem's frame at that time + * @param - frame's time + * @return {SceneItem} An instance itself + * @example + item.removeFrame(time); + */ + + + __proto.removeFrame = function (time) { + var realTime = this.getUnitTime(time); + var items = this.items; + var index = this.times.indexOf(realTime); + delete items[realTime]; // remove time + + if (index > -1) { + this.times.splice(index, 1); + } + + this.needUpdate = true; + return this; + }; + /** + * check if the item has a frame at that time + * @param {Number} time - frame's time + * @return {Boolean} true: the item has a frame // false: not + * @example + if (item.hasFrame(10)) { + // has + } else { + // not + } + */ + + + __proto.hasFrame = function (time) { + return this.getUnitTime(time) in this.items; + }; + /** + * Check if keyframes has propery's name + * @param - property's time + * @return {boolean} true: if has property, false: not + * @example + item.hasName(["transform", "translate"]); // true or not + */ + + + __proto.hasName = function (args) { + this.needUpdate && this.update(); + return !!this.nameMap.get(args); + }; + /** + * merge frame of the previous time at the next time. + * @param - The time of the frame to merge + * @param - The target frame + * @return {SceneItem} An instance itself + * @example + // getFrame(1) contains getFrame(0) + item.merge(0, 1); + */ + + + __proto.mergeFrame = function (time, frame) { + if (frame) { + var toFrame = this.newFrame(time); + toFrame.merge(frame); + } + + return this; + }; + /** + * Get frame of the current time + * @param {Number} time - the current time + * @param {function} easing - the speed curve of an animation + * @return {Frame} frame of the current time + * @example + let item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + // opacity: 0.7; display:"block"; + const frame = item.getNowFrame(1.7); + */ + + + __proto.getNowFrame = function (time, easing, isAccurate) { + var _this = this; + + this.needUpdate && this.update(); + var frame = new Frame(); + + var _a = getNearTimeIndex(this.times, time), + left = _a[0], + right = _a[1]; + + var realEasing = this.getEasing() || easing; + var nameMap = this.nameMap; + + if (this.hasName([TIMING_FUNCTION])) { + var nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true); + isFunction(nowEasing) && (realEasing = nowEasing); + } + + if (isAccurate) { + var prevFrame_1 = this.getFrame(time); + var prevOrderMap = prevFrame_1.orderMap.filter([], function (orders) { + return prevFrame_1.has.apply(prevFrame_1, orders); + }); + + for (var name in ROLES) { + var orders = nameMap.get([name]); + + if (prevOrderMap.get([name]) && orders) { + prevOrderMap.set([name], orders); + } + } + + nameMap = prevOrderMap; + } + + var names = nameMap.gets([]); + frame.setOrderObject(nameMap.orderMap); + names.forEach(function (properties) { + var value = _this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties)); + + if (isUndefined(value)) { + return; + } + + frame.set(properties, value); + }); + return frame; + }; + + __proto.load = function (properties, options) { + var _a; + + if (properties === void 0) { + properties = {}; + } + + if (options === void 0) { + options = properties.options; + } + + options && this.setOptions(options); + + if (isArray(properties)) { + this.set(properties); + } else if (properties.keyframes) { + this.set(properties.keyframes); + } else { + for (var time in properties) { + if (time !== "options") { + this.set((_a = {}, _a[time] = properties[time], _a)); + } + } + } + + if (options && options[DURATION]) { + this.setDuration(options[DURATION]); + } + + return this; + }; + /** + * clone SceneItem. + * @return {SceneItem} An instance of clone + * @example + * item.clone(); + */ + + + __proto.clone = function () { + var item = new SceneItem(); + item.setOptions(this.state); + item.setOrderObject(this.nameMap.orderMap); + this.forEach(function (frame, time) { + item.setFrame(time, frame.clone()); + }); + return item; + }; + /** + * executes a provided function once for each scene item. + * @param - Function to execute for each element, taking three arguments + * @return {Keyframes} An instance itself + */ + + + __proto.forEach = function (callback) { + var times = this.times; + var items = this.items; + times.forEach(function (time) { + callback(items[time], time, items); + }); + return this; + }; + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + _super.prototype.setOptions.call(this, options); + + var id = options.id, + selector = options.selector, + elements = options.elements, + element = options.element, + target = options.target; + id && this.setId(id); + + if (target) { + this.setTarget(target); + } else if (selector) { + this.setSelector(selector); + } else if (elements || element) { + this.setElement(elements || element); + } + + return this; + }; + + __proto.toCSS = function (playCondition, parentDuration, states) { + if (playCondition === void 0) { + playCondition = { + className: START_ANIMATION + }; + } + + if (parentDuration === void 0) { + parentDuration = this.getDuration(); + } + + if (states === void 0) { + states = []; + } + + var itemState = this.state; + var selector = itemState[SELECTOR]; + + if (!selector) { + return ""; + } + + var originalDuration = this.getDuration(); + itemState[DURATION] = originalDuration; + states.push(itemState); + var reversedStates = toArray(states).reverse(); + var id = toId(getRealId(this)); + var superParent = states[0]; + var infiniteIndex = findIndex(reversedStates, function (state) { + return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]); + }, states.length - 1); + var finiteStates = reversedStates.slice(0, infiniteIndex); + var duration = parentDuration || finiteStates.reduce(function (prev, cur) { + return (cur[DELAY] + prev * cur[ITERATION_COUNT]) / cur[PLAY_SPEED]; + }, originalDuration); + var delay = reversedStates.slice(infiniteIndex).reduce(function (prev, cur) { + return (prev + cur[DELAY]) / cur[PLAY_SPEED]; + }, 0); + var easingName = find(reversedStates, function (state) { + return state[EASING] && state[EASING_NAME]; + }, itemState)[EASING_NAME]; + var iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT]; + var fillMode = superParent[FILL_MODE]; + var direction = reversedStates[infiniteIndex][DIRECTION]; + var cssText = makeAnimationProperties({ + fillMode: fillMode, + direction: direction, + iterationCount: iterationCount, + delay: delay + "s", + name: PREFIX + "KEYFRAMES_" + id, + duration: duration / superParent[PLAY_SPEED] + "s", + timingFunction: easingName + }); + var selectors = splitComma(selector).map(function (sel) { + var matches = /([\s\S]+)(:+[a-zA-Z]+)$/g.exec(sel); + + if (matches) { + return [matches[1], matches[2]]; + } else { + return [sel, ""]; + } + }); + var className = playCondition.className; + var selectorCallback = playCondition.selector; + var preselector = isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback; + return "\n " + (preselector || selectors.map(function (_a) { + var sel = _a[0], + peusdo = _a[1]; + return sel + "." + className + peusdo; + })) + " {" + cssText + "}\n " + selectors.map(function (_a) { + var sel = _a[0], + peusdo = _a[1]; + return sel + "." + PAUSE_ANIMATION + peusdo; + }) + " {" + ANIMATION + "-play-state: paused;}\n @" + KEYFRAMES + " " + PREFIX + "KEYFRAMES_" + id + "{" + this._toKeyframes(duration, finiteStates, direction) + "}"; + }; + /** + * Export the CSS of the items to the style. + * @param - Add a selector or className to play. + * @return {SceneItem} An instance itself + */ + + + __proto.exportCSS = function (playCondition, duration, options) { + if (!this.elements.length) { + return ""; + } + + var css = this.toCSS(playCondition, duration, options); + var isParent = options && !isUndefined(options[ITERATION_COUNT]); + + if (!isParent) { + if (this.styledInjector) { + this.styledInjector.destroy(); + this.styledInjector = null; + } + + this.styled = styled(css); + this.styledInjector = this.styled.inject(this.getAnimationElement(), { + original: true + }); + } + + return this; + }; + + __proto.pause = function () { + _super.prototype.pause.call(this); + + isPausedCSS(this) && this.pauseCSS(); + return this; + }; + + __proto.pauseCSS = function () { + this.elements.forEach(function (element) { + addClass(element, PAUSE_ANIMATION); + }); + return this; + }; + + __proto.endCSS = function () { + this.elements.forEach(function (element) { + removeClass(element, PAUSE_ANIMATION); + removeClass(element, START_ANIMATION); + }); + setPlayCSS(this, false); + return this; + }; + + __proto.end = function () { + isEndedCSS(this) && this.endCSS(); + + _super.prototype.end.call(this); + + return this; + }; + /** + * Play using the css animation and keyframes. + * @param - Check if you want to export css. + * @param [playClassName="startAnimation"] - Add a class name to play. + * @param - The shorthand properties for six of the animation properties. + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp} + * @example + item.playCSS(); + item.playCSS(false, "startAnimation", { + direction: "reverse", + fillMode: "forwards", + }); + */ + + + __proto.playCSS = function (isExportCSS, playClassName, properties) { + if (isExportCSS === void 0) { + isExportCSS = true; + } + + if (properties === void 0) { + properties = {}; + } + + playCSS(this, isExportCSS, playClassName, properties); + return this; + }; + + __proto.getAnimationElement = function () { + return this.elements[0]; + }; + + __proto.addPlayClass = function (isPaused, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + var elements = this.elements; + var length = elements.length; + var cssText = makeAnimationProperties(properties); + + if (!length) { + return; + } + + if (isPaused) { + elements.forEach(function (element) { + removeClass(element, PAUSE_ANIMATION); + }); + } else { + elements.forEach(function (element) { + element.style.cssText += cssText; + + if (hasClass(element, START_ANIMATION)) { + removeClass(element, START_ANIMATION); + } + }); + elements.forEach(function (element) { + element.clientWidth; + }); + elements.forEach(function (element) { + addClass(element, START_ANIMATION); + }); + } + + return elements[0]; + }; + /** + * Clear All Frames + * @return {SceneItem} An instance itself + */ + + + __proto.clear = function () { + this.times = []; + this.items = {}; + this.nameMap = new OrderMap(NAME_SEPARATOR); + + if (this.styledInjector) { + this.styledInjector.destroy(); + } + + this.styled = null; + this.styledInjector = null; + this.temp = null; + this.needUpdate = true; + return this; + }; + + __proto.getNowValue = function (time, properties, left, right, isAccurate, easing, usePrevValue) { + var times = this.times; + var length = times.length; + var prevTime; + var nextTime; + var prevFrame; + var nextFrame; + var isUndefinedLeft = isUndefined(left); + var isUndefinedRight = isUndefined(right); + + if (isUndefinedLeft || isUndefinedRight) { + var indicies = getNearTimeIndex(times, time); + isUndefinedLeft && (left = indicies[0]); + isUndefinedRight && (right = indicies[1]); + } + + for (var i = left; i >= 0; --i) { + var frame = this.getFrame(times[i]); + + if (frame.has.apply(frame, properties)) { + prevTime = times[i]; + prevFrame = frame; + break; + } + } + + var prevValue = prevFrame && prevFrame.raw.apply(prevFrame, properties); + + if (isAccurate && !isRole([properties[0]])) { + return prevTime === time ? prevValue : undefined; + } + + if (usePrevValue) { + return prevValue; + } + + for (var i = right; i < length; ++i) { + var frame = this.getFrame(times[i]); + + if (frame.has.apply(frame, properties)) { + nextTime = times[i]; + nextFrame = frame; + break; + } + } + + var nextValue = nextFrame && nextFrame.raw.apply(nextFrame, properties); + + if (!prevFrame || isUndefined(prevValue)) { + return nextValue; + } + + if (!nextFrame || isUndefined(nextValue) || prevValue === nextValue) { + return prevValue; + } + + return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing); + }; + + __proto._toKeyframes = function (duration, states, direction) { + var _this = this; + + var frames = {}; + var times = this.times.slice(); + + if (!times.length) { + return ""; + } + + var originalDuration = this.getDuration(); + !this.getFrame(0) && times.unshift(0); + !this.getFrame(originalDuration) && times.push(originalDuration); + var entries = getEntries(times, states); + var lastEntry = entries[entries.length - 1]; // end delay time + + lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]); + var prevTime = -1; + return entries.map(function (_a) { + var time = _a[0], + keytime = _a[1]; + + if (!frames[keytime]) { + frames[keytime] = (!_this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ? _this.getNowFrame(keytime) : _this.getNowFrame(keytime, 0, true)).toCSS(); + } + + var frameTime = time / duration * 100; + + if (frameTime - prevTime < THRESHOLD) { + frameTime += THRESHOLD; + } + + prevTime = frameTime; + return Math.min(frameTime, 100) + "%{\n " + (time === 0 && !isDirectionReverse(0, 1, direction) ? "" : frames[keytime]) + "\n }"; + }).join(""); + }; + + __proto.updateFrameOrders = function () { + var nameMap = this.nameMap.orderMap; + this.forEach(function (frame) { + frame.setOrderObject(nameMap); + }); + }; + + return SceneItem; +}(Animator); + +/** + * manage sceneItems and play Scene. + * @sort 1 + */ + +var Scene = +/*#__PURE__*/ +function (_super) { + __extends(Scene, _super); + /** + * @param - properties + * @param - options + * @example + const scene = new Scene({ + item1: { + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + }, + }, + item2: { + 2: { + opacity: 1, + }, + } + }); + */ + + + function Scene(properties, options) { + var _this = _super.call(this) || this; + + _this.items = {}; + _this.orderMap = new OrderMap(NAME_SEPARATOR); + + _this.load(properties, options); + + return _this; + } + + var __proto = Scene.prototype; + + __proto.getDuration = function () { + var time = 0; + this.forEach(function (item) { + time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed()); + }); + return time || this.state[DURATION]; + }; + + __proto.setDuration = function (duration) { + var items = this.items; + var sceneDuration = this.getDuration(); + + if (duration === 0 || !isFinite(sceneDuration)) { + return this; + } + + if (sceneDuration === 0) { + this.forEach(function (item) { + item.setDuration(duration); + }); + } else { + var ratio_1 = duration / sceneDuration; + this.forEach(function (item) { + item.setDelay(item.getDelay() * ratio_1); + item.setDuration(item.getDuration() * ratio_1); + }); + } + + _super.prototype.setDuration.call(this, duration); + + return this; + }; + /** + * get item in scene by name + * @param - The item's name + * @return {Scene | SceneItem} item + * @example + const item = scene.getItem("item1") + */ + + + __proto.getItem = function (name) { + return this.items[name]; + }; + /** + * create item in scene + * @param {} name - name of item to create + * @param {} options - The option object of SceneItem + * @return {} Newly created item + * @example + const item = scene.newItem("item1") + */ + + + __proto.newItem = function (name, options) { + if (options === void 0) { + options = {}; + } + + if (this.items[name]) { + return this.items[name]; + } + + var item = new SceneItem(); + this.setItem(name, item); + item.setOptions(options); + return item; + }; + /** + * remove item in scene + * @param - name of item to remove + * @return An instance itself + * @example + const item = scene.newItem("item1") + scene.removeItem("item1"); + */ + + + __proto.removeItem = function (name) { + delete this.items[name]; + this.orderMap.remove([name]); + return this; + }; + /** + * add a sceneItem to the scene + * @param - name of item to create + * @param - sceneItem + * @example + const item = scene.newItem("item1") + */ + + + __proto.setItem = function (name, item) { + item.setId(name); + this.items[name] = item; + this.orderMap.add([name]); + return this; + }; + + __proto.setTime = function (time, isTick, isParent, parentEasing) { + _super.prototype.setTime.call(this, time, isTick, isParent); + + var iterationTime = this.getIterationTime(); + var easing = this.getEasing() || parentEasing; + var frames = {}; + this.forEach(function (item) { + item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing); + frames[item.getId()] = item.temp; + }); + this.temp = frames; + /** + * This event is fired when timeupdate and animate. + * @event Scene#animate + * @param {object} param The object of data to be sent to an event. + * @param {number} param.currentTime The total time that the animator is running. + * @param {number} param.time The iteration time during duration that the animator is running. + * @param {object} param.frames frames of that time. + * @example + const scene = new Scene({ + a: { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }, + b: { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + } + }).on("animate", e => { + console.log(e.frames); + // {a: Frame, b: Frame} + console.log(e.frames.a.get("opacity")); + }); + */ + + this.trigger("animate", { + frames: frames, + currentTime: this.getTime(), + time: iterationTime + }); + return this; + }; + /** + * executes a provided function once for each scene item. + * @param - Function to execute for each element, taking three arguments + * @return {Scene} An instance itself + */ + + + __proto.forEach = function (func) { + var items = this.items; + this.getOrders().forEach(function (id, index) { + func(items[id], id, index, items); + }); + return this; + }; + + __proto.toCSS = function (playCondition, duration, parentStates) { + if (duration === void 0) { + duration = this.getDuration(); + } + + if (parentStates === void 0) { + parentStates = []; + } + + var totalDuration = !duration || !isFinite(duration) ? 0 : duration; + var styles = []; + var state = this.state; + state[DURATION] = this.getDuration(); + this.forEach(function (item) { + styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state))); + }); + return styles.join(""); + }; + /** + * Export the CSS of the items to the style. + * @param - Add a selector or className to play. + * @return {Scene} An instance itself + */ + + + __proto.exportCSS = function (playCondition, duration, parentStates) { + var css = this.toCSS(playCondition, duration, parentStates); + + if (!parentStates || !parentStates.length) { + if (this.styledInjector) { + this.styledInjector.destroy(); + this.styledInjector = null; + } + + this.styled = styled(css); + this.styledInjector = this.styled.inject(this.getAnimationElement(), { + original: true + }); // && exportCSS(getRealId(this), css); + } + + return this; + }; + + __proto.append = function (item) { + item.setDelay(item.getDelay() + this.getDuration()); + this.setItem(getRealId(item), item); + }; + + __proto.pauseCSS = function () { + return this.forEach(function (item) { + item.pauseCSS(); + }); + }; + + __proto.pause = function () { + _super.prototype.pause.call(this); + + isPausedCSS(this) && this.pauseCSS(); + this.forEach(function (item) { + item.pause(); + }); + return this; + }; + + __proto.endCSS = function () { + this.forEach(function (item) { + item.endCSS(); + }); + setPlayCSS(this, false); + }; + + __proto.end = function () { + isEndedCSS(this) && this.endCSS(); + + _super.prototype.end.call(this); + + return this; + }; + /** + * get item orders + * @example + scene.getOrders() // => ["item1", "item2"] + */ + + + __proto.getOrders = function () { + return this.orderMap.get([]) || []; + }; + /** + * set item orders + * @param - orders + * @example + frame.setOrders(["item2", "item1"]) // => ["item2", "item1"] + */ + + + __proto.setOrders = function (orders) { + return this.orderMap.set([], orders); + }; + + __proto.getAnimationElement = function () { + var animtionElement; + this.forEach(function (item) { + var el = item.getAnimationElement(); + !animtionElement && (animtionElement = el); + }); + return animtionElement; + }; + + __proto.addPlayClass = function (isPaused, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + var animtionElement; + this.forEach(function (item) { + var el = item.addPlayClass(isPaused, playClassName, properties); + !animtionElement && (animtionElement = el); + }); + return animtionElement; + }; + /** + * Play using the css animation and keyframes. + * @param - Check if you want to export css. + * @param [playClassName="startAnimation"] - Add a class name to play. + * @param - The shorthand properties for six of the animation properties. + * @return {Scene} An instance itself + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp} + * @example + scene.playCSS(); + scene.playCSS(false, { + direction: "reverse", + fillMode: "forwards", + }); + */ + + + __proto.playCSS = function (isExportCSS, playClassName, properties) { + if (isExportCSS === void 0) { + isExportCSS = true; + } + + if (properties === void 0) { + properties = {}; + } + + playCSS(this, isExportCSS, playClassName, properties); + return this; + }; + /** + * Set properties to the Scene. + * @param - properties + * @return An instance itself + * @example + scene.set({ + ".a": { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + }, + }, + }); + // 0 + console.log(scene.getItem(".a").get(0, "opacity")); + // 1 + console.log(scene.getItem(".a").get(1, "opacity")); + */ + + + __proto.set = function (properties) { + this.load(properties); + return this; + }; + /** + * Clear All Items + * @return {Scene} An instance itself + */ + + + __proto.clear = function () { + this.finish(); + this.items = {}; + this.orderMap = new OrderMap(NAME_SEPARATOR); + + if (this.styledInjector) { + this.styledInjector.destroy(); + } + + this.styled = null; + this.styledInjector = null; + }; + + __proto.load = function (properties, options) { + if (properties === void 0) { + properties = {}; + } + + if (options === void 0) { + options = properties.options; + } + + if (!properties) { + return this; + } + + var selector = options && options[SELECTOR] || this.state[SELECTOR]; + + for (var name in properties) { + if (name === "options") { + continue; + } + + var object = properties[name]; + var item = void 0; + + if (object instanceof Scene || object instanceof SceneItem) { + this.setItem(name, object); + item = object; + } else if (isFunction(object) && selector) { + var elements = IS_WINDOW ? $("" + (isFunction(selector) ? selector(name) : name), true) : []; + var length = elements.length; + var scene = new Scene(); + + for (var i = 0; i < length; ++i) { + scene.newItem(i).setId().setElement(elements[i]).load(object(i, elements[i])); + } + + this.setItem(name, scene); + continue; + } else { + item = this.newItem(name); + item.load(object); + } + + selector && item.setSelector(selector); + } + + this.setOptions(options); + }; + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + _super.prototype.setOptions.call(this, options); + + var selector = options.selector; + + if (selector) { + this.state[SELECTOR] = selector; + } + + return this; + }; + + __proto.setSelector = function (target) { + var state = this.state; + var selector = target || state[SELECTOR]; + state[SELECTOR] = selector; + var isItFunction = isFunction(target); + + if (selector) { + this.forEach(function (item, name) { + item.setSelector(isItFunction ? target(name) : selector); + }); + } + + return this; + }; + + __proto.start = function (delay) { + if (delay === void 0) { + delay = this.state[DELAY]; + } + + var result = _super.prototype.start.call(this, delay); + + if (result) { + this.forEach(function (item) { + item.start(0); + }); + } else { + this.forEach(function (item) { + item.setPlayState(RUNNING); + }); + } + + return result; + }; + /** + * version info + * @type {string} + * @example + * Scene.VERSION // 1.4.0 + */ + + + Scene.VERSION = "1.4.0"; + return Scene; +}(Animator); + +function animate(properties, options) { + return new Scene(properties, options).play(); +} +function animateItem(properties, options) { + return new SceneItem(properties, options).play(); +} + +export default Scene; +export { Animator, EASE, EASE_IN, EASE_IN_OUT, EASE_OUT, EVENTS, FIXED, Frame, LINEAR, NAME_SEPARATOR, OPTIONS, ROLES, STEP_END, STEP_START, SceneItem, animate, animateItem, bezier, setAlias, setRole, steps }; +//# sourceMappingURL=scene.esm.js.map diff --git a/dist/scene.esm.js.map b/dist/scene.esm.js.map new file mode 100644 index 00000000..a7cf3238 --- /dev/null +++ b/dist/scene.esm.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scene.esm.js","sources":["../src/easing.ts","../src/consts.ts","../src/EventTrigger.ts","../src/PropertyObject.ts","../src/utils/property.ts","../src/utils.ts","../src/Animator.ts","../src/Frame.ts","../src/utils/dot.ts","../src/SceneItem.ts","../src/Scene.ts","../src/presets.ts"],"sourcesContent":["import { EasingFunction } from \"./types\";\n\nfunction cubic(y1: number, y2: number, t: number) {\n const t2 = 1 - t;\n\n // Bezier Curve Formula\n return t * t * t + 3 * t * t * t2 * y2 + 3 * t * t2 * t2 * y1;\n}\nfunction solveFromX(x1: number, x2: number, x: number) {\n // x 0 ~ 1\n // t 0 ~ 1\n let t = x;\n let solveX = x;\n let dx = 1;\n\n while (Math.abs(dx) > 1 / 1000) {\n // 예상 t초에 의한 _x값\n solveX = cubic(x1, x2, t);\n dx = solveX - x;\n // 차이가 미세하면 그 값을 t로 지정\n if (Math.abs(dx) < 1 / 1000) {\n return t;\n }\n t -= dx / 2;\n }\n return t;\n}\n/**\n * @namespace easing\n */\n/**\n* Cubic Bezier curve.\n* @memberof easing\n* @func bezier\n* @param {number} [x1] - point1's x\n* @param {number} [y1] - point1's y\n* @param {number} [x2] - point2's x\n* @param {number} [y2] - point2's y\n* @return {function} the curve function\n* @example\nimport {bezier} from \"scenejs\";\nScene.bezier(0, 0, 1, 1) // LINEAR\nScene.bezier(0.25, 0.1, 0.25, 1) // EASE\n*/\nexport function bezier(x1: number, y1: number, x2: number, y2: number) {\n /*\n\t\tx = f(t)\n\t\tcalculate inverse function by x\n\t\tt = f-1(x)\n\t*/\n const func: EasingFunction = (x: number) => {\n const t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0));\n\n return cubic(y1, y2, t);\n };\n\n func.easingName = `cubic-bezier(${x1},${y1},${x2},${y2})`;\n return func;\n}\n/**\n* Specifies a stepping function\n* @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function}\n* @memberof easing\n* @func steps\n* @param {number} count - point1's x\n* @param {\"start\" | \"end\"} postion - point1's y\n* @return {function} the curve function\n* @example\nimport {steps} from \"scenejs\";\nScene.steps(1, \"start\") // Scene.STEP_START\nScene.steps(1, \"end\") // Scene.STEP_END\n*/\nexport function steps(count: number, position: \"start\" | \"end\") {\n const func: EasingFunction = (time: number) => {\n const level = 1 / count;\n\n if (time >= 1) {\n return 1;\n }\n return (position === \"start\" ? level : 0) + Math.floor(time / level) * level;\n };\n\n func.easingName = `steps(${count}, ${position})`;\n\n return func;\n}\n\n/**\n* Equivalent to steps(1, start)\n* @memberof easing\n* @name STEP_START\n* @static\n* @type {function}\n* @example\nimport {STEP_START} from \"scenejs\";\nScene.STEP_START // steps(1, start)\n*/\nexport const STEP_START = /*#__PURE__#*/steps(1, \"start\");\n/**\n* Equivalent to steps(1, end)\n* @memberof easing\n* @name STEP_END\n* @static\n* @type {function}\n* @example\nimport {STEP_END} from \"scenejs\";\nScene.STEP_END // steps(1, end)\n*/\nexport const STEP_END = /*#__PURE__#*/steps(1, \"end\");\n/**\n* Linear Speed (0, 0, 1, 1)\n* @memberof easing\n* @name LINEAR\n* @static\n* @type {function}\n* @example\nimport {LINEAR} from \"scenejs\";\nScene.LINEAR\n*/\nexport const LINEAR = /*#__PURE__#*/bezier(0, 0, 1, 1);\n/**\n* Ease Speed (0.25, 0.1, 0.25, 1)\n* @memberof easing\n* @name EASE\n* @static\n* @type {function}\n* @example\nimport {EASE} from \"scenejs\";\nScene.EASE\n*/\nexport const EASE = /*#__PURE__#*/bezier(0.25, 0.1, 0.25, 1);\n/**\n* Ease In Speed (0.42, 0, 1, 1)\n* @memberof easing\n* @name EASE_IN\n* @static\n* @type {function}\n* @example\nimport {EASE_IN} from \"scenejs\";\nScene.EASE_IN\n*/\nexport const EASE_IN = /*#__PURE__#*/bezier(0.42, 0, 1, 1);\n/**\n* Ease Out Speed (0, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_OUT} from \"scenejs\";\nScene.EASE_OUT\n*/\nexport const EASE_OUT = /*#__PURE__#*/bezier(0, 0, 0.58, 1);\n/**\n* Ease In Out Speed (0.42, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_IN_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_IN_OUT} from \"scenejs\";\nScene.EASE_IN_OUT\n*/\nexport const EASE_IN_OUT = /*#__PURE__#*/bezier(0.42, 0, 0.58, 1);\n","import { IObject } from \"@daybrush/utils\";\nimport { RoleObject, OptionType, EventType, EasingFunction } from \"./types\";\nimport { EASE, EASE_IN, EASE_IN_OUT, LINEAR, EASE_OUT, STEP_START, STEP_END } from \"./easing\";\n\nexport const PREFIX = \"__SCENEJS_\";\nexport const DATA_SCENE_ID = \"data-scene-id\";\nexport const TIMING_FUNCTION = \"animation-timing-function\";\nexport const ROLES: RoleObject = { transform: {}, filter: {}, attribute: {}, html: true };\nexport const ALIAS: IObject = { easing: [TIMING_FUNCTION] };\nexport const FIXED = { [TIMING_FUNCTION]: true, contents: true, html: true };\nexport const MAXIMUM = 1000000;\nexport const THRESHOLD = 0.000001;\n\nexport const DURATION = \"duration\";\nexport const FILL_MODE = \"fillMode\";\nexport const DIRECTION = \"direction\";\nexport const ITERATION_COUNT = \"iterationCount\";\nexport const DELAY = \"delay\";\nexport const EASING = \"easing\";\nexport const PLAY_SPEED = \"playSpeed\";\nexport const EASING_NAME = \"easingName\";\nexport const ITERATION_TIME = \"iterationTime\";\nexport const PAUSED = \"paused\";\nexport const ENDED = \"ended\";\nexport const TIMEUPDATE = \"timeupdate\";\nexport const ANIMATE = \"animate\";\nexport const PLAY = \"play\";\nexport const RUNNING = \"running\";\nexport const ITERATION = \"iteration\";\nexport const START_ANIMATION = \"startAnimation\";\nexport const PAUSE_ANIMATION = \"pauseAnimation\";\nexport const ALTERNATE = \"alternate\";\nexport const REVERSE = \"reverse\";\nexport const ALTERNATE_REVERSE = \"alternate-reverse\";\nexport const NORMAL = \"normal\";\nexport const INFINITE = \"infinite\";\nexport const PLAY_STATE = \"playState\";\nexport const PLAY_CSS = \"playCSS\";\nexport const PREV_TIME = \"prevTime\";\nexport const TICK_TIME = \"tickTime\";\nexport const CURRENT_TIME = \"currentTime\";\nexport const SELECTOR = \"selector\";\nexport const TRANSFORM_NAME = \"transform\";\nexport const EASINGS = {\n \"linear\": LINEAR,\n \"ease\": EASE,\n \"ease-in\": EASE_IN,\n \"ease-out\": EASE_OUT,\n \"ease-in-out\": EASE_IN_OUT,\n \"step-start\": STEP_START,\n \"step-end\": STEP_END,\n};\nexport const NAME_SEPARATOR = \"_///_\";\n/**\n* option name list\n* @name Scene.OPTIONS\n* @memberof Scene\n* @static\n* @type {$ts:OptionType}\n* @example\n* Scene.OPTIONS // [\"duration\", \"fillMode\", \"direction\", \"iterationCount\", \"delay\", \"easing\", \"playSpeed\"]\n*/\nexport const OPTIONS: OptionType = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED];\n\n/**\n* Event name list\n* @name Scene.EVENTS\n* @memberof Scene\n* @static\n* @type {$ts:EventType}\n* @example\n* Scene.EVENTS // [\"paused\", \"ended\", \"timeupdate\", \"animate\", \"play\", \"iteration\"];\n*/\nexport const EVENTS: EventType = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION];\n","import { isObject, isArray, toArray } from \"@daybrush/utils\";\nimport { CallbackType, EventParameter } from \"./types\";\n\n/**\n* attach and trigger event handlers.\n*/\nclass EventTrigger {\n public events: { [name: string]: CallbackType[] };\n /**\n * @example\n const et = new Scene.EventTrigger();\n const scene = new Scene();\n\n scene.on(\"call\", e => {\n console.log(e.param);\n });\n et.on(\"call\", e => {\n console.log(e.param);\n });\n scene.trigger(\"call\", {param: 1});\n et.trigger(\"call\", {param: 1});\n */\n constructor() {\n this.events = {};\n }\n public _on(name: string | EventParameter, callback?: CallbackType | CallbackType[], once?: boolean) {\n const events = this.events;\n\n if (isObject(name)) {\n for (const n in name) {\n this._on(n, name[n], once);\n }\n return;\n }\n if (!(name in events)) {\n events[name] = [];\n }\n if (!callback) {\n return;\n }\n if (isArray(callback)) {\n callback.forEach(func => this._on(name, func, once));\n return;\n }\n events[name].push(once ? function callback2(...args) {\n callback(...args);\n this.off(name, callback2);\n } : callback);\n }\n /**\n * Attach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function() {\n console.log(\"animate\");\n });\n\n target.trigger(\"animate\");\n\n */\n public on(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback);\n return this;\n }\n /**\n * Dettach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n const callback = function() {\n console.log(\"animate\");\n };\n target.on(\"animate\", callback);\n\n target.off(\"animate\", callback);\n target.off(\"animate\");\n\n */\n public off(name?: string, callback?: CallbackType) {\n if (!name) {\n this.events = {};\n } else if (!callback) {\n this.events[name] = [];\n } else {\n const callbacks = this.events[name];\n\n if (!callbacks) {\n return this;\n }\n const index = callbacks.indexOf(callback);\n\n if (index !== -1) {\n callbacks.splice(index, 1);\n }\n }\n return this;\n }\n /**\n * execute event handler\n * @param - event's name\n * @param - event handler's additional parameter\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function(a1, a2) {\n console.log(\"animate\", a1, a2);\n });\n\n target.trigger(\"animate\", [1, 2]); // log => \"animate\", 1, 2\n\n */\n public trigger(name: string, ...data: any[]) {\n const events = this.events;\n\n if (!(name in events)) {\n return this;\n }\n\n const args = data || [];\n\n !args[0] && (args[0] = {});\n const event = events[name];\n const target = args[0];\n\n target.type = name;\n target.currentTarget = this;\n !target.target && (target.target = this);\n toArray(events[name]).forEach(callback => {\n callback.apply(this, data);\n });\n\n return this;\n }\n public once(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback, true);\n return this;\n }\n}\nexport default EventTrigger;\n","import { isString } from \"@daybrush/utils\";\nimport { PropertyObjectState } from \"./types\";\n\n/**\n* Make string, array to PropertyObject for the dot product\n*/\nclass PropertyObject implements PropertyObjectState {\n public value: any[];\n public prefix: string = \"\";\n public suffix: string = \"\";\n public model: string = \"\";\n public type: string = \"\";\n public separator: string = \",\";\n\n /**\n * @param - This value is in the array format.\n * @param - options\n * @example\n var obj = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n */\n constructor(value: string | any[], options?: Partial) {\n options && this.setOptions(options);\n this.value = isString(value) ? value.split(this.separator) : value;\n }\n public setOptions(newOptions: Partial) {\n for (const name in newOptions) {\n this[name as keyof PropertyObjectState] = newOptions[name as keyof PropertyObjectState];\n }\n return this;\n }\n /**\n * the number of values.\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.length);\n // 3\n */\n public size() {\n return this.value.length;\n }\n /**\n * retrieve one of values at the index\n * @param {Number} index - index\n * @return {Object} one of values at the index\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.get(0));\n // 1\n */\n public get(index: number) {\n return this.value[index];\n }\n /**\n * Set the value at that index\n * @param {Number} index - index\n * @param {Object} value - text, a number, object to set\n * @return {PropertyObject} An instance itself\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n obj1.set(0, 2);\n console.log(obj1.toValue());\n // 2,2,3\n */\n public set(index: number, value: any) {\n this.value[index] = value;\n return this;\n }\n /**\n * create a copy of an instance itself.\n * @return {PropertyObject} clone\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n const obj2 = obj1.clone();\n */\n public clone(): PropertyObject {\n const {\n separator,\n prefix,\n suffix,\n model,\n type,\n } = this;\n const arr = this.value.map(v => ((v instanceof PropertyObject) ? v.clone() : v));\n return new PropertyObject(arr, {\n separator,\n prefix,\n suffix,\n model,\n type,\n });\n }\n /**\n * Make Property Object to String\n * @return {String} Make Property Object to String\n * @example\n //rgba(100, 100, 100, 0.5)\n const obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\",\n });\n console.log(obj4.toValue());\n // \"rgba(100,100,100,0.5)\"\n */\n public toValue(): string {\n return this.prefix + this.join() + this.suffix;\n }\n /**\n * Make Property Object's array to String\n * @return {String} Join the elements of an array into a string\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n obj4.join(); // => \"100,100,100,0.5\"\n */\n public join() {\n return this.value.map(v => ((v instanceof PropertyObject) ? v.toValue() : v)).join(this.separator);\n }\n /**\n * executes a provided function once per array element.\n * @param {Function} callback - Function to execute for each element, taking three arguments\n * @param {All} [callback.currentValue] The current element being processed in the array.\n * @param {Number} [callback.index] The index of the current element being processed in the array.\n * @param {Array} [callback.array] the array.\n * @return {PropertyObject} An instance itself\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document.\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n\n obj4.forEach(t => {\n console.log(t);\n }); // => \"100,100,100,0.5\"\n */\n public forEach(func: (value?: any, index?: number, array?: any[]) => void) {\n this.value.forEach(func);\n return this;\n }\n}\nexport default PropertyObject;\n","/**\n* @namespace\n* @name Property\n*/\n\nimport PropertyObject from \"../PropertyObject\";\nimport {\n COLOR_MODELS, isString,\n splitComma, splitSpace, stringToRGBA,\n RGBA, splitBracket, IObject, isArray, splitText\n} from \"@daybrush/utils\";\nimport { NameType } from \"../types\";\n\nexport function splitStyle(str: string) {\n\n const properties = splitText(str, \";\");\n const obj: IObject = {};\n const totalLength = properties.length;\n let length = totalLength;\n\n for (let i = 0; i < totalLength; ++i) {\n const matches = splitText(properties[i], \":\");\n\n if (matches.length < 2 || !matches[1]) {\n --length;\n continue;\n }\n obj[matches[0].trim()] = toPropertyObject(matches[1].trim());\n }\n return { styles: obj, length };\n}\n/**\n* convert array to PropertyObject[type=color].\n* default model \"rgba\"\n* @memberof Property\n* @function arrayToColorObject\n* @param {Array|PropertyObject} value ex) [0, 0, 0, 1]\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\narrayToColorObject([0, 0, 0])\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0, 1], separator=\",\")\n*/\nexport function arrayToColorObject(arr: number[]) {\n const model = RGBA;\n\n if (arr.length === 3) {\n arr[3] = 1;\n }\n return new PropertyObject(arr, {\n model,\n separator: \",\",\n type: \"color\",\n prefix: `${model}(`,\n suffix: \")\",\n });\n}\n/**\n* convert text with parentheses to object.\n* @memberof Property\n* @function stringToBracketObject\n* @param {String} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject\n* @example\nstringToBracketObject(\"abcde(0, 0, 0,1)\")\n// => PropertyObject(model=\"abcde\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToBracketObject(text: string) {\n // [prefix, value, other]\n const { prefix: model, value, suffix: afterModel } = splitBracket(text);\n\n if (typeof value === \"undefined\") {\n return text;\n }\n if (COLOR_MODELS.indexOf(model) > -1) {\n return arrayToColorObject(stringToRGBA(text));\n }\n // divide comma(,)\n const obj = toPropertyObject(value, model);\n\n let arr = [value];\n let separator = \",\";\n let prefix = `${model}(`;\n let suffix = `)${afterModel}`;\n\n if (obj instanceof PropertyObject) {\n separator = obj.separator;\n arr = obj.value;\n prefix += obj.prefix;\n suffix = obj.suffix + suffix;\n }\n return new PropertyObject(arr, {\n separator,\n model,\n prefix,\n suffix,\n });\n}\n\nexport function arrayToPropertyObject(arr: any[], separator: string) {\n return new PropertyObject(arr, {\n type: \"array\",\n separator,\n });\n}\n\n/**\n* convert text with parentheses to PropertyObject[type=color].\n* If the values are not RGBA model, change them RGBA mdoel.\n* @memberof Property\n* @function stringToColorObject\n* @param {String|PropertyObject} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\nstringToColorObject(\"rgba(0, 0, 0,1)\")\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToColorObject(value: string): string | PropertyObject {\n const result = stringToRGBA(value);\n\n return result ? arrayToColorObject(result) : value;\n}\n/**\n* convert CSS Value to PropertyObject\n* @memberof Property\n* @function toPropertyObject\n* @param {String} value it's text contains the array.\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @see referenced regular expression {@link http://stackoverflow.com/questions/20215440/parse-css-gradient-rule-with-javascript-regex}\n* @example\ntoPropertyObject(\"1px solid #000\");\n// => PropertyObject([\"1px\", \"solid\", rgba(0, 0, 0, 1)])\n*/\nexport function toPropertyObject(value: any[], model?: NameType): PropertyObject;\nexport function toPropertyObject(value: IObject, model?: NameType): IObject;\nexport function toPropertyObject(value: string, model?: NameType): PropertyObject | string;\nexport function toPropertyObject(value: string | IObject | any[], model?: NameType) {\n if (!isString(value)) {\n if (isArray(value)) {\n return arrayToPropertyObject(value, \",\");\n }\n return value;\n }\n let values: any = splitComma(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \",\");\n }\n values = splitSpace(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \" \");\n }\n values = /^(['\"])([^'\"]*)(['\"])$/g.exec(value);\n\n if (values && values[1] === values[3]) {\n // Quotes\n return new PropertyObject([toPropertyObject(values[2])], {\n prefix: values[1],\n suffix: values[1],\n });\n } else if (value.indexOf(\"(\") !== -1) {\n // color\n return stringToBracketObject(value);\n } else if (value.charAt(0) === \"#\" && model !== \"url\") {\n return stringToColorObject(value);\n }\n return value;\n}\nexport function toObject(object: PropertyObject, result: IObject = {}) {\n const model = object.model;\n\n if (model) {\n object.setOptions({\n model: \"\",\n suffix: \"\",\n prefix: \"\",\n });\n const value = object.size() > 1 ? object : object.get(0);\n\n result[model] = value;\n } else {\n object.forEach(obj => {\n toObject(obj, result);\n });\n }\n return result;\n}\n","import {\n ROLES, MAXIMUM, FIXED, ALIAS,\n PAUSED, RUNNING, PLAY, ENDED, PREFIX, PLAY_CSS, CURRENT_TIME, START_ANIMATION, EASINGS, NAME_SEPARATOR\n} from \"./consts\";\nimport PropertyObject from \"./PropertyObject\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport {\n isArray, ANIMATION, ARRAY, OBJECT,\n PROPERTY, STRING, NUMBER, IS_WINDOW, IObject, $, document, isObject, addEvent, removeEvent, isString,\n} from \"@daybrush/utils\";\nimport { EasingType, EasingFunction, NameType } from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\nimport { bezier, steps } from \"./easing\";\n\nexport function isPropertyObject(value: any): value is PropertyObject {\n return value instanceof PropertyObject;\n}\nexport function setAlias(name: string, alias: string[]) {\n ALIAS[name] = alias;\n}\nexport function setRole(names: string[], isProperty?: boolean, isFixedProperty?: boolean) {\n const length = names.length;\n let roles: any = ROLES;\n let fixed: any = FIXED;\n\n for (let i = 0; i < length - 1; ++i) {\n !roles[names[i]] && (roles[names[i]] = {});\n roles = roles[names[i]];\n if (isFixedProperty) {\n !fixed[names[i]] && (fixed[names[i]] = {});\n fixed = fixed[names[i]];\n }\n }\n isFixedProperty && (fixed[names[length - 1]] = true);\n roles[names[length - 1]] = isProperty ? true : {};\n}\nexport function getType(value: any) {\n const type = typeof value;\n\n if (type === OBJECT) {\n if (isArray(value)) {\n return ARRAY;\n } else if (isPropertyObject(value)) {\n return PROPERTY;\n }\n } else if (type === STRING || type === NUMBER) {\n return \"value\";\n }\n return type;\n}\nexport function isPureObject(obj: any): obj is object {\n return isObject(obj) && obj.constructor === Object;\n}\nexport function getNames(names: IObject, stack: string[]) {\n let arr: string[][] = [];\n\n if (isPureObject(names)) {\n for (const name in names) {\n stack.push(name);\n arr = arr.concat(getNames(names[name], stack));\n stack.pop();\n }\n } else {\n arr.push(stack.slice());\n }\n return arr;\n}\nexport function updateFrame(names: IObject, properties: IObject) {\n for (const name in properties) {\n const value = properties[name];\n\n if (!isPureObject(value)) {\n names[name] = true;\n continue;\n }\n if (!isObject(names[name])) {\n names[name] = {};\n }\n updateFrame(names[name], properties[name]);\n }\n return names;\n}\nexport function toFixed(num: number) {\n return Math.round(num * MAXIMUM) / MAXIMUM;\n}\nexport function getValueByNames(\n names: Array,\n properties: IObject, length: number = names.length) {\n let value = properties;\n\n for (let i = 0; i < length; ++i) {\n if (!isObject(value) || value == null) {\n return undefined;\n }\n value = value[names[i]];\n }\n return value;\n}\nexport function isInProperties(roles: IObject, args: NameType[], isCheckTrue?: boolean) {\n const length = args.length;\n let role: any = roles;\n\n if (length === 0) {\n return false;\n }\n for (let i = 0; i < length; ++i) {\n if (role === true) {\n return false;\n }\n role = role[args[i]];\n if (!role || (!isCheckTrue && role === true)) {\n return false;\n }\n }\n return true;\n}\nexport function isRole(args: NameType[], isCheckTrue?: boolean) {\n return isInProperties(ROLES, args, isCheckTrue);\n}\nexport function isFixed(args: NameType[]) {\n return isInProperties(FIXED, args, true);\n}\n\nexport interface IterationInterface {\n currentTime: number;\n iterationCount: number;\n elapsedTime: number;\n}\nexport function setPlayCSS(item: Scene | SceneItem, isActivate: boolean) {\n item.state[PLAY_CSS] = isActivate;\n}\nexport function isPausedCSS(item: Scene | SceneItem) {\n return item.state[PLAY_CSS] && item.isPaused();\n}\nexport function isEndedCSS(item: Scene | SceneItem) {\n return !item.isEnded() && item.state[PLAY_CSS];\n}\n\nexport function makeId(selector?: boolean) {\n for (; ;) {\n const id = `${Math.floor(Math.random() * 10000000)}`;\n\n if (!IS_WINDOW || !selector) {\n return id;\n }\n const checkElement = $(`[data-scene-id=\"${id}\"]`);\n\n if (!checkElement) {\n return id;\n }\n }\n}\nexport function getRealId(item: Scene | SceneItem) {\n return item.getId() || item.setId(makeId(false)).getId();\n}\nexport function toId(text: number | string) {\n return `${text}`.match(/[0-9a-zA-Z]+/g).join(\"\");\n}\nexport function playCSS(\n item: Scene | SceneItem, isExportCSS?: boolean,\n playClassName?: string, properties: object = {}) {\n if (!ANIMATION || item.getPlayState() === RUNNING) {\n return;\n }\n const className = playClassName || START_ANIMATION;\n\n if (isPausedCSS(item)) {\n item.addPlayClass(true, className, properties);\n } else {\n if (item.isEnded()) {\n item.setTime(0);\n }\n isExportCSS && item.exportCSS({ className });\n const el = item.addPlayClass(false, className, properties);\n\n if (!el) {\n return;\n }\n addAnimationEvent(item, el);\n setPlayCSS(item, true);\n }\n item.setPlayState(RUNNING);\n}\n\nexport function addAnimationEvent(item: Scene | SceneItem, el: Element) {\n const state = item.state;\n const duration = item.getDuration();\n const isZeroDuration = !duration || !isFinite(duration);\n const animationend = () => {\n setPlayCSS(item, false);\n item.finish();\n };\n const animationstart = () => {\n item.trigger(PLAY);\n\n addEvent(el, \"animationcancel\", animationend);\n addEvent(el, \"animationend\", animationend);\n addEvent(el, \"animationiteration\", animationiteration);\n };\n item.once(ENDED, () => {\n removeEvent(el, \"animationcancel\", animationend);\n removeEvent(el, \"animationend\", animationend);\n removeEvent(el, \"animationiteration\", animationiteration);\n removeEvent(el, \"animationstart\", animationstart);\n });\n const animationiteration = ({ elapsedTime }: any) => {\n const currentTime = elapsedTime;\n const iterationCount = isZeroDuration ? 0 : (currentTime / duration);\n\n state[CURRENT_TIME] = currentTime;\n item.setIteration(iterationCount);\n };\n addEvent(el, \"animationstart\", animationstart);\n}\n\nexport function getEasing(curveArray: string | number[] | EasingFunction): EasingType {\n let easing: EasingType;\n\n if (isString(curveArray)) {\n if (curveArray in EASINGS) {\n easing = EASINGS[curveArray];\n } else {\n const obj = toPropertyObject(curveArray);\n\n if (isString(obj)) {\n return 0;\n } else {\n if (obj.model === \"cubic-bezier\") {\n curveArray = obj.value.map(v => parseFloat(v));\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else if (obj.model === \"steps\") {\n easing = steps(parseFloat(obj.value[0]), obj.value[1]);\n } else {\n return 0;\n }\n }\n }\n } else if (isArray(curveArray)) {\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else {\n easing = curveArray;\n }\n\n return easing;\n}\n\nexport function getFullName(names: NameType[]) {\n return names.join(NAME_SEPARATOR);\n}\n","import {\n THRESHOLD,\n ALTERNATE, ALTERNATE_REVERSE, REVERSE, INFINITE, NORMAL,\n ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED,\n DURATION, EASING, ITERATION_TIME, EASING_NAME, PAUSED,\n RUNNING, PLAY, TIMEUPDATE, ENDED, PLAY_STATE, PREV_TIME, TICK_TIME, CURRENT_TIME, ITERATION, OPTIONS, EASINGS\n} from \"./consts\";\nimport EventTrigger from \"./EventTrigger\";\nimport { bezier, steps } from \"./easing\";\nimport { toFixed, getEasing } from \"./utils\";\nimport { splitUnit, isString, camelize, requestAnimationFrame, isArray, cancelAnimationFrame } from \"@daybrush/utils\";\nimport {\n IterationCountType, DirectionType, AnimatorState,\n EasingFunction, FillModeType, PlayStateType, EasingType, AnimatorOptions,\n} from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\n\nfunction GetterSetter {}>(\n getter: string[], setter: string[], parent: string) {\n return (constructor: T) => {\n const prototype = constructor.prototype;\n\n getter.forEach(name => {\n prototype[camelize(`get ${name}`)] = function() {\n return this[parent][name];\n };\n });\n setter.forEach(name => {\n prototype[camelize(`set ${name}`)] = function(value: any) {\n this[parent][name] = value;\n return this;\n };\n });\n };\n}\nexport function isDirectionReverse(iteration: number, iteraiontCount: IterationCountType, direction: DirectionType) {\n if (direction === REVERSE) {\n return true;\n } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) {\n return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE);\n }\n return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE);\n}\n/**\n* @typedef {Object} AnimatorState The Animator options. Properties used in css animation.\n* @property {number} [duration] The duration property defines how long an animation should take to complete one cycle.\n* @property {\"none\"|\"forwards\"|\"backwards\"|\"both\"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both).\n* @property {\"infinite\"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played.\n* @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation.\n* @property {number} [delay] The delay property specifies a delay for the start of an animation.\n* @property {\"normal\"|\"reverse\"|\"alternate\"|\"alternate-reverse\"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles.\n*/\n\nconst setters = [\"id\", ITERATION_COUNT, DELAY, FILL_MODE,\n DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE];\nconst getters = [...setters, EASING, EASING_NAME];\n\n/**\n* play video, animation, the others\n* @extends EventTrigger\n* @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n*/\n@GetterSetter(getters, setters, \"state\")\nclass Animator\n extends EventTrigger {\n public state: U;\n private timerId: number = 0;\n\n /**\n * @param - animator's options\n * @example\n const animator = new Animator({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n constructor(options?: Partial) {\n super();\n this.state = {\n id: \"\",\n easing: 0,\n easingName: \"linear\",\n iterationCount: 1,\n delay: 0,\n fillMode: \"forwards\",\n direction: NORMAL,\n playSpeed: 1,\n currentTime: 0,\n iterationTime: -1,\n iteration: 0,\n tickTime: 0,\n prevTime: 0,\n playState: PAUSED,\n duration: 0,\n } as U;\n this.setOptions(options);\n }\n /**\n * set animator's easing.\n * @param curverArray - The speed curve of an animation.\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n public setEasing(curveArray: string | number[] | EasingFunction): this {\n const easing: EasingType = getEasing(curveArray);\n const easingName = easing && easing[EASING_NAME] || \"linear\";\n const state = this.state;\n\n state[EASING] = easing;\n state[EASING_NAME] = easingName;\n return this;\n }\n /**\n * set animator's options.\n * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n * @param - animator's options\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.eaasing.EASE,\n });\n */\n public setOptions(options: Partial = {}): this {\n for (const name in options) {\n const value = options[name];\n\n if (name === EASING) {\n this.setEasing(value);\n continue;\n } else if (name === DURATION) {\n value && this.setDuration(value);\n continue;\n }\n if (OPTIONS.indexOf(name as any) > -1) {\n this.state[name] = value;\n }\n }\n\n return this;\n }\n /**\n * Get the animator's total duration including delay\n * @return {number} Total duration\n * @example\n animator.getTotalDuration();\n */\n public getTotalDuration(): number {\n return this.getActiveDuration(true);\n }\n /**\n * Get the animator's total duration excluding delay\n * @return {number} Total duration excluding delay\n * @example\n animator.getActiveDuration();\n */\n public getActiveDuration(delay?: boolean): number {\n const state = this.state;\n const count = state[ITERATION_COUNT];\n if (count === INFINITE) {\n return Infinity;\n }\n return (delay ? state[DELAY] : 0) + this.getDuration() * count;\n }\n /**\n * Check if the animator has reached the end.\n * @return {boolean} ended\n * @example\n animator.isEnded(); // true or false\n */\n public isEnded(): boolean {\n if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) {\n return true;\n } else if (this.getTime() < this.getActiveDuration()) {\n return false;\n }\n return true;\n }\n /**\n *Check if the animator is paused:\n * @return {boolean} paused\n * @example\n animator.isPaused(); // true or false\n */\n public isPaused(): boolean {\n return this.state[PLAY_STATE] === PAUSED;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const state = this.state;\n\n state[PLAY_STATE] = RUNNING;\n if (state[TICK_TIME] >= delay) {\n /**\n * This event is fired when play animator.\n * @event Animator#play\n */\n this.trigger(PLAY);\n return true;\n }\n return false;\n }\n /**\n * play animator\n * @return {Animator} An instance itself.\n */\n public play(toTime?: number) {\n const state = this.state;\n const delay = state[DELAY];\n const currentTime = this.getTime();\n\n state[PLAY_STATE] = RUNNING;\n\n if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) {\n this.setTime(-delay, true);\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n state[PREV_TIME] = time;\n this.tick(time, toTime);\n });\n this.start();\n return this;\n }\n /**\n * pause animator\n * @return {Animator} An instance itself.\n */\n public pause(): this {\n const state = this.state;\n\n if (state[PLAY_STATE] !== PAUSED) {\n state[PLAY_STATE] = PAUSED;\n /**\n * This event is fired when animator is paused.\n * @event Animator#paused\n */\n this.trigger(PAUSED);\n }\n cancelAnimationFrame(this.timerId);\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public finish() {\n this.setTime(0);\n this.state[TICK_TIME] = 0;\n this.end();\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public end() {\n this.pause();\n /**\n * This event is fired when animator is ended.\n * @event Animator#ended\n */\n this.trigger(ENDED);\n return this;\n }\n /**\n * set currentTime\n * @param {Number|String} time - currentTime\n * @return {Animator} An instance itself.\n * @example\n\n animator.setTime(\"from\"); // 0\n animator.setTime(\"to\"); // 100%\n animator.setTime(\"50%\");\n animator.setTime(10);\n animator.getTime() // 10\n */\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean) {\n const activeDuration = this.getActiveDuration();\n const state = this.state;\n const prevTime = state[TICK_TIME];\n const delay = state[DELAY];\n let currentTime = isTick ? (time as number) : this.getUnitTime(time);\n\n state[TICK_TIME] = delay + currentTime;\n if (currentTime < 0) {\n currentTime = 0;\n } else if (currentTime > activeDuration) {\n currentTime = activeDuration;\n }\n state[CURRENT_TIME] = currentTime;\n this.calculate();\n\n if (isTick && !isParent) {\n const tickTime = state[TICK_TIME];\n\n if (prevTime < delay && time >= 0) {\n this.start(0);\n }\n if (tickTime < prevTime || this.isEnded()) {\n this.end();\n return;\n }\n }\n if (this.isDelay()) {\n return this;\n }\n /**\n * This event is fired when the animator updates the time.\n * @event Animator#timeupdate\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(TIMEUPDATE, {\n currentTime,\n time: this.getIterationTime(),\n iterationCount: state[ITERATION],\n });\n\n return this;\n }\n /**\n * Get the animator's current time\n * @return {number} current time\n * @example\n animator.getTime();\n */\n public getTime(): number {\n return this.state[CURRENT_TIME];\n }\n public getUnitTime(time: string | number) {\n if (isString(time)) {\n const duration = this.getDuration() || 100;\n\n if (time === \"from\") {\n return 0;\n } else if (time === \"to\") {\n return duration;\n }\n const { unit, value } = splitUnit(time);\n\n if (unit === \"%\") {\n !this.getDuration() && (this.setDuration(duration));\n return toFixed(parseFloat(time) / 100 * duration);\n } else if (unit === \">\") {\n return value + THRESHOLD;\n } else {\n return value;\n }\n } else {\n return toFixed(time);\n }\n }\n /**\n * Check if the current state of animator is delayed.\n * @return {boolean} check delay state\n */\n public isDelay() {\n const state = this.state;\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n\n return delay > 0 && (tickTime < delay);\n }\n public setIteration(iterationCount: number): this {\n const state = this.state;\n const passIterationCount = Math.floor(iterationCount);\n const maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT];\n\n if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) {\n /**\n * The event is fired when an iteration of an animation ends.\n * @event Animator#iteration\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(\"iteration\", {\n currentTime: state[CURRENT_TIME],\n iterationCount: passIterationCount,\n });\n }\n state[ITERATION] = iterationCount;\n return this;\n }\n protected calculate() {\n const state = this.state;\n const iterationCount = state[ITERATION_COUNT];\n const fillMode = state[FILL_MODE];\n const direction = state[DIRECTION];\n const duration = this.getDuration();\n const time = this.getTime();\n const iteration = duration === 0 ? 0 : time / duration;\n let currentIterationTime = duration ? time % duration : 0;\n\n if (!duration) {\n this.setIterationTime(0);\n return this;\n }\n this.setIteration(iteration);\n\n // direction : normal, reverse, alternate, alternate-reverse\n // fillMode : forwards, backwards, both, none\n const isReverse = isDirectionReverse(iteration, iterationCount, direction);\n\n const isFiniteDuration = isFinite(duration);\n if (isFiniteDuration && isReverse) {\n currentIterationTime = duration - currentIterationTime;\n }\n if (isFiniteDuration && iterationCount !== INFINITE) {\n const isForwards = fillMode === \"both\" || fillMode === \"forwards\";\n\n // fill forwards\n if (iteration >= iterationCount) {\n currentIterationTime = duration * (isForwards ? (iterationCount % 1) || 1 : 0);\n isReverse && (currentIterationTime = duration - currentIterationTime);\n }\n }\n this.setIterationTime(currentIterationTime);\n return this;\n }\n private tick(now: number, to?: number) {\n if (this.isPaused()) {\n return;\n }\n const state = this.state;\n const playSpeed = state[PLAY_SPEED];\n const prevTime = state[PREV_TIME];\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n const currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed;\n\n state[PREV_TIME] = now;\n this.setTime(currentTime - delay, true);\n if (to && to * 1000 < now) {\n this.pause();\n }\n if (state[PLAY_STATE] === PAUSED) {\n return;\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n this.tick(time, to);\n });\n }\n}\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#setId\n * @param {number | string} - String or number of id to be set in the animator\n * @return {Animator} An instance itself.\n */\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#getId\n * @return {number | string} the indicator of the item.\n */\n/**\n * Get a delay for the start of an animation.\n * @method Animator#getDelay\n * @return {number} delay\n */\n/**\n * Set a delay for the start of an animation.\n * @method Animator#setDelay\n * @param {number} delay - delay\n * @return {Animator} An instance itself.\n */\n/**\n * Get fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#getFillMode\n * @return {FillModeType} fillMode\n */\n/**\n * Set fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#setFillMode\n * @param {FillModeType} fillMode - fillMode\n * @return {Animator} An instance itself.\n */\n/**\n * Get the number of times an animation should be played.\n * @method Animator#getIterationCount\n * @return {IterationCountType} iterationCount\n */\n/**\n * Set the number of times an animation should be played.\n * @method Animator#setIterationCount\n * @param {IterationCountType} iterationCount - iterationCount\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#getDirection\n * @return {DirectionType} direction\n */\n/**\n * Set whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#setDirection\n * @param {DirectionType} direction - direction\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether the animation is running or paused.\n * @method Animator#getPlayState\n * @return {PlayStateType} playState\n */\n/**\n * Set whether the animation is running or paused.\n * @method Animator#setPlayState\n * @param {PlayStateType} playState - playState\n * @return {Animator} An instance itself.\n */\n/**\n * Get the animator's play speed\n * @method Animator#getPlaySpeed\n * @return {number} playSpeed\n */\n/**\n * Set the animator's play speed\n * @method Animator#setPlaySpeed\n * @param {number} playSpeed - playSpeed\n * @return {Animator} An instance itself.\n */\n/**\n * Get how long an animation should take to complete one cycle.\n * @method Animator#getDuration\n * @return {number} duration\n */\n/**\n * Set how long an animation should take to complete one cycle.\n * @method Animator#setDuration\n * @param {number} duration - duration\n * @return {Animator} An instance itself.\n */\n/**\n * Get the speed curve of an animation.\n * @method Animator#getEasing\n * @return {EasingType} easing\n */\n/**\n * Get the speed curve's name\n * @method Animator#getEasingName\n * @return {string} the curve's name.\n */\n/**\n\t* Get the animator's current iteration time\n\t* @method Animator#getIterationTime\n\t* @return {number} current iteration time\n\t* @example\nanimator.getIterationTime();\n\t*/\n\n// tslint:disable-next-line:interface-name\ninterface Animator {\n setId(id: number | string): this;\n getId(): number | string;\n getIterationTime(): number;\n setIterationTime(time: number): this;\n setDelay(delay: number): this;\n getDelay(): number;\n setFillMode(fillMode: FillModeType): this;\n getFillMode(): FillModeType;\n setIterationCount(iterationCount: IterationCountType): this;\n getIterationCount(): IterationCountType;\n setDirection(direction: DirectionType): this;\n getDirection(): DirectionType;\n setPlayState(playState: PlayStateType): this;\n getPlayState(): PlayStateType;\n setPlaySpeed(playSpeed: number): this;\n getPlaySpeed(): number;\n setDuration(duration: number): this;\n getDuration(): number;\n getEasing(): EasingType;\n getEasingName(): string;\n}\nexport default Animator;\n","import {\n ALIAS, TIMING_FUNCTION, TRANSFORM_NAME, EASING_NAME, NAME_SEPARATOR\n} from \"./consts\";\nimport { isRole, getType, isPropertyObject, getValueByNames, isFixed, getNames, getEasing, getFullName } from \"./utils\";\nimport { toPropertyObject, splitStyle, toObject } from \"./utils/property\";\nimport {\n isObject, isArray, isString, getKeys,\n ANIMATION, TRANSFORM, FILTER, PROPERTY, FUNCTION, ARRAY, OBJECT, IObject, isUndefined,\n sortOrders,\n} from \"@daybrush/utils\";\nimport { NameType, KeyValueChildren } from \"./types\";\nimport OrderMap from \"order-map\";\n\nfunction toInnerProperties(obj: IObject, orders: NameType[] = []) {\n if (!obj) {\n return \"\";\n }\n const arrObj = [];\n\n const keys = getKeys(obj);\n\n sortOrders(keys, orders);\n\n keys.forEach(name => {\n arrObj.push(`${name.replace(/\\d$/g, \"\")}(${obj[name]})`);\n });\n\n return arrObj.join(\" \");\n}\n\n/* eslint-disable */\nfunction clone(target: IObject, toValue = false) {\n return merge({}, target, toValue);\n}\nfunction merge(to: IObject, from: IObject, toValue = false) {\n for (const name in from) {\n const value = from[name];\n const type = getType(value);\n\n if (type === PROPERTY) {\n to[name] = toValue ? value.toValue() : value.clone();\n } else if (type === FUNCTION) {\n to[name] = toValue ? getValue([name], value) : value;\n } else if (type === ARRAY) {\n to[name] = value.slice();\n } else if (type === OBJECT) {\n if (isObject(to[name]) && !isPropertyObject(to[name])) {\n merge(to[name], value, toValue);\n } else {\n to[name] = clone(value, toValue);\n }\n } else {\n to[name] = from[name];\n }\n }\n return to;\n}\n/* eslint-enable */\n\nfunction getPropertyName(args: NameType[]) {\n return args[0] in ALIAS ? ALIAS[args[0]] : args;\n}\nfunction getValue(names: NameType[], value: any): any {\n const type = getType(value);\n\n if (type === PROPERTY) {\n return value.toValue();\n } else if (type === FUNCTION) {\n if (names[0] !== TIMING_FUNCTION) {\n return getValue(names, value());\n }\n } else if (type === OBJECT) {\n return clone(value, true);\n }\n return value;\n}\n/**\n* Animation's Frame\n*/\nclass Frame {\n public properties: IObject = {};\n public orderMap: OrderMap = new OrderMap(NAME_SEPARATOR);\n /**\n * @param - properties\n * @example\n const frame = new Scene.Frame({\n display: \"none\"\n transform: {\n translate: \"50px\",\n scale: \"5, 5\",\n }\n });\n */\n constructor(properties: any = {}) {\n this.properties = {};\n // this.orders = [];\n this.set(properties);\n }\n /**\n * get property value\n * @param {...Number|String|PropertyObject} args - property name or value\n * @example\n frame.get(\"display\") // => \"none\", \"block\", ....\n frame.get(\"transform\", \"translate\") // => \"10px,10px\"\n */\n public get(...args: NameType[]) {\n const value = this.raw(...args);\n\n return getValue(getPropertyName(args), value);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n frame.getOrders([\"display\"]) // => []\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n return this.orderMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n frame.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n return this.orderMap.set(names, orders);\n }\n /**\n * get properties order object\n * @example\n console.log(frame.getOrderObject());\n */\n public getOrderObject() {\n return this.orderMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n frame.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.orderMap.setObject(obj);\n }\n\n /**\n * get property keys\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [\"translate\"]\n */\n public getKeys(...args: NameType[]): string[] {\n const value = this.raw(...args);\n const keys = getType(value) === OBJECT ? getKeys(value) : [];\n\n sortOrders(keys, this.orderMap.get(args));\n return keys;\n }\n /**\n * get properties array\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [{ key: \"translate\", value: \"10px, 10px\", children: [] }]\n */\n public gets(...args: NameType[]): KeyValueChildren[] {\n const values = this.get(...args);\n const keys = this.getKeys(...args);\n\n return keys.map(key => {\n const nextValue = values[key];\n return { key, value: nextValue, children: this.gets(...args, key) };\n });\n }\n\n public raw(...args: NameType[]) {\n return getValueByNames(getPropertyName(args), this.properties);\n }\n /**\n * remove property value\n * @param {...String} args - property name\n * @return {Frame} An instance itself\n * @example\n frame.remove(\"display\")\n */\n public remove(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return this;\n }\n this.orderMap.remove(params);\n const value = getValueByNames(params, this.properties, length - 1);\n\n if (isObject(value)) {\n delete value[params[length - 1]];\n }\n return this;\n }\n /**\n * set property\n * @param {...Number|String|PropertyObject} args - property names or values\n * @return {Frame} An instance itself\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n filter: {\n brightness: \"50%\",\n grayscale: \"100%\"\n }\n });\n\n // two parameters\n frame.set(\"transform\", {\n translate: \"10px, 10px\",\n scale: \"1\",\n });\n\n // three parameters\n frame.set(\"transform\", \"translate\", \"50px\");\n */\n public set(...args: any[]) {\n const self = this;\n const length = args.length;\n const params = args.slice(0, -1);\n const value = args[length - 1];\n const firstParam = params[0];\n\n if (length === 1 && value instanceof Frame) {\n self.merge(value);\n } else if (firstParam in ALIAS) {\n self._set(ALIAS[firstParam], value);\n } else if (length === 2 && isArray(firstParam)) {\n self._set(firstParam, value);\n } else if (isPropertyObject(value)) {\n if (isRole(params)) {\n self.set(...params, toObject(value));\n } else {\n self._set(params, value);\n }\n } else if (isArray(value)) {\n self._set(params, value);\n } else if (isObject(value)) {\n if (!self.has(...params) && isRole(params)) {\n self._set(params, {});\n }\n for (const name in value) {\n self.set(...params, name, value[name]);\n }\n } else if (isString(value)) {\n if (isRole(params, true)) {\n if (isFixed(params) || !isRole(params)) {\n this._set(params, value);\n } else {\n const obj = toPropertyObject(value);\n\n if (isObject(obj)) {\n self.set(...params, obj);\n }\n }\n return this;\n } else {\n const { styles, length: stylesLength } = splitStyle(value);\n\n for (const name in styles) {\n self.set(...params, name, styles[name]);\n }\n if (stylesLength) {\n return this;\n }\n }\n self._set(params, value);\n } else {\n self._set(params, value);\n }\n return self;\n }\n /**\n * Gets the names of properties.\n * @return the names of properties.\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n });\n\n // [[\"display\"], [\"transform\", \"translate\"], [\"transform\", \"scale\"]]\n console.log(frame.getNames());\n */\n public getNames(): string[][] {\n return getNames(this.properties, []);\n }\n /**\n * check that has property.\n * @param {...String} args - property name\n * @example\n frame.has(\"property\", \"display\") // => true or false\n */\n public has(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return false;\n }\n return !isUndefined(getValueByNames(params, this.properties, length));\n }\n /**\n * clone frame.\n * @return {Frame} An instance of clone\n * @example\n frame.clone();\n */\n public clone() {\n const frame = new Frame();\n\n frame.setOrderObject(this.orderMap.orderMap);\n return frame.merge(this);\n }\n /**\n * merge one frame to other frame.\n * @param - target frame.\n * @return {Frame} An instance itself\n * @example\n frame.merge(frame2);\n */\n public merge(frame: Frame) {\n const properties = this.properties;\n const frameProperties = frame.properties;\n\n if (frameProperties) {\n merge(properties, frameProperties);\n }\n return this;\n }\n /**\n * Specifies an css object that coverted the frame.\n * @return {object} cssObject\n */\n public toCSSObject() {\n const properties = this.get();\n const cssObject: IObject = {};\n\n for (const name in properties) {\n if (isRole([name], true)) {\n continue;\n }\n const value = properties[name];\n\n if (name === TIMING_FUNCTION) {\n cssObject[TIMING_FUNCTION.replace(\"animation\", ANIMATION)] =\n (isString(value) ? value : value[EASING_NAME]) || \"initial\";\n } else {\n cssObject[name] = value;\n }\n }\n const transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME]));\n const filter = toInnerProperties(properties.filter, this.orderMap.get([FILTER]));\n\n TRANSFORM && transform && (cssObject[TRANSFORM] = transform);\n FILTER && filter && (cssObject[FILTER] = filter);\n return cssObject;\n }\n /**\n * Specifies an css text that coverted the frame.\n * @return {string} cssText\n */\n public toCSS() {\n const cssObject = this.toCSSObject();\n const cssArray = [];\n const keys = getKeys(cssObject);\n\n sortOrders(keys, this.orderMap.get([]));\n keys.forEach(name => {\n cssArray.push(`${name}:${cssObject[name]};`);\n });\n return cssArray.join(\"\");\n }\n /**\n * Remove All Properties\n * @return {Frame} An instance itself\n */\n public clear() {\n this.properties = {};\n this.orderMap.clear();\n return this;\n }\n private _set(args: NameType[], value: any) {\n let properties = this.properties;\n const length = args.length;\n\n for (let i = 0; i < length - 1; ++i) {\n const name = args[i];\n\n !(name in properties) && (properties[name] = {});\n properties = properties[name];\n }\n if (!length) {\n return;\n }\n const lastParam = args[length - 1];\n\n this.orderMap.add(args);\n if (length === 1 && lastParam === TIMING_FUNCTION) {\n properties[lastParam] = getEasing(value);\n } else {\n properties[lastParam] = isString(value) && !isFixed(args)\n ? toPropertyObject(value, lastParam)\n : value;\n }\n }\n}\nexport default Frame;\n","\nimport PropertyObject from \"../PropertyObject\";\nimport { getType } from \"../utils\";\nimport { toPropertyObject } from \"./property\";\nimport { splitUnit, PROPERTY, FUNCTION, ARRAY, dot as dotNumber } from \"@daybrush/utils\";\nimport { EasingType } from \"../types\";\n\nfunction dotArray(a1: any[], a2: any, b1: number, b2: number): any {\n const length = a2.length;\n\n return a1.map((v1, i) => {\n if (i >= length) {\n return v1;\n } else {\n return dot(v1, a2[i], b1, b2);\n }\n });\n}\n\nfunction dotColor(color1: PropertyObject, color2: PropertyObject, b1: number, b2: number) {\n // convert array to PropertyObject(type=color)\n const value1 = color1.value;\n const value2 = color2.value;\n // If the model name is not same, the inner product is impossible.\n const model1 = color1.model;\n const model2 = color2.model;\n\n if (model1 !== model2) {\n // It is recognized as a string.\n return dot(color1.toValue(), color2.toValue(), b1, b2);\n }\n if (value1.length === 3) {\n value1[3] = 1;\n }\n if (value2.length === 3) {\n value2[3] = 1;\n }\n const v = dotArray(value1, value2, b1, b2);\n const colorModel = model1;\n\n for (let i = 0; i < 3; ++i) {\n v[i] = parseInt(v[i], 10);\n }\n const object = new PropertyObject(v, {\n type: \"color\",\n model: colorModel,\n prefix: `${colorModel}(`,\n suffix: \")\",\n });\n\n return object;\n}\n\nfunction dotObject(a1: PropertyObject, a2: PropertyObject, b1: number, b2: number) {\n const a1Type = a1.type;\n\n if (a1Type === \"color\") {\n return dotColor(a1, a2, b1, b2);\n }\n const value1 = a1.value;\n const value2 = a2.value;\n const arr = dotArray(value1, value2, b1, b2);\n\n return new PropertyObject(arr, {\n type: a1Type,\n separator: a1.separator || a2.separator,\n prefix: a1.prefix || a2.prefix,\n suffix: a1.suffix || a2.suffix,\n model: a1.model || a2.model,\n });\n}\n/**\n* The dot product of a1 and a2 for the b1 and b2.\n* @memberof Dot\n* @function dot\n* @param {String|Number|PropertyObject} a1 value1\n* @param {String|Number|PropertyObject} a2 value2\n* @param {Number} b1 b1 ratio\n* @param {Number} b2 b2 ratio\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @example\ndot(1, 3, 0.3, 0.7);\n// => 1.6\n*/\nexport function dot(a1: any, a2: any, b1: number, b2: number): any {\n if (b2 === 0) {\n return a2;\n } else if (b1 === 0 || b1 + b2 === 0) {\n // prevent division by zero.\n return a1;\n }\n // dot Object\n\n const type1 = getType(a1);\n const type2 = getType(a2);\n const isFunction1 = type1 === FUNCTION;\n const isFunction2 = type2 === FUNCTION;\n\n if (isFunction1 || isFunction2) {\n return () => {\n return dot(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2);\n };\n } else if (type1 === type2) {\n if (type1 === PROPERTY) {\n return dotObject(a1, a2, b1, b2);\n } else if (type1 === ARRAY) {\n return dotArray(a1, a2, b1, b2);\n } else if (type1 !== \"value\") {\n return a1;\n }\n } else {\n return a1;\n }\n const v1 = splitUnit(`${a1}`);\n const v2 = splitUnit(`${a2}`);\n let v;\n\n // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환\n if (isNaN(v1.value) || isNaN(v2.value)) {\n return a1;\n } else {\n v = dotNumber(v1.value, v2.value, b1, b2);\n }\n const prefix = v1.prefix || v2.prefix;\n const unit = v1.unit || v2.unit;\n\n if (!prefix && !unit) {\n return v;\n }\n return prefix + v + unit;\n}\n\nexport function dotValue(\n time: number,\n prevTime: number,\n nextTime: number,\n prevValue: any,\n nextValue: any,\n easing?: EasingType) {\n if (time === prevTime) {\n return prevValue;\n } else if (time === nextTime) {\n return nextValue;\n } else if (!easing) {\n return dot(prevValue, nextValue, time - prevTime, nextTime - time);\n }\n const ratio = easing((time - prevTime) / (nextTime - prevTime));\n const value = dot(prevValue, nextValue, ratio, 1 - ratio);\n\n return value;\n}\n","import Animator, { isDirectionReverse } from \"./Animator\";\nimport Frame from \"./Frame\";\nimport {\n toFixed,\n isFixed,\n playCSS,\n toId,\n getRealId,\n makeId,\n isPausedCSS,\n isRole,\n getValueByNames,\n isEndedCSS,\n setPlayCSS,\n getNames,\n updateFrame,\n} from \"./utils\";\nimport { dotValue } from \"./utils/dot\";\nimport {\n START_ANIMATION,\n PREFIX, THRESHOLD,\n TIMING_FUNCTION, ALTERNATE, ALTERNATE_REVERSE, INFINITE,\n REVERSE, EASING, FILL_MODE, DIRECTION, ITERATION_COUNT,\n EASING_NAME, DELAY, PLAY_SPEED, DURATION, PAUSE_ANIMATION,\n DATA_SCENE_ID, SELECTOR, ROLES, NAME_SEPARATOR\n} from \"./consts\";\nimport {\n isObject, isArray, isUndefined, decamelize,\n ANIMATION, fromCSS, addClass, removeClass, hasClass,\n KEYFRAMES, isFunction,\n IObject, $, splitComma, toArray, isString, IArrayFormat,\n dot as dotNumber,\n find,\n findIndex,\n getKeys,\n sortOrders,\n} from \"@daybrush/utils\";\nimport {\n NameType, AnimateElement, AnimatorState,\n SceneItemState, SceneItemOptions, EasingType, PlayCondition, DirectionType\n} from \"./types\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n\nfunction getNearTimeIndex(times: number[], time: number) {\n const length = times.length;\n\n for (let i = 0; i < length; ++i) {\n if (times[i] === time) {\n return [i, i];\n } else if (times[i] > time) {\n return [i > 0 ? i - 1 : 0, i];\n }\n }\n return [length - 1, length - 1];\n}\nfunction makeAnimationProperties(properties: object) {\n const cssArray = [];\n\n for (const name in properties) {\n cssArray.push(`${ANIMATION}-${decamelize(name)}:${properties[name]};`);\n }\n return cssArray.join(\"\");\n}\nfunction addTime(times: number[], time: number) {\n const length = times.length;\n for (let i = 0; i < length; ++i) {\n if (time < times[i]) {\n times.splice(i, 0, time);\n return;\n }\n }\n times[length] = time;\n}\nfunction addEntry(entries: number[][], time: number, keytime: number) {\n const prevEntry = entries[entries.length - 1];\n\n (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) &&\n entries.push([toFixed(time), toFixed(keytime)]);\n}\nexport function getEntries(times: number[], states: AnimatorState[]) {\n let entries = times.map(time => ([time, time]));\n let nextEntries = [];\n\n states.forEach(state => {\n const iterationCount = state[ITERATION_COUNT] as number;\n const delay = state[DELAY];\n const playSpeed = state[PLAY_SPEED];\n const direction = state[DIRECTION];\n const intCount = Math.ceil(iterationCount);\n const currentDuration = entries[entries.length - 1][0];\n const length = entries.length;\n const lastTime = currentDuration * iterationCount;\n\n for (let i = 0; i < intCount; ++i) {\n const isReverse =\n direction === REVERSE ||\n direction === ALTERNATE && i % 2 ||\n direction === ALTERNATE_REVERSE && !(i % 2);\n\n for (let j = 0; j < length; ++j) {\n const entry = entries[isReverse ? length - j - 1 : j];\n const time = entry[1];\n const currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]);\n const prevEntry = entries[isReverse ? length - j : j - 1];\n\n if (currentTime > lastTime) {\n if (j !== 0) {\n const prevTime = currentDuration * i +\n (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]);\n const divideTime = dotNumber(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime);\n\n addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime);\n }\n break;\n } else if (\n currentTime === lastTime\n && nextEntries.length\n && nextEntries[nextEntries.length - 1][0] === lastTime + delay\n ) {\n break;\n }\n addEntry(nextEntries, (delay + currentTime) / playSpeed, time);\n }\n }\n // delay time\n delay && nextEntries.unshift([0, nextEntries[0][1]]);\n\n entries = nextEntries;\n nextEntries = [];\n });\n\n return entries;\n}\n/**\n* manage Frame Keyframes and play keyframes.\n* @extends Animator\n* @example\nconst item = new SceneItem({\n\t0: {\n\t\tdisplay: \"none\",\n\t},\n\t1: {\n\t\tdisplay: \"block\",\n\t\topacity: 0,\n\t},\n\t2: {\n\t\topacity: 1,\n\t}\n});\n*/\nclass SceneItem extends Animator {\n public times: number[] = [];\n public items: IObject = {};\n public nameMap = new OrderMap(NAME_SEPARATOR);\n public elements: AnimateElement[] = [];\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: Frame;\n private needUpdate: boolean = true;\n private target: any;\n private targetFunc: (frame: Frame) => void;\n\n /**\n * @param - properties\n * @param - options\n * @example\n const item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n */\n constructor(properties?: any, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n const times = this.times;\n const length = times.length;\n\n return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION];\n }\n /**\n * get size of list\n * @return {Number} length of list\n */\n public size() {\n return this.times.length;\n }\n public setDuration(duration: number) {\n if (!duration) {\n return this;\n }\n const originalDuration = this.getDuration();\n\n if (originalDuration > 0) {\n const ratio = duration / originalDuration;\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(time => {\n const time2 = toFixed(time * ratio);\n\n obj[time2] = items[time];\n\n return time2;\n });\n this.items = obj;\n } else {\n this.newFrame(duration);\n }\n return this;\n }\n public setId(id?: number | string) {\n const state = this.state;\n const elements = this.elements;\n const length = elements.length;\n\n state.id = id || makeId(!!length);\n\n if (length && !state[SELECTOR]) {\n const sceneId = toId(this.getId());\n\n state[SELECTOR] = `[${DATA_SCENE_ID}=\"${sceneId}\"]`;\n elements.forEach(element => {\n element.setAttribute(DATA_SCENE_ID, sceneId);\n });\n }\n return this;\n }\n\n /**\n * Set properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.set(0, \"a\", \"b\") // item.getFrame(0).set(\"a\", \"b\")\n console.log(item.get(0, \"a\")); // \"b\"\n */\n public set(time: any, ...args: any[]) {\n if (time instanceof SceneItem) {\n return this.set(0, time);\n } else if (isArray(time)) {\n const length = time.length;\n\n for (let i = 0; i < length; ++i) {\n const t = length === 1 ? 0 : this.getUnitTime(`${i / (length - 1) * 100}%`);\n\n this.set(t, time[i]);\n }\n } else if (isObject(time)) {\n for (const t in time) {\n const value = time[t];\n\n splitComma(t).forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (isNaN(realTime)) {\n getNames(value, [eachTime]).forEach(names => {\n const innerValue = getValueByNames(names.slice(1), value);\n const arr = isArray(innerValue) ?\n innerValue : [getValueByNames(names, this.target), innerValue];\n const length = arr.length;\n\n for (let i = 0; i < length; ++i) {\n this.newFrame(`${i / (length - 1) * 100}%`).set(...names, arr[i]);\n }\n });\n } else {\n this.set(realTime, value);\n }\n });\n }\n } else if (!isUndefined(time)) {\n const value = args[0];\n\n splitComma(time + \"\").forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (value instanceof SceneItem) {\n const delay = value.getDelay();\n const frames = value.toObject(!this.hasFrame(realTime + delay));\n const duration = value.getDuration();\n const direction = value.getDirection();\n const isReverse = direction.indexOf(\"reverse\") > -1;\n\n for (const frameTime in frames) {\n const nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime);\n this.set(realTime + nextTime, frames[frameTime]);\n }\n } else if (args.length === 1 && isArray(value)) {\n value.forEach((item: any) => {\n this.set(realTime, item);\n });\n } else {\n const frame = this.newFrame(realTime);\n\n frame.set(...args);\n }\n });\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Get properties of the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} args property's name or properties\n * @return {Number|String|PropertyObejct} property value\n * @example\n item.get(0, \"a\"); // item.getFrame(0).get(\"a\");\n item.get(0, \"transform\", \"translate\"); // item.getFrame(0).get(\"transform\", \"translate\");\n */\n public get(time: string | number, ...args: NameType[]) {\n const frame = this.getFrame(time);\n\n return frame && frame.get(...args);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n item.getOrders([\"display\"]) // => []\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n this.needUpdate && this.update();\n\n return this.nameMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n item.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n this.needUpdate && this.update();\n\n const result = this.nameMap.set(names, orders);\n\n this.updateFrameOrders();\n\n return result;\n }\n /**\n * get properties order object\n * @example\n console.log(item.getOrderObject());\n */\n public getOrderObject() {\n return this.nameMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n item.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.nameMap.setObject(obj);\n\n this.updateFrameOrders();\n }\n public remove(time: string | number, ...args: any[]): this;\n /**\n * remove properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.remove(0, \"a\");\n */\n public remove(time: string | number, ...args: NameType[]) {\n if (args.length) {\n const frame = this.getFrame(time);\n\n frame && frame.remove(...args);\n } else {\n this.removeFrame(time);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Append the item or object at the last time.\n * @param - the scene item or item object\n * @return An instance itself\n * @example\n item.append(new SceneItem({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }));\n item.append({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n item.set(item.getDuration(), {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n */\n public append(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n this.set(this.getDuration(), item);\n } else {\n this.append(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push the front frames for the time and prepend the scene item or item object.\n * @param - the scene item or item object\n * @return An instance itself\n */\n public prepend(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n const unshiftTime = item.getDuration() + item.getDelay();\n const firstFrame = this.getFrame(0);\n // remove first frame\n this.removeFrame(0);\n this.unshift(unshiftTime);\n this.set(0, item);\n this.set(unshiftTime + THRESHOLD, firstFrame);\n } else {\n this.prepend(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push out the amount of time.\n * @param - time to push\n * @example\n item.get(0); // frame 0\n item.unshift(3);\n item.get(3) // frame 0\n */\n public unshift(time: number) {\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(t => {\n const time2 = toFixed(time + t);\n\n obj[time2] = items[t];\n return time2;\n });\n this.items = obj;\n return this;\n }\n /**\n * Get the frames in the item in object form.\n * @return {}\n * @example\n item.toObject();\n // {0: {display: \"none\"}, 1: {display: \"block\"}}\n */\n public toObject(isStartZero = true): IObject {\n const obj: IObject = {};\n const delay = this.getDelay();\n\n this.forEach((frame: Frame, time: number) => {\n obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone();\n });\n return obj;\n }\n /**\n * Specifies an element to synchronize items' keyframes.\n * @param {string} selectors - Selectors to find elements in items.\n * @return {SceneItem} An instance itself\n * @example\nitem.setSelector(\"#id.class\");\n */\n public setSelector(target: string | boolean | ((id: number | string) => string)) {\n if (isFunction(target)) {\n this.setElement(target(this.getId()));\n } else {\n this.setElement(target);\n }\n return this;\n }\n /**\n * Get the elements connected to SceneItem.\n */\n public getElements(): AnimateElement[] {\n return this.elements;\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElements(target: boolean | string | AnimateElement | IArrayFormat): this {\n return this.setElement(target);\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElement(target: boolean | string | AnimateElement | IArrayFormat) {\n const state = this.state;\n let elements: AnimateElement[] = [];\n\n if (!target) {\n return this;\n } else if (target === true || isString(target)) {\n const selector = target === true ? `${state.id}` : target;\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(selector);\n\n elements = toArray($(matches ? matches[1] : selector, true));\n state[SELECTOR] = selector;\n } else {\n elements = (target instanceof Element) ? [target] : toArray(target);\n }\n if (!elements.length) {\n return this;\n }\n this.elements = elements;\n this.setId(this.getId());\n this.target = elements[0].style;\n this.targetFunc = (frame: Frame) => {\n const attributes = frame.get(\"attribute\");\n\n if (attributes) {\n for (const name in attributes) {\n elements.forEach(el => {\n el.setAttribute(name, attributes[name]);\n });\n }\n }\n if (frame.has(\"html\")) {\n const html = frame.get(\"html\");\n\n elements.forEach(el => {\n el.innerHTML = html;\n });\n }\n const cssText = frame.toCSS();\n\n if (state.cssText !== cssText) {\n state.cssText = cssText;\n\n elements.forEach(el => {\n el.style.cssText += cssText;\n });\n return frame;\n }\n };\n return this;\n }\n public setTarget(target: any): this {\n this.target = target;\n this.targetFunc = (frame: Frame) => {\n const obj = frame.get();\n\n for (const name in obj) {\n target[name] = obj[name];\n }\n };\n return this;\n }\n /**\n * add css styles of items's element to the frame at that time.\n * @param {Array} properties - elements to synchronize item's keyframes.\n * @return {SceneItem} An instance itself\n * @example\n item.setElement(document.querySelector(\"#id.class\"));\n item.setCSS(0, [\"opacity\"]);\n item.setCSS(0, [\"opacity\", \"width\", \"height\"]);\n */\n public setCSS(time: number, properties: string[]) {\n this.set(time, fromCSS(this.elements, properties));\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frame = this.getNowFrame(iterationTime, easing);\n const currentTime = this.getTime();\n\n this.temp = frame;\n /**\n * This event is fired when timeupdate and animate.\n * @event SceneItem#animate\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Frame} param.frame frame of that time.\n */\n this.trigger(\"animate\", {\n frame,\n currentTime,\n time: iterationTime,\n });\n this.targetFunc && this.targetFunc(frame);\n return this;\n }\n /**\n * update property names used in frames.\n * @return {SceneItem} An instance itself\n * @example\n item.update();\n */\n public update() {\n const prevNameMap = this.nameMap;\n const names = {};\n this.forEach(frame => {\n updateFrame(names, frame.properties);\n });\n\n const nameMap = new OrderMap(NAME_SEPARATOR);\n\n function pushKeys(map: IObject, stack: NameType[]) {\n const keys = getKeys(map);\n\n sortOrders(keys, prevNameMap.get(stack));\n\n nameMap.set(stack, keys);\n keys.forEach(key => {\n const nextMap = map[key];\n if (isObject(nextMap)) {\n pushKeys(nextMap, [...stack, key]);\n }\n });\n }\n pushKeys(names, []);\n\n this.nameMap = nameMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap.orderMap);\n });\n this.needUpdate = false;\n return this;\n }\n /**\n * Create and add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {Frame} Created frame.\n * @example\n item.newFrame(time);\n */\n public newFrame(time: string | number) {\n let frame = this.getFrame(time);\n\n if (frame) {\n return frame;\n }\n frame = new Frame();\n\n this.setFrame(time, frame);\n return frame;\n }\n /**\n * Add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.setFrame(time, frame);\n */\n public setFrame(time: string | number, frame: Frame) {\n const realTime = this.getUnitTime(time);\n\n this.items[realTime] = frame;\n addTime(this.times, realTime);\n this.needUpdate = true;\n return this;\n }\n public getFrame(time: number | string, ...names: any[]): Frame;\n /**\n * get sceneItem's frame at that time\n * @param {Number} time - frame's time\n * @return {Frame} sceneItem's frame at that time\n * @example\n const frame = item.getFrame(time);\n */\n public getFrame(time: number | string) {\n return this.items[this.getUnitTime(time)];\n }\n public removeFrame(time: number | string, ...names: any[]): this;\n /**\n * remove sceneItem's frame at that time\n * @param - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.removeFrame(time);\n */\n public removeFrame(time: number | string) {\n const realTime = this.getUnitTime(time);\n const items = this.items;\n const index = this.times.indexOf(realTime);\n\n delete items[realTime];\n\n // remove time\n if (index > -1) {\n this.times.splice(index, 1);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * check if the item has a frame at that time\n * @param {Number} time - frame's time\n * @return {Boolean} true: the item has a frame // false: not\n * @example\n if (item.hasFrame(10)) {\n // has\n } else {\n // not\n }\n */\n public hasFrame(time: number | string) {\n return this.getUnitTime(time) in this.items;\n }\n /**\n * Check if keyframes has propery's name\n * @param - property's time\n * @return {boolean} true: if has property, false: not\n * @example\n item.hasName([\"transform\", \"translate\"]); // true or not\n */\n public hasName(args: string[]) {\n this.needUpdate && this.update();\n return !!this.nameMap.get(args);\n }\n /**\n * merge frame of the previous time at the next time.\n * @param - The time of the frame to merge\n * @param - The target frame\n * @return {SceneItem} An instance itself\n * @example\n // getFrame(1) contains getFrame(0)\n item.merge(0, 1);\n */\n public mergeFrame(time: number | string, frame: Frame) {\n if (frame) {\n const toFrame = this.newFrame(time);\n\n toFrame.merge(frame);\n }\n return this;\n }\n /**\n * Get frame of the current time\n * @param {Number} time - the current time\n * @param {function} easing - the speed curve of an animation\n * @return {Frame} frame of the current time\n * @example\n let item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n // opacity: 0.7; display:\"block\";\n const frame = item.getNowFrame(1.7);\n */\n public getNowFrame(time: number, easing?: EasingType, isAccurate?: boolean) {\n this.needUpdate && this.update();\n const frame = new Frame();\n const [left, right] = getNearTimeIndex(this.times, time);\n let realEasing = this.getEasing() || easing;\n let nameMap = this.nameMap;\n\n if (this.hasName([TIMING_FUNCTION])) {\n const nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true);\n\n isFunction(nowEasing) && (realEasing = nowEasing);\n }\n if (isAccurate) {\n const prevFrame = this.getFrame(time);\n const prevOrderMap = prevFrame.orderMap.filter([], orders => {\n return prevFrame.has(...orders);\n });\n\n for (const name in ROLES) {\n const orders = nameMap.get([name]);\n if (prevOrderMap.get([name]) && orders) {\n prevOrderMap.set([name], orders);\n }\n }\n nameMap = prevOrderMap;\n }\n const names = nameMap.gets([]);\n\n frame.setOrderObject(nameMap.orderMap);\n names.forEach(properties => {\n const value = this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties));\n\n if (isUndefined(value)) {\n return;\n }\n frame.set(properties, value);\n });\n return frame;\n }\n public load(properties: any = {}, options = properties.options) {\n options && this.setOptions(options);\n\n if (isArray(properties)) {\n this.set(properties);\n } else if (properties.keyframes) {\n this.set(properties.keyframes);\n } else {\n for (const time in properties) {\n if (time !== \"options\") {\n this.set({\n [time]: properties[time],\n });\n }\n }\n }\n if (options && options[DURATION]) {\n this.setDuration(options[DURATION]);\n }\n return this;\n }\n /**\n * clone SceneItem.\n * @return {SceneItem} An instance of clone\n * @example\n * item.clone();\n */\n public clone() {\n const item = new SceneItem();\n\n item.setOptions(this.state);\n item.setOrderObject(this.nameMap.orderMap);\n\n this.forEach((frame: Frame, time: number) => {\n item.setFrame(time, frame.clone());\n });\n return item;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Keyframes} An instance itself\n */\n public forEach(callback: (item: Frame, time: number, items: IObject) => void) {\n const times = this.times;\n const items = this.items;\n\n times.forEach(time => {\n callback(items[time], time, items);\n });\n return this;\n }\n public setOptions(options: Partial = {}) {\n super.setOptions(options);\n const { id, selector, elements, element, target } = options;\n\n id && this.setId(id);\n if (target) {\n this.setTarget(target);\n } else if (selector) {\n this.setSelector(selector);\n } else if (elements || element) {\n this.setElement(elements || element);\n }\n return this;\n }\n public toCSS(\n playCondition: PlayCondition = { className: START_ANIMATION },\n parentDuration = this.getDuration(), states: AnimatorState[] = []) {\n const itemState = this.state;\n const selector = itemState[SELECTOR];\n\n if (!selector) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n itemState[DURATION] = originalDuration;\n states.push(itemState);\n\n const reversedStates = toArray(states).reverse();\n const id = toId(getRealId(this));\n const superParent = states[0];\n const infiniteIndex = findIndex(reversedStates, state => {\n return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]);\n }, states.length - 1);\n const finiteStates = reversedStates.slice(0, infiniteIndex);\n const duration = parentDuration || finiteStates.reduce((prev, cur) => {\n return (cur[DELAY] + prev * (cur[ITERATION_COUNT] as number)) / cur[PLAY_SPEED];\n }, originalDuration);\n const delay = reversedStates.slice(infiniteIndex).reduce((prev, cur) => {\n return (prev + cur[DELAY]) / cur[PLAY_SPEED];\n }, 0);\n const easingName = find(reversedStates, state => (state[EASING] && state[EASING_NAME]), itemState)[EASING_NAME];\n const iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT];\n const fillMode = superParent[FILL_MODE];\n const direction = reversedStates[infiniteIndex][DIRECTION];\n const cssText = makeAnimationProperties({\n fillMode,\n direction,\n iterationCount,\n delay: `${delay}s`,\n name: `${PREFIX}KEYFRAMES_${id}`,\n duration: `${duration / superParent[PLAY_SPEED]}s`,\n timingFunction: easingName,\n });\n const selectors = splitComma(selector).map(sel => {\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(sel);\n\n if (matches) {\n return [matches[1], matches[2]];\n } else {\n return [sel, \"\"];\n }\n });\n const className = playCondition.className;\n const selectorCallback = playCondition.selector;\n const preselector = isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback;\n\n return `\n ${preselector || selectors.map(([sel, peusdo]) => `${sel}.${className}${peusdo}`)} {${cssText}}\n ${selectors.map(([sel, peusdo]) => `${sel}.${PAUSE_ANIMATION}${peusdo}`)} {${ANIMATION}-play-state: paused;}\n @${KEYFRAMES} ${PREFIX}KEYFRAMES_${id}{${this._toKeyframes(duration, finiteStates, direction)}}`;\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {SceneItem} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition,\n duration?: number, options?: AnimatorState[]) {\n if (!this.elements.length) {\n return \"\";\n }\n const css = this.toCSS(playCondition, duration, options);\n const isParent = options && !isUndefined(options[ITERATION_COUNT]);\n\n if (!isParent) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n }\n return this;\n }\n public pause() {\n super.pause();\n isPausedCSS(this) && this.pauseCSS();\n return this;\n }\n public pauseCSS() {\n this.elements.forEach(element => {\n addClass(element, PAUSE_ANIMATION);\n });\n return this;\n }\n public endCSS() {\n this.elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n removeClass(element, START_ANIMATION);\n });\n setPlayCSS(this, false);\n return this;\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n item.playCSS();\n item.playCSS(false, \"startAnimation\", {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: object = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public getAnimationElement(): AnimateElement {\n return this.elements[0];\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n const elements = this.elements;\n const length = elements.length;\n const cssText = makeAnimationProperties(properties);\n\n if (!length) {\n return;\n }\n if (isPaused) {\n elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n });\n } else {\n elements.forEach(element => {\n element.style.cssText += cssText;\n\n if (hasClass(element, START_ANIMATION)) {\n removeClass(element, START_ANIMATION);\n }\n });\n elements.forEach(element => {\n element.clientWidth;\n });\n elements.forEach(element => {\n addClass(element, START_ANIMATION);\n });\n }\n return elements[0];\n }\n /**\n * Clear All Frames\n * @return {SceneItem} An instance itself\n */\n public clear() {\n this.times = [];\n this.items = {};\n this.nameMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n this.temp = null;\n this.needUpdate = true;\n return this;\n }\n public getNowValue(\n time: number,\n properties: NameType[],\n left?: number,\n right?: number,\n isAccurate?: boolean,\n easing?: EasingType,\n usePrevValue?: boolean,\n ) {\n const times = this.times;\n const length = times.length;\n\n let prevTime: number;\n let nextTime: number;\n let prevFrame: Frame;\n let nextFrame: Frame;\n const isUndefinedLeft = isUndefined(left);\n const isUndefinedRight = isUndefined(right);\n if (isUndefinedLeft || isUndefinedRight) {\n const indicies = getNearTimeIndex(times, time);\n isUndefinedLeft && (left = indicies[0]);\n isUndefinedRight && (right = indicies[1]);\n }\n\n for (let i = left; i >= 0; --i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n prevTime = times[i];\n prevFrame = frame;\n break;\n }\n }\n const prevValue = prevFrame && prevFrame.raw(...properties);\n\n if (isAccurate && !isRole([properties[0]])) {\n return prevTime === time ? prevValue : undefined;\n }\n if (usePrevValue) {\n return prevValue;\n }\n for (let i = right; i < length; ++i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n nextTime = times[i];\n nextFrame = frame;\n break;\n }\n }\n const nextValue = nextFrame && nextFrame.raw(...properties);\n\n if (!prevFrame || isUndefined(prevValue)) {\n return nextValue;\n }\n if (!nextFrame || isUndefined(nextValue) || prevValue === nextValue) {\n return prevValue;\n }\n return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing);\n }\n private _toKeyframes(duration: number, states: AnimatorState[], direction: DirectionType) {\n const frames: IObject = {};\n const times = this.times.slice();\n\n if (!times.length) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n (!this.getFrame(0)) && times.unshift(0);\n (!this.getFrame(originalDuration)) && times.push(originalDuration);\n const entries = getEntries(times, states);\n const lastEntry = entries[entries.length - 1];\n\n // end delay time\n lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]);\n let prevTime = -1;\n\n return entries.map(([time, keytime]) => {\n if (!frames[keytime]) {\n frames[keytime] =\n (!this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ?\n this.getNowFrame(keytime) : this.getNowFrame(keytime, 0, true)).toCSS();\n }\n\n let frameTime = time / duration * 100;\n\n if (frameTime - prevTime < THRESHOLD) {\n frameTime += THRESHOLD;\n }\n prevTime = frameTime;\n return `${Math.min(frameTime, 100)}%{\n ${time === 0 && !isDirectionReverse(0, 1, direction) ? \"\" : frames[keytime]}\n }`;\n }).join(\"\");\n }\n private updateFrameOrders() {\n const nameMap = this.nameMap.orderMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap);\n });\n }\n}\n\nexport default SceneItem;\n","import Animator from \"./Animator\";\nimport SceneItem from \"./SceneItem\";\nimport { SELECTOR, DURATION, DELAY, RUNNING, NAME_SEPARATOR } from \"./consts\";\nimport { playCSS, getRealId, isPausedCSS, isEndedCSS, setPlayCSS } from \"./utils\";\nimport { isFunction, IS_WINDOW, IObject, $, IArrayFormat } from \"@daybrush/utils\";\nimport {\n AnimateElement, SceneState, SceneOptions, EasingType,\n AnimatorState, SceneItemOptions, PlayCondition, NameType\n} from \"./types\";\nimport Frame from \"./Frame\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n/**\n * manage sceneItems and play Scene.\n * @sort 1\n */\nclass Scene extends Animator {\n /**\n * version info\n * @type {string}\n * @example\n * Scene.VERSION // #__VERSION__#\n */\n public static VERSION: string = \"#__VERSION__#\";\n public items: IObject = {};\n public orderMap = new OrderMap(NAME_SEPARATOR);\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: IObject;\n /**\n * @param - properties\n * @param - options\n * @example\n const scene = new Scene({\n item1: {\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n },\n },\n item2: {\n 2: {\n opacity: 1,\n },\n }\n });\n */\n constructor(properties?: { options?: Partial } & IObject, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n let time = 0;\n\n this.forEach(item => {\n time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed());\n });\n return time || this.state[DURATION];\n }\n public setDuration(duration: number) {\n const items = this.items;\n const sceneDuration = this.getDuration();\n\n if (duration === 0 || !isFinite(sceneDuration)) {\n return this;\n }\n if (sceneDuration === 0) {\n this.forEach(item => {\n item.setDuration(duration);\n });\n } else {\n const ratio = duration / sceneDuration;\n\n this.forEach(item => {\n item.setDelay(item.getDelay() * ratio);\n item.setDuration(item.getDuration() * ratio);\n });\n }\n super.setDuration(duration);\n return this;\n }\n public getItem(name: number | string): T;\n /**\n * get item in scene by name\n * @param - The item's name\n * @return {Scene | SceneItem} item\n * @example\n const item = scene.getItem(\"item1\")\n */\n public getItem(name: number | string) {\n return this.items[name];\n }\n /**\n * create item in scene\n * @param {} name - name of item to create\n * @param {} options - The option object of SceneItem\n * @return {} Newly created item\n * @example\n const item = scene.newItem(\"item1\")\n */\n public newItem(name: number | string, options: Partial = {}): Scene | SceneItem {\n if (this.items[name]) {\n return this.items[name];\n }\n const item = new SceneItem();\n\n this.setItem(name, item);\n item.setOptions(options);\n\n return item;\n }\n /**\n * remove item in scene\n * @param - name of item to remove\n * @return An instance itself\n * @example\n const item = scene.newItem(\"item1\")\n\n scene.removeItem(\"item1\");\n */\n public removeItem(name: number | string): this {\n delete this.items[name];\n\n this.orderMap.remove([name]);\n return this;\n }\n /**\n * add a sceneItem to the scene\n * @param - name of item to create\n * @param - sceneItem\n * @example\n const item = scene.newItem(\"item1\")\n */\n public setItem(name: number | string, item: Scene | SceneItem) {\n item.setId(name);\n this.items[name] = item;\n\n this.orderMap.add([name]);\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frames: IObject = {};\n\n this.forEach(item => {\n item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing);\n\n frames[item.getId()] = item.temp;\n });\n this.temp = frames;\n\n /**\n * This event is fired when timeupdate and animate.\n * @event Scene#animate\n * @param {object} param The object of data to be sent to an event.\n * @param {number} param.currentTime The total time that the animator is running.\n * @param {number} param.time The iteration time during duration that the animator is running.\n * @param {object} param.frames frames of that time.\n * @example\nconst scene = new Scene({\n a: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n },\n b: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }\n}).on(\"animate\", e => {\n console.log(e.frames);\n // {a: Frame, b: Frame}\n console.log(e.frames.a.get(\"opacity\"));\n});\n */\n this.trigger(\"animate\", {\n frames,\n currentTime: this.getTime(),\n time: iterationTime,\n });\n\n return this;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Scene} An instance itself\n */\n public forEach(\n func: (\n item: Scene | SceneItem,\n id: string | number,\n index: number,\n items: IObject,\n ) => void,\n ) {\n const items = this.items;\n this.getOrders().forEach((id, index) => {\n func(items[id], id, index, items);\n });\n return this;\n }\n public toCSS(\n playCondition?: PlayCondition,\n duration: number = this.getDuration(), parentStates: AnimatorState[] = []) {\n const totalDuration = !duration || !isFinite(duration) ? 0 : duration;\n const styles: string[] = [];\n const state = this.state;\n\n state[DURATION] = this.getDuration();\n\n this.forEach(item => {\n styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state)));\n });\n return styles.join(\"\");\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {Scene} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition, duration?: number, parentStates?: AnimatorState[]) {\n const css = this.toCSS(playCondition, duration, parentStates);\n\n if (!parentStates || !parentStates.length) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n // && exportCSS(getRealId(this), css);\n }\n return this;\n }\n public append(item: SceneItem | Scene) {\n item.setDelay(item.getDelay() + this.getDuration());\n this.setItem(getRealId(item), item);\n }\n public pauseCSS() {\n return this.forEach(item => {\n item.pauseCSS();\n });\n }\n public pause() {\n super.pause();\n\n isPausedCSS(this) && this.pauseCSS();\n this.forEach(item => {\n item.pause();\n });\n return this;\n }\n public endCSS() {\n this.forEach(item => {\n item.endCSS();\n });\n setPlayCSS(this, false);\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * get item orders\n * @example\n scene.getOrders() // => [\"item1\", \"item2\"]\n */\n public getOrders(): NameType[] {\n return this.orderMap.get([]) || [];\n }\n /**\n * set item orders\n * @param - orders\n * @example\n frame.setOrders([\"item2\", \"item1\"]) // => [\"item2\", \"item1\"]\n */\n public setOrders(orders: NameType[]): NameType[] {\n return this.orderMap.set([], orders);\n }\n public getAnimationElement() {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.getAnimationElement();\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.addPlayClass(isPaused, playClassName, properties);\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @return {Scene} An instance itself\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n scene.playCSS();\n scene.playCSS(false, {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: Partial = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public set(properties: any, ...args: any[]): this;\n /**\n * Set properties to the Scene.\n * @param - properties\n * @return An instance itself\n * @example\nscene.set({\n \".a\": {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n },\n },\n});\n// 0\nconsole.log(scene.getItem(\".a\").get(0, \"opacity\"));\n// 1\nconsole.log(scene.getItem(\".a\").get(1, \"opacity\"));\n */\n public set(properties: any) {\n this.load(properties);\n return this;\n }\n /**\n * Clear All Items\n * @return {Scene} An instance itself\n */\n public clear() {\n this.finish();\n this.items = {};\n this.orderMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n }\n public load(properties: any = {}, options = properties.options) {\n if (!properties) {\n return this;\n }\n const selector = options && options[SELECTOR] || this.state[SELECTOR];\n for (const name in properties) {\n if (name === \"options\") {\n continue;\n }\n const object = properties[name];\n let item;\n\n if (object instanceof Scene || object instanceof SceneItem) {\n this.setItem(name, object);\n item = object;\n } else if (isFunction(object) && selector) {\n const elements =\n IS_WINDOW\n ? $(`${isFunction(selector) ? selector(name) : name}`, true) as IArrayFormat\n : ([] as AnimateElement[]);\n const length = elements.length;\n const scene = new Scene();\n\n for (let i = 0; i < length; ++i) {\n (scene.newItem(i) as SceneItem).setId().setElement(elements[i]).load(object(i, elements[i]));\n }\n this.setItem(name, scene);\n continue;\n } else {\n item = this.newItem(name);\n item.load(object);\n }\n selector && item.setSelector(selector);\n }\n this.setOptions(options);\n }\n public setOptions(options: Partial = {}): this {\n super.setOptions(options);\n\n const selector = options.selector;\n\n if (selector) {\n this.state[SELECTOR] = selector;\n }\n return this;\n }\n public setSelector(target?: string | boolean | ((id: number | string) => string)) {\n const state = this.state;\n const selector = target || state[SELECTOR];\n\n state[SELECTOR] = selector;\n const isItFunction = isFunction(target);\n if (selector) {\n this.forEach((item, name) => {\n item.setSelector(isItFunction ? (target as (id: number | string) => string)(name) : selector);\n });\n }\n return this;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const result = super.start(delay);\n\n if (result) {\n this.forEach(item => {\n item.start(0);\n });\n } else {\n this.forEach(item => {\n item.setPlayState(RUNNING);\n });\n }\n return result;\n }\n}\n\nexport default Scene;\n","import { IObject } from \"@daybrush/utils\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport { SceneOptions, SceneItemOptions } from \"./types\";\n\nexport function animate(properties?: IObject, options?: Partial) {\n return new Scene(properties, options).play();\n}\nexport function animateItem(properties?: IObject, options?: Partial) {\n return new SceneItem(properties, options).play();\n}\n"],"names":["cubic","y1","y2","t","t2","solveFromX","x1","x2","x","solveX","dx","Math","abs","bezier","func","max","min","easingName","steps","count","position","time","level","floor","STEP_START","STEP_END","LINEAR","EASE","EASE_IN","EASE_OUT","EASE_IN_OUT","PREFIX","DATA_SCENE_ID","TIMING_FUNCTION","ROLES","transform","filter","attribute","html","ALIAS","easing","FIXED","_a","MAXIMUM","THRESHOLD","DURATION","FILL_MODE","DIRECTION","ITERATION_COUNT","DELAY","EASING","PLAY_SPEED","EASING_NAME","ITERATION_TIME","PAUSED","ENDED","TIMEUPDATE","ANIMATE","PLAY","RUNNING","ITERATION","START_ANIMATION","PAUSE_ANIMATION","ALTERNATE","REVERSE","ALTERNATE_REVERSE","NORMAL","INFINITE","PLAY_STATE","PLAY_CSS","PREV_TIME","TICK_TIME","CURRENT_TIME","SELECTOR","TRANSFORM_NAME","EASINGS","NAME_SEPARATOR","OPTIONS","EVENTS","events","name","callback","once","isObject","n","_on","isArray","forEach","_this","push","callback2","_i","args","off","callbacks","index","indexOf","splice","data","event","target","type","currentTarget","toArray","apply","value","options","setOptions","isString","split","separator","newOptions","length","prefix","suffix","model","arr","map","v","PropertyObject","clone","join","toValue","splitStyle","str","properties","splitText","obj","totalLength","i","matches","trim","toPropertyObject","styles","arrayToColorObject","RGBA","stringToBracketObject","text","splitBracket","afterModel","COLOR_MODELS","stringToRGBA","arrayToPropertyObject","stringToColorObject","result","values","splitComma","splitSpace","exec","charAt","toObject","object","size","get","isPropertyObject","setAlias","alias","setRole","names","isProperty","isFixedProperty","roles","fixed","getType","OBJECT","ARRAY","PROPERTY","STRING","NUMBER","isPureObject","constructor","Object","getNames","stack","concat","pop","slice","updateFrame","toFixed","num","round","getValueByNames","undefined","isInProperties","isCheckTrue","role","isRole","isFixed","setPlayCSS","item","isActivate","state","isPausedCSS","isPaused","isEndedCSS","isEnded","makeId","selector","id","random","IS_WINDOW","checkElement","$","getRealId","getId","setId","toId","match","playCSS","isExportCSS","playClassName","ANIMATION","getPlayState","className","addPlayClass","setTime","exportCSS","el","addAnimationEvent","setPlayState","duration","getDuration","isZeroDuration","isFinite","animationend","finish","animationstart","trigger","addEvent","animationiteration","removeEvent","elapsedTime","currentTime","iterationCount","setIteration","getEasing","curveArray","parseFloat","GetterSetter","getter","setter","parent","prototype","camelize","isDirectionReverse","iteration","iteraiontCount","direction","setters","getters","__extends","_super","delay","fillMode","playSpeed","iterationTime","tickTime","prevTime","playState","setEasing","setDuration","getActiveDuration","Infinity","getTime","toTime","timerId","requestAnimationFrame","tick","start","cancelAnimationFrame","end","pause","isTick","isParent","activeDuration","getUnitTime","calculate","isDelay","getIterationTime","splitUnit","unit","passIterationCount","maxIterationCount","currentIterationTime","setIterationTime","isReverse","isFiniteDuration","isForwards","now","to","Animator","EventTrigger","toInnerProperties","orders","arrObj","keys","getKeys","sortOrders","replace","merge","from","FUNCTION","getValue","getPropertyName","OrderMap","set","raw","orderMap","getObject","setObject","key","nextValue","children","gets","params","remove","self","firstParam","Frame","_set","has","stylesLength","isUndefined","frame","setOrderObject","frameProperties","cssObject","FILTER","TRANSFORM","toCSSObject","cssArray","clear","lastParam","add","dotArray","a1","a2","b1","b2","v1","dot","dotColor","color1","color2","value1","value2","model1","model2","colorModel","parseInt","dotObject","a1Type","type1","type2","isFunction1","isFunction2","v2","isNaN","dotNumber","dotValue","nextTime","prevValue","ratio","getNearTimeIndex","times","makeAnimationProperties","decamelize","addTime","addEntry","entries","keytime","prevEntry","getEntries","states","nextEntries","intCount","ceil","currentDuration","lastTime","j","entry","divideTime","unshift","load","originalDuration","ratio_1","items_1","obj_1","time2","items","newFrame","elements","sceneId_1","element","setAttribute","SceneItem","eachTime","realTime","innerValue","value_1","getDelay","frames","hasFrame","getDirection","frameTime","needUpdate","getFrame","update","nameMap","updateFrameOrders","removeFrame","append","unshiftTime","firstFrame","prepend","isStartZero","isFunction","setElement","Element","style","targetFunc","attributes","html_1","innerHTML","cssText","toCSS","fromCSS","parentEasing","getNowFrame","temp","prevNameMap","pushKeys","nextMap","setFrame","toFrame","isAccurate","left","right","realEasing","hasName","nowEasing","getNowValue","prevFrame_1","prevOrderMap","keyframes","setTarget","setSelector","playCondition","parentDuration","itemState","reversedStates","reverse","superParent","infiniteIndex","findIndex","finiteStates","reduce","prev","cur","find","timingFunction","selectors","sel","selectorCallback","preselector","peusdo","KEYFRAMES","_toKeyframes","css","styledInjector","destroy","styled","inject","getAnimationElement","original","pauseCSS","addClass","removeClass","endCSS","hasClass","clientWidth","usePrevValue","prevFrame","nextFrame","isUndefinedLeft","isUndefinedRight","indicies","lastEntry","getTotalDuration","getPlaySpeed","sceneDuration","setDelay","setItem","getOrders","parentStates","totalDuration","animtionElement","Scene","scene","newItem","isItFunction","animate","play","animateItem"],"mappings":"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"} \ No newline at end of file diff --git a/dist/scene.js b/dist/scene.js new file mode 100644 index 00000000..273c63ef --- /dev/null +++ b/dist/scene.js @@ -0,0 +1,5662 @@ +/* +Copyright (c) 2016 Daybrush +name: scenejs +license: MIT +author: Daybrush +repository: https://github.com/daybrush/scenejs.git +version: 1.4.0 +*/ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = global || self, global.Scene = factory()); +}(this, function () { 'use strict'; + + /*! ***************************************************************************** + 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. + ***************************************************************************** */ + + /* global Reflect, Promise */ + var extendStatics = function (d, b) { + extendStatics = Object.setPrototypeOf || { + __proto__: [] + } instanceof Array && function (d, b) { + d.__proto__ = b; + } || function (d, b) { + for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; + }; + + return extendStatics(d, b); + }; + + function __extends(d, b) { + extendStatics(d, b); + + function __() { + this.constructor = d; + } + + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); + } + function __decorate(decorators, target, key, desc) { + var c = arguments.length, + r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, + d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; + } + function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + + for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j]; + + return r; + } + + function cubic(y1, y2, t) { + var t2 = 1 - t; // Bezier Curve Formula + + return t * t * t + 3 * t * t * t2 * y2 + 3 * t * t2 * t2 * y1; + } + + function solveFromX(x1, x2, x) { + // x 0 ~ 1 + // t 0 ~ 1 + var t = x; + var solveX = x; + var dx = 1; + + while (Math.abs(dx) > 1 / 1000) { + // 예상 t초에 의한 _x값 + solveX = cubic(x1, x2, t); + dx = solveX - x; // 차이가 미세하면 그 값을 t로 지정 + + if (Math.abs(dx) < 1 / 1000) { + return t; + } + + t -= dx / 2; + } + + return t; + } + /** + * @namespace easing + */ + + /** + * Cubic Bezier curve. + * @memberof easing + * @func bezier + * @param {number} [x1] - point1's x + * @param {number} [y1] - point1's y + * @param {number} [x2] - point2's x + * @param {number} [y2] - point2's y + * @return {function} the curve function + * @example + import {bezier} from "scenejs"; + Scene.bezier(0, 0, 1, 1) // LINEAR + Scene.bezier(0.25, 0.1, 0.25, 1) // EASE + */ + + + function bezier(x1, y1, x2, y2) { + /* + x = f(t) + calculate inverse function by x + t = f-1(x) + */ + var func = function (x) { + var t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0)); + return cubic(y1, y2, t); + }; + + func.easingName = "cubic-bezier(" + x1 + "," + y1 + "," + x2 + "," + y2 + ")"; + return func; + } + /** + * Specifies a stepping function + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function} + * @memberof easing + * @func steps + * @param {number} count - point1's x + * @param {"start" | "end"} postion - point1's y + * @return {function} the curve function + * @example + import {steps} from "scenejs"; + Scene.steps(1, "start") // Scene.STEP_START + Scene.steps(1, "end") // Scene.STEP_END + */ + + function steps(count, position) { + var func = function (time) { + var level = 1 / count; + + if (time >= 1) { + return 1; + } + + return (position === "start" ? level : 0) + Math.floor(time / level) * level; + }; + + func.easingName = "steps(" + count + ", " + position + ")"; + return func; + } + /** + * Equivalent to steps(1, start) + * @memberof easing + * @name STEP_START + * @static + * @type {function} + * @example + import {STEP_START} from "scenejs"; + Scene.STEP_START // steps(1, start) + */ + + var STEP_START = + /*#__PURE__#*/ + steps(1, "start"); + /** + * Equivalent to steps(1, end) + * @memberof easing + * @name STEP_END + * @static + * @type {function} + * @example + import {STEP_END} from "scenejs"; + Scene.STEP_END // steps(1, end) + */ + + var STEP_END = + /*#__PURE__#*/ + steps(1, "end"); + /** + * Linear Speed (0, 0, 1, 1) + * @memberof easing + * @name LINEAR + * @static + * @type {function} + * @example + import {LINEAR} from "scenejs"; + Scene.LINEAR + */ + + var LINEAR = + /*#__PURE__#*/ + bezier(0, 0, 1, 1); + /** + * Ease Speed (0.25, 0.1, 0.25, 1) + * @memberof easing + * @name EASE + * @static + * @type {function} + * @example + import {EASE} from "scenejs"; + Scene.EASE + */ + + var EASE = + /*#__PURE__#*/ + bezier(0.25, 0.1, 0.25, 1); + /** + * Ease In Speed (0.42, 0, 1, 1) + * @memberof easing + * @name EASE_IN + * @static + * @type {function} + * @example + import {EASE_IN} from "scenejs"; + Scene.EASE_IN + */ + + var EASE_IN = + /*#__PURE__#*/ + bezier(0.42, 0, 1, 1); + /** + * Ease Out Speed (0, 0, 0.58, 1) + * @memberof easing + * @name EASE_OUT + * @static + * @type {function} + * @example + import {EASE_OUT} from "scenejs"; + Scene.EASE_OUT + */ + + var EASE_OUT = + /*#__PURE__#*/ + bezier(0, 0, 0.58, 1); + /** + * Ease In Out Speed (0.42, 0, 0.58, 1) + * @memberof easing + * @name EASE_IN_OUT + * @static + * @type {function} + * @example + import {EASE_IN_OUT} from "scenejs"; + Scene.EASE_IN_OUT + */ + + var EASE_IN_OUT = + /*#__PURE__#*/ + bezier(0.42, 0, 0.58, 1); + + var _a; + var PREFIX = "__SCENEJS_"; + var DATA_SCENE_ID = "data-scene-id"; + var TIMING_FUNCTION = "animation-timing-function"; + var ROLES = { + transform: {}, + filter: {}, + attribute: {}, + html: true + }; + var ALIAS = { + easing: [TIMING_FUNCTION] + }; + var FIXED = (_a = {}, _a[TIMING_FUNCTION] = true, _a.contents = true, _a.html = true, _a); + var MAXIMUM = 1000000; + var THRESHOLD = 0.000001; + var DURATION = "duration"; + var FILL_MODE = "fillMode"; + var DIRECTION = "direction"; + var ITERATION_COUNT = "iterationCount"; + var DELAY = "delay"; + var EASING = "easing"; + var PLAY_SPEED = "playSpeed"; + var EASING_NAME = "easingName"; + var ITERATION_TIME = "iterationTime"; + var PAUSED = "paused"; + var ENDED = "ended"; + var TIMEUPDATE = "timeupdate"; + var ANIMATE = "animate"; + var PLAY = "play"; + var RUNNING = "running"; + var ITERATION = "iteration"; + var START_ANIMATION = "startAnimation"; + var PAUSE_ANIMATION = "pauseAnimation"; + var ALTERNATE = "alternate"; + var REVERSE = "reverse"; + var ALTERNATE_REVERSE = "alternate-reverse"; + var NORMAL = "normal"; + var INFINITE = "infinite"; + var PLAY_STATE = "playState"; + var PLAY_CSS = "playCSS"; + var PREV_TIME = "prevTime"; + var TICK_TIME = "tickTime"; + var CURRENT_TIME = "currentTime"; + var SELECTOR = "selector"; + var TRANSFORM_NAME = "transform"; + var EASINGS = { + "linear": LINEAR, + "ease": EASE, + "ease-in": EASE_IN, + "ease-out": EASE_OUT, + "ease-in-out": EASE_IN_OUT, + "step-start": STEP_START, + "step-end": STEP_END + }; + var NAME_SEPARATOR = "_///_"; + /** + * option name list + * @name Scene.OPTIONS + * @memberof Scene + * @static + * @type {$ts:OptionType} + * @example + * Scene.OPTIONS // ["duration", "fillMode", "direction", "iterationCount", "delay", "easing", "playSpeed"] + */ + + var OPTIONS = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED]; + /** + * Event name list + * @name Scene.EVENTS + * @memberof Scene + * @static + * @type {$ts:EventType} + * @example + * Scene.EVENTS // ["paused", "ended", "timeupdate", "animate", "play", "iteration"]; + */ + + var EVENTS = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION]; + + /* + Copyright (c) 2018 Daybrush + @name: @daybrush/utils + license: MIT + author: Daybrush + repository: https://github.com/daybrush/utils + @version 0.13.0 + */ + /** + * @namespace + * @name Consts + */ + + /** + * get string "rgb" + * @memberof Color + * @example + import {RGB} from "@daybrush/utils"; + + console.log(RGB); // "rgb" + */ + var RGB = "rgb"; + /** + * get string "rgba" + * @memberof Color + * @example + import {RGBA} from "@daybrush/utils"; + + console.log(RGBA); // "rgba" + */ + + var RGBA = "rgba"; + /** + * get string "hsl" + * @memberof Color + * @example + import {HSL} from "@daybrush/utils"; + + console.log(HSL); // "hsl" + */ + + var HSL = "hsl"; + /** + * get string "hsla" + * @memberof Color + * @example + import {HSLA} from "@daybrush/utils"; + + console.log(HSLA); // "hsla" + */ + + var HSLA = "hsla"; + /** + * gets an array of color models. + * @memberof Color + * @example + import {COLOR_MODELS} from "@daybrush/utils"; + + console.log(COLOR_MODELS); // ["rgb", "rgba", "hsl", "hsla"]; + */ + + var COLOR_MODELS = [RGB, RGBA, HSL, HSLA]; + /** + * get string "function" + * @memberof Consts + * @example + import {FUNCTION} from "@daybrush/utils"; + + console.log(FUNCTION); // "function" + */ + + var FUNCTION = "function"; + /** + * get string "property" + * @memberof Consts + * @example + import {PROPERTY} from "@daybrush/utils"; + + console.log(PROPERTY); // "property" + */ + + var PROPERTY = "property"; + /** + * get string "array" + * @memberof Consts + * @example + import {ARRAY} from "@daybrush/utils"; + + console.log(ARRAY); // "array" + */ + + var ARRAY = "array"; + /** + * get string "object" + * @memberof Consts + * @example + import {OBJECT} from "@daybrush/utils"; + + console.log(OBJECT); // "object" + */ + + var OBJECT = "object"; + /** + * get string "string" + * @memberof Consts + * @example + import {STRING} from "@daybrush/utils"; + + console.log(STRING); // "string" + */ + + var STRING = "string"; + /** + * get string "number" + * @memberof Consts + * @example + import {NUMBER} from "@daybrush/utils"; + + console.log(NUMBER); // "number" + */ + + var NUMBER = "number"; + /** + * get string "undefined" + * @memberof Consts + * @example + import {UNDEFINED} from "@daybrush/utils"; + + console.log(UNDEFINED); // "undefined" + */ + + var UNDEFINED = "undefined"; + /** + * Check whether the environment is window or node.js. + * @memberof Consts + * @example + import {IS_WINDOW} from "@daybrush/utils"; + + console.log(IS_WINDOW); // false in node.js + console.log(IS_WINDOW); // true in browser + */ + + var IS_WINDOW = typeof window !== UNDEFINED; + /** + * Check whether the environment is window or node.js. + * @memberof Consts + * @name document + * @example + import {IS_WINDOW} from "@daybrush/utils"; + + console.log(IS_WINDOW); // false in node.js + console.log(IS_WINDOW); // true in browser + */ + + var doc = typeof document !== UNDEFINED && document; // FIXME: this type maybe false + var prefixes = ["webkit", "ms", "moz", "o"]; + /** + * @namespace CrossBrowser + */ + + /** + * Get a CSS property with a vendor prefix that supports cross browser. + * @function + * @param {string} property - A CSS property + * @return {string} CSS property with cross-browser vendor prefix + * @memberof CrossBrowser + * @example + import {getCrossBrowserProperty} from "@daybrush/utils"; + + console.log(getCrossBrowserProperty("transform")); // "transform", "-ms-transform", "-webkit-transform" + console.log(getCrossBrowserProperty("filter")); // "filter", "-webkit-filter" + */ + + var getCrossBrowserProperty = /*#__PURE__*/function (property) { + if (!doc) { + return ""; + } + + var styles = (doc.body || doc.documentElement).style; + var length = prefixes.length; + + if (typeof styles[property] !== UNDEFINED) { + return property; + } + + for (var i = 0; i < length; ++i) { + var name = "-" + prefixes[i] + "-" + property; + + if (typeof styles[name] !== UNDEFINED) { + return name; + } + } + + return ""; + }; + /** + * get string "transfrom" with the vendor prefix. + * @memberof CrossBrowser + * @example + import {TRANSFORM} from "@daybrush/utils"; + + console.log(TRANSFORM); // "transform", "-ms-transform", "-webkit-transform" + */ + + var TRANSFORM = /*#__PURE__*/getCrossBrowserProperty("transform"); + /** + * get string "filter" with the vendor prefix. + * @memberof CrossBrowser + * @example + import {FILTER} from "@daybrush/utils"; + + console.log(FILTER); // "filter", "-ms-filter", "-webkit-filter" + */ + + var FILTER = /*#__PURE__*/getCrossBrowserProperty("filter"); + /** + * get string "animation" with the vendor prefix. + * @memberof CrossBrowser + * @example + import {ANIMATION} from "@daybrush/utils"; + + console.log(ANIMATION); // "animation", "-ms-animation", "-webkit-animation" + */ + + var ANIMATION = /*#__PURE__*/getCrossBrowserProperty("animation"); + /** + * get string "keyframes" with the vendor prefix. + * @memberof CrossBrowser + * @example + import {KEYFRAMES} from "@daybrush/utils"; + + console.log(KEYFRAMES); // "keyframes", "-ms-keyframes", "-webkit-keyframes" + */ + + var KEYFRAMES = /*#__PURE__*/ANIMATION.replace("animation", "keyframes"); + var OPEN_CLOSED_CHARACTER = ["\"", "'", "\\\"", "\\'"]; + + /** + * @namespace + * @name Utils + */ + + /** + * Returns the inner product of two numbers(`a1`, `a2`) by two criteria(`b1`, `b2`). + * @memberof Utils + * @param - The first number + * @param - The second number + * @param - The first number to base on the inner product + * @param - The second number to base on the inner product + * @return - Returns the inner product + import { dot } from "@daybrush/utils"; + + console.log(dot(0, 15, 2, 3)); // 6 + console.log(dot(5, 15, 2, 3)); // 9 + console.log(dot(5, 15, 1, 1)); // 10 + */ + + function dot(a1, a2, b1, b2) { + return (a1 * b2 + a2 * b1) / (b1 + b2); + } + /** + * Check the type that the value is undefined. + * @memberof Utils + * @param {string} value - Value to check the type + * @return {boolean} true if the type is correct, false otherwise + * @example + import {isUndefined} from "@daybrush/utils"; + + console.log(isUndefined(undefined)); // true + console.log(isUndefined("")); // false + console.log(isUndefined(1)); // false + console.log(isUndefined(null)); // false + */ + + function isUndefined(value) { + return typeof value === UNDEFINED; + } + /** + * Check the type that the value is object. + * @memberof Utils + * @param {string} value - Value to check the type + * @return {} true if the type is correct, false otherwise + * @example + import {isObject} from "@daybrush/utils"; + + console.log(isObject({})); // true + console.log(isObject(undefined)); // false + console.log(isObject("")); // false + console.log(isObject(null)); // false + */ + + function isObject(value) { + return value && typeof value === OBJECT; + } + /** + * Check the type that the value is isArray. + * @memberof Utils + * @param {string} value - Value to check the type + * @return {} true if the type is correct, false otherwise + * @example + import {isArray} from "@daybrush/utils"; + + console.log(isArray([])); // true + console.log(isArray({})); // false + console.log(isArray(undefined)); // false + console.log(isArray(null)); // false + */ + + function isArray(value) { + return Array.isArray(value); + } + /** + * Check the type that the value is string. + * @memberof Utils + * @param {string} value - Value to check the type + * @return {} true if the type is correct, false otherwise + * @example + import {isString} from "@daybrush/utils"; + + console.log(isString("1234")); // true + console.log(isString(undefined)); // false + console.log(isString(1)); // false + console.log(isString(null)); // false + */ + + function isString(value) { + return typeof value === STRING; + } + /** + * Check the type that the value is function. + * @memberof Utils + * @param {string} value - Value to check the type + * @return {} true if the type is correct, false otherwise + * @example + import {isFunction} from "@daybrush/utils"; + + console.log(isFunction(function a() {})); // true + console.log(isFunction(() => {})); // true + console.log(isFunction("1234")); // false + console.log(isFunction(1)); // false + console.log(isFunction(null)); // false + */ + + function isFunction(value) { + return typeof value === FUNCTION; + } + + function findClosed(closedCharacter, texts, index, length) { + for (var i = index; i < length; ++i) { + var character = texts[i].trim(); + + if (character === closedCharacter) { + return i; + } + + var nextIndex = i; + + if (character === "(") { + nextIndex = findClosed(")", texts, i + 1, length); + } else if (OPEN_CLOSED_CHARACTER.indexOf(character) > -1) { + nextIndex = findClosed(character, texts, i + 1, length); + } + + if (nextIndex === -1) { + break; + } + + i = nextIndex; + } + + return -1; + } + + function splitText(text, separator) { + var regexText = "(\\s*" + (separator || ",") + "\\s*|\\(|\\)|\"|'|\\\\\"|\\\\'|\\s+)"; + var regex = new RegExp(regexText, "g"); + var texts = text.split(regex).filter(Boolean); + var length = texts.length; + var values = []; + var tempValues = []; + + for (var i = 0; i < length; ++i) { + var character = texts[i].trim(); + var nextIndex = i; + + if (character === "(") { + nextIndex = findClosed(")", texts, i + 1, length); + } else if (character === ")") { + throw new Error("invalid format"); + } else if (OPEN_CLOSED_CHARACTER.indexOf(character) > -1) { + nextIndex = findClosed(character, texts, i + 1, length); + } else if (character === separator) { + if (tempValues.length) { + values.push(tempValues.join("")); + tempValues = []; + } + + continue; + } + + if (nextIndex === -1) { + nextIndex = length - 1; + } + + tempValues.push(texts.slice(i, nextIndex + 1).join("")); + i = nextIndex; + } + + if (tempValues.length) { + values.push(tempValues.join("")); + } + + return values; + } + /** + * divide text by space. + * @memberof Utils + * @param {string} text - text to divide + * @return {Array} divided texts + * @example + import {spliceSpace} from "@daybrush/utils"; + + console.log(splitSpace("a b c d e f g")); + // ["a", "b", "c", "d", "e", "f", "g"] + console.log(splitSpace("'a,b' c 'd,e' f g")); + // ["'a,b'", "c", "'d,e'", "f", "g"] + */ + + function splitSpace(text) { + // divide comma(,) + return splitText(text, ""); + } + /** + * divide text by comma. + * @memberof Utils + * @param {string} text - text to divide + * @return {Array} divided texts + * @example + import {splitComma} from "@daybrush/utils"; + + console.log(splitComma("a,b,c,d,e,f,g")); + // ["a", "b", "c", "d", "e", "f", "g"] + console.log(splitComma("'a,b',c,'d,e',f,g")); + // ["'a,b'", "c", "'d,e'", "f", "g"] + */ + + function splitComma(text) { + // divide comma(,) + // "[^"]*"|'[^']*' + return splitText(text, ","); + } + /** + * divide text by bracket "(", ")". + * @memberof Utils + * @param {string} text - text to divide + * @return {object} divided texts + * @example + import {splitBracket} from "@daybrush/utils"; + + console.log(splitBracket("a(1, 2)")); + // {prefix: "a", value: "1, 2", suffix: ""} + console.log(splitBracket("a(1, 2)b")); + // {prefix: "a", value: "1, 2", suffix: "b"} + */ + + function splitBracket(text) { + var matches = /([^(]*)\(([\s\S]*)\)([\s\S]*)/g.exec(text); + + if (!matches || matches.length < 4) { + return {}; + } else { + return { + prefix: matches[1], + value: matches[2], + suffix: matches[3] + }; + } + } + /** + * divide text by number and unit. + * @memberof Utils + * @param {string} text - text to divide + * @return {} divided texts + * @example + import {splitUnit} from "@daybrush/utils"; + + console.log(splitUnit("10px")); + // {prefix: "", value: 10, unit: "px"} + console.log(splitUnit("-10px")); + // {prefix: "", value: -10, unit: "px"} + console.log(splitUnit("a10%")); + // {prefix: "a", value: 10, unit: "%"} + */ + + function splitUnit(text) { + var matches = /^([^\d|e|\-|\+]*)((?:\d|\.|-|e-|e\+)+)(\S*)$/g.exec(text); + + if (!matches) { + return { + prefix: "", + unit: "", + value: NaN + }; + } + + var prefix = matches[1]; + var value = matches[2]; + var unit = matches[3]; + return { + prefix: prefix, + unit: unit, + value: parseFloat(value) + }; + } + /** + * transform strings to camel-case + * @memberof Utils + * @param {String} text - string + * @return {String} camel-case string + * @example + import {camelize} from "@daybrush/utils"; + + console.log(camelize("transform-origin")); // transformOrigin + console.log(camelize("abcd_efg")); // abcdEfg + console.log(camelize("abcd efg")); // abcdEfg + */ + + function camelize(str) { + return str.replace(/[\s-_]([a-z])/g, function (all, letter) { + return letter.toUpperCase(); + }); + } + /** + * transform a camelized string into a lowercased string. + * @memberof Utils + * @param {string} text - a camel-cased string + * @param {string} [separator="-"] - a separator + * @return {string} a lowercased string + * @example + import {decamelize} from "@daybrush/utils"; + + console.log(decamelize("transformOrigin")); // transform-origin + console.log(decamelize("abcdEfg", "_")); // abcd_efg + */ + + function decamelize(str, separator) { + if (separator === void 0) { + separator = "-"; + } + + return str.replace(/([a-z])([A-Z])/g, function (all, letter, letter2) { + return "" + letter + separator + letter2.toLowerCase(); + }); + } + /** + * transforms something in an array into an array. + * @memberof Utils + * @param - Array form + * @return an array + * @example + import {toArray} from "@daybrush/utils"; + + const arr1 = toArray(document.querySelectorAll(".a")); // Element[] + const arr2 = toArray(document.querySelectorAll(".a")); // HTMLElement[] + */ + + function toArray(value) { + return [].slice.call(value); + } + /** + * Date.now() method + * @memberof CrossBrowser + * @return {number} milliseconds + * @example + import {now} from "@daybrush/utils"; + + console.log(now()); // 12121324241(milliseconds) + */ + + function now() { + return Date.now ? Date.now() : new Date().getTime(); + } + /** + * Returns the index of the first element in the array that satisfies the provided testing function. + * @function + * @memberof CrossBrowser + * @param - The array `findIndex` was called upon. + * @param - A function to execute on each value in the array until the function returns true, indicating that the satisfying element was found. + * @param - Returns defaultIndex if not found by the function. + * @example + import { findIndex } from "@daybrush/utils"; + + findIndex([{a: 1}, {a: 2}, {a: 3}, {a: 4}], ({ a }) => a === 2); // 1 + */ + + function findIndex(arr, callback, defaultIndex) { + if (defaultIndex === void 0) { + defaultIndex = -1; + } + + var length = arr.length; + + for (var i = 0; i < length; ++i) { + if (callback(arr[i], i, arr)) { + return i; + } + } + + return defaultIndex; + } + /** + * Returns the value of the first element in the array that satisfies the provided testing function. + * @function + * @memberof CrossBrowser + * @param - The array `find` was called upon. + * @param - A function to execute on each value in the array, + * @param - Returns defalutValue if not found by the function. + * @example + import { find } from "@daybrush/utils"; + + find([{a: 1}, {a: 2}, {a: 3}, {a: 4}], ({ a }) => a === 2); // {a: 2} + */ + + function find(arr, callback, defalutValue) { + var index = findIndex(arr, callback); + return index > -1 ? arr[index] : defalutValue; + } + /** + * window.requestAnimationFrame() method with cross browser. + * @function + * @memberof CrossBrowser + * @param {FrameRequestCallback} callback - The function to call when it's time to update your animation for the next repaint. + * @return {number} id + * @example + import {requestAnimationFrame} from "@daybrush/utils"; + + requestAnimationFrame((timestamp) => { + console.log(timestamp); + }); + */ + + var requestAnimationFrame = /*#__PURE__*/function () { + var firstTime = now(); + var raf = IS_WINDOW && (window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.msRequestAnimationFrame); + return raf ? raf.bind(window) : function (callback) { + var currTime = now(); + var id = window.setTimeout(function () { + callback(currTime - firstTime); + }, 1000 / 60); + return id; + }; + }(); + /** + * window.cancelAnimationFrame() method with cross browser. + * @function + * @memberof CrossBrowser + * @param {number} handle - the id obtained through requestAnimationFrame method + * @return {void} + * @example + import { requestAnimationFrame, cancelAnimationFrame } from "@daybrush/utils"; + + const id = requestAnimationFrame((timestamp) => { + console.log(timestamp); + }); + + cancelAnimationFrame(id); + */ + + var cancelAnimationFrame = /*#__PURE__*/function () { + var caf = IS_WINDOW && (window.cancelAnimationFrame || window.webkitCancelAnimationFrame || window.mozCancelAnimationFrame || window.msCancelAnimationFrame); + return caf ? caf.bind(window) : function (handle) { + clearTimeout(handle); + }; + }(); + function getKeys(obj) { + if (Object.keys) { + return Object.keys(obj); + } + + var keys = []; + + for (var name in keys) { + keys.push(name); + } + + return keys; + } + function sortOrders(keys, orders) { + if (orders === void 0) { + orders = []; + } + + keys.sort(function (a, b) { + var index1 = orders.indexOf(a); + var index2 = orders.indexOf(b); + + if (index2 === -1 && index1 === -1) { + return 0; + } + + if (index1 === -1) { + return 1; + } + + if (index2 === -1) { + return -1; + } + + return index1 - index2; + }); + } + + /** + * @namespace + * @name Color + */ + + /** + * Remove the # from the hex color. + * @memberof Color + * @param {} hex - hex color + * @return {} hex color + * @example + import {cutHex} from "@daybrush/utils"; + + console.log(cutHex("#000000")) // "000000" + */ + + function cutHex(hex) { + return hex.replace("#", ""); + } + /** + * convert hex color to rgb color. + * @memberof Color + * @param {} hex - hex color + * @return {} rgb color + * @example + import {hexToRGBA} from "@daybrush/utils"; + + console.log(hexToRGBA("#00000005")); + // [0, 0, 0, 1] + console.log(hexToRGBA("#201045")); + // [32, 16, 69, 1] + */ + + function hexToRGBA(hex) { + var h = cutHex(hex); + var r = parseInt(h.substring(0, 2), 16); + var g = parseInt(h.substring(2, 4), 16); + var b = parseInt(h.substring(4, 6), 16); + var a = parseInt(h.substring(6, 8), 16) / 255; + + if (isNaN(a)) { + a = 1; + } + + return [r, g, b, a]; + } + /** + * convert 3(or 4)-digit hex color to 6(or 8)-digit hex color. + * @memberof Color + * @param {} hex - 3(or 4)-digit hex color + * @return {} 6(or 8)-digit hex color + * @example + import {toFullHex} from "@daybrush/utils"; + + console.log(toFullHex("#123")); // "#112233" + console.log(toFullHex("#123a")); // "#112233aa" + */ + + function toFullHex(h) { + var r = h.charAt(1); + var g = h.charAt(2); + var b = h.charAt(3); + var a = h.charAt(4); + var arr = ["#", r, r, g, g, b, b, a, a]; + return arr.join(""); + } + /** + * convert hsl color to rgba color. + * @memberof Color + * @param {} hsl - hsl color(hue: 0 ~ 360, saturation: 0 ~ 1, lightness: 0 ~ 1, alpha: 0 ~ 1) + * @return {} rgba color + * @example + import {hslToRGBA} from "@daybrush/utils"; + + console.log(hslToRGBA([150, 0.5, 0.4])); + // [51, 153, 102, 1] + */ + + function hslToRGBA(hsl) { + var _a; + + var h = hsl[0]; + var s = hsl[1]; + var l = hsl[2]; + + if (h < 0) { + h += Math.floor((Math.abs(h) + 360) / 360) * 360; + } + + h %= 360; + var c = (1 - Math.abs(2 * l - 1)) * s; + var x = c * (1 - Math.abs(h / 60 % 2 - 1)); + var m = l - c / 2; + var rgb; + + if (h < 60) { + rgb = [c, x, 0]; + } else if (h < 120) { + rgb = [x, c, 0]; + } else if (h < 180) { + rgb = [0, c, x]; + } else if (h < 240) { + rgb = [0, x, c]; + } else if (h < 300) { + rgb = [x, 0, c]; + } else if (h < 360) { + rgb = [c, 0, x]; + } else { + rgb = [0, 0, 0]; + } + + return [Math.round((rgb[0] + m) * 255), Math.round((rgb[1] + m) * 255), Math.round((rgb[2] + m) * 255), (_a = hsl[3]) !== null && _a !== void 0 ? _a : 1]; + } + /** + * convert string to rgba color. + * @memberof Color + * @param {} - 3-hex(#000), 4-hex(#0000) 6-hex(#000000), 8-hex(#00000000) or RGB(A), or HSL(A) + * @return {} rgba color + * @example + import {stringToRGBA} from "@daybrush/utils"; + + console.log(stringToRGBA("#000000")); // [0, 0, 0, 1] + console.log(stringToRGBA("rgb(100, 100, 100)")); // [100, 100, 100, 1] + console.log(stringToRGBA("hsl(150, 0.5, 0.4)")); // [51, 153, 102, 1] + */ + + function stringToRGBA(color) { + if (color.charAt(0) === "#") { + if (color.length === 4 || color.length === 5) { + return hexToRGBA(toFullHex(color)); + } else { + return hexToRGBA(color); + } + } else if (color.indexOf("(") !== -1) { + // in bracket. + var _a = splitBracket(color), + prefix = _a.prefix, + value = _a.value; + + if (!prefix || !value) { + return undefined; + } + + var arr = splitComma(value); + var colorArr = [0, 0, 0, 1]; + var length = arr.length; + + switch (prefix) { + case RGB: + case RGBA: + for (var i = 0; i < length; ++i) { + colorArr[i] = parseFloat(arr[i]); + } + + return colorArr; + + case HSL: + case HSLA: + for (var i = 0; i < length; ++i) { + if (arr[i].indexOf("%") !== -1) { + colorArr[i] = parseFloat(arr[i]) / 100; + } else { + colorArr[i] = parseFloat(arr[i]); + } + } // hsl, hsla to rgba + + + return hslToRGBA(colorArr); + } + } + + return undefined; + } + + /** + * Returns all element descendants of node that + * match selectors. + */ + + /** + * Checks if the specified class value exists in the element's class attribute. + * @memberof DOM + * @param - A DOMString containing one or more selectors to match + * @param - If multi is true, a DOMString containing one or more selectors to match against. + * @example + import {$} from "@daybrush/utils"; + + console.log($("div")); // div element + console.log($("div", true)); // [div, div] elements + */ + + function $(selectors, multi) { + return multi ? doc.querySelectorAll(selectors) : doc.querySelector(selectors); + } + /** + * Checks if the specified class value exists in the element's class attribute. + * @memberof DOM + * @param element - target + * @param className - the class name to search + * @return {boolean} return false if the class is not found. + * @example + import {hasClass} from "@daybrush/utils"; + + console.log(hasClass(element, "start")); // true or false + */ + + function hasClass(element, className) { + if (element.classList) { + return element.classList.contains(className); + } + + return !!element.className.match(new RegExp("(\\s|^)" + className + "(\\s|$)")); + } + /** + * Add the specified class value. If these classe already exist in the element's class attribute they are ignored. + * @memberof DOM + * @param element - target + * @param className - the class name to add + * @example + import {addClass} from "@daybrush/utils"; + + addClass(element, "start"); + */ + + function addClass(element, className) { + if (element.classList) { + element.classList.add(className); + } else { + element.className += " " + className; + } + } + /** + * Removes the specified class value. + * @memberof DOM + * @param element - target + * @param className - the class name to remove + * @example + import {removeClass} from "@daybrush/utils"; + + removeClass(element, "start"); + */ + + function removeClass(element, className) { + if (element.classList) { + element.classList.remove(className); + } else { + var reg = new RegExp("(\\s|^)" + className + "(\\s|$)"); + element.className = element.className.replace(reg, " "); + } + } + /** + * Gets the CSS properties from the element. + * @memberof DOM + * @param elements - elements + * @param properites - the CSS properties + * @return returns CSS properties and values. + * @example + import {fromCSS} from "@daybrush/utils"; + + console.log(fromCSS(element, ["left", "opacity", "top"])); // {"left": "10px", "opacity": 1, "top": "10px"} + */ + + function fromCSS(elements, properties) { + if (!elements || !properties || !properties.length) { + return {}; + } + + var element; + + if (elements instanceof Element) { + element = elements; + } else if (elements.length) { + element = elements[0]; + } else { + return {}; + } + + var cssObject = {}; + var styles = window.getComputedStyle(element); + var length = properties.length; + + for (var i = 0; i < length; ++i) { + cssObject[properties[i]] = styles[properties[i]]; + } + + return cssObject; + } + /** + * Sets up a function that will be called whenever the specified event is delivered to the target + * @memberof DOM + * @param - event target + * @param - A case-sensitive string representing the event type to listen for. + * @param - The object which receives a notification (an object that implements the Event interface) when an event of the specified type occurs + * @param - An options object that specifies characteristics about the event listener. The available options are: + * @example + import {addEvent} from "@daybrush/utils"; + + addEvent(el, "click", e => { + console.log(e); + }); + */ + + function addEvent(el, type, listener, options) { + el.addEventListener(type, listener, options); + } + /** + * removes from the EventTarget an event listener previously registered with EventTarget.addEventListener() + * @memberof DOM + * @param - event target + * @param - A case-sensitive string representing the event type to listen for. + * @param - The EventListener function of the event handler to remove from the event target. + * @example + import {addEvent, removeEvent} from "@daybrush/utils"; + const listener = e => { + console.log(e); + }; + addEvent(el, "click", listener); + removeEvent(el, "click", listener); + */ + + function removeEvent(el, type, listener) { + el.removeEventListener(type, listener); + } + + /** + * attach and trigger event handlers. + */ + + var EventTrigger = + /*#__PURE__*/ + function () { + /** + * @example + const et = new Scene.EventTrigger(); + const scene = new Scene(); + scene.on("call", e => { + console.log(e.param); + }); + et.on("call", e => { + console.log(e.param); + }); + scene.trigger("call", {param: 1}); + et.trigger("call", {param: 1}); + */ + function EventTrigger() { + this.events = {}; + } + + var __proto = EventTrigger.prototype; + + __proto._on = function (name, callback, once) { + var _this = this; + + var events = this.events; + + if (isObject(name)) { + for (var n in name) { + this._on(n, name[n], once); + } + + return; + } + + if (!(name in events)) { + events[name] = []; + } + + if (!callback) { + return; + } + + if (isArray(callback)) { + callback.forEach(function (func) { + return _this._on(name, func, once); + }); + return; + } + + events[name].push(once ? function callback2() { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + callback.apply(void 0, args); + this.off(name, callback2); + } : callback); + }; + /** + * Attach an event handler function for one or more events to target + * @param - event's name + * @param - function to execute when the event is triggered. + * @return {EventTrigger} An Instance itself. + * @example + target.on("animate", function() { + console.log("animate"); + }); + target.trigger("animate"); + */ + + + __proto.on = function (name, callback) { + this._on(name, callback); + + return this; + }; + /** + * Dettach an event handler function for one or more events to target + * @param - event's name + * @param - function to execute when the event is triggered. + * @return {EventTrigger} An Instance itself. + * @example + const callback = function() { + console.log("animate"); + }; + target.on("animate", callback); + target.off("animate", callback); + target.off("animate"); + */ + + + __proto.off = function (name, callback) { + if (!name) { + this.events = {}; + } else if (!callback) { + this.events[name] = []; + } else { + var callbacks = this.events[name]; + + if (!callbacks) { + return this; + } + + var index = callbacks.indexOf(callback); + + if (index !== -1) { + callbacks.splice(index, 1); + } + } + + return this; + }; + /** + * execute event handler + * @param - event's name + * @param - event handler's additional parameter + * @return {EventTrigger} An Instance itself. + * @example + target.on("animate", function(a1, a2) { + console.log("animate", a1, a2); + }); + target.trigger("animate", [1, 2]); // log => "animate", 1, 2 + */ + + + __proto.trigger = function (name) { + var _this = this; + + var data = []; + + for (var _i = 1; _i < arguments.length; _i++) { + data[_i - 1] = arguments[_i]; + } + + var events = this.events; + + if (!(name in events)) { + return this; + } + + var args = data || []; + !args[0] && (args[0] = {}); + var event = events[name]; + var target = args[0]; + target.type = name; + target.currentTarget = this; + !target.target && (target.target = this); + toArray(events[name]).forEach(function (callback) { + callback.apply(_this, data); + }); + return this; + }; + + __proto.once = function (name, callback) { + this._on(name, callback, true); + + return this; + }; + + return EventTrigger; + }(); + + /** + * Make string, array to PropertyObject for the dot product + */ + + var PropertyObject = + /*#__PURE__*/ + function () { + /** + * @param - This value is in the array format. + * @param - options + * @example + var obj = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + */ + function PropertyObject(value, options) { + this.prefix = ""; + this.suffix = ""; + this.model = ""; + this.type = ""; + this.separator = ","; + options && this.setOptions(options); + this.value = isString(value) ? value.split(this.separator) : value; + } + + var __proto = PropertyObject.prototype; + + __proto.setOptions = function (newOptions) { + for (var name in newOptions) { + this[name] = newOptions[name]; + } + + return this; + }; + /** + * the number of values. + * @example + const obj1 = new PropertyObject("1,2,3", ","); + console.log(obj1.length); + // 3 + */ + + + __proto.size = function () { + return this.value.length; + }; + /** + * retrieve one of values at the index + * @param {Number} index - index + * @return {Object} one of values at the index + * @example + const obj1 = new PropertyObject("1,2,3", ","); + console.log(obj1.get(0)); + // 1 + */ + + + __proto.get = function (index) { + return this.value[index]; + }; + /** + * Set the value at that index + * @param {Number} index - index + * @param {Object} value - text, a number, object to set + * @return {PropertyObject} An instance itself + * @example + const obj1 = new PropertyObject("1,2,3", ","); + obj1.set(0, 2); + console.log(obj1.toValue()); + // 2,2,3 + */ + + + __proto.set = function (index, value) { + this.value[index] = value; + return this; + }; + /** + * create a copy of an instance itself. + * @return {PropertyObject} clone + * @example + const obj1 = new PropertyObject("1,2,3", ","); + const obj2 = obj1.clone(); + */ + + + __proto.clone = function () { + var _a = this, + separator = _a.separator, + prefix = _a.prefix, + suffix = _a.suffix, + model = _a.model, + type = _a.type; + + var arr = this.value.map(function (v) { + return v instanceof PropertyObject ? v.clone() : v; + }); + return new PropertyObject(arr, { + separator: separator, + prefix: prefix, + suffix: suffix, + model: model, + type: type + }); + }; + /** + * Make Property Object to String + * @return {String} Make Property Object to String + * @example + //rgba(100, 100, 100, 0.5) + const obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")", + }); + console.log(obj4.toValue()); + // "rgba(100,100,100,0.5)" + */ + + + __proto.toValue = function () { + return this.prefix + this.join() + this.suffix; + }; + /** + * Make Property Object's array to String + * @return {String} Join the elements of an array into a string + * @example + //rgba(100, 100, 100, 0.5) + var obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + obj4.join(); // => "100,100,100,0.5" + */ + + + __proto.join = function () { + return this.value.map(function (v) { + return v instanceof PropertyObject ? v.toValue() : v; + }).join(this.separator); + }; + /** + * executes a provided function once per array element. + * @param {Function} callback - Function to execute for each element, taking three arguments + * @param {All} [callback.currentValue] The current element being processed in the array. + * @param {Number} [callback.index] The index of the current element being processed in the array. + * @param {Array} [callback.array] the array. + * @return {PropertyObject} An instance itself + * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document. + * @example + //rgba(100, 100, 100, 0.5) + var obj4 = new PropertyObject([100,100,100,0.5], { + "separator" : ",", + "prefix" : "rgba(", + "suffix" : ")" + }); + obj4.forEach(t => { + console.log(t); + }); // => "100,100,100,0.5" + */ + + + __proto.forEach = function (func) { + this.value.forEach(func); + return this; + }; + + return PropertyObject; + }(); + + /** + * @namespace + * @name Property + */ + function splitStyle(str) { + var properties = splitText(str, ";"); + var obj = {}; + var totalLength = properties.length; + var length = totalLength; + + for (var i = 0; i < totalLength; ++i) { + var matches = splitText(properties[i], ":"); + + if (matches.length < 2 || !matches[1]) { + --length; + continue; + } + + obj[matches[0].trim()] = toPropertyObject(matches[1].trim()); + } + + return { + styles: obj, + length: length + }; + } + /** + * convert array to PropertyObject[type=color]. + * default model "rgba" + * @memberof Property + * @function arrayToColorObject + * @param {Array|PropertyObject} value ex) [0, 0, 0, 1] + * @return {PropertyObject} PropertyObject[type=color] + * @example + arrayToColorObject([0, 0, 0]) + // => PropertyObject(type="color", model="rgba", value=[0, 0, 0, 1], separator=",") + */ + + function arrayToColorObject(arr) { + var model = RGBA; + + if (arr.length === 3) { + arr[3] = 1; + } + + return new PropertyObject(arr, { + model: model, + separator: ",", + type: "color", + prefix: model + "(", + suffix: ")" + }); + } + /** + * convert text with parentheses to object. + * @memberof Property + * @function stringToBracketObject + * @param {String} value ex) "rgba(0,0,0,1)" + * @return {PropertyObject} PropertyObject + * @example + stringToBracketObject("abcde(0, 0, 0,1)") + // => PropertyObject(model="abcde", value=[0, 0, 0,1], separator=",") + */ + + function stringToBracketObject(text) { + // [prefix, value, other] + var _a = splitBracket(text), + model = _a.prefix, + value = _a.value, + afterModel = _a.suffix; + + if (typeof value === "undefined") { + return text; + } + + if (COLOR_MODELS.indexOf(model) > -1) { + return arrayToColorObject(stringToRGBA(text)); + } // divide comma(,) + + + var obj = toPropertyObject(value, model); + var arr = [value]; + var separator = ","; + var prefix = model + "("; + var suffix = ")" + afterModel; + + if (obj instanceof PropertyObject) { + separator = obj.separator; + arr = obj.value; + prefix += obj.prefix; + suffix = obj.suffix + suffix; + } + + return new PropertyObject(arr, { + separator: separator, + model: model, + prefix: prefix, + suffix: suffix + }); + } + function arrayToPropertyObject(arr, separator) { + return new PropertyObject(arr, { + type: "array", + separator: separator + }); + } + /** + * convert text with parentheses to PropertyObject[type=color]. + * If the values are not RGBA model, change them RGBA mdoel. + * @memberof Property + * @function stringToColorObject + * @param {String|PropertyObject} value ex) "rgba(0,0,0,1)" + * @return {PropertyObject} PropertyObject[type=color] + * @example + stringToColorObject("rgba(0, 0, 0,1)") + // => PropertyObject(type="color", model="rgba", value=[0, 0, 0,1], separator=",") + */ + + function stringToColorObject(value) { + var result = stringToRGBA(value); + return result ? arrayToColorObject(result) : value; + } + function toPropertyObject(value, model) { + if (!isString(value)) { + if (isArray(value)) { + return arrayToPropertyObject(value, ","); + } + + return value; + } + + var values = splitComma(value); + + if (values.length > 1) { + return arrayToPropertyObject(values.map(function (v) { + return toPropertyObject(v); + }), ","); + } + + values = splitSpace(value); + + if (values.length > 1) { + return arrayToPropertyObject(values.map(function (v) { + return toPropertyObject(v); + }), " "); + } + + values = /^(['"])([^'"]*)(['"])$/g.exec(value); + + if (values && values[1] === values[3]) { + // Quotes + return new PropertyObject([toPropertyObject(values[2])], { + prefix: values[1], + suffix: values[1] + }); + } else if (value.indexOf("(") !== -1) { + // color + return stringToBracketObject(value); + } else if (value.charAt(0) === "#" && model !== "url") { + return stringToColorObject(value); + } + + return value; + } + function toObject(object, result) { + if (result === void 0) { + result = {}; + } + + var model = object.model; + + if (model) { + object.setOptions({ + model: "", + suffix: "", + prefix: "" + }); + var value = object.size() > 1 ? object : object.get(0); + result[model] = value; + } else { + object.forEach(function (obj) { + toObject(obj, result); + }); + } + + return result; + } + + function isPropertyObject(value) { + return value instanceof PropertyObject; + } + function setAlias(name, alias) { + ALIAS[name] = alias; + } + function setRole(names, isProperty, isFixedProperty) { + var length = names.length; + var roles = ROLES; + var fixed = FIXED; + + for (var i = 0; i < length - 1; ++i) { + !roles[names[i]] && (roles[names[i]] = {}); + roles = roles[names[i]]; + + if (isFixedProperty) { + !fixed[names[i]] && (fixed[names[i]] = {}); + fixed = fixed[names[i]]; + } + } + + isFixedProperty && (fixed[names[length - 1]] = true); + roles[names[length - 1]] = isProperty ? true : {}; + } + function getType(value) { + var type = typeof value; + + if (type === OBJECT) { + if (isArray(value)) { + return ARRAY; + } else if (isPropertyObject(value)) { + return PROPERTY; + } + } else if (type === STRING || type === NUMBER) { + return "value"; + } + + return type; + } + function isPureObject(obj) { + return isObject(obj) && obj.constructor === Object; + } + function getNames(names, stack) { + var arr = []; + + if (isPureObject(names)) { + for (var name in names) { + stack.push(name); + arr = arr.concat(getNames(names[name], stack)); + stack.pop(); + } + } else { + arr.push(stack.slice()); + } + + return arr; + } + function updateFrame(names, properties) { + for (var name in properties) { + var value = properties[name]; + + if (!isPureObject(value)) { + names[name] = true; + continue; + } + + if (!isObject(names[name])) { + names[name] = {}; + } + + updateFrame(names[name], properties[name]); + } + + return names; + } + function toFixed(num) { + return Math.round(num * MAXIMUM) / MAXIMUM; + } + function getValueByNames(names, properties, length) { + if (length === void 0) { + length = names.length; + } + + var value = properties; + + for (var i = 0; i < length; ++i) { + if (!isObject(value) || value == null) { + return undefined; + } + + value = value[names[i]]; + } + + return value; + } + function isInProperties(roles, args, isCheckTrue) { + var length = args.length; + var role = roles; + + if (length === 0) { + return false; + } + + for (var i = 0; i < length; ++i) { + if (role === true) { + return false; + } + + role = role[args[i]]; + + if (!role || !isCheckTrue && role === true) { + return false; + } + } + + return true; + } + function isRole(args, isCheckTrue) { + return isInProperties(ROLES, args, isCheckTrue); + } + function isFixed(args) { + return isInProperties(FIXED, args, true); + } + function setPlayCSS(item, isActivate) { + item.state[PLAY_CSS] = isActivate; + } + function isPausedCSS(item) { + return item.state[PLAY_CSS] && item.isPaused(); + } + function isEndedCSS(item) { + return !item.isEnded() && item.state[PLAY_CSS]; + } + function makeId(selector) { + for (;;) { + var id = "" + Math.floor(Math.random() * 10000000); + + if (!IS_WINDOW || !selector) { + return id; + } + + var checkElement = $("[data-scene-id=\"" + id + "\"]"); + + if (!checkElement) { + return id; + } + } + } + function getRealId(item) { + return item.getId() || item.setId(makeId(false)).getId(); + } + function toId(text) { + return ("" + text).match(/[0-9a-zA-Z]+/g).join(""); + } + function playCSS(item, isExportCSS, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + if (!ANIMATION || item.getPlayState() === RUNNING) { + return; + } + + var className = playClassName || START_ANIMATION; + + if (isPausedCSS(item)) { + item.addPlayClass(true, className, properties); + } else { + if (item.isEnded()) { + item.setTime(0); + } + + isExportCSS && item.exportCSS({ + className: className + }); + var el = item.addPlayClass(false, className, properties); + + if (!el) { + return; + } + + addAnimationEvent(item, el); + setPlayCSS(item, true); + } + + item.setPlayState(RUNNING); + } + function addAnimationEvent(item, el) { + var state = item.state; + var duration = item.getDuration(); + var isZeroDuration = !duration || !isFinite(duration); + + var animationend = function () { + setPlayCSS(item, false); + item.finish(); + }; + + var animationstart = function () { + item.trigger(PLAY); + addEvent(el, "animationcancel", animationend); + addEvent(el, "animationend", animationend); + addEvent(el, "animationiteration", animationiteration); + }; + + item.once(ENDED, function () { + removeEvent(el, "animationcancel", animationend); + removeEvent(el, "animationend", animationend); + removeEvent(el, "animationiteration", animationiteration); + removeEvent(el, "animationstart", animationstart); + }); + + var animationiteration = function (_a) { + var elapsedTime = _a.elapsedTime; + var currentTime = elapsedTime; + var iterationCount = isZeroDuration ? 0 : currentTime / duration; + state[CURRENT_TIME] = currentTime; + item.setIteration(iterationCount); + }; + + addEvent(el, "animationstart", animationstart); + } + function getEasing(curveArray) { + var easing; + + if (isString(curveArray)) { + if (curveArray in EASINGS) { + easing = EASINGS[curveArray]; + } else { + var obj = toPropertyObject(curveArray); + + if (isString(obj)) { + return 0; + } else { + if (obj.model === "cubic-bezier") { + curveArray = obj.value.map(function (v) { + return parseFloat(v); + }); + easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]); + } else if (obj.model === "steps") { + easing = steps(parseFloat(obj.value[0]), obj.value[1]); + } else { + return 0; + } + } + } + } else if (isArray(curveArray)) { + easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]); + } else { + easing = curveArray; + } + + return easing; + } + + function GetterSetter(getter, setter, parent) { + return function (constructor) { + var prototype = constructor.prototype; + getter.forEach(function (name) { + prototype[camelize("get " + name)] = function () { + return this[parent][name]; + }; + }); + setter.forEach(function (name) { + prototype[camelize("set " + name)] = function (value) { + this[parent][name] = value; + return this; + }; + }); + }; + } + + function isDirectionReverse(iteration, iteraiontCount, direction) { + if (direction === REVERSE) { + return true; + } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) { + return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE); + } + + return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE); + } + /** + * @typedef {Object} AnimatorState The Animator options. Properties used in css animation. + * @property {number} [duration] The duration property defines how long an animation should take to complete one cycle. + * @property {"none"|"forwards"|"backwards"|"both"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both). + * @property {"infinite"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played. + * @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation. + * @property {number} [delay] The delay property specifies a delay for the start of an animation. + * @property {"normal"|"reverse"|"alternate"|"alternate-reverse"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles. + */ + + var setters = ["id", ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE]; + + var getters = __spreadArrays(setters, [EASING, EASING_NAME]); + /** + * play video, animation, the others + * @extends EventTrigger + * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation} + */ + + + var Animator = + /*#__PURE__*/ + function (_super) { + __extends(Animator, _super); + /** + * @param - animator's options + * @example + const animator = new Animator({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.easing.EASE, + }); + */ + + + function Animator(options) { + var _this = _super.call(this) || this; + + _this.timerId = 0; + _this.state = { + id: "", + easing: 0, + easingName: "linear", + iterationCount: 1, + delay: 0, + fillMode: "forwards", + direction: NORMAL, + playSpeed: 1, + currentTime: 0, + iterationTime: -1, + iteration: 0, + tickTime: 0, + prevTime: 0, + playState: PAUSED, + duration: 0 + }; + + _this.setOptions(options); + + return _this; + } + /** + * set animator's easing. + * @param curverArray - The speed curve of an animation. + * @return {Animator} An instance itself. + * @example + animator.({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.easing.EASE, + }); + */ + + + var __proto = Animator.prototype; + + __proto.setEasing = function (curveArray) { + var easing = getEasing(curveArray); + var easingName = easing && easing[EASING_NAME] || "linear"; + var state = this.state; + state[EASING] = easing; + state[EASING_NAME] = easingName; + return this; + }; + /** + * set animator's options. + * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation} + * @param - animator's options + * @return {Animator} An instance itself. + * @example + animator.({ + delay: 2, + diretion: "alternate", + duration: 2, + fillMode: "forwards", + iterationCount: 3, + easing: Scene.eaasing.EASE, + }); + */ + + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + for (var name in options) { + var value = options[name]; + + if (name === EASING) { + this.setEasing(value); + continue; + } else if (name === DURATION) { + value && this.setDuration(value); + continue; + } + + if (OPTIONS.indexOf(name) > -1) { + this.state[name] = value; + } + } + + return this; + }; + /** + * Get the animator's total duration including delay + * @return {number} Total duration + * @example + animator.getTotalDuration(); + */ + + + __proto.getTotalDuration = function () { + return this.getActiveDuration(true); + }; + /** + * Get the animator's total duration excluding delay + * @return {number} Total duration excluding delay + * @example + animator.getActiveDuration(); + */ + + + __proto.getActiveDuration = function (delay) { + var state = this.state; + var count = state[ITERATION_COUNT]; + + if (count === INFINITE) { + return Infinity; + } + + return (delay ? state[DELAY] : 0) + this.getDuration() * count; + }; + /** + * Check if the animator has reached the end. + * @return {boolean} ended + * @example + animator.isEnded(); // true or false + */ + + + __proto.isEnded = function () { + if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) { + return true; + } else if (this.getTime() < this.getActiveDuration()) { + return false; + } + + return true; + }; + /** + *Check if the animator is paused: + * @return {boolean} paused + * @example + animator.isPaused(); // true or false + */ + + + __proto.isPaused = function () { + return this.state[PLAY_STATE] === PAUSED; + }; + + __proto.start = function (delay) { + if (delay === void 0) { + delay = this.state[DELAY]; + } + + var state = this.state; + state[PLAY_STATE] = RUNNING; + + if (state[TICK_TIME] >= delay) { + /** + * This event is fired when play animator. + * @event Animator#play + */ + this.trigger(PLAY); + return true; + } + + return false; + }; + /** + * play animator + * @return {Animator} An instance itself. + */ + + + __proto.play = function (toTime) { + var _this = this; + + var state = this.state; + var delay = state[DELAY]; + var currentTime = this.getTime(); + state[PLAY_STATE] = RUNNING; + + if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) { + this.setTime(-delay, true); + } + + this.timerId = requestAnimationFrame(function (time) { + state[PREV_TIME] = time; + + _this.tick(time, toTime); + }); + this.start(); + return this; + }; + /** + * pause animator + * @return {Animator} An instance itself. + */ + + + __proto.pause = function () { + var state = this.state; + + if (state[PLAY_STATE] !== PAUSED) { + state[PLAY_STATE] = PAUSED; + /** + * This event is fired when animator is paused. + * @event Animator#paused + */ + + this.trigger(PAUSED); + } + + cancelAnimationFrame(this.timerId); + return this; + }; + /** + * end animator + * @return {Animator} An instance itself. + */ + + + __proto.finish = function () { + this.setTime(0); + this.state[TICK_TIME] = 0; + this.end(); + return this; + }; + /** + * end animator + * @return {Animator} An instance itself. + */ + + + __proto.end = function () { + this.pause(); + /** + * This event is fired when animator is ended. + * @event Animator#ended + */ + + this.trigger(ENDED); + return this; + }; + /** + * set currentTime + * @param {Number|String} time - currentTime + * @return {Animator} An instance itself. + * @example + animator.setTime("from"); // 0 + animator.setTime("to"); // 100% + animator.setTime("50%"); + animator.setTime(10); + animator.getTime() // 10 + */ + + + __proto.setTime = function (time, isTick, isParent) { + var activeDuration = this.getActiveDuration(); + var state = this.state; + var prevTime = state[TICK_TIME]; + var delay = state[DELAY]; + var currentTime = isTick ? time : this.getUnitTime(time); + state[TICK_TIME] = delay + currentTime; + + if (currentTime < 0) { + currentTime = 0; + } else if (currentTime > activeDuration) { + currentTime = activeDuration; + } + + state[CURRENT_TIME] = currentTime; + this.calculate(); + + if (isTick && !isParent) { + var tickTime = state[TICK_TIME]; + + if (prevTime < delay && time >= 0) { + this.start(0); + } + + if (tickTime < prevTime || this.isEnded()) { + this.end(); + return; + } + } + + if (this.isDelay()) { + return this; + } + /** + * This event is fired when the animator updates the time. + * @event Animator#timeupdate + * @param {Object} param The object of data to be sent to an event. + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.time The iteration time during duration that the animator is running. + * @param {Number} param.iterationCount The iteration count that the animator is running. + */ + + + this.trigger(TIMEUPDATE, { + currentTime: currentTime, + time: this.getIterationTime(), + iterationCount: state[ITERATION] + }); + return this; + }; + /** + * Get the animator's current time + * @return {number} current time + * @example + animator.getTime(); + */ + + + __proto.getTime = function () { + return this.state[CURRENT_TIME]; + }; + + __proto.getUnitTime = function (time) { + if (isString(time)) { + var duration = this.getDuration() || 100; + + if (time === "from") { + return 0; + } else if (time === "to") { + return duration; + } + + var _a = splitUnit(time), + unit = _a.unit, + value = _a.value; + + if (unit === "%") { + !this.getDuration() && this.setDuration(duration); + return toFixed(parseFloat(time) / 100 * duration); + } else if (unit === ">") { + return value + THRESHOLD; + } else { + return value; + } + } else { + return toFixed(time); + } + }; + /** + * Check if the current state of animator is delayed. + * @return {boolean} check delay state + */ + + + __proto.isDelay = function () { + var state = this.state; + var delay = state[DELAY]; + var tickTime = state[TICK_TIME]; + return delay > 0 && tickTime < delay; + }; + + __proto.setIteration = function (iterationCount) { + var state = this.state; + var passIterationCount = Math.floor(iterationCount); + var maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT]; + + if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) { + /** + * The event is fired when an iteration of an animation ends. + * @event Animator#iteration + * @param {Object} param The object of data to be sent to an event. + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.iterationCount The iteration count that the animator is running. + */ + this.trigger("iteration", { + currentTime: state[CURRENT_TIME], + iterationCount: passIterationCount + }); + } + + state[ITERATION] = iterationCount; + return this; + }; + + __proto.calculate = function () { + var state = this.state; + var iterationCount = state[ITERATION_COUNT]; + var fillMode = state[FILL_MODE]; + var direction = state[DIRECTION]; + var duration = this.getDuration(); + var time = this.getTime(); + var iteration = duration === 0 ? 0 : time / duration; + var currentIterationTime = duration ? time % duration : 0; + + if (!duration) { + this.setIterationTime(0); + return this; + } + + this.setIteration(iteration); // direction : normal, reverse, alternate, alternate-reverse + // fillMode : forwards, backwards, both, none + + var isReverse = isDirectionReverse(iteration, iterationCount, direction); + var isFiniteDuration = isFinite(duration); + + if (isFiniteDuration && isReverse) { + currentIterationTime = duration - currentIterationTime; + } + + if (isFiniteDuration && iterationCount !== INFINITE) { + var isForwards = fillMode === "both" || fillMode === "forwards"; // fill forwards + + if (iteration >= iterationCount) { + currentIterationTime = duration * (isForwards ? iterationCount % 1 || 1 : 0); + isReverse && (currentIterationTime = duration - currentIterationTime); + } + } + + this.setIterationTime(currentIterationTime); + return this; + }; + + __proto.tick = function (now, to) { + var _this = this; + + if (this.isPaused()) { + return; + } + + var state = this.state; + var playSpeed = state[PLAY_SPEED]; + var prevTime = state[PREV_TIME]; + var delay = state[DELAY]; + var tickTime = state[TICK_TIME]; + var currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed; + state[PREV_TIME] = now; + this.setTime(currentTime - delay, true); + + if (to && to * 1000 < now) { + this.pause(); + } + + if (state[PLAY_STATE] === PAUSED) { + return; + } + + this.timerId = requestAnimationFrame(function (time) { + _this.tick(time, to); + }); + }; + + Animator = __decorate([GetterSetter(getters, setters, "state")], Animator); + return Animator; + }(EventTrigger); + + /* + Copyright (c) 2019 Daybrush + name: order-map + license: MIT + author: Daybrush + repository: git+https://github.com/daybrush/order-map.git + version: 0.2.1 + */ + /** + * + */ + var OrderMap = + /*#__PURE__*/ + function () { + /** + * + */ + function OrderMap(separator) { + this.separator = separator; + this.orderMap = {}; + } + /** + * + */ + + + var __proto = OrderMap.prototype; + + __proto.getFullName = function (names) { + return names.join(this.separator); + }; + /** + * + */ + + + __proto.get = function (names) { + return this.orderMap[this.getFullName(names)]; + }; + /** + * + */ + + + __proto.gets = function (names, isFull) { + if (isFull === void 0) { + isFull = true; + } + + var fullOrders = []; + var self = this; + + function pushOrders(nextNames, stack) { + var orders = self.get(nextNames); + + if (!orders) { + return; + } + + orders.forEach(function (name) { + var nextStack = stack.concat([name]); + var nextOrders = pushOrders(nextNames.concat([name]), nextStack); + + if (!nextOrders || !nextOrders.length) { + fullOrders.push(stack.concat([name])); + } + }); + return orders; + } + + pushOrders(names, isFull ? names : []); + return fullOrders; + }; + /** + * + */ + + + __proto.set = function (names, orders) { + var _this = this; + + names.forEach(function (name, i) { + _this.addName(names.slice(0, i), name); + }); + this.orderMap[this.getFullName(names)] = orders; + return orders; + }; + /** + * + */ + + + __proto.add = function (names) { + var length = names.length; + + if (!length) { + return []; + } + + return this.addName(names.slice(0, -1), names[length - 1]); + }; + /** + * + */ + + + __proto.addName = function (names, name) { + var orders = this.get(names) || this.set(names, []); + + if (orders.indexOf(name) === -1) { + orders.push(name); + } + + return orders; + }; + /** + * + */ + + + __proto.findIndex = function (names, orderName) { + var orders = this.orderMap[this.getFullName(names)]; + + if (!orders) { + return -1; + } + + return orders.indexOf(orderName); + }; + /** + * + */ + + + __proto.remove = function (names) { + var fullName = this.getFullName(names); + var orderMap = this.orderMap; + + for (var name in orderMap) { + if (name.indexOf(fullName) === 0) { + delete orderMap[name]; + } + } + + var length = names.length; + + if (length) { + var prevNames = names.slice(0, -1); + var lastName = names[length - 1]; + this.splice(prevNames, this.findIndex(prevNames, lastName), 1); + } + + return this; + }; + /** + * + */ + + + __proto.filter = function (names, callback, isFull) { + if (isFull === void 0) { + isFull = true; + } + + var result = this.gets(names, isFull).filter(callback); + var map = new OrderMap(this.separator); + var stack = isFull ? [] : names; + result.forEach(function (nextNames) { + map.add(stack.concat(nextNames)); + }); + return map; + }; + /** + * + */ + + + __proto.splice = function (names, index, deleteCount) { + var orders = []; + + for (var _i = 3; _i < arguments.length; _i++) { + orders[_i - 3] = arguments[_i]; + } + + var currentOrders = this.get(names) || this.set(names, []); + currentOrders.splice.apply(currentOrders, [index, deleteCount].concat(orders)); + return this; + }; + /** + * + */ + + + __proto.clear = function () { + this.orderMap = {}; + }; + /** + * + */ + + + __proto.setObject = function (obj) { + var orderMap = this.orderMap; + + for (var name in obj) { + orderMap[name] = obj[name].slice(); + } + }; + /** + * + */ + + + __proto.getObject = function () { + var nextMap = {}; + var orderMap = this.orderMap; + + for (var name in orderMap) { + nextMap[name] = orderMap[name].slice(); + } + + return nextMap; + }; + /** + * + */ + + + __proto.clone = function () { + var map = new OrderMap(this.separator); + map.setObject(map.orderMap); + return map; + }; + + return OrderMap; + }(); + + function toInnerProperties(obj, orders) { + if (orders === void 0) { + orders = []; + } + + if (!obj) { + return ""; + } + + var arrObj = []; + var keys = getKeys(obj); + sortOrders(keys, orders); + keys.forEach(function (name) { + arrObj.push(name.replace(/\d$/g, "") + "(" + obj[name] + ")"); + }); + return arrObj.join(" "); + } + /* eslint-disable */ + + + function clone(target, toValue) { + if (toValue === void 0) { + toValue = false; + } + + return merge({}, target, toValue); + } + + function merge(to, from, toValue) { + if (toValue === void 0) { + toValue = false; + } + + for (var name in from) { + var value = from[name]; + var type = getType(value); + + if (type === PROPERTY) { + to[name] = toValue ? value.toValue() : value.clone(); + } else if (type === FUNCTION) { + to[name] = toValue ? getValue([name], value) : value; + } else if (type === ARRAY) { + to[name] = value.slice(); + } else if (type === OBJECT) { + if (isObject(to[name]) && !isPropertyObject(to[name])) { + merge(to[name], value, toValue); + } else { + to[name] = clone(value, toValue); + } + } else { + to[name] = from[name]; + } + } + + return to; + } + /* eslint-enable */ + + + function getPropertyName(args) { + return args[0] in ALIAS ? ALIAS[args[0]] : args; + } + + function getValue(names, value) { + var type = getType(value); + + if (type === PROPERTY) { + return value.toValue(); + } else if (type === FUNCTION) { + if (names[0] !== TIMING_FUNCTION) { + return getValue(names, value()); + } + } else if (type === OBJECT) { + return clone(value, true); + } + + return value; + } + /** + * Animation's Frame + */ + + + var Frame = + /*#__PURE__*/ + function () { + /** + * @param - properties + * @example + const frame = new Scene.Frame({ + display: "none" + transform: { + translate: "50px", + scale: "5, 5", + } + }); + */ + function Frame(properties) { + if (properties === void 0) { + properties = {}; + } + + this.properties = {}; + this.orderMap = new OrderMap(NAME_SEPARATOR); + this.properties = {}; // this.orders = []; + + this.set(properties); + } + /** + * get property value + * @param {...Number|String|PropertyObject} args - property name or value + * @example + frame.get("display") // => "none", "block", .... + frame.get("transform", "translate") // => "10px,10px" + */ + + + var __proto = Frame.prototype; + + __proto.get = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var value = this.raw.apply(this, args); + return getValue(getPropertyName(args), value); + }; + /** + * get properties orders + * @param - property names + * @example + frame.getOrders(["display"]) // => [] + frame.getOrders(["transform"]) // => ["translate", "scale"] + */ + + + __proto.getOrders = function (names) { + return this.orderMap.get(names); + }; + /** + * set properties orders + * @param - property names + * @param - orders + * @example + frame.getOrders(["transform"]) // => ["translate", "scale"] + frame.setOrders(["transform"], ["scale", "tralsate"]) + */ + + + __proto.setOrders = function (names, orders) { + return this.orderMap.set(names, orders); + }; + /** + * get properties order object + * @example + console.log(frame.getOrderObject()); + */ + + + __proto.getOrderObject = function () { + return this.orderMap.getObject(); + }; + /** + * set properties orders object + * @param - properties orders object + * @example + frame.setOrderObject({ + "": ["transform"], + "transform": ["scale", "tralsate"], + }); + */ + + + __proto.setOrderObject = function (obj) { + this.orderMap.setObject(obj); + }; + /** + * get property keys + * @param - property names + * @example + frame.gets("display") // => [] + frame.gets("transform") // => ["translate"] + */ + + + __proto.getKeys = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var value = this.raw.apply(this, args); + var keys = getType(value) === OBJECT ? getKeys(value) : []; + sortOrders(keys, this.orderMap.get(args)); + return keys; + }; + /** + * get properties array + * @param - property names + * @example + frame.gets("display") // => [] + frame.gets("transform") // => [{ key: "translate", value: "10px, 10px", children: [] }] + */ + + + __proto.gets = function () { + var _this = this; + + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var values = this.get.apply(this, args); + var keys = this.getKeys.apply(this, args); + return keys.map(function (key) { + var nextValue = values[key]; + return { + key: key, + value: nextValue, + children: _this.gets.apply(_this, __spreadArrays(args, [key])) + }; + }); + }; + + __proto.raw = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + return getValueByNames(getPropertyName(args), this.properties); + }; + /** + * remove property value + * @param {...String} args - property name + * @return {Frame} An instance itself + * @example + frame.remove("display") + */ + + + __proto.remove = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var params = getPropertyName(args); + var length = params.length; + + if (!length) { + return this; + } + + this.orderMap.remove(params); + var value = getValueByNames(params, this.properties, length - 1); + + if (isObject(value)) { + delete value[params[length - 1]]; + } + + return this; + }; + /** + * set property + * @param {...Number|String|PropertyObject} args - property names or values + * @return {Frame} An instance itself + * @example + // one parameter + frame.set({ + display: "none", + transform: { + translate: "10px, 10px", + scale: "1", + }, + filter: { + brightness: "50%", + grayscale: "100%" + } + }); + // two parameters + frame.set("transform", { + translate: "10px, 10px", + scale: "1", + }); + // three parameters + frame.set("transform", "translate", "50px"); + */ + + + __proto.set = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var self = this; + var length = args.length; + var params = args.slice(0, -1); + var value = args[length - 1]; + var firstParam = params[0]; + + if (length === 1 && value instanceof Frame) { + self.merge(value); + } else if (firstParam in ALIAS) { + self._set(ALIAS[firstParam], value); + } else if (length === 2 && isArray(firstParam)) { + self._set(firstParam, value); + } else if (isPropertyObject(value)) { + if (isRole(params)) { + self.set.apply(self, __spreadArrays(params, [toObject(value)])); + } else { + self._set(params, value); + } + } else if (isArray(value)) { + self._set(params, value); + } else if (isObject(value)) { + if (!self.has.apply(self, params) && isRole(params)) { + self._set(params, {}); + } + + for (var name in value) { + self.set.apply(self, __spreadArrays(params, [name, value[name]])); + } + } else if (isString(value)) { + if (isRole(params, true)) { + if (isFixed(params) || !isRole(params)) { + this._set(params, value); + } else { + var obj = toPropertyObject(value); + + if (isObject(obj)) { + self.set.apply(self, __spreadArrays(params, [obj])); + } + } + + return this; + } else { + var _a = splitStyle(value), + styles = _a.styles, + stylesLength = _a.length; + + for (var name in styles) { + self.set.apply(self, __spreadArrays(params, [name, styles[name]])); + } + + if (stylesLength) { + return this; + } + } + + self._set(params, value); + } else { + self._set(params, value); + } + + return self; + }; + /** + * Gets the names of properties. + * @return the names of properties. + * @example + // one parameter + frame.set({ + display: "none", + transform: { + translate: "10px, 10px", + scale: "1", + }, + }); + // [["display"], ["transform", "translate"], ["transform", "scale"]] + console.log(frame.getNames()); + */ + + + __proto.getNames = function () { + return getNames(this.properties, []); + }; + /** + * check that has property. + * @param {...String} args - property name + * @example + frame.has("property", "display") // => true or false + */ + + + __proto.has = function () { + var args = []; + + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + + var params = getPropertyName(args); + var length = params.length; + + if (!length) { + return false; + } + + return !isUndefined(getValueByNames(params, this.properties, length)); + }; + /** + * clone frame. + * @return {Frame} An instance of clone + * @example + frame.clone(); + */ + + + __proto.clone = function () { + var frame = new Frame(); + frame.setOrderObject(this.orderMap.orderMap); + return frame.merge(this); + }; + /** + * merge one frame to other frame. + * @param - target frame. + * @return {Frame} An instance itself + * @example + frame.merge(frame2); + */ + + + __proto.merge = function (frame) { + var properties = this.properties; + var frameProperties = frame.properties; + + if (frameProperties) { + merge(properties, frameProperties); + } + + return this; + }; + /** + * Specifies an css object that coverted the frame. + * @return {object} cssObject + */ + + + __proto.toCSSObject = function () { + var properties = this.get(); + var cssObject = {}; + + for (var name in properties) { + if (isRole([name], true)) { + continue; + } + + var value = properties[name]; + + if (name === TIMING_FUNCTION) { + cssObject[TIMING_FUNCTION.replace("animation", ANIMATION)] = (isString(value) ? value : value[EASING_NAME]) || "initial"; + } else { + cssObject[name] = value; + } + } + + var transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME])); + var filter = toInnerProperties(properties.filter, this.orderMap.get([FILTER])); + TRANSFORM && transform && (cssObject[TRANSFORM] = transform); + FILTER && filter && (cssObject[FILTER] = filter); + return cssObject; + }; + /** + * Specifies an css text that coverted the frame. + * @return {string} cssText + */ + + + __proto.toCSS = function () { + var cssObject = this.toCSSObject(); + var cssArray = []; + var keys = getKeys(cssObject); + sortOrders(keys, this.orderMap.get([])); + keys.forEach(function (name) { + cssArray.push(name + ":" + cssObject[name] + ";"); + }); + return cssArray.join(""); + }; + /** + * Remove All Properties + * @return {Frame} An instance itself + */ + + + __proto.clear = function () { + this.properties = {}; + this.orderMap.clear(); + return this; + }; + + __proto._set = function (args, value) { + var properties = this.properties; + var length = args.length; + + for (var i = 0; i < length - 1; ++i) { + var name = args[i]; + !(name in properties) && (properties[name] = {}); + properties = properties[name]; + } + + if (!length) { + return; + } + + var lastParam = args[length - 1]; + this.orderMap.add(args); + + if (length === 1 && lastParam === TIMING_FUNCTION) { + properties[lastParam] = getEasing(value); + } else { + properties[lastParam] = isString(value) && !isFixed(args) ? toPropertyObject(value, lastParam) : value; + } + }; + + return Frame; + }(); + + function dotArray(a1, a2, b1, b2) { + var length = a2.length; + return a1.map(function (v1, i) { + if (i >= length) { + return v1; + } else { + return dot$1(v1, a2[i], b1, b2); + } + }); + } + + function dotColor(color1, color2, b1, b2) { + // convert array to PropertyObject(type=color) + var value1 = color1.value; + var value2 = color2.value; // If the model name is not same, the inner product is impossible. + + var model1 = color1.model; + var model2 = color2.model; + + if (model1 !== model2) { + // It is recognized as a string. + return dot$1(color1.toValue(), color2.toValue(), b1, b2); + } + + if (value1.length === 3) { + value1[3] = 1; + } + + if (value2.length === 3) { + value2[3] = 1; + } + + var v = dotArray(value1, value2, b1, b2); + var colorModel = model1; + + for (var i = 0; i < 3; ++i) { + v[i] = parseInt(v[i], 10); + } + + var object = new PropertyObject(v, { + type: "color", + model: colorModel, + prefix: colorModel + "(", + suffix: ")" + }); + return object; + } + + function dotObject(a1, a2, b1, b2) { + var a1Type = a1.type; + + if (a1Type === "color") { + return dotColor(a1, a2, b1, b2); + } + + var value1 = a1.value; + var value2 = a2.value; + var arr = dotArray(value1, value2, b1, b2); + return new PropertyObject(arr, { + type: a1Type, + separator: a1.separator || a2.separator, + prefix: a1.prefix || a2.prefix, + suffix: a1.suffix || a2.suffix, + model: a1.model || a2.model + }); + } + /** + * The dot product of a1 and a2 for the b1 and b2. + * @memberof Dot + * @function dot + * @param {String|Number|PropertyObject} a1 value1 + * @param {String|Number|PropertyObject} a2 value2 + * @param {Number} b1 b1 ratio + * @param {Number} b2 b2 ratio + * @return {String} Not Array, Not Separator, Only Number & Unit + * @return {PropertyObject} Array with Separator. + * @example + dot(1, 3, 0.3, 0.7); + // => 1.6 + */ + + + function dot$1(a1, a2, b1, b2) { + if (b2 === 0) { + return a2; + } else if (b1 === 0 || b1 + b2 === 0) { + // prevent division by zero. + return a1; + } // dot Object + + + var type1 = getType(a1); + var type2 = getType(a2); + var isFunction1 = type1 === FUNCTION; + var isFunction2 = type2 === FUNCTION; + + if (isFunction1 || isFunction2) { + return function () { + return dot$1(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2); + }; + } else if (type1 === type2) { + if (type1 === PROPERTY) { + return dotObject(a1, a2, b1, b2); + } else if (type1 === ARRAY) { + return dotArray(a1, a2, b1, b2); + } else if (type1 !== "value") { + return a1; + } + } else { + return a1; + } + + var v1 = splitUnit("" + a1); + var v2 = splitUnit("" + a2); + var v; // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환 + + if (isNaN(v1.value) || isNaN(v2.value)) { + return a1; + } else { + v = dot(v1.value, v2.value, b1, b2); + } + + var prefix = v1.prefix || v2.prefix; + var unit = v1.unit || v2.unit; + + if (!prefix && !unit) { + return v; + } + + return prefix + v + unit; + } + function dotValue(time, prevTime, nextTime, prevValue, nextValue, easing) { + if (time === prevTime) { + return prevValue; + } else if (time === nextTime) { + return nextValue; + } else if (!easing) { + return dot$1(prevValue, nextValue, time - prevTime, nextTime - time); + } + + var ratio = easing((time - prevTime) / (nextTime - prevTime)); + var value = dot$1(prevValue, nextValue, ratio, 1 - ratio); + return value; + } + + /* + Copyright (c) 2018 Daybrush + @name: @daybrush/utils + license: MIT + author: Daybrush + repository: https://github.com/daybrush/utils + @version 0.10.5 + */ + var OPEN_CLOSED_CHARACTER$1 = ["\"", "'", "\\\"", "\\'"]; + + function findClosed$1(closedCharacter, texts, index, length) { + for (var i = index; i < length; ++i) { + var character = texts[i].trim(); + + if (character === closedCharacter) { + return i; + } + + var nextIndex = i; + + if (character === "(") { + nextIndex = findClosed$1(")", texts, i + 1, length); + } else if (OPEN_CLOSED_CHARACTER$1.indexOf(character) > -1) { + nextIndex = findClosed$1(character, texts, i + 1, length); + } + + if (nextIndex === -1) { + break; + } + + i = nextIndex; + } + + return -1; + } + + function splitText$1(text, separator) { + var regexText = "(\\s*" + (separator || ",") + "\\s*|\\(|\\)|\"|'|\\\\\"|\\\\'|\\s+)"; + var regex = new RegExp(regexText, "g"); + var texts = text.split(regex).filter(Boolean); + var length = texts.length; + var values = []; + var tempValues = []; + + for (var i = 0; i < length; ++i) { + var character = texts[i].trim(); + var nextIndex = i; + + if (character === "(") { + nextIndex = findClosed$1(")", texts, i + 1, length); + } else if (character === ")") { + throw new Error("invalid format"); + } else if (OPEN_CLOSED_CHARACTER$1.indexOf(character) > -1) { + nextIndex = findClosed$1(character, texts, i + 1, length); + } else if (character === separator) { + if (tempValues.length) { + values.push(tempValues.join("")); + tempValues = []; + } + + continue; + } + + if (nextIndex === -1) { + nextIndex = length - 1; + } + + tempValues.push(texts.slice(i, nextIndex + 1).join("")); + i = nextIndex; + } + + if (tempValues.length) { + values.push(tempValues.join("")); + } + + return values; + } + /** + * divide text by comma. + * @memberof Utils + * @param {string} text - text to divide + * @return {Array} divided texts + * @example + import {splitComma} from "@daybrush/utils"; + + console.log(splitComma("a,b,c,d,e,f,g")); + // ["a", "b", "c", "d", "e", "f", "g"] + console.log(splitComma("'a,b',c,'d,e',f,g")); + // ["'a,b'", "c", "'d,e'", "f", "g"] + */ + + function splitComma$1(text) { + // divide comma(,) + // "[^"]*"|'[^']*' + return splitText$1(text, ","); + } + + /* + Copyright (c) 2019 Daybrush + name: css-styled + license: MIT + author: Daybrush + repository: git+https://github.com/daybrush/css-styled.git + version: 0.2.1 + */ + + function hash(str) { + var hash = 5381, + i = str.length; + + while(i) { + hash = (hash * 33) ^ str.charCodeAt(--i); + } + + /* JavaScript does bitwise operations (like XOR, above) on 32-bit signed + * integers. Since we want the results to be always positive, convert the + * signed int to an unsigned by doing an unsigned bitshift. */ + return hash >>> 0; + } + + var stringHash = hash; + + function getHash(str) { + return stringHash(str).toString(36); + } + function getShadowRoot(parentElement) { + if (parentElement.getRootNode) { + var rootNode = parentElement.getRootNode(); + + if (rootNode.nodeType === 11) { + return rootNode; + } + } + + return; + } + function injectStyle(className, css, options, shadowRoot) { + var style = document.createElement("style"); + style.setAttribute("type", "text/css"); + style.setAttribute("data-styled-id", className); + + if (options.nonce) { + style.setAttribute("nonce", options.nonce); + } + + var styleCSS = css; + + if (!options.original) { + styleCSS = css.replace(/([^}{]*){/mg, function (all, selector) { + return splitComma$1(selector).map(function (subSelector) { + if (subSelector.indexOf(":global") > -1) { + return subSelector.replace(/\:global/g, ""); + } else if (subSelector.indexOf(":host") > -1) { + return "" + subSelector.replace(/\:host/g, "." + className); + } + + return "." + className + " " + subSelector; + }).join(", ") + "{"; + }); + } + + style.innerHTML = styleCSS; + (shadowRoot || document.head || document.body).appendChild(style); + return style; + } + + function styled(css) { + var injectClassName = "rCS" + getHash(css); + var injectCount = 0; + var injectElement; + return { + className: injectClassName, + inject: function (el, options) { + if (options === void 0) { + options = {}; + } + + var shadowRoot = getShadowRoot(el); + var firstMount = injectCount === 0; + var styleElement; + + if (shadowRoot || firstMount) { + styleElement = injectStyle(injectClassName, css, options, shadowRoot); + } + + if (firstMount) { + injectElement = styleElement; + } + + if (!shadowRoot) { + ++injectCount; + } + + return { + destroy: function () { + if (shadowRoot) { + el.removeChild(styleElement); + styleElement = null; + } else { + if (injectCount > 0) { + --injectCount; + } + + if (injectCount === 0 && injectElement) { + injectElement.parentNode.removeChild(injectElement); + injectElement = null; + } + } + } + }; + } + }; + } + + function getNearTimeIndex(times, time) { + var length = times.length; + + for (var i = 0; i < length; ++i) { + if (times[i] === time) { + return [i, i]; + } else if (times[i] > time) { + return [i > 0 ? i - 1 : 0, i]; + } + } + + return [length - 1, length - 1]; + } + + function makeAnimationProperties(properties) { + var cssArray = []; + + for (var name in properties) { + cssArray.push(ANIMATION + "-" + decamelize(name) + ":" + properties[name] + ";"); + } + + return cssArray.join(""); + } + + function addTime(times, time) { + var length = times.length; + + for (var i = 0; i < length; ++i) { + if (time < times[i]) { + times.splice(i, 0, time); + return; + } + } + + times[length] = time; + } + + function addEntry(entries, time, keytime) { + var prevEntry = entries[entries.length - 1]; + (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) && entries.push([toFixed(time), toFixed(keytime)]); + } + + function getEntries(times, states) { + var entries = times.map(function (time) { + return [time, time]; + }); + var nextEntries = []; + states.forEach(function (state) { + var iterationCount = state[ITERATION_COUNT]; + var delay = state[DELAY]; + var playSpeed = state[PLAY_SPEED]; + var direction = state[DIRECTION]; + var intCount = Math.ceil(iterationCount); + var currentDuration = entries[entries.length - 1][0]; + var length = entries.length; + var lastTime = currentDuration * iterationCount; + + for (var i = 0; i < intCount; ++i) { + var isReverse = direction === REVERSE || direction === ALTERNATE && i % 2 || direction === ALTERNATE_REVERSE && !(i % 2); + + for (var j = 0; j < length; ++j) { + var entry = entries[isReverse ? length - j - 1 : j]; + var time = entry[1]; + var currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]); + var prevEntry = entries[isReverse ? length - j : j - 1]; + + if (currentTime > lastTime) { + if (j !== 0) { + var prevTime = currentDuration * i + (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]); + var divideTime = dot(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime); + addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime); + } + + break; + } else if (currentTime === lastTime && nextEntries.length && nextEntries[nextEntries.length - 1][0] === lastTime + delay) { + break; + } + + addEntry(nextEntries, (delay + currentTime) / playSpeed, time); + } + } // delay time + + + delay && nextEntries.unshift([0, nextEntries[0][1]]); + entries = nextEntries; + nextEntries = []; + }); + return entries; + } + /** + * manage Frame Keyframes and play keyframes. + * @extends Animator + * @example + const item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + */ + + var SceneItem = + /*#__PURE__*/ + function (_super) { + __extends(SceneItem, _super); + /** + * @param - properties + * @param - options + * @example + const item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + */ + + + function SceneItem(properties, options) { + var _this = _super.call(this) || this; + + _this.times = []; + _this.items = {}; + _this.nameMap = new OrderMap(NAME_SEPARATOR); + _this.elements = []; + _this.needUpdate = true; + + _this.load(properties, options); + + return _this; + } + + var __proto = SceneItem.prototype; + + __proto.getDuration = function () { + var times = this.times; + var length = times.length; + return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION]; + }; + /** + * get size of list + * @return {Number} length of list + */ + + + __proto.size = function () { + return this.times.length; + }; + + __proto.setDuration = function (duration) { + if (!duration) { + return this; + } + + var originalDuration = this.getDuration(); + + if (originalDuration > 0) { + var ratio_1 = duration / originalDuration; + + var _a = this, + times = _a.times, + items_1 = _a.items; + + var obj_1 = {}; + this.times = times.map(function (time) { + var time2 = toFixed(time * ratio_1); + obj_1[time2] = items_1[time]; + return time2; + }); + this.items = obj_1; + } else { + this.newFrame(duration); + } + + return this; + }; + + __proto.setId = function (id) { + var state = this.state; + var elements = this.elements; + var length = elements.length; + state.id = id || makeId(!!length); + + if (length && !state[SELECTOR]) { + var sceneId_1 = toId(this.getId()); + state[SELECTOR] = "[" + DATA_SCENE_ID + "=\"" + sceneId_1 + "\"]"; + elements.forEach(function (element) { + element.setAttribute(DATA_SCENE_ID, sceneId_1); + }); + } + + return this; + }; + /** + * Set properties to the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} [properties] - property names or values + * @return {SceneItem} An instance itself + * @example + item.set(0, "a", "b") // item.getFrame(0).set("a", "b") + console.log(item.get(0, "a")); // "b" + */ + + + __proto.set = function (time) { + var _this = this; + + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + if (time instanceof SceneItem) { + return this.set(0, time); + } else if (isArray(time)) { + var length = time.length; + + for (var i = 0; i < length; ++i) { + var t = length === 1 ? 0 : this.getUnitTime(i / (length - 1) * 100 + "%"); + this.set(t, time[i]); + } + } else if (isObject(time)) { + var _loop_1 = function (t) { + var value = time[t]; + splitComma(t).forEach(function (eachTime) { + var realTime = _this.getUnitTime(eachTime); + + if (isNaN(realTime)) { + getNames(value, [eachTime]).forEach(function (names) { + var _a; + + var innerValue = getValueByNames(names.slice(1), value); + var arr = isArray(innerValue) ? innerValue : [getValueByNames(names, _this.target), innerValue]; + var length = arr.length; + + for (var i = 0; i < length; ++i) { + (_a = _this.newFrame(i / (length - 1) * 100 + "%")).set.apply(_a, __spreadArrays(names, [arr[i]])); + } + }); + } else { + _this.set(realTime, value); + } + }); + }; + + for (var t in time) { + _loop_1(t); + } + } else if (!isUndefined(time)) { + var value_1 = args[0]; + splitComma(time + "").forEach(function (eachTime) { + var realTime = _this.getUnitTime(eachTime); + + if (value_1 instanceof SceneItem) { + var delay = value_1.getDelay(); + var frames = value_1.toObject(!_this.hasFrame(realTime + delay)); + var duration = value_1.getDuration(); + var direction = value_1.getDirection(); + var isReverse = direction.indexOf("reverse") > -1; + + for (var frameTime in frames) { + var nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime); + + _this.set(realTime + nextTime, frames[frameTime]); + } + } else if (args.length === 1 && isArray(value_1)) { + value_1.forEach(function (item) { + _this.set(realTime, item); + }); + } else { + var frame = _this.newFrame(realTime); + + frame.set.apply(frame, args); + } + }); + } + + this.needUpdate = true; + return this; + }; + /** + * Get properties of the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} args property's name or properties + * @return {Number|String|PropertyObejct} property value + * @example + item.get(0, "a"); // item.getFrame(0).get("a"); + item.get(0, "transform", "translate"); // item.getFrame(0).get("transform", "translate"); + */ + + + __proto.get = function (time) { + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + var frame = this.getFrame(time); + return frame && frame.get.apply(frame, args); + }; + /** + * get properties orders + * @param - property names + * @example + item.getOrders(["display"]) // => [] + item.getOrders(["transform"]) // => ["translate", "scale"] + */ + + + __proto.getOrders = function (names) { + this.needUpdate && this.update(); + return this.nameMap.get(names); + }; + /** + * set properties orders + * @param - property names + * @param - orders + * @example + item.getOrders(["transform"]) // => ["translate", "scale"] + item.setOrders(["transform"], ["scale", "tralsate"]) + */ + + + __proto.setOrders = function (names, orders) { + this.needUpdate && this.update(); + var result = this.nameMap.set(names, orders); + this.updateFrameOrders(); + return result; + }; + /** + * get properties order object + * @example + console.log(item.getOrderObject()); + */ + + + __proto.getOrderObject = function () { + return this.nameMap.getObject(); + }; + /** + * set properties orders object + * @param - properties orders object + * @example + item.setOrderObject({ + "": ["transform"], + "transform": ["scale", "tralsate"], + }); + */ + + + __proto.setOrderObject = function (obj) { + this.nameMap.setObject(obj); + this.updateFrameOrders(); + }; + /** + * remove properties to the sceneItem at that time + * @param {Number} time - time + * @param {...String|Object} [properties] - property names or values + * @return {SceneItem} An instance itself + * @example + item.remove(0, "a"); + */ + + + __proto.remove = function (time) { + var args = []; + + for (var _i = 1; _i < arguments.length; _i++) { + args[_i - 1] = arguments[_i]; + } + + if (args.length) { + var frame = this.getFrame(time); + frame && frame.remove.apply(frame, args); + } else { + this.removeFrame(time); + } + + this.needUpdate = true; + return this; + }; + /** + * Append the item or object at the last time. + * @param - the scene item or item object + * @return An instance itself + * @example + item.append(new SceneItem({ + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + })); + item.append({ + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }); + item.set(item.getDuration(), { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }); + */ + + + __proto.append = function (item) { + if (item instanceof SceneItem) { + this.set(this.getDuration(), item); + } else { + this.append(new SceneItem(item)); + } + + return this; + }; + /** + * Push the front frames for the time and prepend the scene item or item object. + * @param - the scene item or item object + * @return An instance itself + */ + + + __proto.prepend = function (item) { + if (item instanceof SceneItem) { + var unshiftTime = item.getDuration() + item.getDelay(); + var firstFrame = this.getFrame(0); // remove first frame + + this.removeFrame(0); + this.unshift(unshiftTime); + this.set(0, item); + this.set(unshiftTime + THRESHOLD, firstFrame); + } else { + this.prepend(new SceneItem(item)); + } + + return this; + }; + /** + * Push out the amount of time. + * @param - time to push + * @example + item.get(0); // frame 0 + item.unshift(3); + item.get(3) // frame 0 + */ + + + __proto.unshift = function (time) { + var _a = this, + times = _a.times, + items = _a.items; + + var obj = {}; + this.times = times.map(function (t) { + var time2 = toFixed(time + t); + obj[time2] = items[t]; + return time2; + }); + this.items = obj; + return this; + }; + /** + * Get the frames in the item in object form. + * @return {} + * @example + item.toObject(); + // {0: {display: "none"}, 1: {display: "block"}} + */ + + + __proto.toObject = function (isStartZero) { + if (isStartZero === void 0) { + isStartZero = true; + } + + var obj = {}; + var delay = this.getDelay(); + this.forEach(function (frame, time) { + obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone(); + }); + return obj; + }; + /** + * Specifies an element to synchronize items' keyframes. + * @param {string} selectors - Selectors to find elements in items. + * @return {SceneItem} An instance itself + * @example + item.setSelector("#id.class"); + */ + + + __proto.setSelector = function (target) { + if (isFunction(target)) { + this.setElement(target(this.getId())); + } else { + this.setElement(target); + } + + return this; + }; + /** + * Get the elements connected to SceneItem. + */ + + + __proto.getElements = function () { + return this.elements; + }; + /** + * Specifies an element to synchronize item's keyframes. + * @param - elements to synchronize item's keyframes. + * @param - Make sure that you have peusdo. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setElement(document.querySelectorAll(".class")); + */ + + + __proto.setElements = function (target) { + return this.setElement(target); + }; + /** + * Specifies an element to synchronize item's keyframes. + * @param - elements to synchronize item's keyframes. + * @param - Make sure that you have peusdo. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setElement(document.querySelectorAll(".class")); + */ + + + __proto.setElement = function (target) { + var state = this.state; + var elements = []; + + if (!target) { + return this; + } else if (target === true || isString(target)) { + var selector = target === true ? "" + state.id : target; + var matches = /([\s\S]+)(:+[a-zA-Z]+)$/g.exec(selector); + elements = toArray($(matches ? matches[1] : selector, true)); + state[SELECTOR] = selector; + } else { + elements = target instanceof Element ? [target] : toArray(target); + } + + if (!elements.length) { + return this; + } + + this.elements = elements; + this.setId(this.getId()); + this.target = elements[0].style; + + this.targetFunc = function (frame) { + var attributes = frame.get("attribute"); + + if (attributes) { + var _loop_2 = function (name) { + elements.forEach(function (el) { + el.setAttribute(name, attributes[name]); + }); + }; + + for (var name in attributes) { + _loop_2(name); + } + } + + if (frame.has("html")) { + var html_1 = frame.get("html"); + elements.forEach(function (el) { + el.innerHTML = html_1; + }); + } + + var cssText = frame.toCSS(); + + if (state.cssText !== cssText) { + state.cssText = cssText; + elements.forEach(function (el) { + el.style.cssText += cssText; + }); + return frame; + } + }; + + return this; + }; + + __proto.setTarget = function (target) { + this.target = target; + + this.targetFunc = function (frame) { + var obj = frame.get(); + + for (var name in obj) { + target[name] = obj[name]; + } + }; + + return this; + }; + /** + * add css styles of items's element to the frame at that time. + * @param {Array} properties - elements to synchronize item's keyframes. + * @return {SceneItem} An instance itself + * @example + item.setElement(document.querySelector("#id.class")); + item.setCSS(0, ["opacity"]); + item.setCSS(0, ["opacity", "width", "height"]); + */ + + + __proto.setCSS = function (time, properties) { + this.set(time, fromCSS(this.elements, properties)); + return this; + }; + + __proto.setTime = function (time, isTick, isParent, parentEasing) { + _super.prototype.setTime.call(this, time, isTick, isParent); + + var iterationTime = this.getIterationTime(); + var easing = this.getEasing() || parentEasing; + var frame = this.getNowFrame(iterationTime, easing); + var currentTime = this.getTime(); + this.temp = frame; + /** + * This event is fired when timeupdate and animate. + * @event SceneItem#animate + * @param {Number} param.currentTime The total time that the animator is running. + * @param {Number} param.time The iteration time during duration that the animator is running. + * @param {Frame} param.frame frame of that time. + */ + + this.trigger("animate", { + frame: frame, + currentTime: currentTime, + time: iterationTime + }); + this.targetFunc && this.targetFunc(frame); + return this; + }; + /** + * update property names used in frames. + * @return {SceneItem} An instance itself + * @example + item.update(); + */ + + + __proto.update = function () { + var prevNameMap = this.nameMap; + var names = {}; + this.forEach(function (frame) { + updateFrame(names, frame.properties); + }); + var nameMap = new OrderMap(NAME_SEPARATOR); + + function pushKeys(map, stack) { + var keys = getKeys(map); + sortOrders(keys, prevNameMap.get(stack)); + nameMap.set(stack, keys); + keys.forEach(function (key) { + var nextMap = map[key]; + + if (isObject(nextMap)) { + pushKeys(nextMap, __spreadArrays(stack, [key])); + } + }); + } + + pushKeys(names, []); + this.nameMap = nameMap; + this.forEach(function (frame) { + frame.setOrderObject(nameMap.orderMap); + }); + this.needUpdate = false; + return this; + }; + /** + * Create and add a frame to the sceneItem at that time + * @param {Number} time - frame's time + * @return {Frame} Created frame. + * @example + item.newFrame(time); + */ + + + __proto.newFrame = function (time) { + var frame = this.getFrame(time); + + if (frame) { + return frame; + } + + frame = new Frame(); + this.setFrame(time, frame); + return frame; + }; + /** + * Add a frame to the sceneItem at that time + * @param {Number} time - frame's time + * @return {SceneItem} An instance itself + * @example + item.setFrame(time, frame); + */ + + + __proto.setFrame = function (time, frame) { + var realTime = this.getUnitTime(time); + this.items[realTime] = frame; + addTime(this.times, realTime); + this.needUpdate = true; + return this; + }; + /** + * get sceneItem's frame at that time + * @param {Number} time - frame's time + * @return {Frame} sceneItem's frame at that time + * @example + const frame = item.getFrame(time); + */ + + + __proto.getFrame = function (time) { + return this.items[this.getUnitTime(time)]; + }; + /** + * remove sceneItem's frame at that time + * @param - frame's time + * @return {SceneItem} An instance itself + * @example + item.removeFrame(time); + */ + + + __proto.removeFrame = function (time) { + var realTime = this.getUnitTime(time); + var items = this.items; + var index = this.times.indexOf(realTime); + delete items[realTime]; // remove time + + if (index > -1) { + this.times.splice(index, 1); + } + + this.needUpdate = true; + return this; + }; + /** + * check if the item has a frame at that time + * @param {Number} time - frame's time + * @return {Boolean} true: the item has a frame // false: not + * @example + if (item.hasFrame(10)) { + // has + } else { + // not + } + */ + + + __proto.hasFrame = function (time) { + return this.getUnitTime(time) in this.items; + }; + /** + * Check if keyframes has propery's name + * @param - property's time + * @return {boolean} true: if has property, false: not + * @example + item.hasName(["transform", "translate"]); // true or not + */ + + + __proto.hasName = function (args) { + this.needUpdate && this.update(); + return !!this.nameMap.get(args); + }; + /** + * merge frame of the previous time at the next time. + * @param - The time of the frame to merge + * @param - The target frame + * @return {SceneItem} An instance itself + * @example + // getFrame(1) contains getFrame(0) + item.merge(0, 1); + */ + + + __proto.mergeFrame = function (time, frame) { + if (frame) { + var toFrame = this.newFrame(time); + toFrame.merge(frame); + } + + return this; + }; + /** + * Get frame of the current time + * @param {Number} time - the current time + * @param {function} easing - the speed curve of an animation + * @return {Frame} frame of the current time + * @example + let item = new SceneItem({ + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + } + }); + // opacity: 0.7; display:"block"; + const frame = item.getNowFrame(1.7); + */ + + + __proto.getNowFrame = function (time, easing, isAccurate) { + var _this = this; + + this.needUpdate && this.update(); + var frame = new Frame(); + + var _a = getNearTimeIndex(this.times, time), + left = _a[0], + right = _a[1]; + + var realEasing = this.getEasing() || easing; + var nameMap = this.nameMap; + + if (this.hasName([TIMING_FUNCTION])) { + var nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true); + isFunction(nowEasing) && (realEasing = nowEasing); + } + + if (isAccurate) { + var prevFrame_1 = this.getFrame(time); + var prevOrderMap = prevFrame_1.orderMap.filter([], function (orders) { + return prevFrame_1.has.apply(prevFrame_1, orders); + }); + + for (var name in ROLES) { + var orders = nameMap.get([name]); + + if (prevOrderMap.get([name]) && orders) { + prevOrderMap.set([name], orders); + } + } + + nameMap = prevOrderMap; + } + + var names = nameMap.gets([]); + frame.setOrderObject(nameMap.orderMap); + names.forEach(function (properties) { + var value = _this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties)); + + if (isUndefined(value)) { + return; + } + + frame.set(properties, value); + }); + return frame; + }; + + __proto.load = function (properties, options) { + var _a; + + if (properties === void 0) { + properties = {}; + } + + if (options === void 0) { + options = properties.options; + } + + options && this.setOptions(options); + + if (isArray(properties)) { + this.set(properties); + } else if (properties.keyframes) { + this.set(properties.keyframes); + } else { + for (var time in properties) { + if (time !== "options") { + this.set((_a = {}, _a[time] = properties[time], _a)); + } + } + } + + if (options && options[DURATION]) { + this.setDuration(options[DURATION]); + } + + return this; + }; + /** + * clone SceneItem. + * @return {SceneItem} An instance of clone + * @example + * item.clone(); + */ + + + __proto.clone = function () { + var item = new SceneItem(); + item.setOptions(this.state); + item.setOrderObject(this.nameMap.orderMap); + this.forEach(function (frame, time) { + item.setFrame(time, frame.clone()); + }); + return item; + }; + /** + * executes a provided function once for each scene item. + * @param - Function to execute for each element, taking three arguments + * @return {Keyframes} An instance itself + */ + + + __proto.forEach = function (callback) { + var times = this.times; + var items = this.items; + times.forEach(function (time) { + callback(items[time], time, items); + }); + return this; + }; + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + _super.prototype.setOptions.call(this, options); + + var id = options.id, + selector = options.selector, + elements = options.elements, + element = options.element, + target = options.target; + id && this.setId(id); + + if (target) { + this.setTarget(target); + } else if (selector) { + this.setSelector(selector); + } else if (elements || element) { + this.setElement(elements || element); + } + + return this; + }; + + __proto.toCSS = function (playCondition, parentDuration, states) { + if (playCondition === void 0) { + playCondition = { + className: START_ANIMATION + }; + } + + if (parentDuration === void 0) { + parentDuration = this.getDuration(); + } + + if (states === void 0) { + states = []; + } + + var itemState = this.state; + var selector = itemState[SELECTOR]; + + if (!selector) { + return ""; + } + + var originalDuration = this.getDuration(); + itemState[DURATION] = originalDuration; + states.push(itemState); + var reversedStates = toArray(states).reverse(); + var id = toId(getRealId(this)); + var superParent = states[0]; + var infiniteIndex = findIndex(reversedStates, function (state) { + return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]); + }, states.length - 1); + var finiteStates = reversedStates.slice(0, infiniteIndex); + var duration = parentDuration || finiteStates.reduce(function (prev, cur) { + return (cur[DELAY] + prev * cur[ITERATION_COUNT]) / cur[PLAY_SPEED]; + }, originalDuration); + var delay = reversedStates.slice(infiniteIndex).reduce(function (prev, cur) { + return (prev + cur[DELAY]) / cur[PLAY_SPEED]; + }, 0); + var easingName = find(reversedStates, function (state) { + return state[EASING] && state[EASING_NAME]; + }, itemState)[EASING_NAME]; + var iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT]; + var fillMode = superParent[FILL_MODE]; + var direction = reversedStates[infiniteIndex][DIRECTION]; + var cssText = makeAnimationProperties({ + fillMode: fillMode, + direction: direction, + iterationCount: iterationCount, + delay: delay + "s", + name: PREFIX + "KEYFRAMES_" + id, + duration: duration / superParent[PLAY_SPEED] + "s", + timingFunction: easingName + }); + var selectors = splitComma(selector).map(function (sel) { + var matches = /([\s\S]+)(:+[a-zA-Z]+)$/g.exec(sel); + + if (matches) { + return [matches[1], matches[2]]; + } else { + return [sel, ""]; + } + }); + var className = playCondition.className; + var selectorCallback = playCondition.selector; + var preselector = isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback; + return "\n " + (preselector || selectors.map(function (_a) { + var sel = _a[0], + peusdo = _a[1]; + return sel + "." + className + peusdo; + })) + " {" + cssText + "}\n " + selectors.map(function (_a) { + var sel = _a[0], + peusdo = _a[1]; + return sel + "." + PAUSE_ANIMATION + peusdo; + }) + " {" + ANIMATION + "-play-state: paused;}\n @" + KEYFRAMES + " " + PREFIX + "KEYFRAMES_" + id + "{" + this._toKeyframes(duration, finiteStates, direction) + "}"; + }; + /** + * Export the CSS of the items to the style. + * @param - Add a selector or className to play. + * @return {SceneItem} An instance itself + */ + + + __proto.exportCSS = function (playCondition, duration, options) { + if (!this.elements.length) { + return ""; + } + + var css = this.toCSS(playCondition, duration, options); + var isParent = options && !isUndefined(options[ITERATION_COUNT]); + + if (!isParent) { + if (this.styledInjector) { + this.styledInjector.destroy(); + this.styledInjector = null; + } + + this.styled = styled(css); + this.styledInjector = this.styled.inject(this.getAnimationElement(), { + original: true + }); + } + + return this; + }; + + __proto.pause = function () { + _super.prototype.pause.call(this); + + isPausedCSS(this) && this.pauseCSS(); + return this; + }; + + __proto.pauseCSS = function () { + this.elements.forEach(function (element) { + addClass(element, PAUSE_ANIMATION); + }); + return this; + }; + + __proto.endCSS = function () { + this.elements.forEach(function (element) { + removeClass(element, PAUSE_ANIMATION); + removeClass(element, START_ANIMATION); + }); + setPlayCSS(this, false); + return this; + }; + + __proto.end = function () { + isEndedCSS(this) && this.endCSS(); + + _super.prototype.end.call(this); + + return this; + }; + /** + * Play using the css animation and keyframes. + * @param - Check if you want to export css. + * @param [playClassName="startAnimation"] - Add a class name to play. + * @param - The shorthand properties for six of the animation properties. + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp} + * @example + item.playCSS(); + item.playCSS(false, "startAnimation", { + direction: "reverse", + fillMode: "forwards", + }); + */ + + + __proto.playCSS = function (isExportCSS, playClassName, properties) { + if (isExportCSS === void 0) { + isExportCSS = true; + } + + if (properties === void 0) { + properties = {}; + } + + playCSS(this, isExportCSS, playClassName, properties); + return this; + }; + + __proto.getAnimationElement = function () { + return this.elements[0]; + }; + + __proto.addPlayClass = function (isPaused, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + var elements = this.elements; + var length = elements.length; + var cssText = makeAnimationProperties(properties); + + if (!length) { + return; + } + + if (isPaused) { + elements.forEach(function (element) { + removeClass(element, PAUSE_ANIMATION); + }); + } else { + elements.forEach(function (element) { + element.style.cssText += cssText; + + if (hasClass(element, START_ANIMATION)) { + removeClass(element, START_ANIMATION); + } + }); + elements.forEach(function (element) { + element.clientWidth; + }); + elements.forEach(function (element) { + addClass(element, START_ANIMATION); + }); + } + + return elements[0]; + }; + /** + * Clear All Frames + * @return {SceneItem} An instance itself + */ + + + __proto.clear = function () { + this.times = []; + this.items = {}; + this.nameMap = new OrderMap(NAME_SEPARATOR); + + if (this.styledInjector) { + this.styledInjector.destroy(); + } + + this.styled = null; + this.styledInjector = null; + this.temp = null; + this.needUpdate = true; + return this; + }; + + __proto.getNowValue = function (time, properties, left, right, isAccurate, easing, usePrevValue) { + var times = this.times; + var length = times.length; + var prevTime; + var nextTime; + var prevFrame; + var nextFrame; + var isUndefinedLeft = isUndefined(left); + var isUndefinedRight = isUndefined(right); + + if (isUndefinedLeft || isUndefinedRight) { + var indicies = getNearTimeIndex(times, time); + isUndefinedLeft && (left = indicies[0]); + isUndefinedRight && (right = indicies[1]); + } + + for (var i = left; i >= 0; --i) { + var frame = this.getFrame(times[i]); + + if (frame.has.apply(frame, properties)) { + prevTime = times[i]; + prevFrame = frame; + break; + } + } + + var prevValue = prevFrame && prevFrame.raw.apply(prevFrame, properties); + + if (isAccurate && !isRole([properties[0]])) { + return prevTime === time ? prevValue : undefined; + } + + if (usePrevValue) { + return prevValue; + } + + for (var i = right; i < length; ++i) { + var frame = this.getFrame(times[i]); + + if (frame.has.apply(frame, properties)) { + nextTime = times[i]; + nextFrame = frame; + break; + } + } + + var nextValue = nextFrame && nextFrame.raw.apply(nextFrame, properties); + + if (!prevFrame || isUndefined(prevValue)) { + return nextValue; + } + + if (!nextFrame || isUndefined(nextValue) || prevValue === nextValue) { + return prevValue; + } + + return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing); + }; + + __proto._toKeyframes = function (duration, states, direction) { + var _this = this; + + var frames = {}; + var times = this.times.slice(); + + if (!times.length) { + return ""; + } + + var originalDuration = this.getDuration(); + !this.getFrame(0) && times.unshift(0); + !this.getFrame(originalDuration) && times.push(originalDuration); + var entries = getEntries(times, states); + var lastEntry = entries[entries.length - 1]; // end delay time + + lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]); + var prevTime = -1; + return entries.map(function (_a) { + var time = _a[0], + keytime = _a[1]; + + if (!frames[keytime]) { + frames[keytime] = (!_this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ? _this.getNowFrame(keytime) : _this.getNowFrame(keytime, 0, true)).toCSS(); + } + + var frameTime = time / duration * 100; + + if (frameTime - prevTime < THRESHOLD) { + frameTime += THRESHOLD; + } + + prevTime = frameTime; + return Math.min(frameTime, 100) + "%{\n " + (time === 0 && !isDirectionReverse(0, 1, direction) ? "" : frames[keytime]) + "\n }"; + }).join(""); + }; + + __proto.updateFrameOrders = function () { + var nameMap = this.nameMap.orderMap; + this.forEach(function (frame) { + frame.setOrderObject(nameMap); + }); + }; + + return SceneItem; + }(Animator); + + /** + * manage sceneItems and play Scene. + * @sort 1 + */ + + var Scene = + /*#__PURE__*/ + function (_super) { + __extends(Scene, _super); + /** + * @param - properties + * @param - options + * @example + const scene = new Scene({ + item1: { + 0: { + display: "none", + }, + 1: { + display: "block", + opacity: 0, + }, + 2: { + opacity: 1, + }, + }, + item2: { + 2: { + opacity: 1, + }, + } + }); + */ + + + function Scene(properties, options) { + var _this = _super.call(this) || this; + + _this.items = {}; + _this.orderMap = new OrderMap(NAME_SEPARATOR); + + _this.load(properties, options); + + return _this; + } + + var __proto = Scene.prototype; + + __proto.getDuration = function () { + var time = 0; + this.forEach(function (item) { + time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed()); + }); + return time || this.state[DURATION]; + }; + + __proto.setDuration = function (duration) { + var items = this.items; + var sceneDuration = this.getDuration(); + + if (duration === 0 || !isFinite(sceneDuration)) { + return this; + } + + if (sceneDuration === 0) { + this.forEach(function (item) { + item.setDuration(duration); + }); + } else { + var ratio_1 = duration / sceneDuration; + this.forEach(function (item) { + item.setDelay(item.getDelay() * ratio_1); + item.setDuration(item.getDuration() * ratio_1); + }); + } + + _super.prototype.setDuration.call(this, duration); + + return this; + }; + /** + * get item in scene by name + * @param - The item's name + * @return {Scene | SceneItem} item + * @example + const item = scene.getItem("item1") + */ + + + __proto.getItem = function (name) { + return this.items[name]; + }; + /** + * create item in scene + * @param {} name - name of item to create + * @param {} options - The option object of SceneItem + * @return {} Newly created item + * @example + const item = scene.newItem("item1") + */ + + + __proto.newItem = function (name, options) { + if (options === void 0) { + options = {}; + } + + if (this.items[name]) { + return this.items[name]; + } + + var item = new SceneItem(); + this.setItem(name, item); + item.setOptions(options); + return item; + }; + /** + * remove item in scene + * @param - name of item to remove + * @return An instance itself + * @example + const item = scene.newItem("item1") + scene.removeItem("item1"); + */ + + + __proto.removeItem = function (name) { + delete this.items[name]; + this.orderMap.remove([name]); + return this; + }; + /** + * add a sceneItem to the scene + * @param - name of item to create + * @param - sceneItem + * @example + const item = scene.newItem("item1") + */ + + + __proto.setItem = function (name, item) { + item.setId(name); + this.items[name] = item; + this.orderMap.add([name]); + return this; + }; + + __proto.setTime = function (time, isTick, isParent, parentEasing) { + _super.prototype.setTime.call(this, time, isTick, isParent); + + var iterationTime = this.getIterationTime(); + var easing = this.getEasing() || parentEasing; + var frames = {}; + this.forEach(function (item) { + item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing); + frames[item.getId()] = item.temp; + }); + this.temp = frames; + /** + * This event is fired when timeupdate and animate. + * @event Scene#animate + * @param {object} param The object of data to be sent to an event. + * @param {number} param.currentTime The total time that the animator is running. + * @param {number} param.time The iteration time during duration that the animator is running. + * @param {object} param.frames frames of that time. + * @example + const scene = new Scene({ + a: { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + }, + b: { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + } + } + }).on("animate", e => { + console.log(e.frames); + // {a: Frame, b: Frame} + console.log(e.frames.a.get("opacity")); + }); + */ + + this.trigger("animate", { + frames: frames, + currentTime: this.getTime(), + time: iterationTime + }); + return this; + }; + /** + * executes a provided function once for each scene item. + * @param - Function to execute for each element, taking three arguments + * @return {Scene} An instance itself + */ + + + __proto.forEach = function (func) { + var items = this.items; + this.getOrders().forEach(function (id, index) { + func(items[id], id, index, items); + }); + return this; + }; + + __proto.toCSS = function (playCondition, duration, parentStates) { + if (duration === void 0) { + duration = this.getDuration(); + } + + if (parentStates === void 0) { + parentStates = []; + } + + var totalDuration = !duration || !isFinite(duration) ? 0 : duration; + var styles = []; + var state = this.state; + state[DURATION] = this.getDuration(); + this.forEach(function (item) { + styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state))); + }); + return styles.join(""); + }; + /** + * Export the CSS of the items to the style. + * @param - Add a selector or className to play. + * @return {Scene} An instance itself + */ + + + __proto.exportCSS = function (playCondition, duration, parentStates) { + var css = this.toCSS(playCondition, duration, parentStates); + + if (!parentStates || !parentStates.length) { + if (this.styledInjector) { + this.styledInjector.destroy(); + this.styledInjector = null; + } + + this.styled = styled(css); + this.styledInjector = this.styled.inject(this.getAnimationElement(), { + original: true + }); // && exportCSS(getRealId(this), css); + } + + return this; + }; + + __proto.append = function (item) { + item.setDelay(item.getDelay() + this.getDuration()); + this.setItem(getRealId(item), item); + }; + + __proto.pauseCSS = function () { + return this.forEach(function (item) { + item.pauseCSS(); + }); + }; + + __proto.pause = function () { + _super.prototype.pause.call(this); + + isPausedCSS(this) && this.pauseCSS(); + this.forEach(function (item) { + item.pause(); + }); + return this; + }; + + __proto.endCSS = function () { + this.forEach(function (item) { + item.endCSS(); + }); + setPlayCSS(this, false); + }; + + __proto.end = function () { + isEndedCSS(this) && this.endCSS(); + + _super.prototype.end.call(this); + + return this; + }; + /** + * get item orders + * @example + scene.getOrders() // => ["item1", "item2"] + */ + + + __proto.getOrders = function () { + return this.orderMap.get([]) || []; + }; + /** + * set item orders + * @param - orders + * @example + frame.setOrders(["item2", "item1"]) // => ["item2", "item1"] + */ + + + __proto.setOrders = function (orders) { + return this.orderMap.set([], orders); + }; + + __proto.getAnimationElement = function () { + var animtionElement; + this.forEach(function (item) { + var el = item.getAnimationElement(); + !animtionElement && (animtionElement = el); + }); + return animtionElement; + }; + + __proto.addPlayClass = function (isPaused, playClassName, properties) { + if (properties === void 0) { + properties = {}; + } + + var animtionElement; + this.forEach(function (item) { + var el = item.addPlayClass(isPaused, playClassName, properties); + !animtionElement && (animtionElement = el); + }); + return animtionElement; + }; + /** + * Play using the css animation and keyframes. + * @param - Check if you want to export css. + * @param [playClassName="startAnimation"] - Add a class name to play. + * @param - The shorthand properties for six of the animation properties. + * @return {Scene} An instance itself + * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp} + * @example + scene.playCSS(); + scene.playCSS(false, { + direction: "reverse", + fillMode: "forwards", + }); + */ + + + __proto.playCSS = function (isExportCSS, playClassName, properties) { + if (isExportCSS === void 0) { + isExportCSS = true; + } + + if (properties === void 0) { + properties = {}; + } + + playCSS(this, isExportCSS, playClassName, properties); + return this; + }; + /** + * Set properties to the Scene. + * @param - properties + * @return An instance itself + * @example + scene.set({ + ".a": { + 0: { + opacity: 0, + }, + 1: { + opacity: 1, + }, + }, + }); + // 0 + console.log(scene.getItem(".a").get(0, "opacity")); + // 1 + console.log(scene.getItem(".a").get(1, "opacity")); + */ + + + __proto.set = function (properties) { + this.load(properties); + return this; + }; + /** + * Clear All Items + * @return {Scene} An instance itself + */ + + + __proto.clear = function () { + this.finish(); + this.items = {}; + this.orderMap = new OrderMap(NAME_SEPARATOR); + + if (this.styledInjector) { + this.styledInjector.destroy(); + } + + this.styled = null; + this.styledInjector = null; + }; + + __proto.load = function (properties, options) { + if (properties === void 0) { + properties = {}; + } + + if (options === void 0) { + options = properties.options; + } + + if (!properties) { + return this; + } + + var selector = options && options[SELECTOR] || this.state[SELECTOR]; + + for (var name in properties) { + if (name === "options") { + continue; + } + + var object = properties[name]; + var item = void 0; + + if (object instanceof Scene || object instanceof SceneItem) { + this.setItem(name, object); + item = object; + } else if (isFunction(object) && selector) { + var elements = IS_WINDOW ? $("" + (isFunction(selector) ? selector(name) : name), true) : []; + var length = elements.length; + var scene = new Scene(); + + for (var i = 0; i < length; ++i) { + scene.newItem(i).setId().setElement(elements[i]).load(object(i, elements[i])); + } + + this.setItem(name, scene); + continue; + } else { + item = this.newItem(name); + item.load(object); + } + + selector && item.setSelector(selector); + } + + this.setOptions(options); + }; + + __proto.setOptions = function (options) { + if (options === void 0) { + options = {}; + } + + _super.prototype.setOptions.call(this, options); + + var selector = options.selector; + + if (selector) { + this.state[SELECTOR] = selector; + } + + return this; + }; + + __proto.setSelector = function (target) { + var state = this.state; + var selector = target || state[SELECTOR]; + state[SELECTOR] = selector; + var isItFunction = isFunction(target); + + if (selector) { + this.forEach(function (item, name) { + item.setSelector(isItFunction ? target(name) : selector); + }); + } + + return this; + }; + + __proto.start = function (delay) { + if (delay === void 0) { + delay = this.state[DELAY]; + } + + var result = _super.prototype.start.call(this, delay); + + if (result) { + this.forEach(function (item) { + item.start(0); + }); + } else { + this.forEach(function (item) { + item.setPlayState(RUNNING); + }); + } + + return result; + }; + /** + * version info + * @type {string} + * @example + * Scene.VERSION // 1.4.0 + */ + + + Scene.VERSION = "1.4.0"; + return Scene; + }(Animator); + + function animate(properties, options) { + return new Scene(properties, options).play(); + } + function animateItem(properties, options) { + return new SceneItem(properties, options).play(); + } + + + + var others = ({ + SceneItem: SceneItem, + Frame: Frame, + Animator: Animator, + 'default': Scene, + OPTIONS: OPTIONS, + EVENTS: EVENTS, + FIXED: FIXED, + ROLES: ROLES, + NAME_SEPARATOR: NAME_SEPARATOR, + setRole: setRole, + setAlias: setAlias, + bezier: bezier, + steps: steps, + STEP_START: STEP_START, + STEP_END: STEP_END, + LINEAR: LINEAR, + EASE: EASE, + EASE_IN: EASE_IN, + EASE_OUT: EASE_OUT, + EASE_IN_OUT: EASE_IN_OUT, + animate: animate, + animateItem: animateItem + }); + + for (var name in others) { + Scene[name] = others[name]; + } + + return Scene; + +})); +//# sourceMappingURL=scene.js.map diff --git a/dist/scene.js.map b/dist/scene.js.map new file mode 100644 index 00000000..a65c735c --- /dev/null +++ b/dist/scene.js.map @@ -0,0 +1 @@ +{"version":3,"file":"scene.js","sources":["../src/easing.ts","../src/consts.ts","../src/EventTrigger.ts","../src/PropertyObject.ts","../src/utils/property.ts","../src/utils.ts","../src/Animator.ts","../src/Frame.ts","../src/utils/dot.ts","../src/SceneItem.ts","../src/Scene.ts","../src/presets.ts","../src/index.umd.ts"],"sourcesContent":["import { EasingFunction } from \"./types\";\n\nfunction cubic(y1: number, y2: number, t: number) {\n const t2 = 1 - t;\n\n // Bezier Curve Formula\n return t * t * t + 3 * t * t * t2 * y2 + 3 * t * t2 * t2 * y1;\n}\nfunction solveFromX(x1: number, x2: number, x: number) {\n // x 0 ~ 1\n // t 0 ~ 1\n let t = x;\n let solveX = x;\n let dx = 1;\n\n while (Math.abs(dx) > 1 / 1000) {\n // 예상 t초에 의한 _x값\n solveX = cubic(x1, x2, t);\n dx = solveX - x;\n // 차이가 미세하면 그 값을 t로 지정\n if (Math.abs(dx) < 1 / 1000) {\n return t;\n }\n t -= dx / 2;\n }\n return t;\n}\n/**\n * @namespace easing\n */\n/**\n* Cubic Bezier curve.\n* @memberof easing\n* @func bezier\n* @param {number} [x1] - point1's x\n* @param {number} [y1] - point1's y\n* @param {number} [x2] - point2's x\n* @param {number} [y2] - point2's y\n* @return {function} the curve function\n* @example\nimport {bezier} from \"scenejs\";\nScene.bezier(0, 0, 1, 1) // LINEAR\nScene.bezier(0.25, 0.1, 0.25, 1) // EASE\n*/\nexport function bezier(x1: number, y1: number, x2: number, y2: number) {\n /*\n\t\tx = f(t)\n\t\tcalculate inverse function by x\n\t\tt = f-1(x)\n\t*/\n const func: EasingFunction = (x: number) => {\n const t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0));\n\n return cubic(y1, y2, t);\n };\n\n func.easingName = `cubic-bezier(${x1},${y1},${x2},${y2})`;\n return func;\n}\n/**\n* Specifies a stepping function\n* @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function}\n* @memberof easing\n* @func steps\n* @param {number} count - point1's x\n* @param {\"start\" | \"end\"} postion - point1's y\n* @return {function} the curve function\n* @example\nimport {steps} from \"scenejs\";\nScene.steps(1, \"start\") // Scene.STEP_START\nScene.steps(1, \"end\") // Scene.STEP_END\n*/\nexport function steps(count: number, position: \"start\" | \"end\") {\n const func: EasingFunction = (time: number) => {\n const level = 1 / count;\n\n if (time >= 1) {\n return 1;\n }\n return (position === \"start\" ? level : 0) + Math.floor(time / level) * level;\n };\n\n func.easingName = `steps(${count}, ${position})`;\n\n return func;\n}\n\n/**\n* Equivalent to steps(1, start)\n* @memberof easing\n* @name STEP_START\n* @static\n* @type {function}\n* @example\nimport {STEP_START} from \"scenejs\";\nScene.STEP_START // steps(1, start)\n*/\nexport const STEP_START = /*#__PURE__#*/steps(1, \"start\");\n/**\n* Equivalent to steps(1, end)\n* @memberof easing\n* @name STEP_END\n* @static\n* @type {function}\n* @example\nimport {STEP_END} from \"scenejs\";\nScene.STEP_END // steps(1, end)\n*/\nexport const STEP_END = /*#__PURE__#*/steps(1, \"end\");\n/**\n* Linear Speed (0, 0, 1, 1)\n* @memberof easing\n* @name LINEAR\n* @static\n* @type {function}\n* @example\nimport {LINEAR} from \"scenejs\";\nScene.LINEAR\n*/\nexport const LINEAR = /*#__PURE__#*/bezier(0, 0, 1, 1);\n/**\n* Ease Speed (0.25, 0.1, 0.25, 1)\n* @memberof easing\n* @name EASE\n* @static\n* @type {function}\n* @example\nimport {EASE} from \"scenejs\";\nScene.EASE\n*/\nexport const EASE = /*#__PURE__#*/bezier(0.25, 0.1, 0.25, 1);\n/**\n* Ease In Speed (0.42, 0, 1, 1)\n* @memberof easing\n* @name EASE_IN\n* @static\n* @type {function}\n* @example\nimport {EASE_IN} from \"scenejs\";\nScene.EASE_IN\n*/\nexport const EASE_IN = /*#__PURE__#*/bezier(0.42, 0, 1, 1);\n/**\n* Ease Out Speed (0, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_OUT} from \"scenejs\";\nScene.EASE_OUT\n*/\nexport const EASE_OUT = /*#__PURE__#*/bezier(0, 0, 0.58, 1);\n/**\n* Ease In Out Speed (0.42, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_IN_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_IN_OUT} from \"scenejs\";\nScene.EASE_IN_OUT\n*/\nexport const EASE_IN_OUT = /*#__PURE__#*/bezier(0.42, 0, 0.58, 1);\n","import { IObject } from \"@daybrush/utils\";\nimport { RoleObject, OptionType, EventType, EasingFunction } from \"./types\";\nimport { EASE, EASE_IN, EASE_IN_OUT, LINEAR, EASE_OUT, STEP_START, STEP_END } from \"./easing\";\n\nexport const PREFIX = \"__SCENEJS_\";\nexport const DATA_SCENE_ID = \"data-scene-id\";\nexport const TIMING_FUNCTION = \"animation-timing-function\";\nexport const ROLES: RoleObject = { transform: {}, filter: {}, attribute: {}, html: true };\nexport const ALIAS: IObject = { easing: [TIMING_FUNCTION] };\nexport const FIXED = { [TIMING_FUNCTION]: true, contents: true, html: true };\nexport const MAXIMUM = 1000000;\nexport const THRESHOLD = 0.000001;\n\nexport const DURATION = \"duration\";\nexport const FILL_MODE = \"fillMode\";\nexport const DIRECTION = \"direction\";\nexport const ITERATION_COUNT = \"iterationCount\";\nexport const DELAY = \"delay\";\nexport const EASING = \"easing\";\nexport const PLAY_SPEED = \"playSpeed\";\nexport const EASING_NAME = \"easingName\";\nexport const ITERATION_TIME = \"iterationTime\";\nexport const PAUSED = \"paused\";\nexport const ENDED = \"ended\";\nexport const TIMEUPDATE = \"timeupdate\";\nexport const ANIMATE = \"animate\";\nexport const PLAY = \"play\";\nexport const RUNNING = \"running\";\nexport const ITERATION = \"iteration\";\nexport const START_ANIMATION = \"startAnimation\";\nexport const PAUSE_ANIMATION = \"pauseAnimation\";\nexport const ALTERNATE = \"alternate\";\nexport const REVERSE = \"reverse\";\nexport const ALTERNATE_REVERSE = \"alternate-reverse\";\nexport const NORMAL = \"normal\";\nexport const INFINITE = \"infinite\";\nexport const PLAY_STATE = \"playState\";\nexport const PLAY_CSS = \"playCSS\";\nexport const PREV_TIME = \"prevTime\";\nexport const TICK_TIME = \"tickTime\";\nexport const CURRENT_TIME = \"currentTime\";\nexport const SELECTOR = \"selector\";\nexport const TRANSFORM_NAME = \"transform\";\nexport const EASINGS = {\n \"linear\": LINEAR,\n \"ease\": EASE,\n \"ease-in\": EASE_IN,\n \"ease-out\": EASE_OUT,\n \"ease-in-out\": EASE_IN_OUT,\n \"step-start\": STEP_START,\n \"step-end\": STEP_END,\n};\nexport const NAME_SEPARATOR = \"_///_\";\n/**\n* option name list\n* @name Scene.OPTIONS\n* @memberof Scene\n* @static\n* @type {$ts:OptionType}\n* @example\n* Scene.OPTIONS // [\"duration\", \"fillMode\", \"direction\", \"iterationCount\", \"delay\", \"easing\", \"playSpeed\"]\n*/\nexport const OPTIONS: OptionType = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED];\n\n/**\n* Event name list\n* @name Scene.EVENTS\n* @memberof Scene\n* @static\n* @type {$ts:EventType}\n* @example\n* Scene.EVENTS // [\"paused\", \"ended\", \"timeupdate\", \"animate\", \"play\", \"iteration\"];\n*/\nexport const EVENTS: EventType = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION];\n","import { isObject, isArray, toArray } from \"@daybrush/utils\";\nimport { CallbackType, EventParameter } from \"./types\";\n\n/**\n* attach and trigger event handlers.\n*/\nclass EventTrigger {\n public events: { [name: string]: CallbackType[] };\n /**\n * @example\n const et = new Scene.EventTrigger();\n const scene = new Scene();\n\n scene.on(\"call\", e => {\n console.log(e.param);\n });\n et.on(\"call\", e => {\n console.log(e.param);\n });\n scene.trigger(\"call\", {param: 1});\n et.trigger(\"call\", {param: 1});\n */\n constructor() {\n this.events = {};\n }\n public _on(name: string | EventParameter, callback?: CallbackType | CallbackType[], once?: boolean) {\n const events = this.events;\n\n if (isObject(name)) {\n for (const n in name) {\n this._on(n, name[n], once);\n }\n return;\n }\n if (!(name in events)) {\n events[name] = [];\n }\n if (!callback) {\n return;\n }\n if (isArray(callback)) {\n callback.forEach(func => this._on(name, func, once));\n return;\n }\n events[name].push(once ? function callback2(...args) {\n callback(...args);\n this.off(name, callback2);\n } : callback);\n }\n /**\n * Attach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function() {\n console.log(\"animate\");\n });\n\n target.trigger(\"animate\");\n\n */\n public on(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback);\n return this;\n }\n /**\n * Dettach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n const callback = function() {\n console.log(\"animate\");\n };\n target.on(\"animate\", callback);\n\n target.off(\"animate\", callback);\n target.off(\"animate\");\n\n */\n public off(name?: string, callback?: CallbackType) {\n if (!name) {\n this.events = {};\n } else if (!callback) {\n this.events[name] = [];\n } else {\n const callbacks = this.events[name];\n\n if (!callbacks) {\n return this;\n }\n const index = callbacks.indexOf(callback);\n\n if (index !== -1) {\n callbacks.splice(index, 1);\n }\n }\n return this;\n }\n /**\n * execute event handler\n * @param - event's name\n * @param - event handler's additional parameter\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function(a1, a2) {\n console.log(\"animate\", a1, a2);\n });\n\n target.trigger(\"animate\", [1, 2]); // log => \"animate\", 1, 2\n\n */\n public trigger(name: string, ...data: any[]) {\n const events = this.events;\n\n if (!(name in events)) {\n return this;\n }\n\n const args = data || [];\n\n !args[0] && (args[0] = {});\n const event = events[name];\n const target = args[0];\n\n target.type = name;\n target.currentTarget = this;\n !target.target && (target.target = this);\n toArray(events[name]).forEach(callback => {\n callback.apply(this, data);\n });\n\n return this;\n }\n public once(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback, true);\n return this;\n }\n}\nexport default EventTrigger;\n","import { isString } from \"@daybrush/utils\";\nimport { PropertyObjectState } from \"./types\";\n\n/**\n* Make string, array to PropertyObject for the dot product\n*/\nclass PropertyObject implements PropertyObjectState {\n public value: any[];\n public prefix: string = \"\";\n public suffix: string = \"\";\n public model: string = \"\";\n public type: string = \"\";\n public separator: string = \",\";\n\n /**\n * @param - This value is in the array format.\n * @param - options\n * @example\n var obj = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n */\n constructor(value: string | any[], options?: Partial) {\n options && this.setOptions(options);\n this.value = isString(value) ? value.split(this.separator) : value;\n }\n public setOptions(newOptions: Partial) {\n for (const name in newOptions) {\n this[name as keyof PropertyObjectState] = newOptions[name as keyof PropertyObjectState];\n }\n return this;\n }\n /**\n * the number of values.\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.length);\n // 3\n */\n public size() {\n return this.value.length;\n }\n /**\n * retrieve one of values at the index\n * @param {Number} index - index\n * @return {Object} one of values at the index\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.get(0));\n // 1\n */\n public get(index: number) {\n return this.value[index];\n }\n /**\n * Set the value at that index\n * @param {Number} index - index\n * @param {Object} value - text, a number, object to set\n * @return {PropertyObject} An instance itself\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n obj1.set(0, 2);\n console.log(obj1.toValue());\n // 2,2,3\n */\n public set(index: number, value: any) {\n this.value[index] = value;\n return this;\n }\n /**\n * create a copy of an instance itself.\n * @return {PropertyObject} clone\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n const obj2 = obj1.clone();\n */\n public clone(): PropertyObject {\n const {\n separator,\n prefix,\n suffix,\n model,\n type,\n } = this;\n const arr = this.value.map(v => ((v instanceof PropertyObject) ? v.clone() : v));\n return new PropertyObject(arr, {\n separator,\n prefix,\n suffix,\n model,\n type,\n });\n }\n /**\n * Make Property Object to String\n * @return {String} Make Property Object to String\n * @example\n //rgba(100, 100, 100, 0.5)\n const obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\",\n });\n console.log(obj4.toValue());\n // \"rgba(100,100,100,0.5)\"\n */\n public toValue(): string {\n return this.prefix + this.join() + this.suffix;\n }\n /**\n * Make Property Object's array to String\n * @return {String} Join the elements of an array into a string\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n obj4.join(); // => \"100,100,100,0.5\"\n */\n public join() {\n return this.value.map(v => ((v instanceof PropertyObject) ? v.toValue() : v)).join(this.separator);\n }\n /**\n * executes a provided function once per array element.\n * @param {Function} callback - Function to execute for each element, taking three arguments\n * @param {All} [callback.currentValue] The current element being processed in the array.\n * @param {Number} [callback.index] The index of the current element being processed in the array.\n * @param {Array} [callback.array] the array.\n * @return {PropertyObject} An instance itself\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document.\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n\n obj4.forEach(t => {\n console.log(t);\n }); // => \"100,100,100,0.5\"\n */\n public forEach(func: (value?: any, index?: number, array?: any[]) => void) {\n this.value.forEach(func);\n return this;\n }\n}\nexport default PropertyObject;\n","/**\n* @namespace\n* @name Property\n*/\n\nimport PropertyObject from \"../PropertyObject\";\nimport {\n COLOR_MODELS, isString,\n splitComma, splitSpace, stringToRGBA,\n RGBA, splitBracket, IObject, isArray, splitText\n} from \"@daybrush/utils\";\nimport { NameType } from \"../types\";\n\nexport function splitStyle(str: string) {\n\n const properties = splitText(str, \";\");\n const obj: IObject = {};\n const totalLength = properties.length;\n let length = totalLength;\n\n for (let i = 0; i < totalLength; ++i) {\n const matches = splitText(properties[i], \":\");\n\n if (matches.length < 2 || !matches[1]) {\n --length;\n continue;\n }\n obj[matches[0].trim()] = toPropertyObject(matches[1].trim());\n }\n return { styles: obj, length };\n}\n/**\n* convert array to PropertyObject[type=color].\n* default model \"rgba\"\n* @memberof Property\n* @function arrayToColorObject\n* @param {Array|PropertyObject} value ex) [0, 0, 0, 1]\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\narrayToColorObject([0, 0, 0])\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0, 1], separator=\",\")\n*/\nexport function arrayToColorObject(arr: number[]) {\n const model = RGBA;\n\n if (arr.length === 3) {\n arr[3] = 1;\n }\n return new PropertyObject(arr, {\n model,\n separator: \",\",\n type: \"color\",\n prefix: `${model}(`,\n suffix: \")\",\n });\n}\n/**\n* convert text with parentheses to object.\n* @memberof Property\n* @function stringToBracketObject\n* @param {String} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject\n* @example\nstringToBracketObject(\"abcde(0, 0, 0,1)\")\n// => PropertyObject(model=\"abcde\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToBracketObject(text: string) {\n // [prefix, value, other]\n const { prefix: model, value, suffix: afterModel } = splitBracket(text);\n\n if (typeof value === \"undefined\") {\n return text;\n }\n if (COLOR_MODELS.indexOf(model) > -1) {\n return arrayToColorObject(stringToRGBA(text));\n }\n // divide comma(,)\n const obj = toPropertyObject(value, model);\n\n let arr = [value];\n let separator = \",\";\n let prefix = `${model}(`;\n let suffix = `)${afterModel}`;\n\n if (obj instanceof PropertyObject) {\n separator = obj.separator;\n arr = obj.value;\n prefix += obj.prefix;\n suffix = obj.suffix + suffix;\n }\n return new PropertyObject(arr, {\n separator,\n model,\n prefix,\n suffix,\n });\n}\n\nexport function arrayToPropertyObject(arr: any[], separator: string) {\n return new PropertyObject(arr, {\n type: \"array\",\n separator,\n });\n}\n\n/**\n* convert text with parentheses to PropertyObject[type=color].\n* If the values are not RGBA model, change them RGBA mdoel.\n* @memberof Property\n* @function stringToColorObject\n* @param {String|PropertyObject} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\nstringToColorObject(\"rgba(0, 0, 0,1)\")\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToColorObject(value: string): string | PropertyObject {\n const result = stringToRGBA(value);\n\n return result ? arrayToColorObject(result) : value;\n}\n/**\n* convert CSS Value to PropertyObject\n* @memberof Property\n* @function toPropertyObject\n* @param {String} value it's text contains the array.\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @see referenced regular expression {@link http://stackoverflow.com/questions/20215440/parse-css-gradient-rule-with-javascript-regex}\n* @example\ntoPropertyObject(\"1px solid #000\");\n// => PropertyObject([\"1px\", \"solid\", rgba(0, 0, 0, 1)])\n*/\nexport function toPropertyObject(value: any[], model?: NameType): PropertyObject;\nexport function toPropertyObject(value: IObject, model?: NameType): IObject;\nexport function toPropertyObject(value: string, model?: NameType): PropertyObject | string;\nexport function toPropertyObject(value: string | IObject | any[], model?: NameType) {\n if (!isString(value)) {\n if (isArray(value)) {\n return arrayToPropertyObject(value, \",\");\n }\n return value;\n }\n let values: any = splitComma(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \",\");\n }\n values = splitSpace(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \" \");\n }\n values = /^(['\"])([^'\"]*)(['\"])$/g.exec(value);\n\n if (values && values[1] === values[3]) {\n // Quotes\n return new PropertyObject([toPropertyObject(values[2])], {\n prefix: values[1],\n suffix: values[1],\n });\n } else if (value.indexOf(\"(\") !== -1) {\n // color\n return stringToBracketObject(value);\n } else if (value.charAt(0) === \"#\" && model !== \"url\") {\n return stringToColorObject(value);\n }\n return value;\n}\nexport function toObject(object: PropertyObject, result: IObject = {}) {\n const model = object.model;\n\n if (model) {\n object.setOptions({\n model: \"\",\n suffix: \"\",\n prefix: \"\",\n });\n const value = object.size() > 1 ? object : object.get(0);\n\n result[model] = value;\n } else {\n object.forEach(obj => {\n toObject(obj, result);\n });\n }\n return result;\n}\n","import {\n ROLES, MAXIMUM, FIXED, ALIAS,\n PAUSED, RUNNING, PLAY, ENDED, PREFIX, PLAY_CSS, CURRENT_TIME, START_ANIMATION, EASINGS, NAME_SEPARATOR\n} from \"./consts\";\nimport PropertyObject from \"./PropertyObject\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport {\n isArray, ANIMATION, ARRAY, OBJECT,\n PROPERTY, STRING, NUMBER, IS_WINDOW, IObject, $, document, isObject, addEvent, removeEvent, isString,\n} from \"@daybrush/utils\";\nimport { EasingType, EasingFunction, NameType } from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\nimport { bezier, steps } from \"./easing\";\n\nexport function isPropertyObject(value: any): value is PropertyObject {\n return value instanceof PropertyObject;\n}\nexport function setAlias(name: string, alias: string[]) {\n ALIAS[name] = alias;\n}\nexport function setRole(names: string[], isProperty?: boolean, isFixedProperty?: boolean) {\n const length = names.length;\n let roles: any = ROLES;\n let fixed: any = FIXED;\n\n for (let i = 0; i < length - 1; ++i) {\n !roles[names[i]] && (roles[names[i]] = {});\n roles = roles[names[i]];\n if (isFixedProperty) {\n !fixed[names[i]] && (fixed[names[i]] = {});\n fixed = fixed[names[i]];\n }\n }\n isFixedProperty && (fixed[names[length - 1]] = true);\n roles[names[length - 1]] = isProperty ? true : {};\n}\nexport function getType(value: any) {\n const type = typeof value;\n\n if (type === OBJECT) {\n if (isArray(value)) {\n return ARRAY;\n } else if (isPropertyObject(value)) {\n return PROPERTY;\n }\n } else if (type === STRING || type === NUMBER) {\n return \"value\";\n }\n return type;\n}\nexport function isPureObject(obj: any): obj is object {\n return isObject(obj) && obj.constructor === Object;\n}\nexport function getNames(names: IObject, stack: string[]) {\n let arr: string[][] = [];\n\n if (isPureObject(names)) {\n for (const name in names) {\n stack.push(name);\n arr = arr.concat(getNames(names[name], stack));\n stack.pop();\n }\n } else {\n arr.push(stack.slice());\n }\n return arr;\n}\nexport function updateFrame(names: IObject, properties: IObject) {\n for (const name in properties) {\n const value = properties[name];\n\n if (!isPureObject(value)) {\n names[name] = true;\n continue;\n }\n if (!isObject(names[name])) {\n names[name] = {};\n }\n updateFrame(names[name], properties[name]);\n }\n return names;\n}\nexport function toFixed(num: number) {\n return Math.round(num * MAXIMUM) / MAXIMUM;\n}\nexport function getValueByNames(\n names: Array,\n properties: IObject, length: number = names.length) {\n let value = properties;\n\n for (let i = 0; i < length; ++i) {\n if (!isObject(value) || value == null) {\n return undefined;\n }\n value = value[names[i]];\n }\n return value;\n}\nexport function isInProperties(roles: IObject, args: NameType[], isCheckTrue?: boolean) {\n const length = args.length;\n let role: any = roles;\n\n if (length === 0) {\n return false;\n }\n for (let i = 0; i < length; ++i) {\n if (role === true) {\n return false;\n }\n role = role[args[i]];\n if (!role || (!isCheckTrue && role === true)) {\n return false;\n }\n }\n return true;\n}\nexport function isRole(args: NameType[], isCheckTrue?: boolean) {\n return isInProperties(ROLES, args, isCheckTrue);\n}\nexport function isFixed(args: NameType[]) {\n return isInProperties(FIXED, args, true);\n}\n\nexport interface IterationInterface {\n currentTime: number;\n iterationCount: number;\n elapsedTime: number;\n}\nexport function setPlayCSS(item: Scene | SceneItem, isActivate: boolean) {\n item.state[PLAY_CSS] = isActivate;\n}\nexport function isPausedCSS(item: Scene | SceneItem) {\n return item.state[PLAY_CSS] && item.isPaused();\n}\nexport function isEndedCSS(item: Scene | SceneItem) {\n return !item.isEnded() && item.state[PLAY_CSS];\n}\n\nexport function makeId(selector?: boolean) {\n for (; ;) {\n const id = `${Math.floor(Math.random() * 10000000)}`;\n\n if (!IS_WINDOW || !selector) {\n return id;\n }\n const checkElement = $(`[data-scene-id=\"${id}\"]`);\n\n if (!checkElement) {\n return id;\n }\n }\n}\nexport function getRealId(item: Scene | SceneItem) {\n return item.getId() || item.setId(makeId(false)).getId();\n}\nexport function toId(text: number | string) {\n return `${text}`.match(/[0-9a-zA-Z]+/g).join(\"\");\n}\nexport function playCSS(\n item: Scene | SceneItem, isExportCSS?: boolean,\n playClassName?: string, properties: object = {}) {\n if (!ANIMATION || item.getPlayState() === RUNNING) {\n return;\n }\n const className = playClassName || START_ANIMATION;\n\n if (isPausedCSS(item)) {\n item.addPlayClass(true, className, properties);\n } else {\n if (item.isEnded()) {\n item.setTime(0);\n }\n isExportCSS && item.exportCSS({ className });\n const el = item.addPlayClass(false, className, properties);\n\n if (!el) {\n return;\n }\n addAnimationEvent(item, el);\n setPlayCSS(item, true);\n }\n item.setPlayState(RUNNING);\n}\n\nexport function addAnimationEvent(item: Scene | SceneItem, el: Element) {\n const state = item.state;\n const duration = item.getDuration();\n const isZeroDuration = !duration || !isFinite(duration);\n const animationend = () => {\n setPlayCSS(item, false);\n item.finish();\n };\n const animationstart = () => {\n item.trigger(PLAY);\n\n addEvent(el, \"animationcancel\", animationend);\n addEvent(el, \"animationend\", animationend);\n addEvent(el, \"animationiteration\", animationiteration);\n };\n item.once(ENDED, () => {\n removeEvent(el, \"animationcancel\", animationend);\n removeEvent(el, \"animationend\", animationend);\n removeEvent(el, \"animationiteration\", animationiteration);\n removeEvent(el, \"animationstart\", animationstart);\n });\n const animationiteration = ({ elapsedTime }: any) => {\n const currentTime = elapsedTime;\n const iterationCount = isZeroDuration ? 0 : (currentTime / duration);\n\n state[CURRENT_TIME] = currentTime;\n item.setIteration(iterationCount);\n };\n addEvent(el, \"animationstart\", animationstart);\n}\n\nexport function getEasing(curveArray: string | number[] | EasingFunction): EasingType {\n let easing: EasingType;\n\n if (isString(curveArray)) {\n if (curveArray in EASINGS) {\n easing = EASINGS[curveArray];\n } else {\n const obj = toPropertyObject(curveArray);\n\n if (isString(obj)) {\n return 0;\n } else {\n if (obj.model === \"cubic-bezier\") {\n curveArray = obj.value.map(v => parseFloat(v));\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else if (obj.model === \"steps\") {\n easing = steps(parseFloat(obj.value[0]), obj.value[1]);\n } else {\n return 0;\n }\n }\n }\n } else if (isArray(curveArray)) {\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else {\n easing = curveArray;\n }\n\n return easing;\n}\n\nexport function getFullName(names: NameType[]) {\n return names.join(NAME_SEPARATOR);\n}\n","import {\n THRESHOLD,\n ALTERNATE, ALTERNATE_REVERSE, REVERSE, INFINITE, NORMAL,\n ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED,\n DURATION, EASING, ITERATION_TIME, EASING_NAME, PAUSED,\n RUNNING, PLAY, TIMEUPDATE, ENDED, PLAY_STATE, PREV_TIME, TICK_TIME, CURRENT_TIME, ITERATION, OPTIONS, EASINGS\n} from \"./consts\";\nimport EventTrigger from \"./EventTrigger\";\nimport { bezier, steps } from \"./easing\";\nimport { toFixed, getEasing } from \"./utils\";\nimport { splitUnit, isString, camelize, requestAnimationFrame, isArray, cancelAnimationFrame } from \"@daybrush/utils\";\nimport {\n IterationCountType, DirectionType, AnimatorState,\n EasingFunction, FillModeType, PlayStateType, EasingType, AnimatorOptions,\n} from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\n\nfunction GetterSetter {}>(\n getter: string[], setter: string[], parent: string) {\n return (constructor: T) => {\n const prototype = constructor.prototype;\n\n getter.forEach(name => {\n prototype[camelize(`get ${name}`)] = function() {\n return this[parent][name];\n };\n });\n setter.forEach(name => {\n prototype[camelize(`set ${name}`)] = function(value: any) {\n this[parent][name] = value;\n return this;\n };\n });\n };\n}\nexport function isDirectionReverse(iteration: number, iteraiontCount: IterationCountType, direction: DirectionType) {\n if (direction === REVERSE) {\n return true;\n } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) {\n return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE);\n }\n return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE);\n}\n/**\n* @typedef {Object} AnimatorState The Animator options. Properties used in css animation.\n* @property {number} [duration] The duration property defines how long an animation should take to complete one cycle.\n* @property {\"none\"|\"forwards\"|\"backwards\"|\"both\"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both).\n* @property {\"infinite\"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played.\n* @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation.\n* @property {number} [delay] The delay property specifies a delay for the start of an animation.\n* @property {\"normal\"|\"reverse\"|\"alternate\"|\"alternate-reverse\"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles.\n*/\n\nconst setters = [\"id\", ITERATION_COUNT, DELAY, FILL_MODE,\n DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE];\nconst getters = [...setters, EASING, EASING_NAME];\n\n/**\n* play video, animation, the others\n* @extends EventTrigger\n* @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n*/\n@GetterSetter(getters, setters, \"state\")\nclass Animator\n extends EventTrigger {\n public state: U;\n private timerId: number = 0;\n\n /**\n * @param - animator's options\n * @example\n const animator = new Animator({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n constructor(options?: Partial) {\n super();\n this.state = {\n id: \"\",\n easing: 0,\n easingName: \"linear\",\n iterationCount: 1,\n delay: 0,\n fillMode: \"forwards\",\n direction: NORMAL,\n playSpeed: 1,\n currentTime: 0,\n iterationTime: -1,\n iteration: 0,\n tickTime: 0,\n prevTime: 0,\n playState: PAUSED,\n duration: 0,\n } as U;\n this.setOptions(options);\n }\n /**\n * set animator's easing.\n * @param curverArray - The speed curve of an animation.\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n public setEasing(curveArray: string | number[] | EasingFunction): this {\n const easing: EasingType = getEasing(curveArray);\n const easingName = easing && easing[EASING_NAME] || \"linear\";\n const state = this.state;\n\n state[EASING] = easing;\n state[EASING_NAME] = easingName;\n return this;\n }\n /**\n * set animator's options.\n * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n * @param - animator's options\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.eaasing.EASE,\n });\n */\n public setOptions(options: Partial = {}): this {\n for (const name in options) {\n const value = options[name];\n\n if (name === EASING) {\n this.setEasing(value);\n continue;\n } else if (name === DURATION) {\n value && this.setDuration(value);\n continue;\n }\n if (OPTIONS.indexOf(name as any) > -1) {\n this.state[name] = value;\n }\n }\n\n return this;\n }\n /**\n * Get the animator's total duration including delay\n * @return {number} Total duration\n * @example\n animator.getTotalDuration();\n */\n public getTotalDuration(): number {\n return this.getActiveDuration(true);\n }\n /**\n * Get the animator's total duration excluding delay\n * @return {number} Total duration excluding delay\n * @example\n animator.getActiveDuration();\n */\n public getActiveDuration(delay?: boolean): number {\n const state = this.state;\n const count = state[ITERATION_COUNT];\n if (count === INFINITE) {\n return Infinity;\n }\n return (delay ? state[DELAY] : 0) + this.getDuration() * count;\n }\n /**\n * Check if the animator has reached the end.\n * @return {boolean} ended\n * @example\n animator.isEnded(); // true or false\n */\n public isEnded(): boolean {\n if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) {\n return true;\n } else if (this.getTime() < this.getActiveDuration()) {\n return false;\n }\n return true;\n }\n /**\n *Check if the animator is paused:\n * @return {boolean} paused\n * @example\n animator.isPaused(); // true or false\n */\n public isPaused(): boolean {\n return this.state[PLAY_STATE] === PAUSED;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const state = this.state;\n\n state[PLAY_STATE] = RUNNING;\n if (state[TICK_TIME] >= delay) {\n /**\n * This event is fired when play animator.\n * @event Animator#play\n */\n this.trigger(PLAY);\n return true;\n }\n return false;\n }\n /**\n * play animator\n * @return {Animator} An instance itself.\n */\n public play(toTime?: number) {\n const state = this.state;\n const delay = state[DELAY];\n const currentTime = this.getTime();\n\n state[PLAY_STATE] = RUNNING;\n\n if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) {\n this.setTime(-delay, true);\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n state[PREV_TIME] = time;\n this.tick(time, toTime);\n });\n this.start();\n return this;\n }\n /**\n * pause animator\n * @return {Animator} An instance itself.\n */\n public pause(): this {\n const state = this.state;\n\n if (state[PLAY_STATE] !== PAUSED) {\n state[PLAY_STATE] = PAUSED;\n /**\n * This event is fired when animator is paused.\n * @event Animator#paused\n */\n this.trigger(PAUSED);\n }\n cancelAnimationFrame(this.timerId);\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public finish() {\n this.setTime(0);\n this.state[TICK_TIME] = 0;\n this.end();\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public end() {\n this.pause();\n /**\n * This event is fired when animator is ended.\n * @event Animator#ended\n */\n this.trigger(ENDED);\n return this;\n }\n /**\n * set currentTime\n * @param {Number|String} time - currentTime\n * @return {Animator} An instance itself.\n * @example\n\n animator.setTime(\"from\"); // 0\n animator.setTime(\"to\"); // 100%\n animator.setTime(\"50%\");\n animator.setTime(10);\n animator.getTime() // 10\n */\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean) {\n const activeDuration = this.getActiveDuration();\n const state = this.state;\n const prevTime = state[TICK_TIME];\n const delay = state[DELAY];\n let currentTime = isTick ? (time as number) : this.getUnitTime(time);\n\n state[TICK_TIME] = delay + currentTime;\n if (currentTime < 0) {\n currentTime = 0;\n } else if (currentTime > activeDuration) {\n currentTime = activeDuration;\n }\n state[CURRENT_TIME] = currentTime;\n this.calculate();\n\n if (isTick && !isParent) {\n const tickTime = state[TICK_TIME];\n\n if (prevTime < delay && time >= 0) {\n this.start(0);\n }\n if (tickTime < prevTime || this.isEnded()) {\n this.end();\n return;\n }\n }\n if (this.isDelay()) {\n return this;\n }\n /**\n * This event is fired when the animator updates the time.\n * @event Animator#timeupdate\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(TIMEUPDATE, {\n currentTime,\n time: this.getIterationTime(),\n iterationCount: state[ITERATION],\n });\n\n return this;\n }\n /**\n * Get the animator's current time\n * @return {number} current time\n * @example\n animator.getTime();\n */\n public getTime(): number {\n return this.state[CURRENT_TIME];\n }\n public getUnitTime(time: string | number) {\n if (isString(time)) {\n const duration = this.getDuration() || 100;\n\n if (time === \"from\") {\n return 0;\n } else if (time === \"to\") {\n return duration;\n }\n const { unit, value } = splitUnit(time);\n\n if (unit === \"%\") {\n !this.getDuration() && (this.setDuration(duration));\n return toFixed(parseFloat(time) / 100 * duration);\n } else if (unit === \">\") {\n return value + THRESHOLD;\n } else {\n return value;\n }\n } else {\n return toFixed(time);\n }\n }\n /**\n * Check if the current state of animator is delayed.\n * @return {boolean} check delay state\n */\n public isDelay() {\n const state = this.state;\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n\n return delay > 0 && (tickTime < delay);\n }\n public setIteration(iterationCount: number): this {\n const state = this.state;\n const passIterationCount = Math.floor(iterationCount);\n const maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT];\n\n if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) {\n /**\n * The event is fired when an iteration of an animation ends.\n * @event Animator#iteration\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(\"iteration\", {\n currentTime: state[CURRENT_TIME],\n iterationCount: passIterationCount,\n });\n }\n state[ITERATION] = iterationCount;\n return this;\n }\n protected calculate() {\n const state = this.state;\n const iterationCount = state[ITERATION_COUNT];\n const fillMode = state[FILL_MODE];\n const direction = state[DIRECTION];\n const duration = this.getDuration();\n const time = this.getTime();\n const iteration = duration === 0 ? 0 : time / duration;\n let currentIterationTime = duration ? time % duration : 0;\n\n if (!duration) {\n this.setIterationTime(0);\n return this;\n }\n this.setIteration(iteration);\n\n // direction : normal, reverse, alternate, alternate-reverse\n // fillMode : forwards, backwards, both, none\n const isReverse = isDirectionReverse(iteration, iterationCount, direction);\n\n const isFiniteDuration = isFinite(duration);\n if (isFiniteDuration && isReverse) {\n currentIterationTime = duration - currentIterationTime;\n }\n if (isFiniteDuration && iterationCount !== INFINITE) {\n const isForwards = fillMode === \"both\" || fillMode === \"forwards\";\n\n // fill forwards\n if (iteration >= iterationCount) {\n currentIterationTime = duration * (isForwards ? (iterationCount % 1) || 1 : 0);\n isReverse && (currentIterationTime = duration - currentIterationTime);\n }\n }\n this.setIterationTime(currentIterationTime);\n return this;\n }\n private tick(now: number, to?: number) {\n if (this.isPaused()) {\n return;\n }\n const state = this.state;\n const playSpeed = state[PLAY_SPEED];\n const prevTime = state[PREV_TIME];\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n const currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed;\n\n state[PREV_TIME] = now;\n this.setTime(currentTime - delay, true);\n if (to && to * 1000 < now) {\n this.pause();\n }\n if (state[PLAY_STATE] === PAUSED) {\n return;\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n this.tick(time, to);\n });\n }\n}\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#setId\n * @param {number | string} - String or number of id to be set in the animator\n * @return {Animator} An instance itself.\n */\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#getId\n * @return {number | string} the indicator of the item.\n */\n/**\n * Get a delay for the start of an animation.\n * @method Animator#getDelay\n * @return {number} delay\n */\n/**\n * Set a delay for the start of an animation.\n * @method Animator#setDelay\n * @param {number} delay - delay\n * @return {Animator} An instance itself.\n */\n/**\n * Get fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#getFillMode\n * @return {FillModeType} fillMode\n */\n/**\n * Set fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#setFillMode\n * @param {FillModeType} fillMode - fillMode\n * @return {Animator} An instance itself.\n */\n/**\n * Get the number of times an animation should be played.\n * @method Animator#getIterationCount\n * @return {IterationCountType} iterationCount\n */\n/**\n * Set the number of times an animation should be played.\n * @method Animator#setIterationCount\n * @param {IterationCountType} iterationCount - iterationCount\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#getDirection\n * @return {DirectionType} direction\n */\n/**\n * Set whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#setDirection\n * @param {DirectionType} direction - direction\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether the animation is running or paused.\n * @method Animator#getPlayState\n * @return {PlayStateType} playState\n */\n/**\n * Set whether the animation is running or paused.\n * @method Animator#setPlayState\n * @param {PlayStateType} playState - playState\n * @return {Animator} An instance itself.\n */\n/**\n * Get the animator's play speed\n * @method Animator#getPlaySpeed\n * @return {number} playSpeed\n */\n/**\n * Set the animator's play speed\n * @method Animator#setPlaySpeed\n * @param {number} playSpeed - playSpeed\n * @return {Animator} An instance itself.\n */\n/**\n * Get how long an animation should take to complete one cycle.\n * @method Animator#getDuration\n * @return {number} duration\n */\n/**\n * Set how long an animation should take to complete one cycle.\n * @method Animator#setDuration\n * @param {number} duration - duration\n * @return {Animator} An instance itself.\n */\n/**\n * Get the speed curve of an animation.\n * @method Animator#getEasing\n * @return {EasingType} easing\n */\n/**\n * Get the speed curve's name\n * @method Animator#getEasingName\n * @return {string} the curve's name.\n */\n/**\n\t* Get the animator's current iteration time\n\t* @method Animator#getIterationTime\n\t* @return {number} current iteration time\n\t* @example\nanimator.getIterationTime();\n\t*/\n\n// tslint:disable-next-line:interface-name\ninterface Animator {\n setId(id: number | string): this;\n getId(): number | string;\n getIterationTime(): number;\n setIterationTime(time: number): this;\n setDelay(delay: number): this;\n getDelay(): number;\n setFillMode(fillMode: FillModeType): this;\n getFillMode(): FillModeType;\n setIterationCount(iterationCount: IterationCountType): this;\n getIterationCount(): IterationCountType;\n setDirection(direction: DirectionType): this;\n getDirection(): DirectionType;\n setPlayState(playState: PlayStateType): this;\n getPlayState(): PlayStateType;\n setPlaySpeed(playSpeed: number): this;\n getPlaySpeed(): number;\n setDuration(duration: number): this;\n getDuration(): number;\n getEasing(): EasingType;\n getEasingName(): string;\n}\nexport default Animator;\n","import {\n ALIAS, TIMING_FUNCTION, TRANSFORM_NAME, EASING_NAME, NAME_SEPARATOR\n} from \"./consts\";\nimport { isRole, getType, isPropertyObject, getValueByNames, isFixed, getNames, getEasing, getFullName } from \"./utils\";\nimport { toPropertyObject, splitStyle, toObject } from \"./utils/property\";\nimport {\n isObject, isArray, isString, getKeys,\n ANIMATION, TRANSFORM, FILTER, PROPERTY, FUNCTION, ARRAY, OBJECT, IObject, isUndefined,\n sortOrders,\n} from \"@daybrush/utils\";\nimport { NameType, KeyValueChildren } from \"./types\";\nimport OrderMap from \"order-map\";\n\nfunction toInnerProperties(obj: IObject, orders: NameType[] = []) {\n if (!obj) {\n return \"\";\n }\n const arrObj = [];\n\n const keys = getKeys(obj);\n\n sortOrders(keys, orders);\n\n keys.forEach(name => {\n arrObj.push(`${name.replace(/\\d$/g, \"\")}(${obj[name]})`);\n });\n\n return arrObj.join(\" \");\n}\n\n/* eslint-disable */\nfunction clone(target: IObject, toValue = false) {\n return merge({}, target, toValue);\n}\nfunction merge(to: IObject, from: IObject, toValue = false) {\n for (const name in from) {\n const value = from[name];\n const type = getType(value);\n\n if (type === PROPERTY) {\n to[name] = toValue ? value.toValue() : value.clone();\n } else if (type === FUNCTION) {\n to[name] = toValue ? getValue([name], value) : value;\n } else if (type === ARRAY) {\n to[name] = value.slice();\n } else if (type === OBJECT) {\n if (isObject(to[name]) && !isPropertyObject(to[name])) {\n merge(to[name], value, toValue);\n } else {\n to[name] = clone(value, toValue);\n }\n } else {\n to[name] = from[name];\n }\n }\n return to;\n}\n/* eslint-enable */\n\nfunction getPropertyName(args: NameType[]) {\n return args[0] in ALIAS ? ALIAS[args[0]] : args;\n}\nfunction getValue(names: NameType[], value: any): any {\n const type = getType(value);\n\n if (type === PROPERTY) {\n return value.toValue();\n } else if (type === FUNCTION) {\n if (names[0] !== TIMING_FUNCTION) {\n return getValue(names, value());\n }\n } else if (type === OBJECT) {\n return clone(value, true);\n }\n return value;\n}\n/**\n* Animation's Frame\n*/\nclass Frame {\n public properties: IObject = {};\n public orderMap: OrderMap = new OrderMap(NAME_SEPARATOR);\n /**\n * @param - properties\n * @example\n const frame = new Scene.Frame({\n display: \"none\"\n transform: {\n translate: \"50px\",\n scale: \"5, 5\",\n }\n });\n */\n constructor(properties: any = {}) {\n this.properties = {};\n // this.orders = [];\n this.set(properties);\n }\n /**\n * get property value\n * @param {...Number|String|PropertyObject} args - property name or value\n * @example\n frame.get(\"display\") // => \"none\", \"block\", ....\n frame.get(\"transform\", \"translate\") // => \"10px,10px\"\n */\n public get(...args: NameType[]) {\n const value = this.raw(...args);\n\n return getValue(getPropertyName(args), value);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n frame.getOrders([\"display\"]) // => []\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n return this.orderMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n frame.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n return this.orderMap.set(names, orders);\n }\n /**\n * get properties order object\n * @example\n console.log(frame.getOrderObject());\n */\n public getOrderObject() {\n return this.orderMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n frame.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.orderMap.setObject(obj);\n }\n\n /**\n * get property keys\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [\"translate\"]\n */\n public getKeys(...args: NameType[]): string[] {\n const value = this.raw(...args);\n const keys = getType(value) === OBJECT ? getKeys(value) : [];\n\n sortOrders(keys, this.orderMap.get(args));\n return keys;\n }\n /**\n * get properties array\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [{ key: \"translate\", value: \"10px, 10px\", children: [] }]\n */\n public gets(...args: NameType[]): KeyValueChildren[] {\n const values = this.get(...args);\n const keys = this.getKeys(...args);\n\n return keys.map(key => {\n const nextValue = values[key];\n return { key, value: nextValue, children: this.gets(...args, key) };\n });\n }\n\n public raw(...args: NameType[]) {\n return getValueByNames(getPropertyName(args), this.properties);\n }\n /**\n * remove property value\n * @param {...String} args - property name\n * @return {Frame} An instance itself\n * @example\n frame.remove(\"display\")\n */\n public remove(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return this;\n }\n this.orderMap.remove(params);\n const value = getValueByNames(params, this.properties, length - 1);\n\n if (isObject(value)) {\n delete value[params[length - 1]];\n }\n return this;\n }\n /**\n * set property\n * @param {...Number|String|PropertyObject} args - property names or values\n * @return {Frame} An instance itself\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n filter: {\n brightness: \"50%\",\n grayscale: \"100%\"\n }\n });\n\n // two parameters\n frame.set(\"transform\", {\n translate: \"10px, 10px\",\n scale: \"1\",\n });\n\n // three parameters\n frame.set(\"transform\", \"translate\", \"50px\");\n */\n public set(...args: any[]) {\n const self = this;\n const length = args.length;\n const params = args.slice(0, -1);\n const value = args[length - 1];\n const firstParam = params[0];\n\n if (length === 1 && value instanceof Frame) {\n self.merge(value);\n } else if (firstParam in ALIAS) {\n self._set(ALIAS[firstParam], value);\n } else if (length === 2 && isArray(firstParam)) {\n self._set(firstParam, value);\n } else if (isPropertyObject(value)) {\n if (isRole(params)) {\n self.set(...params, toObject(value));\n } else {\n self._set(params, value);\n }\n } else if (isArray(value)) {\n self._set(params, value);\n } else if (isObject(value)) {\n if (!self.has(...params) && isRole(params)) {\n self._set(params, {});\n }\n for (const name in value) {\n self.set(...params, name, value[name]);\n }\n } else if (isString(value)) {\n if (isRole(params, true)) {\n if (isFixed(params) || !isRole(params)) {\n this._set(params, value);\n } else {\n const obj = toPropertyObject(value);\n\n if (isObject(obj)) {\n self.set(...params, obj);\n }\n }\n return this;\n } else {\n const { styles, length: stylesLength } = splitStyle(value);\n\n for (const name in styles) {\n self.set(...params, name, styles[name]);\n }\n if (stylesLength) {\n return this;\n }\n }\n self._set(params, value);\n } else {\n self._set(params, value);\n }\n return self;\n }\n /**\n * Gets the names of properties.\n * @return the names of properties.\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n });\n\n // [[\"display\"], [\"transform\", \"translate\"], [\"transform\", \"scale\"]]\n console.log(frame.getNames());\n */\n public getNames(): string[][] {\n return getNames(this.properties, []);\n }\n /**\n * check that has property.\n * @param {...String} args - property name\n * @example\n frame.has(\"property\", \"display\") // => true or false\n */\n public has(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return false;\n }\n return !isUndefined(getValueByNames(params, this.properties, length));\n }\n /**\n * clone frame.\n * @return {Frame} An instance of clone\n * @example\n frame.clone();\n */\n public clone() {\n const frame = new Frame();\n\n frame.setOrderObject(this.orderMap.orderMap);\n return frame.merge(this);\n }\n /**\n * merge one frame to other frame.\n * @param - target frame.\n * @return {Frame} An instance itself\n * @example\n frame.merge(frame2);\n */\n public merge(frame: Frame) {\n const properties = this.properties;\n const frameProperties = frame.properties;\n\n if (frameProperties) {\n merge(properties, frameProperties);\n }\n return this;\n }\n /**\n * Specifies an css object that coverted the frame.\n * @return {object} cssObject\n */\n public toCSSObject() {\n const properties = this.get();\n const cssObject: IObject = {};\n\n for (const name in properties) {\n if (isRole([name], true)) {\n continue;\n }\n const value = properties[name];\n\n if (name === TIMING_FUNCTION) {\n cssObject[TIMING_FUNCTION.replace(\"animation\", ANIMATION)] =\n (isString(value) ? value : value[EASING_NAME]) || \"initial\";\n } else {\n cssObject[name] = value;\n }\n }\n const transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME]));\n const filter = toInnerProperties(properties.filter, this.orderMap.get([FILTER]));\n\n TRANSFORM && transform && (cssObject[TRANSFORM] = transform);\n FILTER && filter && (cssObject[FILTER] = filter);\n return cssObject;\n }\n /**\n * Specifies an css text that coverted the frame.\n * @return {string} cssText\n */\n public toCSS() {\n const cssObject = this.toCSSObject();\n const cssArray = [];\n const keys = getKeys(cssObject);\n\n sortOrders(keys, this.orderMap.get([]));\n keys.forEach(name => {\n cssArray.push(`${name}:${cssObject[name]};`);\n });\n return cssArray.join(\"\");\n }\n /**\n * Remove All Properties\n * @return {Frame} An instance itself\n */\n public clear() {\n this.properties = {};\n this.orderMap.clear();\n return this;\n }\n private _set(args: NameType[], value: any) {\n let properties = this.properties;\n const length = args.length;\n\n for (let i = 0; i < length - 1; ++i) {\n const name = args[i];\n\n !(name in properties) && (properties[name] = {});\n properties = properties[name];\n }\n if (!length) {\n return;\n }\n const lastParam = args[length - 1];\n\n this.orderMap.add(args);\n if (length === 1 && lastParam === TIMING_FUNCTION) {\n properties[lastParam] = getEasing(value);\n } else {\n properties[lastParam] = isString(value) && !isFixed(args)\n ? toPropertyObject(value, lastParam)\n : value;\n }\n }\n}\nexport default Frame;\n","\nimport PropertyObject from \"../PropertyObject\";\nimport { getType } from \"../utils\";\nimport { toPropertyObject } from \"./property\";\nimport { splitUnit, PROPERTY, FUNCTION, ARRAY, dot as dotNumber } from \"@daybrush/utils\";\nimport { EasingType } from \"../types\";\n\nfunction dotArray(a1: any[], a2: any, b1: number, b2: number): any {\n const length = a2.length;\n\n return a1.map((v1, i) => {\n if (i >= length) {\n return v1;\n } else {\n return dot(v1, a2[i], b1, b2);\n }\n });\n}\n\nfunction dotColor(color1: PropertyObject, color2: PropertyObject, b1: number, b2: number) {\n // convert array to PropertyObject(type=color)\n const value1 = color1.value;\n const value2 = color2.value;\n // If the model name is not same, the inner product is impossible.\n const model1 = color1.model;\n const model2 = color2.model;\n\n if (model1 !== model2) {\n // It is recognized as a string.\n return dot(color1.toValue(), color2.toValue(), b1, b2);\n }\n if (value1.length === 3) {\n value1[3] = 1;\n }\n if (value2.length === 3) {\n value2[3] = 1;\n }\n const v = dotArray(value1, value2, b1, b2);\n const colorModel = model1;\n\n for (let i = 0; i < 3; ++i) {\n v[i] = parseInt(v[i], 10);\n }\n const object = new PropertyObject(v, {\n type: \"color\",\n model: colorModel,\n prefix: `${colorModel}(`,\n suffix: \")\",\n });\n\n return object;\n}\n\nfunction dotObject(a1: PropertyObject, a2: PropertyObject, b1: number, b2: number) {\n const a1Type = a1.type;\n\n if (a1Type === \"color\") {\n return dotColor(a1, a2, b1, b2);\n }\n const value1 = a1.value;\n const value2 = a2.value;\n const arr = dotArray(value1, value2, b1, b2);\n\n return new PropertyObject(arr, {\n type: a1Type,\n separator: a1.separator || a2.separator,\n prefix: a1.prefix || a2.prefix,\n suffix: a1.suffix || a2.suffix,\n model: a1.model || a2.model,\n });\n}\n/**\n* The dot product of a1 and a2 for the b1 and b2.\n* @memberof Dot\n* @function dot\n* @param {String|Number|PropertyObject} a1 value1\n* @param {String|Number|PropertyObject} a2 value2\n* @param {Number} b1 b1 ratio\n* @param {Number} b2 b2 ratio\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @example\ndot(1, 3, 0.3, 0.7);\n// => 1.6\n*/\nexport function dot(a1: any, a2: any, b1: number, b2: number): any {\n if (b2 === 0) {\n return a2;\n } else if (b1 === 0 || b1 + b2 === 0) {\n // prevent division by zero.\n return a1;\n }\n // dot Object\n\n const type1 = getType(a1);\n const type2 = getType(a2);\n const isFunction1 = type1 === FUNCTION;\n const isFunction2 = type2 === FUNCTION;\n\n if (isFunction1 || isFunction2) {\n return () => {\n return dot(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2);\n };\n } else if (type1 === type2) {\n if (type1 === PROPERTY) {\n return dotObject(a1, a2, b1, b2);\n } else if (type1 === ARRAY) {\n return dotArray(a1, a2, b1, b2);\n } else if (type1 !== \"value\") {\n return a1;\n }\n } else {\n return a1;\n }\n const v1 = splitUnit(`${a1}`);\n const v2 = splitUnit(`${a2}`);\n let v;\n\n // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환\n if (isNaN(v1.value) || isNaN(v2.value)) {\n return a1;\n } else {\n v = dotNumber(v1.value, v2.value, b1, b2);\n }\n const prefix = v1.prefix || v2.prefix;\n const unit = v1.unit || v2.unit;\n\n if (!prefix && !unit) {\n return v;\n }\n return prefix + v + unit;\n}\n\nexport function dotValue(\n time: number,\n prevTime: number,\n nextTime: number,\n prevValue: any,\n nextValue: any,\n easing?: EasingType) {\n if (time === prevTime) {\n return prevValue;\n } else if (time === nextTime) {\n return nextValue;\n } else if (!easing) {\n return dot(prevValue, nextValue, time - prevTime, nextTime - time);\n }\n const ratio = easing((time - prevTime) / (nextTime - prevTime));\n const value = dot(prevValue, nextValue, ratio, 1 - ratio);\n\n return value;\n}\n","import Animator, { isDirectionReverse } from \"./Animator\";\nimport Frame from \"./Frame\";\nimport {\n toFixed,\n isFixed,\n playCSS,\n toId,\n getRealId,\n makeId,\n isPausedCSS,\n isRole,\n getValueByNames,\n isEndedCSS,\n setPlayCSS,\n getNames,\n updateFrame,\n} from \"./utils\";\nimport { dotValue } from \"./utils/dot\";\nimport {\n START_ANIMATION,\n PREFIX, THRESHOLD,\n TIMING_FUNCTION, ALTERNATE, ALTERNATE_REVERSE, INFINITE,\n REVERSE, EASING, FILL_MODE, DIRECTION, ITERATION_COUNT,\n EASING_NAME, DELAY, PLAY_SPEED, DURATION, PAUSE_ANIMATION,\n DATA_SCENE_ID, SELECTOR, ROLES, NAME_SEPARATOR\n} from \"./consts\";\nimport {\n isObject, isArray, isUndefined, decamelize,\n ANIMATION, fromCSS, addClass, removeClass, hasClass,\n KEYFRAMES, isFunction,\n IObject, $, splitComma, toArray, isString, IArrayFormat,\n dot as dotNumber,\n find,\n findIndex,\n getKeys,\n sortOrders,\n} from \"@daybrush/utils\";\nimport {\n NameType, AnimateElement, AnimatorState,\n SceneItemState, SceneItemOptions, EasingType, PlayCondition, DirectionType\n} from \"./types\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n\nfunction getNearTimeIndex(times: number[], time: number) {\n const length = times.length;\n\n for (let i = 0; i < length; ++i) {\n if (times[i] === time) {\n return [i, i];\n } else if (times[i] > time) {\n return [i > 0 ? i - 1 : 0, i];\n }\n }\n return [length - 1, length - 1];\n}\nfunction makeAnimationProperties(properties: object) {\n const cssArray = [];\n\n for (const name in properties) {\n cssArray.push(`${ANIMATION}-${decamelize(name)}:${properties[name]};`);\n }\n return cssArray.join(\"\");\n}\nfunction addTime(times: number[], time: number) {\n const length = times.length;\n for (let i = 0; i < length; ++i) {\n if (time < times[i]) {\n times.splice(i, 0, time);\n return;\n }\n }\n times[length] = time;\n}\nfunction addEntry(entries: number[][], time: number, keytime: number) {\n const prevEntry = entries[entries.length - 1];\n\n (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) &&\n entries.push([toFixed(time), toFixed(keytime)]);\n}\nexport function getEntries(times: number[], states: AnimatorState[]) {\n let entries = times.map(time => ([time, time]));\n let nextEntries = [];\n\n states.forEach(state => {\n const iterationCount = state[ITERATION_COUNT] as number;\n const delay = state[DELAY];\n const playSpeed = state[PLAY_SPEED];\n const direction = state[DIRECTION];\n const intCount = Math.ceil(iterationCount);\n const currentDuration = entries[entries.length - 1][0];\n const length = entries.length;\n const lastTime = currentDuration * iterationCount;\n\n for (let i = 0; i < intCount; ++i) {\n const isReverse =\n direction === REVERSE ||\n direction === ALTERNATE && i % 2 ||\n direction === ALTERNATE_REVERSE && !(i % 2);\n\n for (let j = 0; j < length; ++j) {\n const entry = entries[isReverse ? length - j - 1 : j];\n const time = entry[1];\n const currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]);\n const prevEntry = entries[isReverse ? length - j : j - 1];\n\n if (currentTime > lastTime) {\n if (j !== 0) {\n const prevTime = currentDuration * i +\n (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]);\n const divideTime = dotNumber(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime);\n\n addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime);\n }\n break;\n } else if (\n currentTime === lastTime\n && nextEntries.length\n && nextEntries[nextEntries.length - 1][0] === lastTime + delay\n ) {\n break;\n }\n addEntry(nextEntries, (delay + currentTime) / playSpeed, time);\n }\n }\n // delay time\n delay && nextEntries.unshift([0, nextEntries[0][1]]);\n\n entries = nextEntries;\n nextEntries = [];\n });\n\n return entries;\n}\n/**\n* manage Frame Keyframes and play keyframes.\n* @extends Animator\n* @example\nconst item = new SceneItem({\n\t0: {\n\t\tdisplay: \"none\",\n\t},\n\t1: {\n\t\tdisplay: \"block\",\n\t\topacity: 0,\n\t},\n\t2: {\n\t\topacity: 1,\n\t}\n});\n*/\nclass SceneItem extends Animator {\n public times: number[] = [];\n public items: IObject = {};\n public nameMap = new OrderMap(NAME_SEPARATOR);\n public elements: AnimateElement[] = [];\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: Frame;\n private needUpdate: boolean = true;\n private target: any;\n private targetFunc: (frame: Frame) => void;\n\n /**\n * @param - properties\n * @param - options\n * @example\n const item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n */\n constructor(properties?: any, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n const times = this.times;\n const length = times.length;\n\n return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION];\n }\n /**\n * get size of list\n * @return {Number} length of list\n */\n public size() {\n return this.times.length;\n }\n public setDuration(duration: number) {\n if (!duration) {\n return this;\n }\n const originalDuration = this.getDuration();\n\n if (originalDuration > 0) {\n const ratio = duration / originalDuration;\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(time => {\n const time2 = toFixed(time * ratio);\n\n obj[time2] = items[time];\n\n return time2;\n });\n this.items = obj;\n } else {\n this.newFrame(duration);\n }\n return this;\n }\n public setId(id?: number | string) {\n const state = this.state;\n const elements = this.elements;\n const length = elements.length;\n\n state.id = id || makeId(!!length);\n\n if (length && !state[SELECTOR]) {\n const sceneId = toId(this.getId());\n\n state[SELECTOR] = `[${DATA_SCENE_ID}=\"${sceneId}\"]`;\n elements.forEach(element => {\n element.setAttribute(DATA_SCENE_ID, sceneId);\n });\n }\n return this;\n }\n\n /**\n * Set properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.set(0, \"a\", \"b\") // item.getFrame(0).set(\"a\", \"b\")\n console.log(item.get(0, \"a\")); // \"b\"\n */\n public set(time: any, ...args: any[]) {\n if (time instanceof SceneItem) {\n return this.set(0, time);\n } else if (isArray(time)) {\n const length = time.length;\n\n for (let i = 0; i < length; ++i) {\n const t = length === 1 ? 0 : this.getUnitTime(`${i / (length - 1) * 100}%`);\n\n this.set(t, time[i]);\n }\n } else if (isObject(time)) {\n for (const t in time) {\n const value = time[t];\n\n splitComma(t).forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (isNaN(realTime)) {\n getNames(value, [eachTime]).forEach(names => {\n const innerValue = getValueByNames(names.slice(1), value);\n const arr = isArray(innerValue) ?\n innerValue : [getValueByNames(names, this.target), innerValue];\n const length = arr.length;\n\n for (let i = 0; i < length; ++i) {\n this.newFrame(`${i / (length - 1) * 100}%`).set(...names, arr[i]);\n }\n });\n } else {\n this.set(realTime, value);\n }\n });\n }\n } else if (!isUndefined(time)) {\n const value = args[0];\n\n splitComma(time + \"\").forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (value instanceof SceneItem) {\n const delay = value.getDelay();\n const frames = value.toObject(!this.hasFrame(realTime + delay));\n const duration = value.getDuration();\n const direction = value.getDirection();\n const isReverse = direction.indexOf(\"reverse\") > -1;\n\n for (const frameTime in frames) {\n const nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime);\n this.set(realTime + nextTime, frames[frameTime]);\n }\n } else if (args.length === 1 && isArray(value)) {\n value.forEach((item: any) => {\n this.set(realTime, item);\n });\n } else {\n const frame = this.newFrame(realTime);\n\n frame.set(...args);\n }\n });\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Get properties of the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} args property's name or properties\n * @return {Number|String|PropertyObejct} property value\n * @example\n item.get(0, \"a\"); // item.getFrame(0).get(\"a\");\n item.get(0, \"transform\", \"translate\"); // item.getFrame(0).get(\"transform\", \"translate\");\n */\n public get(time: string | number, ...args: NameType[]) {\n const frame = this.getFrame(time);\n\n return frame && frame.get(...args);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n item.getOrders([\"display\"]) // => []\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n this.needUpdate && this.update();\n\n return this.nameMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n item.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n this.needUpdate && this.update();\n\n const result = this.nameMap.set(names, orders);\n\n this.updateFrameOrders();\n\n return result;\n }\n /**\n * get properties order object\n * @example\n console.log(item.getOrderObject());\n */\n public getOrderObject() {\n return this.nameMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n item.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.nameMap.setObject(obj);\n\n this.updateFrameOrders();\n }\n public remove(time: string | number, ...args: any[]): this;\n /**\n * remove properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.remove(0, \"a\");\n */\n public remove(time: string | number, ...args: NameType[]) {\n if (args.length) {\n const frame = this.getFrame(time);\n\n frame && frame.remove(...args);\n } else {\n this.removeFrame(time);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Append the item or object at the last time.\n * @param - the scene item or item object\n * @return An instance itself\n * @example\n item.append(new SceneItem({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }));\n item.append({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n item.set(item.getDuration(), {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n */\n public append(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n this.set(this.getDuration(), item);\n } else {\n this.append(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push the front frames for the time and prepend the scene item or item object.\n * @param - the scene item or item object\n * @return An instance itself\n */\n public prepend(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n const unshiftTime = item.getDuration() + item.getDelay();\n const firstFrame = this.getFrame(0);\n // remove first frame\n this.removeFrame(0);\n this.unshift(unshiftTime);\n this.set(0, item);\n this.set(unshiftTime + THRESHOLD, firstFrame);\n } else {\n this.prepend(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push out the amount of time.\n * @param - time to push\n * @example\n item.get(0); // frame 0\n item.unshift(3);\n item.get(3) // frame 0\n */\n public unshift(time: number) {\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(t => {\n const time2 = toFixed(time + t);\n\n obj[time2] = items[t];\n return time2;\n });\n this.items = obj;\n return this;\n }\n /**\n * Get the frames in the item in object form.\n * @return {}\n * @example\n item.toObject();\n // {0: {display: \"none\"}, 1: {display: \"block\"}}\n */\n public toObject(isStartZero = true): IObject {\n const obj: IObject = {};\n const delay = this.getDelay();\n\n this.forEach((frame: Frame, time: number) => {\n obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone();\n });\n return obj;\n }\n /**\n * Specifies an element to synchronize items' keyframes.\n * @param {string} selectors - Selectors to find elements in items.\n * @return {SceneItem} An instance itself\n * @example\nitem.setSelector(\"#id.class\");\n */\n public setSelector(target: string | boolean | ((id: number | string) => string)) {\n if (isFunction(target)) {\n this.setElement(target(this.getId()));\n } else {\n this.setElement(target);\n }\n return this;\n }\n /**\n * Get the elements connected to SceneItem.\n */\n public getElements(): AnimateElement[] {\n return this.elements;\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElements(target: boolean | string | AnimateElement | IArrayFormat): this {\n return this.setElement(target);\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElement(target: boolean | string | AnimateElement | IArrayFormat) {\n const state = this.state;\n let elements: AnimateElement[] = [];\n\n if (!target) {\n return this;\n } else if (target === true || isString(target)) {\n const selector = target === true ? `${state.id}` : target;\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(selector);\n\n elements = toArray($(matches ? matches[1] : selector, true));\n state[SELECTOR] = selector;\n } else {\n elements = (target instanceof Element) ? [target] : toArray(target);\n }\n if (!elements.length) {\n return this;\n }\n this.elements = elements;\n this.setId(this.getId());\n this.target = elements[0].style;\n this.targetFunc = (frame: Frame) => {\n const attributes = frame.get(\"attribute\");\n\n if (attributes) {\n for (const name in attributes) {\n elements.forEach(el => {\n el.setAttribute(name, attributes[name]);\n });\n }\n }\n if (frame.has(\"html\")) {\n const html = frame.get(\"html\");\n\n elements.forEach(el => {\n el.innerHTML = html;\n });\n }\n const cssText = frame.toCSS();\n\n if (state.cssText !== cssText) {\n state.cssText = cssText;\n\n elements.forEach(el => {\n el.style.cssText += cssText;\n });\n return frame;\n }\n };\n return this;\n }\n public setTarget(target: any): this {\n this.target = target;\n this.targetFunc = (frame: Frame) => {\n const obj = frame.get();\n\n for (const name in obj) {\n target[name] = obj[name];\n }\n };\n return this;\n }\n /**\n * add css styles of items's element to the frame at that time.\n * @param {Array} properties - elements to synchronize item's keyframes.\n * @return {SceneItem} An instance itself\n * @example\n item.setElement(document.querySelector(\"#id.class\"));\n item.setCSS(0, [\"opacity\"]);\n item.setCSS(0, [\"opacity\", \"width\", \"height\"]);\n */\n public setCSS(time: number, properties: string[]) {\n this.set(time, fromCSS(this.elements, properties));\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frame = this.getNowFrame(iterationTime, easing);\n const currentTime = this.getTime();\n\n this.temp = frame;\n /**\n * This event is fired when timeupdate and animate.\n * @event SceneItem#animate\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Frame} param.frame frame of that time.\n */\n this.trigger(\"animate\", {\n frame,\n currentTime,\n time: iterationTime,\n });\n this.targetFunc && this.targetFunc(frame);\n return this;\n }\n /**\n * update property names used in frames.\n * @return {SceneItem} An instance itself\n * @example\n item.update();\n */\n public update() {\n const prevNameMap = this.nameMap;\n const names = {};\n this.forEach(frame => {\n updateFrame(names, frame.properties);\n });\n\n const nameMap = new OrderMap(NAME_SEPARATOR);\n\n function pushKeys(map: IObject, stack: NameType[]) {\n const keys = getKeys(map);\n\n sortOrders(keys, prevNameMap.get(stack));\n\n nameMap.set(stack, keys);\n keys.forEach(key => {\n const nextMap = map[key];\n if (isObject(nextMap)) {\n pushKeys(nextMap, [...stack, key]);\n }\n });\n }\n pushKeys(names, []);\n\n this.nameMap = nameMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap.orderMap);\n });\n this.needUpdate = false;\n return this;\n }\n /**\n * Create and add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {Frame} Created frame.\n * @example\n item.newFrame(time);\n */\n public newFrame(time: string | number) {\n let frame = this.getFrame(time);\n\n if (frame) {\n return frame;\n }\n frame = new Frame();\n\n this.setFrame(time, frame);\n return frame;\n }\n /**\n * Add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.setFrame(time, frame);\n */\n public setFrame(time: string | number, frame: Frame) {\n const realTime = this.getUnitTime(time);\n\n this.items[realTime] = frame;\n addTime(this.times, realTime);\n this.needUpdate = true;\n return this;\n }\n public getFrame(time: number | string, ...names: any[]): Frame;\n /**\n * get sceneItem's frame at that time\n * @param {Number} time - frame's time\n * @return {Frame} sceneItem's frame at that time\n * @example\n const frame = item.getFrame(time);\n */\n public getFrame(time: number | string) {\n return this.items[this.getUnitTime(time)];\n }\n public removeFrame(time: number | string, ...names: any[]): this;\n /**\n * remove sceneItem's frame at that time\n * @param - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.removeFrame(time);\n */\n public removeFrame(time: number | string) {\n const realTime = this.getUnitTime(time);\n const items = this.items;\n const index = this.times.indexOf(realTime);\n\n delete items[realTime];\n\n // remove time\n if (index > -1) {\n this.times.splice(index, 1);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * check if the item has a frame at that time\n * @param {Number} time - frame's time\n * @return {Boolean} true: the item has a frame // false: not\n * @example\n if (item.hasFrame(10)) {\n // has\n } else {\n // not\n }\n */\n public hasFrame(time: number | string) {\n return this.getUnitTime(time) in this.items;\n }\n /**\n * Check if keyframes has propery's name\n * @param - property's time\n * @return {boolean} true: if has property, false: not\n * @example\n item.hasName([\"transform\", \"translate\"]); // true or not\n */\n public hasName(args: string[]) {\n this.needUpdate && this.update();\n return !!this.nameMap.get(args);\n }\n /**\n * merge frame of the previous time at the next time.\n * @param - The time of the frame to merge\n * @param - The target frame\n * @return {SceneItem} An instance itself\n * @example\n // getFrame(1) contains getFrame(0)\n item.merge(0, 1);\n */\n public mergeFrame(time: number | string, frame: Frame) {\n if (frame) {\n const toFrame = this.newFrame(time);\n\n toFrame.merge(frame);\n }\n return this;\n }\n /**\n * Get frame of the current time\n * @param {Number} time - the current time\n * @param {function} easing - the speed curve of an animation\n * @return {Frame} frame of the current time\n * @example\n let item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n // opacity: 0.7; display:\"block\";\n const frame = item.getNowFrame(1.7);\n */\n public getNowFrame(time: number, easing?: EasingType, isAccurate?: boolean) {\n this.needUpdate && this.update();\n const frame = new Frame();\n const [left, right] = getNearTimeIndex(this.times, time);\n let realEasing = this.getEasing() || easing;\n let nameMap = this.nameMap;\n\n if (this.hasName([TIMING_FUNCTION])) {\n const nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true);\n\n isFunction(nowEasing) && (realEasing = nowEasing);\n }\n if (isAccurate) {\n const prevFrame = this.getFrame(time);\n const prevOrderMap = prevFrame.orderMap.filter([], orders => {\n return prevFrame.has(...orders);\n });\n\n for (const name in ROLES) {\n const orders = nameMap.get([name]);\n if (prevOrderMap.get([name]) && orders) {\n prevOrderMap.set([name], orders);\n }\n }\n nameMap = prevOrderMap;\n }\n const names = nameMap.gets([]);\n\n frame.setOrderObject(nameMap.orderMap);\n names.forEach(properties => {\n const value = this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties));\n\n if (isUndefined(value)) {\n return;\n }\n frame.set(properties, value);\n });\n return frame;\n }\n public load(properties: any = {}, options = properties.options) {\n options && this.setOptions(options);\n\n if (isArray(properties)) {\n this.set(properties);\n } else if (properties.keyframes) {\n this.set(properties.keyframes);\n } else {\n for (const time in properties) {\n if (time !== \"options\") {\n this.set({\n [time]: properties[time],\n });\n }\n }\n }\n if (options && options[DURATION]) {\n this.setDuration(options[DURATION]);\n }\n return this;\n }\n /**\n * clone SceneItem.\n * @return {SceneItem} An instance of clone\n * @example\n * item.clone();\n */\n public clone() {\n const item = new SceneItem();\n\n item.setOptions(this.state);\n item.setOrderObject(this.nameMap.orderMap);\n\n this.forEach((frame: Frame, time: number) => {\n item.setFrame(time, frame.clone());\n });\n return item;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Keyframes} An instance itself\n */\n public forEach(callback: (item: Frame, time: number, items: IObject) => void) {\n const times = this.times;\n const items = this.items;\n\n times.forEach(time => {\n callback(items[time], time, items);\n });\n return this;\n }\n public setOptions(options: Partial = {}) {\n super.setOptions(options);\n const { id, selector, elements, element, target } = options;\n\n id && this.setId(id);\n if (target) {\n this.setTarget(target);\n } else if (selector) {\n this.setSelector(selector);\n } else if (elements || element) {\n this.setElement(elements || element);\n }\n return this;\n }\n public toCSS(\n playCondition: PlayCondition = { className: START_ANIMATION },\n parentDuration = this.getDuration(), states: AnimatorState[] = []) {\n const itemState = this.state;\n const selector = itemState[SELECTOR];\n\n if (!selector) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n itemState[DURATION] = originalDuration;\n states.push(itemState);\n\n const reversedStates = toArray(states).reverse();\n const id = toId(getRealId(this));\n const superParent = states[0];\n const infiniteIndex = findIndex(reversedStates, state => {\n return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]);\n }, states.length - 1);\n const finiteStates = reversedStates.slice(0, infiniteIndex);\n const duration = parentDuration || finiteStates.reduce((prev, cur) => {\n return (cur[DELAY] + prev * (cur[ITERATION_COUNT] as number)) / cur[PLAY_SPEED];\n }, originalDuration);\n const delay = reversedStates.slice(infiniteIndex).reduce((prev, cur) => {\n return (prev + cur[DELAY]) / cur[PLAY_SPEED];\n }, 0);\n const easingName = find(reversedStates, state => (state[EASING] && state[EASING_NAME]), itemState)[EASING_NAME];\n const iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT];\n const fillMode = superParent[FILL_MODE];\n const direction = reversedStates[infiniteIndex][DIRECTION];\n const cssText = makeAnimationProperties({\n fillMode,\n direction,\n iterationCount,\n delay: `${delay}s`,\n name: `${PREFIX}KEYFRAMES_${id}`,\n duration: `${duration / superParent[PLAY_SPEED]}s`,\n timingFunction: easingName,\n });\n const selectors = splitComma(selector).map(sel => {\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(sel);\n\n if (matches) {\n return [matches[1], matches[2]];\n } else {\n return [sel, \"\"];\n }\n });\n const className = playCondition.className;\n const selectorCallback = playCondition.selector;\n const preselector = isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback;\n\n return `\n ${preselector || selectors.map(([sel, peusdo]) => `${sel}.${className}${peusdo}`)} {${cssText}}\n ${selectors.map(([sel, peusdo]) => `${sel}.${PAUSE_ANIMATION}${peusdo}`)} {${ANIMATION}-play-state: paused;}\n @${KEYFRAMES} ${PREFIX}KEYFRAMES_${id}{${this._toKeyframes(duration, finiteStates, direction)}}`;\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {SceneItem} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition,\n duration?: number, options?: AnimatorState[]) {\n if (!this.elements.length) {\n return \"\";\n }\n const css = this.toCSS(playCondition, duration, options);\n const isParent = options && !isUndefined(options[ITERATION_COUNT]);\n\n if (!isParent) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n }\n return this;\n }\n public pause() {\n super.pause();\n isPausedCSS(this) && this.pauseCSS();\n return this;\n }\n public pauseCSS() {\n this.elements.forEach(element => {\n addClass(element, PAUSE_ANIMATION);\n });\n return this;\n }\n public endCSS() {\n this.elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n removeClass(element, START_ANIMATION);\n });\n setPlayCSS(this, false);\n return this;\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n item.playCSS();\n item.playCSS(false, \"startAnimation\", {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: object = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public getAnimationElement(): AnimateElement {\n return this.elements[0];\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n const elements = this.elements;\n const length = elements.length;\n const cssText = makeAnimationProperties(properties);\n\n if (!length) {\n return;\n }\n if (isPaused) {\n elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n });\n } else {\n elements.forEach(element => {\n element.style.cssText += cssText;\n\n if (hasClass(element, START_ANIMATION)) {\n removeClass(element, START_ANIMATION);\n }\n });\n elements.forEach(element => {\n element.clientWidth;\n });\n elements.forEach(element => {\n addClass(element, START_ANIMATION);\n });\n }\n return elements[0];\n }\n /**\n * Clear All Frames\n * @return {SceneItem} An instance itself\n */\n public clear() {\n this.times = [];\n this.items = {};\n this.nameMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n this.temp = null;\n this.needUpdate = true;\n return this;\n }\n public getNowValue(\n time: number,\n properties: NameType[],\n left?: number,\n right?: number,\n isAccurate?: boolean,\n easing?: EasingType,\n usePrevValue?: boolean,\n ) {\n const times = this.times;\n const length = times.length;\n\n let prevTime: number;\n let nextTime: number;\n let prevFrame: Frame;\n let nextFrame: Frame;\n const isUndefinedLeft = isUndefined(left);\n const isUndefinedRight = isUndefined(right);\n if (isUndefinedLeft || isUndefinedRight) {\n const indicies = getNearTimeIndex(times, time);\n isUndefinedLeft && (left = indicies[0]);\n isUndefinedRight && (right = indicies[1]);\n }\n\n for (let i = left; i >= 0; --i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n prevTime = times[i];\n prevFrame = frame;\n break;\n }\n }\n const prevValue = prevFrame && prevFrame.raw(...properties);\n\n if (isAccurate && !isRole([properties[0]])) {\n return prevTime === time ? prevValue : undefined;\n }\n if (usePrevValue) {\n return prevValue;\n }\n for (let i = right; i < length; ++i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n nextTime = times[i];\n nextFrame = frame;\n break;\n }\n }\n const nextValue = nextFrame && nextFrame.raw(...properties);\n\n if (!prevFrame || isUndefined(prevValue)) {\n return nextValue;\n }\n if (!nextFrame || isUndefined(nextValue) || prevValue === nextValue) {\n return prevValue;\n }\n return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing);\n }\n private _toKeyframes(duration: number, states: AnimatorState[], direction: DirectionType) {\n const frames: IObject = {};\n const times = this.times.slice();\n\n if (!times.length) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n (!this.getFrame(0)) && times.unshift(0);\n (!this.getFrame(originalDuration)) && times.push(originalDuration);\n const entries = getEntries(times, states);\n const lastEntry = entries[entries.length - 1];\n\n // end delay time\n lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]);\n let prevTime = -1;\n\n return entries.map(([time, keytime]) => {\n if (!frames[keytime]) {\n frames[keytime] =\n (!this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ?\n this.getNowFrame(keytime) : this.getNowFrame(keytime, 0, true)).toCSS();\n }\n\n let frameTime = time / duration * 100;\n\n if (frameTime - prevTime < THRESHOLD) {\n frameTime += THRESHOLD;\n }\n prevTime = frameTime;\n return `${Math.min(frameTime, 100)}%{\n ${time === 0 && !isDirectionReverse(0, 1, direction) ? \"\" : frames[keytime]}\n }`;\n }).join(\"\");\n }\n private updateFrameOrders() {\n const nameMap = this.nameMap.orderMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap);\n });\n }\n}\n\nexport default SceneItem;\n","import Animator from \"./Animator\";\nimport SceneItem from \"./SceneItem\";\nimport { SELECTOR, DURATION, DELAY, RUNNING, NAME_SEPARATOR } from \"./consts\";\nimport { playCSS, getRealId, isPausedCSS, isEndedCSS, setPlayCSS } from \"./utils\";\nimport { isFunction, IS_WINDOW, IObject, $, IArrayFormat } from \"@daybrush/utils\";\nimport {\n AnimateElement, SceneState, SceneOptions, EasingType,\n AnimatorState, SceneItemOptions, PlayCondition, NameType\n} from \"./types\";\nimport Frame from \"./Frame\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n/**\n * manage sceneItems and play Scene.\n * @sort 1\n */\nclass Scene extends Animator {\n /**\n * version info\n * @type {string}\n * @example\n * Scene.VERSION // #__VERSION__#\n */\n public static VERSION: string = \"#__VERSION__#\";\n public items: IObject = {};\n public orderMap = new OrderMap(NAME_SEPARATOR);\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: IObject;\n /**\n * @param - properties\n * @param - options\n * @example\n const scene = new Scene({\n item1: {\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n },\n },\n item2: {\n 2: {\n opacity: 1,\n },\n }\n });\n */\n constructor(properties?: { options?: Partial } & IObject, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n let time = 0;\n\n this.forEach(item => {\n time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed());\n });\n return time || this.state[DURATION];\n }\n public setDuration(duration: number) {\n const items = this.items;\n const sceneDuration = this.getDuration();\n\n if (duration === 0 || !isFinite(sceneDuration)) {\n return this;\n }\n if (sceneDuration === 0) {\n this.forEach(item => {\n item.setDuration(duration);\n });\n } else {\n const ratio = duration / sceneDuration;\n\n this.forEach(item => {\n item.setDelay(item.getDelay() * ratio);\n item.setDuration(item.getDuration() * ratio);\n });\n }\n super.setDuration(duration);\n return this;\n }\n public getItem(name: number | string): T;\n /**\n * get item in scene by name\n * @param - The item's name\n * @return {Scene | SceneItem} item\n * @example\n const item = scene.getItem(\"item1\")\n */\n public getItem(name: number | string) {\n return this.items[name];\n }\n /**\n * create item in scene\n * @param {} name - name of item to create\n * @param {} options - The option object of SceneItem\n * @return {} Newly created item\n * @example\n const item = scene.newItem(\"item1\")\n */\n public newItem(name: number | string, options: Partial = {}): Scene | SceneItem {\n if (this.items[name]) {\n return this.items[name];\n }\n const item = new SceneItem();\n\n this.setItem(name, item);\n item.setOptions(options);\n\n return item;\n }\n /**\n * remove item in scene\n * @param - name of item to remove\n * @return An instance itself\n * @example\n const item = scene.newItem(\"item1\")\n\n scene.removeItem(\"item1\");\n */\n public removeItem(name: number | string): this {\n delete this.items[name];\n\n this.orderMap.remove([name]);\n return this;\n }\n /**\n * add a sceneItem to the scene\n * @param - name of item to create\n * @param - sceneItem\n * @example\n const item = scene.newItem(\"item1\")\n */\n public setItem(name: number | string, item: Scene | SceneItem) {\n item.setId(name);\n this.items[name] = item;\n\n this.orderMap.add([name]);\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frames: IObject = {};\n\n this.forEach(item => {\n item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing);\n\n frames[item.getId()] = item.temp;\n });\n this.temp = frames;\n\n /**\n * This event is fired when timeupdate and animate.\n * @event Scene#animate\n * @param {object} param The object of data to be sent to an event.\n * @param {number} param.currentTime The total time that the animator is running.\n * @param {number} param.time The iteration time during duration that the animator is running.\n * @param {object} param.frames frames of that time.\n * @example\nconst scene = new Scene({\n a: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n },\n b: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }\n}).on(\"animate\", e => {\n console.log(e.frames);\n // {a: Frame, b: Frame}\n console.log(e.frames.a.get(\"opacity\"));\n});\n */\n this.trigger(\"animate\", {\n frames,\n currentTime: this.getTime(),\n time: iterationTime,\n });\n\n return this;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Scene} An instance itself\n */\n public forEach(\n func: (\n item: Scene | SceneItem,\n id: string | number,\n index: number,\n items: IObject,\n ) => void,\n ) {\n const items = this.items;\n this.getOrders().forEach((id, index) => {\n func(items[id], id, index, items);\n });\n return this;\n }\n public toCSS(\n playCondition?: PlayCondition,\n duration: number = this.getDuration(), parentStates: AnimatorState[] = []) {\n const totalDuration = !duration || !isFinite(duration) ? 0 : duration;\n const styles: string[] = [];\n const state = this.state;\n\n state[DURATION] = this.getDuration();\n\n this.forEach(item => {\n styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state)));\n });\n return styles.join(\"\");\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {Scene} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition, duration?: number, parentStates?: AnimatorState[]) {\n const css = this.toCSS(playCondition, duration, parentStates);\n\n if (!parentStates || !parentStates.length) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n // && exportCSS(getRealId(this), css);\n }\n return this;\n }\n public append(item: SceneItem | Scene) {\n item.setDelay(item.getDelay() + this.getDuration());\n this.setItem(getRealId(item), item);\n }\n public pauseCSS() {\n return this.forEach(item => {\n item.pauseCSS();\n });\n }\n public pause() {\n super.pause();\n\n isPausedCSS(this) && this.pauseCSS();\n this.forEach(item => {\n item.pause();\n });\n return this;\n }\n public endCSS() {\n this.forEach(item => {\n item.endCSS();\n });\n setPlayCSS(this, false);\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * get item orders\n * @example\n scene.getOrders() // => [\"item1\", \"item2\"]\n */\n public getOrders(): NameType[] {\n return this.orderMap.get([]) || [];\n }\n /**\n * set item orders\n * @param - orders\n * @example\n frame.setOrders([\"item2\", \"item1\"]) // => [\"item2\", \"item1\"]\n */\n public setOrders(orders: NameType[]): NameType[] {\n return this.orderMap.set([], orders);\n }\n public getAnimationElement() {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.getAnimationElement();\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.addPlayClass(isPaused, playClassName, properties);\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @return {Scene} An instance itself\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n scene.playCSS();\n scene.playCSS(false, {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: Partial = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public set(properties: any, ...args: any[]): this;\n /**\n * Set properties to the Scene.\n * @param - properties\n * @return An instance itself\n * @example\nscene.set({\n \".a\": {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n },\n },\n});\n// 0\nconsole.log(scene.getItem(\".a\").get(0, \"opacity\"));\n// 1\nconsole.log(scene.getItem(\".a\").get(1, \"opacity\"));\n */\n public set(properties: any) {\n this.load(properties);\n return this;\n }\n /**\n * Clear All Items\n * @return {Scene} An instance itself\n */\n public clear() {\n this.finish();\n this.items = {};\n this.orderMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n }\n public load(properties: any = {}, options = properties.options) {\n if (!properties) {\n return this;\n }\n const selector = options && options[SELECTOR] || this.state[SELECTOR];\n for (const name in properties) {\n if (name === \"options\") {\n continue;\n }\n const object = properties[name];\n let item;\n\n if (object instanceof Scene || object instanceof SceneItem) {\n this.setItem(name, object);\n item = object;\n } else if (isFunction(object) && selector) {\n const elements =\n IS_WINDOW\n ? $(`${isFunction(selector) ? selector(name) : name}`, true) as IArrayFormat\n : ([] as AnimateElement[]);\n const length = elements.length;\n const scene = new Scene();\n\n for (let i = 0; i < length; ++i) {\n (scene.newItem(i) as SceneItem).setId().setElement(elements[i]).load(object(i, elements[i]));\n }\n this.setItem(name, scene);\n continue;\n } else {\n item = this.newItem(name);\n item.load(object);\n }\n selector && item.setSelector(selector);\n }\n this.setOptions(options);\n }\n public setOptions(options: Partial = {}): this {\n super.setOptions(options);\n\n const selector = options.selector;\n\n if (selector) {\n this.state[SELECTOR] = selector;\n }\n return this;\n }\n public setSelector(target?: string | boolean | ((id: number | string) => string)) {\n const state = this.state;\n const selector = target || state[SELECTOR];\n\n state[SELECTOR] = selector;\n const isItFunction = isFunction(target);\n if (selector) {\n this.forEach((item, name) => {\n item.setSelector(isItFunction ? (target as (id: number | string) => string)(name) : selector);\n });\n }\n return this;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const result = super.start(delay);\n\n if (result) {\n this.forEach(item => {\n item.start(0);\n });\n } else {\n this.forEach(item => {\n item.setPlayState(RUNNING);\n });\n }\n return result;\n }\n}\n\nexport default Scene;\n","import { IObject } from \"@daybrush/utils\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport { SceneOptions, SceneItemOptions } from \"./types\";\n\nexport function animate(properties?: IObject, options?: Partial) {\n return new Scene(properties, options).play();\n}\nexport function animateItem(properties?: IObject, options?: Partial) {\n return new SceneItem(properties, options).play();\n}\n","import Scene, * as others from \"./index\";\n\nfor (const name in others) {\n (Scene as any)[name] = (others as any)[name];\n}\n\nexport default Scene;\n"],"names":["cubic","y1","y2","t","t2","solveFromX","x1","x2","x","solveX","dx","Math","abs","bezier","func","max","min","easingName","steps","count","position","time","level","floor","STEP_START","STEP_END","LINEAR","EASE","EASE_IN","EASE_OUT","EASE_IN_OUT","PREFIX","DATA_SCENE_ID","TIMING_FUNCTION","ROLES","transform","filter","attribute","html","ALIAS","easing","FIXED","_a","MAXIMUM","THRESHOLD","DURATION","FILL_MODE","DIRECTION","ITERATION_COUNT","DELAY","EASING","PLAY_SPEED","EASING_NAME","ITERATION_TIME","PAUSED","ENDED","TIMEUPDATE","ANIMATE","PLAY","RUNNING","ITERATION","START_ANIMATION","PAUSE_ANIMATION","ALTERNATE","REVERSE","ALTERNATE_REVERSE","NORMAL","INFINITE","PLAY_STATE","PLAY_CSS","PREV_TIME","TICK_TIME","CURRENT_TIME","SELECTOR","TRANSFORM_NAME","EASINGS","NAME_SEPARATOR","OPTIONS","EVENTS","events","name","callback","once","isObject","n","_on","isArray","forEach","_this","push","callback2","_i","args","off","callbacks","index","indexOf","splice","data","event","target","type","currentTarget","toArray","apply","value","options","setOptions","isString","split","separator","newOptions","length","prefix","suffix","model","arr","map","v","PropertyObject","clone","join","toValue","splitStyle","str","properties","splitText","obj","totalLength","i","matches","trim","toPropertyObject","styles","arrayToColorObject","RGBA","stringToBracketObject","text","splitBracket","afterModel","COLOR_MODELS","stringToRGBA","arrayToPropertyObject","stringToColorObject","result","values","splitComma","splitSpace","exec","charAt","toObject","object","size","get","isPropertyObject","setAlias","alias","setRole","names","isProperty","isFixedProperty","roles","fixed","getType","OBJECT","ARRAY","PROPERTY","STRING","NUMBER","isPureObject","constructor","Object","getNames","stack","concat","pop","slice","updateFrame","toFixed","num","round","getValueByNames","undefined","isInProperties","isCheckTrue","role","isRole","isFixed","setPlayCSS","item","isActivate","state","isPausedCSS","isPaused","isEndedCSS","isEnded","makeId","selector","id","random","IS_WINDOW","checkElement","$","getRealId","getId","setId","toId","match","playCSS","isExportCSS","playClassName","ANIMATION","getPlayState","className","addPlayClass","setTime","exportCSS","el","addAnimationEvent","setPlayState","duration","getDuration","isZeroDuration","isFinite","animationend","finish","animationstart","trigger","addEvent","animationiteration","removeEvent","elapsedTime","currentTime","iterationCount","setIteration","getEasing","curveArray","parseFloat","GetterSetter","getter","setter","parent","prototype","camelize","isDirectionReverse","iteration","iteraiontCount","direction","setters","getters","__extends","_super","delay","fillMode","playSpeed","iterationTime","tickTime","prevTime","playState","setEasing","setDuration","getActiveDuration","Infinity","getTime","toTime","timerId","requestAnimationFrame","tick","start","cancelAnimationFrame","end","pause","isTick","isParent","activeDuration","getUnitTime","calculate","isDelay","getIterationTime","splitUnit","unit","passIterationCount","maxIterationCount","currentIterationTime","setIterationTime","isReverse","isFiniteDuration","isForwards","now","to","Animator","EventTrigger","toInnerProperties","orders","arrObj","keys","getKeys","sortOrders","replace","merge","from","FUNCTION","getValue","getPropertyName","OrderMap","set","raw","orderMap","getObject","setObject","key","nextValue","children","gets","params","remove","self","firstParam","Frame","_set","has","stylesLength","isUndefined","frame","setOrderObject","frameProperties","cssObject","FILTER","TRANSFORM","toCSSObject","cssArray","clear","lastParam","add","dotArray","a1","a2","b1","b2","v1","dot","dotColor","color1","color2","value1","value2","model1","model2","colorModel","parseInt","dotObject","a1Type","type1","type2","isFunction1","isFunction2","v2","isNaN","dotNumber","dotValue","nextTime","prevValue","ratio","getNearTimeIndex","times","makeAnimationProperties","decamelize","addTime","addEntry","entries","keytime","prevEntry","getEntries","states","nextEntries","intCount","ceil","currentDuration","lastTime","j","entry","divideTime","unshift","load","originalDuration","ratio_1","items_1","obj_1","time2","items","newFrame","elements","sceneId_1","element","setAttribute","SceneItem","eachTime","realTime","innerValue","value_1","getDelay","frames","hasFrame","getDirection","frameTime","needUpdate","getFrame","update","nameMap","updateFrameOrders","removeFrame","append","unshiftTime","firstFrame","prepend","isStartZero","isFunction","setElement","Element","style","targetFunc","attributes","html_1","innerHTML","cssText","toCSS","fromCSS","parentEasing","getNowFrame","temp","prevNameMap","pushKeys","nextMap","setFrame","toFrame","isAccurate","left","right","realEasing","hasName","nowEasing","getNowValue","prevFrame_1","prevOrderMap","keyframes","setTarget","setSelector","playCondition","parentDuration","itemState","reversedStates","reverse","superParent","infiniteIndex","findIndex","finiteStates","reduce","prev","cur","find","timingFunction","selectors","sel","selectorCallback","preselector","peusdo","KEYFRAMES","_toKeyframes","css","styledInjector","destroy","styled","inject","getAnimationElement","original","pauseCSS","addClass","removeClass","endCSS","hasClass","clientWidth","usePrevValue","prevFrame","nextFrame","isUndefinedLeft","isUndefinedRight","indicies","lastEntry","getTotalDuration","getPlaySpeed","sceneDuration","setDelay","setItem","getOrders","parentStates","totalDuration","animtionElement","Scene","scene","newItem","isItFunction","animate","play","animateItem","others"],"mappings":"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"} \ No newline at end of file diff --git a/dist/scene.min.js b/dist/scene.min.js new file mode 100644 index 00000000..53c45458 --- /dev/null +++ b/dist/scene.min.js @@ -0,0 +1,10 @@ +/* +Copyright (c) 2016 Daybrush +name: scenejs +license: MIT +author: Daybrush +repository: https://github.com/daybrush/scenejs.git +version: 1.4.0 +*/ +!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self).Scene=e()}(this,function(){"use strict";var r=function(t,e){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])})(t,e)};function i(t,e){function n(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}function p(){for(var t=0,e=0,n=arguments.length;e=t&&(this.trigger(_),!0)},e.play=function(e){var n=this,r=this.state,t=r[T],i=this.getTime();return r[q]=U,this.isEnded()&&(0===i||i>=this.getActiveDuration())&&this.setTime(-t,!0),this.timerId=Pt(function(t){r[Z]=t,n.tick(t,e)}),this.start(),this},e.pause=function(){var t=this.state;return t[q]!==N&&(t[q]=N,this.trigger(N)),Rt(this.timerId),this},e.finish=function(){return this.setTime(0),this.state[B]=0,this.end(),this},e.end=function(){return this.pause(),this.trigger(D),this},e.setTime=function(t,e,n){var r=this.getActiveDuration(),i=this.state,s=i[B],a=i[T],o=e?t:this.getUnitTime(t);if(i[B]=a+o,o<0?o=0:r"===r?i+O:i}return ne(t)},e.isDelay=function(){var t=this.state,e=t[T],n=t[B];return 0>>0};function Ce(s){var a,o="rCS"+function(t){return De(t).toString(36)}(s),u=0;return{className:o,inject:function(t,e){void 0===e&&(e={});var n,r=function(t){if(t.getRootNode){var e=t.getRootNode();if(11===e.nodeType)return e}}(t),i=0===u;return(r||i)&&(n=function(n,t,e,r){var i=document.createElement("style");i.setAttribute("type","text/css"),i.setAttribute("data-styled-id",n),e.nonce&&i.setAttribute("nonce",e.nonce);var s=t;return e.original||(s=t.replace(/([^}{]*){/gm,function(t,e){return Ne(e).map(function(t){return-1e)return[0 1 / 1000) {\n // 예상 t초에 의한 _x값\n solveX = cubic(x1, x2, t);\n dx = solveX - x;\n // 차이가 미세하면 그 값을 t로 지정\n if (Math.abs(dx) < 1 / 1000) {\n return t;\n }\n t -= dx / 2;\n }\n return t;\n}\n/**\n * @namespace easing\n */\n/**\n* Cubic Bezier curve.\n* @memberof easing\n* @func bezier\n* @param {number} [x1] - point1's x\n* @param {number} [y1] - point1's y\n* @param {number} [x2] - point2's x\n* @param {number} [y2] - point2's y\n* @return {function} the curve function\n* @example\nimport {bezier} from \"scenejs\";\nScene.bezier(0, 0, 1, 1) // LINEAR\nScene.bezier(0.25, 0.1, 0.25, 1) // EASE\n*/\nexport function bezier(x1: number, y1: number, x2: number, y2: number) {\n /*\n\t\tx = f(t)\n\t\tcalculate inverse function by x\n\t\tt = f-1(x)\n\t*/\n const func: EasingFunction = (x: number) => {\n const t = solveFromX(x1, x2, Math.max(Math.min(1, x), 0));\n\n return cubic(y1, y2, t);\n };\n\n func.easingName = `cubic-bezier(${x1},${y1},${x2},${y2})`;\n return func;\n}\n/**\n* Specifies a stepping function\n* @see {@link https://www.w3schools.com/cssref/css3_pr_animation-timing-function.asp|CSS3 Timing Function}\n* @memberof easing\n* @func steps\n* @param {number} count - point1's x\n* @param {\"start\" | \"end\"} postion - point1's y\n* @return {function} the curve function\n* @example\nimport {steps} from \"scenejs\";\nScene.steps(1, \"start\") // Scene.STEP_START\nScene.steps(1, \"end\") // Scene.STEP_END\n*/\nexport function steps(count: number, position: \"start\" | \"end\") {\n const func: EasingFunction = (time: number) => {\n const level = 1 / count;\n\n if (time >= 1) {\n return 1;\n }\n return (position === \"start\" ? level : 0) + Math.floor(time / level) * level;\n };\n\n func.easingName = `steps(${count}, ${position})`;\n\n return func;\n}\n\n/**\n* Equivalent to steps(1, start)\n* @memberof easing\n* @name STEP_START\n* @static\n* @type {function}\n* @example\nimport {STEP_START} from \"scenejs\";\nScene.STEP_START // steps(1, start)\n*/\nexport const STEP_START = /*#__PURE__#*/steps(1, \"start\");\n/**\n* Equivalent to steps(1, end)\n* @memberof easing\n* @name STEP_END\n* @static\n* @type {function}\n* @example\nimport {STEP_END} from \"scenejs\";\nScene.STEP_END // steps(1, end)\n*/\nexport const STEP_END = /*#__PURE__#*/steps(1, \"end\");\n/**\n* Linear Speed (0, 0, 1, 1)\n* @memberof easing\n* @name LINEAR\n* @static\n* @type {function}\n* @example\nimport {LINEAR} from \"scenejs\";\nScene.LINEAR\n*/\nexport const LINEAR = /*#__PURE__#*/bezier(0, 0, 1, 1);\n/**\n* Ease Speed (0.25, 0.1, 0.25, 1)\n* @memberof easing\n* @name EASE\n* @static\n* @type {function}\n* @example\nimport {EASE} from \"scenejs\";\nScene.EASE\n*/\nexport const EASE = /*#__PURE__#*/bezier(0.25, 0.1, 0.25, 1);\n/**\n* Ease In Speed (0.42, 0, 1, 1)\n* @memberof easing\n* @name EASE_IN\n* @static\n* @type {function}\n* @example\nimport {EASE_IN} from \"scenejs\";\nScene.EASE_IN\n*/\nexport const EASE_IN = /*#__PURE__#*/bezier(0.42, 0, 1, 1);\n/**\n* Ease Out Speed (0, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_OUT} from \"scenejs\";\nScene.EASE_OUT\n*/\nexport const EASE_OUT = /*#__PURE__#*/bezier(0, 0, 0.58, 1);\n/**\n* Ease In Out Speed (0.42, 0, 0.58, 1)\n* @memberof easing\n* @name EASE_IN_OUT\n* @static\n* @type {function}\n* @example\nimport {EASE_IN_OUT} from \"scenejs\";\nScene.EASE_IN_OUT\n*/\nexport const EASE_IN_OUT = /*#__PURE__#*/bezier(0.42, 0, 0.58, 1);\n","import { IObject } from \"@daybrush/utils\";\nimport { RoleObject, OptionType, EventType, EasingFunction } from \"./types\";\nimport { EASE, EASE_IN, EASE_IN_OUT, LINEAR, EASE_OUT, STEP_START, STEP_END } from \"./easing\";\n\nexport const PREFIX = \"__SCENEJS_\";\nexport const DATA_SCENE_ID = \"data-scene-id\";\nexport const TIMING_FUNCTION = \"animation-timing-function\";\nexport const ROLES: RoleObject = { transform: {}, filter: {}, attribute: {}, html: true };\nexport const ALIAS: IObject = { easing: [TIMING_FUNCTION] };\nexport const FIXED = { [TIMING_FUNCTION]: true, contents: true, html: true };\nexport const MAXIMUM = 1000000;\nexport const THRESHOLD = 0.000001;\n\nexport const DURATION = \"duration\";\nexport const FILL_MODE = \"fillMode\";\nexport const DIRECTION = \"direction\";\nexport const ITERATION_COUNT = \"iterationCount\";\nexport const DELAY = \"delay\";\nexport const EASING = \"easing\";\nexport const PLAY_SPEED = \"playSpeed\";\nexport const EASING_NAME = \"easingName\";\nexport const ITERATION_TIME = \"iterationTime\";\nexport const PAUSED = \"paused\";\nexport const ENDED = \"ended\";\nexport const TIMEUPDATE = \"timeupdate\";\nexport const ANIMATE = \"animate\";\nexport const PLAY = \"play\";\nexport const RUNNING = \"running\";\nexport const ITERATION = \"iteration\";\nexport const START_ANIMATION = \"startAnimation\";\nexport const PAUSE_ANIMATION = \"pauseAnimation\";\nexport const ALTERNATE = \"alternate\";\nexport const REVERSE = \"reverse\";\nexport const ALTERNATE_REVERSE = \"alternate-reverse\";\nexport const NORMAL = \"normal\";\nexport const INFINITE = \"infinite\";\nexport const PLAY_STATE = \"playState\";\nexport const PLAY_CSS = \"playCSS\";\nexport const PREV_TIME = \"prevTime\";\nexport const TICK_TIME = \"tickTime\";\nexport const CURRENT_TIME = \"currentTime\";\nexport const SELECTOR = \"selector\";\nexport const TRANSFORM_NAME = \"transform\";\nexport const EASINGS = {\n \"linear\": LINEAR,\n \"ease\": EASE,\n \"ease-in\": EASE_IN,\n \"ease-out\": EASE_OUT,\n \"ease-in-out\": EASE_IN_OUT,\n \"step-start\": STEP_START,\n \"step-end\": STEP_END,\n};\nexport const NAME_SEPARATOR = \"_///_\";\n/**\n* option name list\n* @name Scene.OPTIONS\n* @memberof Scene\n* @static\n* @type {$ts:OptionType}\n* @example\n* Scene.OPTIONS // [\"duration\", \"fillMode\", \"direction\", \"iterationCount\", \"delay\", \"easing\", \"playSpeed\"]\n*/\nexport const OPTIONS: OptionType = [DURATION, FILL_MODE, DIRECTION, ITERATION_COUNT, DELAY, EASING, PLAY_SPEED];\n\n/**\n* Event name list\n* @name Scene.EVENTS\n* @memberof Scene\n* @static\n* @type {$ts:EventType}\n* @example\n* Scene.EVENTS // [\"paused\", \"ended\", \"timeupdate\", \"animate\", \"play\", \"iteration\"];\n*/\nexport const EVENTS: EventType = [PAUSED, ENDED, TIMEUPDATE, ANIMATE, PLAY, ITERATION];\n","import { isObject, isArray, toArray } from \"@daybrush/utils\";\nimport { CallbackType, EventParameter } from \"./types\";\n\n/**\n* attach and trigger event handlers.\n*/\nclass EventTrigger {\n public events: { [name: string]: CallbackType[] };\n /**\n * @example\n const et = new Scene.EventTrigger();\n const scene = new Scene();\n\n scene.on(\"call\", e => {\n console.log(e.param);\n });\n et.on(\"call\", e => {\n console.log(e.param);\n });\n scene.trigger(\"call\", {param: 1});\n et.trigger(\"call\", {param: 1});\n */\n constructor() {\n this.events = {};\n }\n public _on(name: string | EventParameter, callback?: CallbackType | CallbackType[], once?: boolean) {\n const events = this.events;\n\n if (isObject(name)) {\n for (const n in name) {\n this._on(n, name[n], once);\n }\n return;\n }\n if (!(name in events)) {\n events[name] = [];\n }\n if (!callback) {\n return;\n }\n if (isArray(callback)) {\n callback.forEach(func => this._on(name, func, once));\n return;\n }\n events[name].push(once ? function callback2(...args) {\n callback(...args);\n this.off(name, callback2);\n } : callback);\n }\n /**\n * Attach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function() {\n console.log(\"animate\");\n });\n\n target.trigger(\"animate\");\n\n */\n public on(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback);\n return this;\n }\n /**\n * Dettach an event handler function for one or more events to target\n * @param - event's name\n * @param - function to execute when the event is triggered.\n * @return {EventTrigger} An Instance itself.\n * @example\n const callback = function() {\n console.log(\"animate\");\n };\n target.on(\"animate\", callback);\n\n target.off(\"animate\", callback);\n target.off(\"animate\");\n\n */\n public off(name?: string, callback?: CallbackType) {\n if (!name) {\n this.events = {};\n } else if (!callback) {\n this.events[name] = [];\n } else {\n const callbacks = this.events[name];\n\n if (!callbacks) {\n return this;\n }\n const index = callbacks.indexOf(callback);\n\n if (index !== -1) {\n callbacks.splice(index, 1);\n }\n }\n return this;\n }\n /**\n * execute event handler\n * @param - event's name\n * @param - event handler's additional parameter\n * @return {EventTrigger} An Instance itself.\n * @example\n target.on(\"animate\", function(a1, a2) {\n console.log(\"animate\", a1, a2);\n });\n\n target.trigger(\"animate\", [1, 2]); // log => \"animate\", 1, 2\n\n */\n public trigger(name: string, ...data: any[]) {\n const events = this.events;\n\n if (!(name in events)) {\n return this;\n }\n\n const args = data || [];\n\n !args[0] && (args[0] = {});\n const event = events[name];\n const target = args[0];\n\n target.type = name;\n target.currentTarget = this;\n !target.target && (target.target = this);\n toArray(events[name]).forEach(callback => {\n callback.apply(this, data);\n });\n\n return this;\n }\n public once(name: string | EventParameter, callback?: CallbackType | CallbackType[]) {\n this._on(name, callback, true);\n return this;\n }\n}\nexport default EventTrigger;\n","import { isString } from \"@daybrush/utils\";\nimport { PropertyObjectState } from \"./types\";\n\n/**\n* Make string, array to PropertyObject for the dot product\n*/\nclass PropertyObject implements PropertyObjectState {\n public value: any[];\n public prefix: string = \"\";\n public suffix: string = \"\";\n public model: string = \"\";\n public type: string = \"\";\n public separator: string = \",\";\n\n /**\n * @param - This value is in the array format.\n * @param - options\n * @example\n var obj = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n */\n constructor(value: string | any[], options?: Partial) {\n options && this.setOptions(options);\n this.value = isString(value) ? value.split(this.separator) : value;\n }\n public setOptions(newOptions: Partial) {\n for (const name in newOptions) {\n this[name as keyof PropertyObjectState] = newOptions[name as keyof PropertyObjectState];\n }\n return this;\n }\n /**\n * the number of values.\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.length);\n // 3\n */\n public size() {\n return this.value.length;\n }\n /**\n * retrieve one of values at the index\n * @param {Number} index - index\n * @return {Object} one of values at the index\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n\n console.log(obj1.get(0));\n // 1\n */\n public get(index: number) {\n return this.value[index];\n }\n /**\n * Set the value at that index\n * @param {Number} index - index\n * @param {Object} value - text, a number, object to set\n * @return {PropertyObject} An instance itself\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n obj1.set(0, 2);\n console.log(obj1.toValue());\n // 2,2,3\n */\n public set(index: number, value: any) {\n this.value[index] = value;\n return this;\n }\n /**\n * create a copy of an instance itself.\n * @return {PropertyObject} clone\n * @example\n const obj1 = new PropertyObject(\"1,2,3\", \",\");\n const obj2 = obj1.clone();\n */\n public clone(): PropertyObject {\n const {\n separator,\n prefix,\n suffix,\n model,\n type,\n } = this;\n const arr = this.value.map(v => ((v instanceof PropertyObject) ? v.clone() : v));\n return new PropertyObject(arr, {\n separator,\n prefix,\n suffix,\n model,\n type,\n });\n }\n /**\n * Make Property Object to String\n * @return {String} Make Property Object to String\n * @example\n //rgba(100, 100, 100, 0.5)\n const obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\",\n });\n console.log(obj4.toValue());\n // \"rgba(100,100,100,0.5)\"\n */\n public toValue(): string {\n return this.prefix + this.join() + this.suffix;\n }\n /**\n * Make Property Object's array to String\n * @return {String} Join the elements of an array into a string\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n obj4.join(); // => \"100,100,100,0.5\"\n */\n public join() {\n return this.value.map(v => ((v instanceof PropertyObject) ? v.toValue() : v)).join(this.separator);\n }\n /**\n * executes a provided function once per array element.\n * @param {Function} callback - Function to execute for each element, taking three arguments\n * @param {All} [callback.currentValue] The current element being processed in the array.\n * @param {Number} [callback.index] The index of the current element being processed in the array.\n * @param {Array} [callback.array] the array.\n * @return {PropertyObject} An instance itself\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach|MDN Array.forEach()} reference to MDN document.\n * @example\n //rgba(100, 100, 100, 0.5)\n var obj4 = new PropertyObject([100,100,100,0.5], {\n \"separator\" : \",\",\n \"prefix\" : \"rgba(\",\n \"suffix\" : \")\"\n });\n\n obj4.forEach(t => {\n console.log(t);\n }); // => \"100,100,100,0.5\"\n */\n public forEach(func: (value?: any, index?: number, array?: any[]) => void) {\n this.value.forEach(func);\n return this;\n }\n}\nexport default PropertyObject;\n","/**\n* @namespace\n* @name Property\n*/\n\nimport PropertyObject from \"../PropertyObject\";\nimport {\n COLOR_MODELS, isString,\n splitComma, splitSpace, stringToRGBA,\n RGBA, splitBracket, IObject, isArray, splitText\n} from \"@daybrush/utils\";\nimport { NameType } from \"../types\";\n\nexport function splitStyle(str: string) {\n\n const properties = splitText(str, \";\");\n const obj: IObject = {};\n const totalLength = properties.length;\n let length = totalLength;\n\n for (let i = 0; i < totalLength; ++i) {\n const matches = splitText(properties[i], \":\");\n\n if (matches.length < 2 || !matches[1]) {\n --length;\n continue;\n }\n obj[matches[0].trim()] = toPropertyObject(matches[1].trim());\n }\n return { styles: obj, length };\n}\n/**\n* convert array to PropertyObject[type=color].\n* default model \"rgba\"\n* @memberof Property\n* @function arrayToColorObject\n* @param {Array|PropertyObject} value ex) [0, 0, 0, 1]\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\narrayToColorObject([0, 0, 0])\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0, 1], separator=\",\")\n*/\nexport function arrayToColorObject(arr: number[]) {\n const model = RGBA;\n\n if (arr.length === 3) {\n arr[3] = 1;\n }\n return new PropertyObject(arr, {\n model,\n separator: \",\",\n type: \"color\",\n prefix: `${model}(`,\n suffix: \")\",\n });\n}\n/**\n* convert text with parentheses to object.\n* @memberof Property\n* @function stringToBracketObject\n* @param {String} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject\n* @example\nstringToBracketObject(\"abcde(0, 0, 0,1)\")\n// => PropertyObject(model=\"abcde\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToBracketObject(text: string) {\n // [prefix, value, other]\n const { prefix: model, value, suffix: afterModel } = splitBracket(text);\n\n if (typeof value === \"undefined\") {\n return text;\n }\n if (COLOR_MODELS.indexOf(model) > -1) {\n return arrayToColorObject(stringToRGBA(text));\n }\n // divide comma(,)\n const obj = toPropertyObject(value, model);\n\n let arr = [value];\n let separator = \",\";\n let prefix = `${model}(`;\n let suffix = `)${afterModel}`;\n\n if (obj instanceof PropertyObject) {\n separator = obj.separator;\n arr = obj.value;\n prefix += obj.prefix;\n suffix = obj.suffix + suffix;\n }\n return new PropertyObject(arr, {\n separator,\n model,\n prefix,\n suffix,\n });\n}\n\nexport function arrayToPropertyObject(arr: any[], separator: string) {\n return new PropertyObject(arr, {\n type: \"array\",\n separator,\n });\n}\n\n/**\n* convert text with parentheses to PropertyObject[type=color].\n* If the values are not RGBA model, change them RGBA mdoel.\n* @memberof Property\n* @function stringToColorObject\n* @param {String|PropertyObject} value ex) \"rgba(0,0,0,1)\"\n* @return {PropertyObject} PropertyObject[type=color]\n* @example\nstringToColorObject(\"rgba(0, 0, 0,1)\")\n// => PropertyObject(type=\"color\", model=\"rgba\", value=[0, 0, 0,1], separator=\",\")\n*/\nexport function stringToColorObject(value: string): string | PropertyObject {\n const result = stringToRGBA(value);\n\n return result ? arrayToColorObject(result) : value;\n}\n/**\n* convert CSS Value to PropertyObject\n* @memberof Property\n* @function toPropertyObject\n* @param {String} value it's text contains the array.\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @see referenced regular expression {@link http://stackoverflow.com/questions/20215440/parse-css-gradient-rule-with-javascript-regex}\n* @example\ntoPropertyObject(\"1px solid #000\");\n// => PropertyObject([\"1px\", \"solid\", rgba(0, 0, 0, 1)])\n*/\nexport function toPropertyObject(value: any[], model?: NameType): PropertyObject;\nexport function toPropertyObject(value: IObject, model?: NameType): IObject;\nexport function toPropertyObject(value: string, model?: NameType): PropertyObject | string;\nexport function toPropertyObject(value: string | IObject | any[], model?: NameType) {\n if (!isString(value)) {\n if (isArray(value)) {\n return arrayToPropertyObject(value, \",\");\n }\n return value;\n }\n let values: any = splitComma(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \",\");\n }\n values = splitSpace(value);\n\n if (values.length > 1) {\n return arrayToPropertyObject(values.map(v => toPropertyObject(v)), \" \");\n }\n values = /^(['\"])([^'\"]*)(['\"])$/g.exec(value);\n\n if (values && values[1] === values[3]) {\n // Quotes\n return new PropertyObject([toPropertyObject(values[2])], {\n prefix: values[1],\n suffix: values[1],\n });\n } else if (value.indexOf(\"(\") !== -1) {\n // color\n return stringToBracketObject(value);\n } else if (value.charAt(0) === \"#\" && model !== \"url\") {\n return stringToColorObject(value);\n }\n return value;\n}\nexport function toObject(object: PropertyObject, result: IObject = {}) {\n const model = object.model;\n\n if (model) {\n object.setOptions({\n model: \"\",\n suffix: \"\",\n prefix: \"\",\n });\n const value = object.size() > 1 ? object : object.get(0);\n\n result[model] = value;\n } else {\n object.forEach(obj => {\n toObject(obj, result);\n });\n }\n return result;\n}\n","import {\n ROLES, MAXIMUM, FIXED, ALIAS,\n PAUSED, RUNNING, PLAY, ENDED, PREFIX, PLAY_CSS, CURRENT_TIME, START_ANIMATION, EASINGS, NAME_SEPARATOR\n} from \"./consts\";\nimport PropertyObject from \"./PropertyObject\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport {\n isArray, ANIMATION, ARRAY, OBJECT,\n PROPERTY, STRING, NUMBER, IS_WINDOW, IObject, $, document, isObject, addEvent, removeEvent, isString,\n} from \"@daybrush/utils\";\nimport { EasingType, EasingFunction, NameType } from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\nimport { bezier, steps } from \"./easing\";\n\nexport function isPropertyObject(value: any): value is PropertyObject {\n return value instanceof PropertyObject;\n}\nexport function setAlias(name: string, alias: string[]) {\n ALIAS[name] = alias;\n}\nexport function setRole(names: string[], isProperty?: boolean, isFixedProperty?: boolean) {\n const length = names.length;\n let roles: any = ROLES;\n let fixed: any = FIXED;\n\n for (let i = 0; i < length - 1; ++i) {\n !roles[names[i]] && (roles[names[i]] = {});\n roles = roles[names[i]];\n if (isFixedProperty) {\n !fixed[names[i]] && (fixed[names[i]] = {});\n fixed = fixed[names[i]];\n }\n }\n isFixedProperty && (fixed[names[length - 1]] = true);\n roles[names[length - 1]] = isProperty ? true : {};\n}\nexport function getType(value: any) {\n const type = typeof value;\n\n if (type === OBJECT) {\n if (isArray(value)) {\n return ARRAY;\n } else if (isPropertyObject(value)) {\n return PROPERTY;\n }\n } else if (type === STRING || type === NUMBER) {\n return \"value\";\n }\n return type;\n}\nexport function isPureObject(obj: any): obj is object {\n return isObject(obj) && obj.constructor === Object;\n}\nexport function getNames(names: IObject, stack: string[]) {\n let arr: string[][] = [];\n\n if (isPureObject(names)) {\n for (const name in names) {\n stack.push(name);\n arr = arr.concat(getNames(names[name], stack));\n stack.pop();\n }\n } else {\n arr.push(stack.slice());\n }\n return arr;\n}\nexport function updateFrame(names: IObject, properties: IObject) {\n for (const name in properties) {\n const value = properties[name];\n\n if (!isPureObject(value)) {\n names[name] = true;\n continue;\n }\n if (!isObject(names[name])) {\n names[name] = {};\n }\n updateFrame(names[name], properties[name]);\n }\n return names;\n}\nexport function toFixed(num: number) {\n return Math.round(num * MAXIMUM) / MAXIMUM;\n}\nexport function getValueByNames(\n names: Array,\n properties: IObject, length: number = names.length) {\n let value = properties;\n\n for (let i = 0; i < length; ++i) {\n if (!isObject(value) || value == null) {\n return undefined;\n }\n value = value[names[i]];\n }\n return value;\n}\nexport function isInProperties(roles: IObject, args: NameType[], isCheckTrue?: boolean) {\n const length = args.length;\n let role: any = roles;\n\n if (length === 0) {\n return false;\n }\n for (let i = 0; i < length; ++i) {\n if (role === true) {\n return false;\n }\n role = role[args[i]];\n if (!role || (!isCheckTrue && role === true)) {\n return false;\n }\n }\n return true;\n}\nexport function isRole(args: NameType[], isCheckTrue?: boolean) {\n return isInProperties(ROLES, args, isCheckTrue);\n}\nexport function isFixed(args: NameType[]) {\n return isInProperties(FIXED, args, true);\n}\n\nexport interface IterationInterface {\n currentTime: number;\n iterationCount: number;\n elapsedTime: number;\n}\nexport function setPlayCSS(item: Scene | SceneItem, isActivate: boolean) {\n item.state[PLAY_CSS] = isActivate;\n}\nexport function isPausedCSS(item: Scene | SceneItem) {\n return item.state[PLAY_CSS] && item.isPaused();\n}\nexport function isEndedCSS(item: Scene | SceneItem) {\n return !item.isEnded() && item.state[PLAY_CSS];\n}\n\nexport function makeId(selector?: boolean) {\n for (; ;) {\n const id = `${Math.floor(Math.random() * 10000000)}`;\n\n if (!IS_WINDOW || !selector) {\n return id;\n }\n const checkElement = $(`[data-scene-id=\"${id}\"]`);\n\n if (!checkElement) {\n return id;\n }\n }\n}\nexport function getRealId(item: Scene | SceneItem) {\n return item.getId() || item.setId(makeId(false)).getId();\n}\nexport function toId(text: number | string) {\n return `${text}`.match(/[0-9a-zA-Z]+/g).join(\"\");\n}\nexport function playCSS(\n item: Scene | SceneItem, isExportCSS?: boolean,\n playClassName?: string, properties: object = {}) {\n if (!ANIMATION || item.getPlayState() === RUNNING) {\n return;\n }\n const className = playClassName || START_ANIMATION;\n\n if (isPausedCSS(item)) {\n item.addPlayClass(true, className, properties);\n } else {\n if (item.isEnded()) {\n item.setTime(0);\n }\n isExportCSS && item.exportCSS({ className });\n const el = item.addPlayClass(false, className, properties);\n\n if (!el) {\n return;\n }\n addAnimationEvent(item, el);\n setPlayCSS(item, true);\n }\n item.setPlayState(RUNNING);\n}\n\nexport function addAnimationEvent(item: Scene | SceneItem, el: Element) {\n const state = item.state;\n const duration = item.getDuration();\n const isZeroDuration = !duration || !isFinite(duration);\n const animationend = () => {\n setPlayCSS(item, false);\n item.finish();\n };\n const animationstart = () => {\n item.trigger(PLAY);\n\n addEvent(el, \"animationcancel\", animationend);\n addEvent(el, \"animationend\", animationend);\n addEvent(el, \"animationiteration\", animationiteration);\n };\n item.once(ENDED, () => {\n removeEvent(el, \"animationcancel\", animationend);\n removeEvent(el, \"animationend\", animationend);\n removeEvent(el, \"animationiteration\", animationiteration);\n removeEvent(el, \"animationstart\", animationstart);\n });\n const animationiteration = ({ elapsedTime }: any) => {\n const currentTime = elapsedTime;\n const iterationCount = isZeroDuration ? 0 : (currentTime / duration);\n\n state[CURRENT_TIME] = currentTime;\n item.setIteration(iterationCount);\n };\n addEvent(el, \"animationstart\", animationstart);\n}\n\nexport function getEasing(curveArray: string | number[] | EasingFunction): EasingType {\n let easing: EasingType;\n\n if (isString(curveArray)) {\n if (curveArray in EASINGS) {\n easing = EASINGS[curveArray];\n } else {\n const obj = toPropertyObject(curveArray);\n\n if (isString(obj)) {\n return 0;\n } else {\n if (obj.model === \"cubic-bezier\") {\n curveArray = obj.value.map(v => parseFloat(v));\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else if (obj.model === \"steps\") {\n easing = steps(parseFloat(obj.value[0]), obj.value[1]);\n } else {\n return 0;\n }\n }\n }\n } else if (isArray(curveArray)) {\n easing = bezier(curveArray[0], curveArray[1], curveArray[2], curveArray[3]);\n } else {\n easing = curveArray;\n }\n\n return easing;\n}\n\nexport function getFullName(names: NameType[]) {\n return names.join(NAME_SEPARATOR);\n}\n","import {\n THRESHOLD,\n ALTERNATE, ALTERNATE_REVERSE, REVERSE, INFINITE, NORMAL,\n ITERATION_COUNT, DELAY, FILL_MODE, DIRECTION, PLAY_SPEED,\n DURATION, EASING, ITERATION_TIME, EASING_NAME, PAUSED,\n RUNNING, PLAY, TIMEUPDATE, ENDED, PLAY_STATE, PREV_TIME, TICK_TIME, CURRENT_TIME, ITERATION, OPTIONS, EASINGS\n} from \"./consts\";\nimport EventTrigger from \"./EventTrigger\";\nimport { bezier, steps } from \"./easing\";\nimport { toFixed, getEasing } from \"./utils\";\nimport { splitUnit, isString, camelize, requestAnimationFrame, isArray, cancelAnimationFrame } from \"@daybrush/utils\";\nimport {\n IterationCountType, DirectionType, AnimatorState,\n EasingFunction, FillModeType, PlayStateType, EasingType, AnimatorOptions,\n} from \"./types\";\nimport { toPropertyObject } from \"./utils/property\";\n\nfunction GetterSetter {}>(\n getter: string[], setter: string[], parent: string) {\n return (constructor: T) => {\n const prototype = constructor.prototype;\n\n getter.forEach(name => {\n prototype[camelize(`get ${name}`)] = function() {\n return this[parent][name];\n };\n });\n setter.forEach(name => {\n prototype[camelize(`set ${name}`)] = function(value: any) {\n this[parent][name] = value;\n return this;\n };\n });\n };\n}\nexport function isDirectionReverse(iteration: number, iteraiontCount: IterationCountType, direction: DirectionType) {\n if (direction === REVERSE) {\n return true;\n } else if (iteraiontCount !== INFINITE && iteration === iteraiontCount && iteraiontCount % 1 === 0) {\n return direction === (iteration % 2 >= 1 ? ALTERNATE_REVERSE : ALTERNATE);\n }\n return direction === (iteration % 2 >= 1 ? ALTERNATE : ALTERNATE_REVERSE);\n}\n/**\n* @typedef {Object} AnimatorState The Animator options. Properties used in css animation.\n* @property {number} [duration] The duration property defines how long an animation should take to complete one cycle.\n* @property {\"none\"|\"forwards\"|\"backwards\"|\"both\"} [fillMode] The fillMode property specifies a style for the element when the animation is not playing (before it starts, after it ends, or both).\n* @property {\"infinite\"|number} [iterationCount] The iterationCount property specifies the number of times an animation should be played.\n* @property {array|function} [easing] The easing(timing-function) specifies the speed curve of an animation.\n* @property {number} [delay] The delay property specifies a delay for the start of an animation.\n* @property {\"normal\"|\"reverse\"|\"alternate\"|\"alternate-reverse\"} [direction] The direction property defines whether an animation should be played forwards, backwards or in alternate cycles.\n*/\n\nconst setters = [\"id\", ITERATION_COUNT, DELAY, FILL_MODE,\n DIRECTION, PLAY_SPEED, DURATION, PLAY_SPEED, ITERATION_TIME, PLAY_STATE];\nconst getters = [...setters, EASING, EASING_NAME];\n\n/**\n* play video, animation, the others\n* @extends EventTrigger\n* @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n*/\n@GetterSetter(getters, setters, \"state\")\nclass Animator\n extends EventTrigger {\n public state: U;\n private timerId: number = 0;\n\n /**\n * @param - animator's options\n * @example\n const animator = new Animator({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n constructor(options?: Partial) {\n super();\n this.state = {\n id: \"\",\n easing: 0,\n easingName: \"linear\",\n iterationCount: 1,\n delay: 0,\n fillMode: \"forwards\",\n direction: NORMAL,\n playSpeed: 1,\n currentTime: 0,\n iterationTime: -1,\n iteration: 0,\n tickTime: 0,\n prevTime: 0,\n playState: PAUSED,\n duration: 0,\n } as U;\n this.setOptions(options);\n }\n /**\n * set animator's easing.\n * @param curverArray - The speed curve of an animation.\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.easing.EASE,\n });\n */\n public setEasing(curveArray: string | number[] | EasingFunction): this {\n const easing: EasingType = getEasing(curveArray);\n const easingName = easing && easing[EASING_NAME] || \"linear\";\n const state = this.state;\n\n state[EASING] = easing;\n state[EASING_NAME] = easingName;\n return this;\n }\n /**\n * set animator's options.\n * @see {@link https://www.w3schools.com/css/css3_animations.asp|CSS3 Animation}\n * @param - animator's options\n * @return {Animator} An instance itself.\n * @example\n animator.({\n delay: 2,\n diretion: \"alternate\",\n duration: 2,\n fillMode: \"forwards\",\n iterationCount: 3,\n easing: Scene.eaasing.EASE,\n });\n */\n public setOptions(options: Partial = {}): this {\n for (const name in options) {\n const value = options[name];\n\n if (name === EASING) {\n this.setEasing(value);\n continue;\n } else if (name === DURATION) {\n value && this.setDuration(value);\n continue;\n }\n if (OPTIONS.indexOf(name as any) > -1) {\n this.state[name] = value;\n }\n }\n\n return this;\n }\n /**\n * Get the animator's total duration including delay\n * @return {number} Total duration\n * @example\n animator.getTotalDuration();\n */\n public getTotalDuration(): number {\n return this.getActiveDuration(true);\n }\n /**\n * Get the animator's total duration excluding delay\n * @return {number} Total duration excluding delay\n * @example\n animator.getActiveDuration();\n */\n public getActiveDuration(delay?: boolean): number {\n const state = this.state;\n const count = state[ITERATION_COUNT];\n if (count === INFINITE) {\n return Infinity;\n }\n return (delay ? state[DELAY] : 0) + this.getDuration() * count;\n }\n /**\n * Check if the animator has reached the end.\n * @return {boolean} ended\n * @example\n animator.isEnded(); // true or false\n */\n public isEnded(): boolean {\n if (this.state[TICK_TIME] === 0 && this.state[PLAY_STATE] === PAUSED) {\n return true;\n } else if (this.getTime() < this.getActiveDuration()) {\n return false;\n }\n return true;\n }\n /**\n *Check if the animator is paused:\n * @return {boolean} paused\n * @example\n animator.isPaused(); // true or false\n */\n public isPaused(): boolean {\n return this.state[PLAY_STATE] === PAUSED;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const state = this.state;\n\n state[PLAY_STATE] = RUNNING;\n if (state[TICK_TIME] >= delay) {\n /**\n * This event is fired when play animator.\n * @event Animator#play\n */\n this.trigger(PLAY);\n return true;\n }\n return false;\n }\n /**\n * play animator\n * @return {Animator} An instance itself.\n */\n public play(toTime?: number) {\n const state = this.state;\n const delay = state[DELAY];\n const currentTime = this.getTime();\n\n state[PLAY_STATE] = RUNNING;\n\n if (this.isEnded() && (currentTime === 0 || currentTime >= this.getActiveDuration())) {\n this.setTime(-delay, true);\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n state[PREV_TIME] = time;\n this.tick(time, toTime);\n });\n this.start();\n return this;\n }\n /**\n * pause animator\n * @return {Animator} An instance itself.\n */\n public pause(): this {\n const state = this.state;\n\n if (state[PLAY_STATE] !== PAUSED) {\n state[PLAY_STATE] = PAUSED;\n /**\n * This event is fired when animator is paused.\n * @event Animator#paused\n */\n this.trigger(PAUSED);\n }\n cancelAnimationFrame(this.timerId);\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public finish() {\n this.setTime(0);\n this.state[TICK_TIME] = 0;\n this.end();\n return this;\n }\n /**\n * end animator\n * @return {Animator} An instance itself.\n */\n public end() {\n this.pause();\n /**\n * This event is fired when animator is ended.\n * @event Animator#ended\n */\n this.trigger(ENDED);\n return this;\n }\n /**\n * set currentTime\n * @param {Number|String} time - currentTime\n * @return {Animator} An instance itself.\n * @example\n\n animator.setTime(\"from\"); // 0\n animator.setTime(\"to\"); // 100%\n animator.setTime(\"50%\");\n animator.setTime(10);\n animator.getTime() // 10\n */\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean) {\n const activeDuration = this.getActiveDuration();\n const state = this.state;\n const prevTime = state[TICK_TIME];\n const delay = state[DELAY];\n let currentTime = isTick ? (time as number) : this.getUnitTime(time);\n\n state[TICK_TIME] = delay + currentTime;\n if (currentTime < 0) {\n currentTime = 0;\n } else if (currentTime > activeDuration) {\n currentTime = activeDuration;\n }\n state[CURRENT_TIME] = currentTime;\n this.calculate();\n\n if (isTick && !isParent) {\n const tickTime = state[TICK_TIME];\n\n if (prevTime < delay && time >= 0) {\n this.start(0);\n }\n if (tickTime < prevTime || this.isEnded()) {\n this.end();\n return;\n }\n }\n if (this.isDelay()) {\n return this;\n }\n /**\n * This event is fired when the animator updates the time.\n * @event Animator#timeupdate\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(TIMEUPDATE, {\n currentTime,\n time: this.getIterationTime(),\n iterationCount: state[ITERATION],\n });\n\n return this;\n }\n /**\n * Get the animator's current time\n * @return {number} current time\n * @example\n animator.getTime();\n */\n public getTime(): number {\n return this.state[CURRENT_TIME];\n }\n public getUnitTime(time: string | number) {\n if (isString(time)) {\n const duration = this.getDuration() || 100;\n\n if (time === \"from\") {\n return 0;\n } else if (time === \"to\") {\n return duration;\n }\n const { unit, value } = splitUnit(time);\n\n if (unit === \"%\") {\n !this.getDuration() && (this.setDuration(duration));\n return toFixed(parseFloat(time) / 100 * duration);\n } else if (unit === \">\") {\n return value + THRESHOLD;\n } else {\n return value;\n }\n } else {\n return toFixed(time);\n }\n }\n /**\n * Check if the current state of animator is delayed.\n * @return {boolean} check delay state\n */\n public isDelay() {\n const state = this.state;\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n\n return delay > 0 && (tickTime < delay);\n }\n public setIteration(iterationCount: number): this {\n const state = this.state;\n const passIterationCount = Math.floor(iterationCount);\n const maxIterationCount = state[ITERATION_COUNT] === INFINITE ? Infinity : state[ITERATION_COUNT];\n\n if (state[ITERATION] < passIterationCount && passIterationCount < maxIterationCount) {\n /**\n * The event is fired when an iteration of an animation ends.\n * @event Animator#iteration\n * @param {Object} param The object of data to be sent to an event.\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.iterationCount The iteration count that the animator is running.\n */\n this.trigger(\"iteration\", {\n currentTime: state[CURRENT_TIME],\n iterationCount: passIterationCount,\n });\n }\n state[ITERATION] = iterationCount;\n return this;\n }\n protected calculate() {\n const state = this.state;\n const iterationCount = state[ITERATION_COUNT];\n const fillMode = state[FILL_MODE];\n const direction = state[DIRECTION];\n const duration = this.getDuration();\n const time = this.getTime();\n const iteration = duration === 0 ? 0 : time / duration;\n let currentIterationTime = duration ? time % duration : 0;\n\n if (!duration) {\n this.setIterationTime(0);\n return this;\n }\n this.setIteration(iteration);\n\n // direction : normal, reverse, alternate, alternate-reverse\n // fillMode : forwards, backwards, both, none\n const isReverse = isDirectionReverse(iteration, iterationCount, direction);\n\n const isFiniteDuration = isFinite(duration);\n if (isFiniteDuration && isReverse) {\n currentIterationTime = duration - currentIterationTime;\n }\n if (isFiniteDuration && iterationCount !== INFINITE) {\n const isForwards = fillMode === \"both\" || fillMode === \"forwards\";\n\n // fill forwards\n if (iteration >= iterationCount) {\n currentIterationTime = duration * (isForwards ? (iterationCount % 1) || 1 : 0);\n isReverse && (currentIterationTime = duration - currentIterationTime);\n }\n }\n this.setIterationTime(currentIterationTime);\n return this;\n }\n private tick(now: number, to?: number) {\n if (this.isPaused()) {\n return;\n }\n const state = this.state;\n const playSpeed = state[PLAY_SPEED];\n const prevTime = state[PREV_TIME];\n const delay = state[DELAY];\n const tickTime = state[TICK_TIME];\n const currentTime = tickTime + Math.min(1000, now - prevTime) / 1000 * playSpeed;\n\n state[PREV_TIME] = now;\n this.setTime(currentTime - delay, true);\n if (to && to * 1000 < now) {\n this.pause();\n }\n if (state[PLAY_STATE] === PAUSED) {\n return;\n }\n\n this.timerId = requestAnimationFrame((time: number) => {\n this.tick(time, to);\n });\n }\n}\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#setId\n * @param {number | string} - String or number of id to be set in the animator\n * @return {Animator} An instance itself.\n */\n/**\n * Specifies the unique indicator of the animator\n * @method Animator#getId\n * @return {number | string} the indicator of the item.\n */\n/**\n * Get a delay for the start of an animation.\n * @method Animator#getDelay\n * @return {number} delay\n */\n/**\n * Set a delay for the start of an animation.\n * @method Animator#setDelay\n * @param {number} delay - delay\n * @return {Animator} An instance itself.\n */\n/**\n * Get fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#getFillMode\n * @return {FillModeType} fillMode\n */\n/**\n * Set fill mode for the item when the animation is not playing (before it starts, after it ends, or both)\n * @method Animator#setFillMode\n * @param {FillModeType} fillMode - fillMode\n * @return {Animator} An instance itself.\n */\n/**\n * Get the number of times an animation should be played.\n * @method Animator#getIterationCount\n * @return {IterationCountType} iterationCount\n */\n/**\n * Set the number of times an animation should be played.\n * @method Animator#setIterationCount\n * @param {IterationCountType} iterationCount - iterationCount\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#getDirection\n * @return {DirectionType} direction\n */\n/**\n * Set whether an animation should be played forwards, backwards or in alternate cycles.\n * @method Animator#setDirection\n * @param {DirectionType} direction - direction\n * @return {Animator} An instance itself.\n */\n/**\n * Get whether the animation is running or paused.\n * @method Animator#getPlayState\n * @return {PlayStateType} playState\n */\n/**\n * Set whether the animation is running or paused.\n * @method Animator#setPlayState\n * @param {PlayStateType} playState - playState\n * @return {Animator} An instance itself.\n */\n/**\n * Get the animator's play speed\n * @method Animator#getPlaySpeed\n * @return {number} playSpeed\n */\n/**\n * Set the animator's play speed\n * @method Animator#setPlaySpeed\n * @param {number} playSpeed - playSpeed\n * @return {Animator} An instance itself.\n */\n/**\n * Get how long an animation should take to complete one cycle.\n * @method Animator#getDuration\n * @return {number} duration\n */\n/**\n * Set how long an animation should take to complete one cycle.\n * @method Animator#setDuration\n * @param {number} duration - duration\n * @return {Animator} An instance itself.\n */\n/**\n * Get the speed curve of an animation.\n * @method Animator#getEasing\n * @return {EasingType} easing\n */\n/**\n * Get the speed curve's name\n * @method Animator#getEasingName\n * @return {string} the curve's name.\n */\n/**\n\t* Get the animator's current iteration time\n\t* @method Animator#getIterationTime\n\t* @return {number} current iteration time\n\t* @example\nanimator.getIterationTime();\n\t*/\n\n// tslint:disable-next-line:interface-name\ninterface Animator {\n setId(id: number | string): this;\n getId(): number | string;\n getIterationTime(): number;\n setIterationTime(time: number): this;\n setDelay(delay: number): this;\n getDelay(): number;\n setFillMode(fillMode: FillModeType): this;\n getFillMode(): FillModeType;\n setIterationCount(iterationCount: IterationCountType): this;\n getIterationCount(): IterationCountType;\n setDirection(direction: DirectionType): this;\n getDirection(): DirectionType;\n setPlayState(playState: PlayStateType): this;\n getPlayState(): PlayStateType;\n setPlaySpeed(playSpeed: number): this;\n getPlaySpeed(): number;\n setDuration(duration: number): this;\n getDuration(): number;\n getEasing(): EasingType;\n getEasingName(): string;\n}\nexport default Animator;\n","import {\n ALIAS, TIMING_FUNCTION, TRANSFORM_NAME, EASING_NAME, NAME_SEPARATOR\n} from \"./consts\";\nimport { isRole, getType, isPropertyObject, getValueByNames, isFixed, getNames, getEasing, getFullName } from \"./utils\";\nimport { toPropertyObject, splitStyle, toObject } from \"./utils/property\";\nimport {\n isObject, isArray, isString, getKeys,\n ANIMATION, TRANSFORM, FILTER, PROPERTY, FUNCTION, ARRAY, OBJECT, IObject, isUndefined,\n sortOrders,\n} from \"@daybrush/utils\";\nimport { NameType, KeyValueChildren } from \"./types\";\nimport OrderMap from \"order-map\";\n\nfunction toInnerProperties(obj: IObject, orders: NameType[] = []) {\n if (!obj) {\n return \"\";\n }\n const arrObj = [];\n\n const keys = getKeys(obj);\n\n sortOrders(keys, orders);\n\n keys.forEach(name => {\n arrObj.push(`${name.replace(/\\d$/g, \"\")}(${obj[name]})`);\n });\n\n return arrObj.join(\" \");\n}\n\n/* eslint-disable */\nfunction clone(target: IObject, toValue = false) {\n return merge({}, target, toValue);\n}\nfunction merge(to: IObject, from: IObject, toValue = false) {\n for (const name in from) {\n const value = from[name];\n const type = getType(value);\n\n if (type === PROPERTY) {\n to[name] = toValue ? value.toValue() : value.clone();\n } else if (type === FUNCTION) {\n to[name] = toValue ? getValue([name], value) : value;\n } else if (type === ARRAY) {\n to[name] = value.slice();\n } else if (type === OBJECT) {\n if (isObject(to[name]) && !isPropertyObject(to[name])) {\n merge(to[name], value, toValue);\n } else {\n to[name] = clone(value, toValue);\n }\n } else {\n to[name] = from[name];\n }\n }\n return to;\n}\n/* eslint-enable */\n\nfunction getPropertyName(args: NameType[]) {\n return args[0] in ALIAS ? ALIAS[args[0]] : args;\n}\nfunction getValue(names: NameType[], value: any): any {\n const type = getType(value);\n\n if (type === PROPERTY) {\n return value.toValue();\n } else if (type === FUNCTION) {\n if (names[0] !== TIMING_FUNCTION) {\n return getValue(names, value());\n }\n } else if (type === OBJECT) {\n return clone(value, true);\n }\n return value;\n}\n/**\n* Animation's Frame\n*/\nclass Frame {\n public properties: IObject = {};\n public orderMap: OrderMap = new OrderMap(NAME_SEPARATOR);\n /**\n * @param - properties\n * @example\n const frame = new Scene.Frame({\n display: \"none\"\n transform: {\n translate: \"50px\",\n scale: \"5, 5\",\n }\n });\n */\n constructor(properties: any = {}) {\n this.properties = {};\n // this.orders = [];\n this.set(properties);\n }\n /**\n * get property value\n * @param {...Number|String|PropertyObject} args - property name or value\n * @example\n frame.get(\"display\") // => \"none\", \"block\", ....\n frame.get(\"transform\", \"translate\") // => \"10px,10px\"\n */\n public get(...args: NameType[]) {\n const value = this.raw(...args);\n\n return getValue(getPropertyName(args), value);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n frame.getOrders([\"display\"]) // => []\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n return this.orderMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n frame.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n frame.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n return this.orderMap.set(names, orders);\n }\n /**\n * get properties order object\n * @example\n console.log(frame.getOrderObject());\n */\n public getOrderObject() {\n return this.orderMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n frame.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.orderMap.setObject(obj);\n }\n\n /**\n * get property keys\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [\"translate\"]\n */\n public getKeys(...args: NameType[]): string[] {\n const value = this.raw(...args);\n const keys = getType(value) === OBJECT ? getKeys(value) : [];\n\n sortOrders(keys, this.orderMap.get(args));\n return keys;\n }\n /**\n * get properties array\n * @param - property names\n * @example\n frame.gets(\"display\") // => []\n frame.gets(\"transform\") // => [{ key: \"translate\", value: \"10px, 10px\", children: [] }]\n */\n public gets(...args: NameType[]): KeyValueChildren[] {\n const values = this.get(...args);\n const keys = this.getKeys(...args);\n\n return keys.map(key => {\n const nextValue = values[key];\n return { key, value: nextValue, children: this.gets(...args, key) };\n });\n }\n\n public raw(...args: NameType[]) {\n return getValueByNames(getPropertyName(args), this.properties);\n }\n /**\n * remove property value\n * @param {...String} args - property name\n * @return {Frame} An instance itself\n * @example\n frame.remove(\"display\")\n */\n public remove(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return this;\n }\n this.orderMap.remove(params);\n const value = getValueByNames(params, this.properties, length - 1);\n\n if (isObject(value)) {\n delete value[params[length - 1]];\n }\n return this;\n }\n /**\n * set property\n * @param {...Number|String|PropertyObject} args - property names or values\n * @return {Frame} An instance itself\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n filter: {\n brightness: \"50%\",\n grayscale: \"100%\"\n }\n });\n\n // two parameters\n frame.set(\"transform\", {\n translate: \"10px, 10px\",\n scale: \"1\",\n });\n\n // three parameters\n frame.set(\"transform\", \"translate\", \"50px\");\n */\n public set(...args: any[]) {\n const self = this;\n const length = args.length;\n const params = args.slice(0, -1);\n const value = args[length - 1];\n const firstParam = params[0];\n\n if (length === 1 && value instanceof Frame) {\n self.merge(value);\n } else if (firstParam in ALIAS) {\n self._set(ALIAS[firstParam], value);\n } else if (length === 2 && isArray(firstParam)) {\n self._set(firstParam, value);\n } else if (isPropertyObject(value)) {\n if (isRole(params)) {\n self.set(...params, toObject(value));\n } else {\n self._set(params, value);\n }\n } else if (isArray(value)) {\n self._set(params, value);\n } else if (isObject(value)) {\n if (!self.has(...params) && isRole(params)) {\n self._set(params, {});\n }\n for (const name in value) {\n self.set(...params, name, value[name]);\n }\n } else if (isString(value)) {\n if (isRole(params, true)) {\n if (isFixed(params) || !isRole(params)) {\n this._set(params, value);\n } else {\n const obj = toPropertyObject(value);\n\n if (isObject(obj)) {\n self.set(...params, obj);\n }\n }\n return this;\n } else {\n const { styles, length: stylesLength } = splitStyle(value);\n\n for (const name in styles) {\n self.set(...params, name, styles[name]);\n }\n if (stylesLength) {\n return this;\n }\n }\n self._set(params, value);\n } else {\n self._set(params, value);\n }\n return self;\n }\n /**\n * Gets the names of properties.\n * @return the names of properties.\n * @example\n // one parameter\n frame.set({\n display: \"none\",\n transform: {\n translate: \"10px, 10px\",\n scale: \"1\",\n },\n });\n\n // [[\"display\"], [\"transform\", \"translate\"], [\"transform\", \"scale\"]]\n console.log(frame.getNames());\n */\n public getNames(): string[][] {\n return getNames(this.properties, []);\n }\n /**\n * check that has property.\n * @param {...String} args - property name\n * @example\n frame.has(\"property\", \"display\") // => true or false\n */\n public has(...args: NameType[]) {\n const params = getPropertyName(args);\n const length = params.length;\n\n if (!length) {\n return false;\n }\n return !isUndefined(getValueByNames(params, this.properties, length));\n }\n /**\n * clone frame.\n * @return {Frame} An instance of clone\n * @example\n frame.clone();\n */\n public clone() {\n const frame = new Frame();\n\n frame.setOrderObject(this.orderMap.orderMap);\n return frame.merge(this);\n }\n /**\n * merge one frame to other frame.\n * @param - target frame.\n * @return {Frame} An instance itself\n * @example\n frame.merge(frame2);\n */\n public merge(frame: Frame) {\n const properties = this.properties;\n const frameProperties = frame.properties;\n\n if (frameProperties) {\n merge(properties, frameProperties);\n }\n return this;\n }\n /**\n * Specifies an css object that coverted the frame.\n * @return {object} cssObject\n */\n public toCSSObject() {\n const properties = this.get();\n const cssObject: IObject = {};\n\n for (const name in properties) {\n if (isRole([name], true)) {\n continue;\n }\n const value = properties[name];\n\n if (name === TIMING_FUNCTION) {\n cssObject[TIMING_FUNCTION.replace(\"animation\", ANIMATION)] =\n (isString(value) ? value : value[EASING_NAME]) || \"initial\";\n } else {\n cssObject[name] = value;\n }\n }\n const transform = toInnerProperties(properties[TRANSFORM_NAME], this.orderMap.get([TRANSFORM_NAME]));\n const filter = toInnerProperties(properties.filter, this.orderMap.get([FILTER]));\n\n TRANSFORM && transform && (cssObject[TRANSFORM] = transform);\n FILTER && filter && (cssObject[FILTER] = filter);\n return cssObject;\n }\n /**\n * Specifies an css text that coverted the frame.\n * @return {string} cssText\n */\n public toCSS() {\n const cssObject = this.toCSSObject();\n const cssArray = [];\n const keys = getKeys(cssObject);\n\n sortOrders(keys, this.orderMap.get([]));\n keys.forEach(name => {\n cssArray.push(`${name}:${cssObject[name]};`);\n });\n return cssArray.join(\"\");\n }\n /**\n * Remove All Properties\n * @return {Frame} An instance itself\n */\n public clear() {\n this.properties = {};\n this.orderMap.clear();\n return this;\n }\n private _set(args: NameType[], value: any) {\n let properties = this.properties;\n const length = args.length;\n\n for (let i = 0; i < length - 1; ++i) {\n const name = args[i];\n\n !(name in properties) && (properties[name] = {});\n properties = properties[name];\n }\n if (!length) {\n return;\n }\n const lastParam = args[length - 1];\n\n this.orderMap.add(args);\n if (length === 1 && lastParam === TIMING_FUNCTION) {\n properties[lastParam] = getEasing(value);\n } else {\n properties[lastParam] = isString(value) && !isFixed(args)\n ? toPropertyObject(value, lastParam)\n : value;\n }\n }\n}\nexport default Frame;\n","\nimport PropertyObject from \"../PropertyObject\";\nimport { getType } from \"../utils\";\nimport { toPropertyObject } from \"./property\";\nimport { splitUnit, PROPERTY, FUNCTION, ARRAY, dot as dotNumber } from \"@daybrush/utils\";\nimport { EasingType } from \"../types\";\n\nfunction dotArray(a1: any[], a2: any, b1: number, b2: number): any {\n const length = a2.length;\n\n return a1.map((v1, i) => {\n if (i >= length) {\n return v1;\n } else {\n return dot(v1, a2[i], b1, b2);\n }\n });\n}\n\nfunction dotColor(color1: PropertyObject, color2: PropertyObject, b1: number, b2: number) {\n // convert array to PropertyObject(type=color)\n const value1 = color1.value;\n const value2 = color2.value;\n // If the model name is not same, the inner product is impossible.\n const model1 = color1.model;\n const model2 = color2.model;\n\n if (model1 !== model2) {\n // It is recognized as a string.\n return dot(color1.toValue(), color2.toValue(), b1, b2);\n }\n if (value1.length === 3) {\n value1[3] = 1;\n }\n if (value2.length === 3) {\n value2[3] = 1;\n }\n const v = dotArray(value1, value2, b1, b2);\n const colorModel = model1;\n\n for (let i = 0; i < 3; ++i) {\n v[i] = parseInt(v[i], 10);\n }\n const object = new PropertyObject(v, {\n type: \"color\",\n model: colorModel,\n prefix: `${colorModel}(`,\n suffix: \")\",\n });\n\n return object;\n}\n\nfunction dotObject(a1: PropertyObject, a2: PropertyObject, b1: number, b2: number) {\n const a1Type = a1.type;\n\n if (a1Type === \"color\") {\n return dotColor(a1, a2, b1, b2);\n }\n const value1 = a1.value;\n const value2 = a2.value;\n const arr = dotArray(value1, value2, b1, b2);\n\n return new PropertyObject(arr, {\n type: a1Type,\n separator: a1.separator || a2.separator,\n prefix: a1.prefix || a2.prefix,\n suffix: a1.suffix || a2.suffix,\n model: a1.model || a2.model,\n });\n}\n/**\n* The dot product of a1 and a2 for the b1 and b2.\n* @memberof Dot\n* @function dot\n* @param {String|Number|PropertyObject} a1 value1\n* @param {String|Number|PropertyObject} a2 value2\n* @param {Number} b1 b1 ratio\n* @param {Number} b2 b2 ratio\n* @return {String} Not Array, Not Separator, Only Number & Unit\n* @return {PropertyObject} Array with Separator.\n* @example\ndot(1, 3, 0.3, 0.7);\n// => 1.6\n*/\nexport function dot(a1: any, a2: any, b1: number, b2: number): any {\n if (b2 === 0) {\n return a2;\n } else if (b1 === 0 || b1 + b2 === 0) {\n // prevent division by zero.\n return a1;\n }\n // dot Object\n\n const type1 = getType(a1);\n const type2 = getType(a2);\n const isFunction1 = type1 === FUNCTION;\n const isFunction2 = type2 === FUNCTION;\n\n if (isFunction1 || isFunction2) {\n return () => {\n return dot(isFunction1 ? toPropertyObject(a1()) : a1, isFunction2 ? toPropertyObject(a2()) : a2, b1, b2);\n };\n } else if (type1 === type2) {\n if (type1 === PROPERTY) {\n return dotObject(a1, a2, b1, b2);\n } else if (type1 === ARRAY) {\n return dotArray(a1, a2, b1, b2);\n } else if (type1 !== \"value\") {\n return a1;\n }\n } else {\n return a1;\n }\n const v1 = splitUnit(`${a1}`);\n const v2 = splitUnit(`${a2}`);\n let v;\n\n // 숫자가 아닐경우 첫번째 값을 반환 b2가 0일경우 두번째 값을 반환\n if (isNaN(v1.value) || isNaN(v2.value)) {\n return a1;\n } else {\n v = dotNumber(v1.value, v2.value, b1, b2);\n }\n const prefix = v1.prefix || v2.prefix;\n const unit = v1.unit || v2.unit;\n\n if (!prefix && !unit) {\n return v;\n }\n return prefix + v + unit;\n}\n\nexport function dotValue(\n time: number,\n prevTime: number,\n nextTime: number,\n prevValue: any,\n nextValue: any,\n easing?: EasingType) {\n if (time === prevTime) {\n return prevValue;\n } else if (time === nextTime) {\n return nextValue;\n } else if (!easing) {\n return dot(prevValue, nextValue, time - prevTime, nextTime - time);\n }\n const ratio = easing((time - prevTime) / (nextTime - prevTime));\n const value = dot(prevValue, nextValue, ratio, 1 - ratio);\n\n return value;\n}\n","import Animator, { isDirectionReverse } from \"./Animator\";\nimport Frame from \"./Frame\";\nimport {\n toFixed,\n isFixed,\n playCSS,\n toId,\n getRealId,\n makeId,\n isPausedCSS,\n isRole,\n getValueByNames,\n isEndedCSS,\n setPlayCSS,\n getNames,\n updateFrame,\n} from \"./utils\";\nimport { dotValue } from \"./utils/dot\";\nimport {\n START_ANIMATION,\n PREFIX, THRESHOLD,\n TIMING_FUNCTION, ALTERNATE, ALTERNATE_REVERSE, INFINITE,\n REVERSE, EASING, FILL_MODE, DIRECTION, ITERATION_COUNT,\n EASING_NAME, DELAY, PLAY_SPEED, DURATION, PAUSE_ANIMATION,\n DATA_SCENE_ID, SELECTOR, ROLES, NAME_SEPARATOR\n} from \"./consts\";\nimport {\n isObject, isArray, isUndefined, decamelize,\n ANIMATION, fromCSS, addClass, removeClass, hasClass,\n KEYFRAMES, isFunction,\n IObject, $, splitComma, toArray, isString, IArrayFormat,\n dot as dotNumber,\n find,\n findIndex,\n getKeys,\n sortOrders,\n} from \"@daybrush/utils\";\nimport {\n NameType, AnimateElement, AnimatorState,\n SceneItemState, SceneItemOptions, EasingType, PlayCondition, DirectionType\n} from \"./types\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n\nfunction getNearTimeIndex(times: number[], time: number) {\n const length = times.length;\n\n for (let i = 0; i < length; ++i) {\n if (times[i] === time) {\n return [i, i];\n } else if (times[i] > time) {\n return [i > 0 ? i - 1 : 0, i];\n }\n }\n return [length - 1, length - 1];\n}\nfunction makeAnimationProperties(properties: object) {\n const cssArray = [];\n\n for (const name in properties) {\n cssArray.push(`${ANIMATION}-${decamelize(name)}:${properties[name]};`);\n }\n return cssArray.join(\"\");\n}\nfunction addTime(times: number[], time: number) {\n const length = times.length;\n for (let i = 0; i < length; ++i) {\n if (time < times[i]) {\n times.splice(i, 0, time);\n return;\n }\n }\n times[length] = time;\n}\nfunction addEntry(entries: number[][], time: number, keytime: number) {\n const prevEntry = entries[entries.length - 1];\n\n (!prevEntry || prevEntry[0] !== time || prevEntry[1] !== keytime) &&\n entries.push([toFixed(time), toFixed(keytime)]);\n}\nexport function getEntries(times: number[], states: AnimatorState[]) {\n let entries = times.map(time => ([time, time]));\n let nextEntries = [];\n\n states.forEach(state => {\n const iterationCount = state[ITERATION_COUNT] as number;\n const delay = state[DELAY];\n const playSpeed = state[PLAY_SPEED];\n const direction = state[DIRECTION];\n const intCount = Math.ceil(iterationCount);\n const currentDuration = entries[entries.length - 1][0];\n const length = entries.length;\n const lastTime = currentDuration * iterationCount;\n\n for (let i = 0; i < intCount; ++i) {\n const isReverse =\n direction === REVERSE ||\n direction === ALTERNATE && i % 2 ||\n direction === ALTERNATE_REVERSE && !(i % 2);\n\n for (let j = 0; j < length; ++j) {\n const entry = entries[isReverse ? length - j - 1 : j];\n const time = entry[1];\n const currentTime = currentDuration * i + (isReverse ? currentDuration - entry[0] : entry[0]);\n const prevEntry = entries[isReverse ? length - j : j - 1];\n\n if (currentTime > lastTime) {\n if (j !== 0) {\n const prevTime = currentDuration * i +\n (isReverse ? currentDuration - prevEntry[0] : prevEntry[0]);\n const divideTime = dotNumber(prevEntry[1], time, lastTime - prevTime, currentTime - lastTime);\n\n addEntry(nextEntries, (delay + currentDuration * iterationCount) / playSpeed, divideTime);\n }\n break;\n } else if (\n currentTime === lastTime\n && nextEntries.length\n && nextEntries[nextEntries.length - 1][0] === lastTime + delay\n ) {\n break;\n }\n addEntry(nextEntries, (delay + currentTime) / playSpeed, time);\n }\n }\n // delay time\n delay && nextEntries.unshift([0, nextEntries[0][1]]);\n\n entries = nextEntries;\n nextEntries = [];\n });\n\n return entries;\n}\n/**\n* manage Frame Keyframes and play keyframes.\n* @extends Animator\n* @example\nconst item = new SceneItem({\n\t0: {\n\t\tdisplay: \"none\",\n\t},\n\t1: {\n\t\tdisplay: \"block\",\n\t\topacity: 0,\n\t},\n\t2: {\n\t\topacity: 1,\n\t}\n});\n*/\nclass SceneItem extends Animator {\n public times: number[] = [];\n public items: IObject = {};\n public nameMap = new OrderMap(NAME_SEPARATOR);\n public elements: AnimateElement[] = [];\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: Frame;\n private needUpdate: boolean = true;\n private target: any;\n private targetFunc: (frame: Frame) => void;\n\n /**\n * @param - properties\n * @param - options\n * @example\n const item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n */\n constructor(properties?: any, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n const times = this.times;\n const length = times.length;\n\n return (length === 0 ? 0 : times[length - 1]) || this.state[DURATION];\n }\n /**\n * get size of list\n * @return {Number} length of list\n */\n public size() {\n return this.times.length;\n }\n public setDuration(duration: number) {\n if (!duration) {\n return this;\n }\n const originalDuration = this.getDuration();\n\n if (originalDuration > 0) {\n const ratio = duration / originalDuration;\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(time => {\n const time2 = toFixed(time * ratio);\n\n obj[time2] = items[time];\n\n return time2;\n });\n this.items = obj;\n } else {\n this.newFrame(duration);\n }\n return this;\n }\n public setId(id?: number | string) {\n const state = this.state;\n const elements = this.elements;\n const length = elements.length;\n\n state.id = id || makeId(!!length);\n\n if (length && !state[SELECTOR]) {\n const sceneId = toId(this.getId());\n\n state[SELECTOR] = `[${DATA_SCENE_ID}=\"${sceneId}\"]`;\n elements.forEach(element => {\n element.setAttribute(DATA_SCENE_ID, sceneId);\n });\n }\n return this;\n }\n\n /**\n * Set properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.set(0, \"a\", \"b\") // item.getFrame(0).set(\"a\", \"b\")\n console.log(item.get(0, \"a\")); // \"b\"\n */\n public set(time: any, ...args: any[]) {\n if (time instanceof SceneItem) {\n return this.set(0, time);\n } else if (isArray(time)) {\n const length = time.length;\n\n for (let i = 0; i < length; ++i) {\n const t = length === 1 ? 0 : this.getUnitTime(`${i / (length - 1) * 100}%`);\n\n this.set(t, time[i]);\n }\n } else if (isObject(time)) {\n for (const t in time) {\n const value = time[t];\n\n splitComma(t).forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (isNaN(realTime)) {\n getNames(value, [eachTime]).forEach(names => {\n const innerValue = getValueByNames(names.slice(1), value);\n const arr = isArray(innerValue) ?\n innerValue : [getValueByNames(names, this.target), innerValue];\n const length = arr.length;\n\n for (let i = 0; i < length; ++i) {\n this.newFrame(`${i / (length - 1) * 100}%`).set(...names, arr[i]);\n }\n });\n } else {\n this.set(realTime, value);\n }\n });\n }\n } else if (!isUndefined(time)) {\n const value = args[0];\n\n splitComma(time + \"\").forEach(eachTime => {\n const realTime = this.getUnitTime(eachTime);\n\n if (value instanceof SceneItem) {\n const delay = value.getDelay();\n const frames = value.toObject(!this.hasFrame(realTime + delay));\n const duration = value.getDuration();\n const direction = value.getDirection();\n const isReverse = direction.indexOf(\"reverse\") > -1;\n\n for (const frameTime in frames) {\n const nextTime = isReverse ? duration - parseFloat(frameTime) : parseFloat(frameTime);\n this.set(realTime + nextTime, frames[frameTime]);\n }\n } else if (args.length === 1 && isArray(value)) {\n value.forEach((item: any) => {\n this.set(realTime, item);\n });\n } else {\n const frame = this.newFrame(realTime);\n\n frame.set(...args);\n }\n });\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Get properties of the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} args property's name or properties\n * @return {Number|String|PropertyObejct} property value\n * @example\n item.get(0, \"a\"); // item.getFrame(0).get(\"a\");\n item.get(0, \"transform\", \"translate\"); // item.getFrame(0).get(\"transform\", \"translate\");\n */\n public get(time: string | number, ...args: NameType[]) {\n const frame = this.getFrame(time);\n\n return frame && frame.get(...args);\n }\n /**\n * get properties orders\n * @param - property names\n * @example\n item.getOrders([\"display\"]) // => []\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n */\n public getOrders(names: NameType[]): NameType[] | undefined {\n this.needUpdate && this.update();\n\n return this.nameMap.get(names);\n }\n /**\n * set properties orders\n * @param - property names\n * @param - orders\n * @example\n item.getOrders([\"transform\"]) // => [\"translate\", \"scale\"]\n item.setOrders([\"transform\"], [\"scale\", \"tralsate\"])\n */\n public setOrders(names: NameType[], orders: NameType[]): NameType[] {\n this.needUpdate && this.update();\n\n const result = this.nameMap.set(names, orders);\n\n this.updateFrameOrders();\n\n return result;\n }\n /**\n * get properties order object\n * @example\n console.log(item.getOrderObject());\n */\n public getOrderObject() {\n return this.nameMap.getObject();\n }\n /**\n * set properties orders object\n * @param - properties orders object\n * @example\n item.setOrderObject({\n \"\": [\"transform\"],\n \"transform\": [\"scale\", \"tralsate\"],\n });\n */\n public setOrderObject(obj: IObject) {\n this.nameMap.setObject(obj);\n\n this.updateFrameOrders();\n }\n public remove(time: string | number, ...args: any[]): this;\n /**\n * remove properties to the sceneItem at that time\n * @param {Number} time - time\n * @param {...String|Object} [properties] - property names or values\n * @return {SceneItem} An instance itself\n * @example\n item.remove(0, \"a\");\n */\n public remove(time: string | number, ...args: NameType[]) {\n if (args.length) {\n const frame = this.getFrame(time);\n\n frame && frame.remove(...args);\n } else {\n this.removeFrame(time);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * Append the item or object at the last time.\n * @param - the scene item or item object\n * @return An instance itself\n * @example\n item.append(new SceneItem({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }));\n item.append({\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n item.set(item.getDuration(), {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n });\n */\n public append(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n this.set(this.getDuration(), item);\n } else {\n this.append(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push the front frames for the time and prepend the scene item or item object.\n * @param - the scene item or item object\n * @return An instance itself\n */\n public prepend(item: SceneItem | IObject) {\n if (item instanceof SceneItem) {\n const unshiftTime = item.getDuration() + item.getDelay();\n const firstFrame = this.getFrame(0);\n // remove first frame\n this.removeFrame(0);\n this.unshift(unshiftTime);\n this.set(0, item);\n this.set(unshiftTime + THRESHOLD, firstFrame);\n } else {\n this.prepend(new SceneItem(item));\n }\n return this;\n }\n /**\n * Push out the amount of time.\n * @param - time to push\n * @example\n item.get(0); // frame 0\n item.unshift(3);\n item.get(3) // frame 0\n */\n public unshift(time: number) {\n const { times, items } = this;\n const obj: IObject = {};\n\n this.times = times.map(t => {\n const time2 = toFixed(time + t);\n\n obj[time2] = items[t];\n return time2;\n });\n this.items = obj;\n return this;\n }\n /**\n * Get the frames in the item in object form.\n * @return {}\n * @example\n item.toObject();\n // {0: {display: \"none\"}, 1: {display: \"block\"}}\n */\n public toObject(isStartZero = true): IObject {\n const obj: IObject = {};\n const delay = this.getDelay();\n\n this.forEach((frame: Frame, time: number) => {\n obj[(!time && !isStartZero ? THRESHOLD : 0) + delay + time] = frame.clone();\n });\n return obj;\n }\n /**\n * Specifies an element to synchronize items' keyframes.\n * @param {string} selectors - Selectors to find elements in items.\n * @return {SceneItem} An instance itself\n * @example\nitem.setSelector(\"#id.class\");\n */\n public setSelector(target: string | boolean | ((id: number | string) => string)) {\n if (isFunction(target)) {\n this.setElement(target(this.getId()));\n } else {\n this.setElement(target);\n }\n return this;\n }\n /**\n * Get the elements connected to SceneItem.\n */\n public getElements(): AnimateElement[] {\n return this.elements;\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElements(target: boolean | string | AnimateElement | IArrayFormat): this {\n return this.setElement(target);\n }\n /**\n * Specifies an element to synchronize item's keyframes.\n * @param - elements to synchronize item's keyframes.\n * @param - Make sure that you have peusdo.\n * @return {SceneItem} An instance itself\n * @example\nitem.setElement(document.querySelector(\"#id.class\"));\nitem.setElement(document.querySelectorAll(\".class\"));\n */\n public setElement(target: boolean | string | AnimateElement | IArrayFormat) {\n const state = this.state;\n let elements: AnimateElement[] = [];\n\n if (!target) {\n return this;\n } else if (target === true || isString(target)) {\n const selector = target === true ? `${state.id}` : target;\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(selector);\n\n elements = toArray($(matches ? matches[1] : selector, true));\n state[SELECTOR] = selector;\n } else {\n elements = (target instanceof Element) ? [target] : toArray(target);\n }\n if (!elements.length) {\n return this;\n }\n this.elements = elements;\n this.setId(this.getId());\n this.target = elements[0].style;\n this.targetFunc = (frame: Frame) => {\n const attributes = frame.get(\"attribute\");\n\n if (attributes) {\n for (const name in attributes) {\n elements.forEach(el => {\n el.setAttribute(name, attributes[name]);\n });\n }\n }\n if (frame.has(\"html\")) {\n const html = frame.get(\"html\");\n\n elements.forEach(el => {\n el.innerHTML = html;\n });\n }\n const cssText = frame.toCSS();\n\n if (state.cssText !== cssText) {\n state.cssText = cssText;\n\n elements.forEach(el => {\n el.style.cssText += cssText;\n });\n return frame;\n }\n };\n return this;\n }\n public setTarget(target: any): this {\n this.target = target;\n this.targetFunc = (frame: Frame) => {\n const obj = frame.get();\n\n for (const name in obj) {\n target[name] = obj[name];\n }\n };\n return this;\n }\n /**\n * add css styles of items's element to the frame at that time.\n * @param {Array} properties - elements to synchronize item's keyframes.\n * @return {SceneItem} An instance itself\n * @example\n item.setElement(document.querySelector(\"#id.class\"));\n item.setCSS(0, [\"opacity\"]);\n item.setCSS(0, [\"opacity\", \"width\", \"height\"]);\n */\n public setCSS(time: number, properties: string[]) {\n this.set(time, fromCSS(this.elements, properties));\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frame = this.getNowFrame(iterationTime, easing);\n const currentTime = this.getTime();\n\n this.temp = frame;\n /**\n * This event is fired when timeupdate and animate.\n * @event SceneItem#animate\n * @param {Number} param.currentTime The total time that the animator is running.\n * @param {Number} param.time The iteration time during duration that the animator is running.\n * @param {Frame} param.frame frame of that time.\n */\n this.trigger(\"animate\", {\n frame,\n currentTime,\n time: iterationTime,\n });\n this.targetFunc && this.targetFunc(frame);\n return this;\n }\n /**\n * update property names used in frames.\n * @return {SceneItem} An instance itself\n * @example\n item.update();\n */\n public update() {\n const prevNameMap = this.nameMap;\n const names = {};\n this.forEach(frame => {\n updateFrame(names, frame.properties);\n });\n\n const nameMap = new OrderMap(NAME_SEPARATOR);\n\n function pushKeys(map: IObject, stack: NameType[]) {\n const keys = getKeys(map);\n\n sortOrders(keys, prevNameMap.get(stack));\n\n nameMap.set(stack, keys);\n keys.forEach(key => {\n const nextMap = map[key];\n if (isObject(nextMap)) {\n pushKeys(nextMap, [...stack, key]);\n }\n });\n }\n pushKeys(names, []);\n\n this.nameMap = nameMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap.orderMap);\n });\n this.needUpdate = false;\n return this;\n }\n /**\n * Create and add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {Frame} Created frame.\n * @example\n item.newFrame(time);\n */\n public newFrame(time: string | number) {\n let frame = this.getFrame(time);\n\n if (frame) {\n return frame;\n }\n frame = new Frame();\n\n this.setFrame(time, frame);\n return frame;\n }\n /**\n * Add a frame to the sceneItem at that time\n * @param {Number} time - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.setFrame(time, frame);\n */\n public setFrame(time: string | number, frame: Frame) {\n const realTime = this.getUnitTime(time);\n\n this.items[realTime] = frame;\n addTime(this.times, realTime);\n this.needUpdate = true;\n return this;\n }\n public getFrame(time: number | string, ...names: any[]): Frame;\n /**\n * get sceneItem's frame at that time\n * @param {Number} time - frame's time\n * @return {Frame} sceneItem's frame at that time\n * @example\n const frame = item.getFrame(time);\n */\n public getFrame(time: number | string) {\n return this.items[this.getUnitTime(time)];\n }\n public removeFrame(time: number | string, ...names: any[]): this;\n /**\n * remove sceneItem's frame at that time\n * @param - frame's time\n * @return {SceneItem} An instance itself\n * @example\n item.removeFrame(time);\n */\n public removeFrame(time: number | string) {\n const realTime = this.getUnitTime(time);\n const items = this.items;\n const index = this.times.indexOf(realTime);\n\n delete items[realTime];\n\n // remove time\n if (index > -1) {\n this.times.splice(index, 1);\n }\n this.needUpdate = true;\n return this;\n }\n /**\n * check if the item has a frame at that time\n * @param {Number} time - frame's time\n * @return {Boolean} true: the item has a frame // false: not\n * @example\n if (item.hasFrame(10)) {\n // has\n } else {\n // not\n }\n */\n public hasFrame(time: number | string) {\n return this.getUnitTime(time) in this.items;\n }\n /**\n * Check if keyframes has propery's name\n * @param - property's time\n * @return {boolean} true: if has property, false: not\n * @example\n item.hasName([\"transform\", \"translate\"]); // true or not\n */\n public hasName(args: string[]) {\n this.needUpdate && this.update();\n return !!this.nameMap.get(args);\n }\n /**\n * merge frame of the previous time at the next time.\n * @param - The time of the frame to merge\n * @param - The target frame\n * @return {SceneItem} An instance itself\n * @example\n // getFrame(1) contains getFrame(0)\n item.merge(0, 1);\n */\n public mergeFrame(time: number | string, frame: Frame) {\n if (frame) {\n const toFrame = this.newFrame(time);\n\n toFrame.merge(frame);\n }\n return this;\n }\n /**\n * Get frame of the current time\n * @param {Number} time - the current time\n * @param {function} easing - the speed curve of an animation\n * @return {Frame} frame of the current time\n * @example\n let item = new SceneItem({\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n }\n });\n // opacity: 0.7; display:\"block\";\n const frame = item.getNowFrame(1.7);\n */\n public getNowFrame(time: number, easing?: EasingType, isAccurate?: boolean) {\n this.needUpdate && this.update();\n const frame = new Frame();\n const [left, right] = getNearTimeIndex(this.times, time);\n let realEasing = this.getEasing() || easing;\n let nameMap = this.nameMap;\n\n if (this.hasName([TIMING_FUNCTION])) {\n const nowEasing = this.getNowValue(time, [TIMING_FUNCTION], left, right, false, 0, true);\n\n isFunction(nowEasing) && (realEasing = nowEasing);\n }\n if (isAccurate) {\n const prevFrame = this.getFrame(time);\n const prevOrderMap = prevFrame.orderMap.filter([], orders => {\n return prevFrame.has(...orders);\n });\n\n for (const name in ROLES) {\n const orders = nameMap.get([name]);\n if (prevOrderMap.get([name]) && orders) {\n prevOrderMap.set([name], orders);\n }\n }\n nameMap = prevOrderMap;\n }\n const names = nameMap.gets([]);\n\n frame.setOrderObject(nameMap.orderMap);\n names.forEach(properties => {\n const value = this.getNowValue(time, properties, left, right, isAccurate, realEasing, isFixed(properties));\n\n if (isUndefined(value)) {\n return;\n }\n frame.set(properties, value);\n });\n return frame;\n }\n public load(properties: any = {}, options = properties.options) {\n options && this.setOptions(options);\n\n if (isArray(properties)) {\n this.set(properties);\n } else if (properties.keyframes) {\n this.set(properties.keyframes);\n } else {\n for (const time in properties) {\n if (time !== \"options\") {\n this.set({\n [time]: properties[time],\n });\n }\n }\n }\n if (options && options[DURATION]) {\n this.setDuration(options[DURATION]);\n }\n return this;\n }\n /**\n * clone SceneItem.\n * @return {SceneItem} An instance of clone\n * @example\n * item.clone();\n */\n public clone() {\n const item = new SceneItem();\n\n item.setOptions(this.state);\n item.setOrderObject(this.nameMap.orderMap);\n\n this.forEach((frame: Frame, time: number) => {\n item.setFrame(time, frame.clone());\n });\n return item;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Keyframes} An instance itself\n */\n public forEach(callback: (item: Frame, time: number, items: IObject) => void) {\n const times = this.times;\n const items = this.items;\n\n times.forEach(time => {\n callback(items[time], time, items);\n });\n return this;\n }\n public setOptions(options: Partial = {}) {\n super.setOptions(options);\n const { id, selector, elements, element, target } = options;\n\n id && this.setId(id);\n if (target) {\n this.setTarget(target);\n } else if (selector) {\n this.setSelector(selector);\n } else if (elements || element) {\n this.setElement(elements || element);\n }\n return this;\n }\n public toCSS(\n playCondition: PlayCondition = { className: START_ANIMATION },\n parentDuration = this.getDuration(), states: AnimatorState[] = []) {\n const itemState = this.state;\n const selector = itemState[SELECTOR];\n\n if (!selector) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n itemState[DURATION] = originalDuration;\n states.push(itemState);\n\n const reversedStates = toArray(states).reverse();\n const id = toId(getRealId(this));\n const superParent = states[0];\n const infiniteIndex = findIndex(reversedStates, state => {\n return state[ITERATION_COUNT] === INFINITE || !isFinite(state[DURATION]);\n }, states.length - 1);\n const finiteStates = reversedStates.slice(0, infiniteIndex);\n const duration = parentDuration || finiteStates.reduce((prev, cur) => {\n return (cur[DELAY] + prev * (cur[ITERATION_COUNT] as number)) / cur[PLAY_SPEED];\n }, originalDuration);\n const delay = reversedStates.slice(infiniteIndex).reduce((prev, cur) => {\n return (prev + cur[DELAY]) / cur[PLAY_SPEED];\n }, 0);\n const easingName = find(reversedStates, state => (state[EASING] && state[EASING_NAME]), itemState)[EASING_NAME];\n const iterationCount = reversedStates[infiniteIndex][ITERATION_COUNT];\n const fillMode = superParent[FILL_MODE];\n const direction = reversedStates[infiniteIndex][DIRECTION];\n const cssText = makeAnimationProperties({\n fillMode,\n direction,\n iterationCount,\n delay: `${delay}s`,\n name: `${PREFIX}KEYFRAMES_${id}`,\n duration: `${duration / superParent[PLAY_SPEED]}s`,\n timingFunction: easingName,\n });\n const selectors = splitComma(selector).map(sel => {\n const matches = /([\\s\\S]+)(:+[a-zA-Z]+)$/g.exec(sel);\n\n if (matches) {\n return [matches[1], matches[2]];\n } else {\n return [sel, \"\"];\n }\n });\n const className = playCondition.className;\n const selectorCallback = playCondition.selector;\n const preselector = isFunction(selectorCallback) ? selectorCallback(this, selector) : selectorCallback;\n\n return `\n ${preselector || selectors.map(([sel, peusdo]) => `${sel}.${className}${peusdo}`)} {${cssText}}\n ${selectors.map(([sel, peusdo]) => `${sel}.${PAUSE_ANIMATION}${peusdo}`)} {${ANIMATION}-play-state: paused;}\n @${KEYFRAMES} ${PREFIX}KEYFRAMES_${id}{${this._toKeyframes(duration, finiteStates, direction)}}`;\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {SceneItem} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition,\n duration?: number, options?: AnimatorState[]) {\n if (!this.elements.length) {\n return \"\";\n }\n const css = this.toCSS(playCondition, duration, options);\n const isParent = options && !isUndefined(options[ITERATION_COUNT]);\n\n if (!isParent) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n }\n return this;\n }\n public pause() {\n super.pause();\n isPausedCSS(this) && this.pauseCSS();\n return this;\n }\n public pauseCSS() {\n this.elements.forEach(element => {\n addClass(element, PAUSE_ANIMATION);\n });\n return this;\n }\n public endCSS() {\n this.elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n removeClass(element, START_ANIMATION);\n });\n setPlayCSS(this, false);\n return this;\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n item.playCSS();\n item.playCSS(false, \"startAnimation\", {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: object = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public getAnimationElement(): AnimateElement {\n return this.elements[0];\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n const elements = this.elements;\n const length = elements.length;\n const cssText = makeAnimationProperties(properties);\n\n if (!length) {\n return;\n }\n if (isPaused) {\n elements.forEach(element => {\n removeClass(element, PAUSE_ANIMATION);\n });\n } else {\n elements.forEach(element => {\n element.style.cssText += cssText;\n\n if (hasClass(element, START_ANIMATION)) {\n removeClass(element, START_ANIMATION);\n }\n });\n elements.forEach(element => {\n element.clientWidth;\n });\n elements.forEach(element => {\n addClass(element, START_ANIMATION);\n });\n }\n return elements[0];\n }\n /**\n * Clear All Frames\n * @return {SceneItem} An instance itself\n */\n public clear() {\n this.times = [];\n this.items = {};\n this.nameMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n this.temp = null;\n this.needUpdate = true;\n return this;\n }\n public getNowValue(\n time: number,\n properties: NameType[],\n left?: number,\n right?: number,\n isAccurate?: boolean,\n easing?: EasingType,\n usePrevValue?: boolean,\n ) {\n const times = this.times;\n const length = times.length;\n\n let prevTime: number;\n let nextTime: number;\n let prevFrame: Frame;\n let nextFrame: Frame;\n const isUndefinedLeft = isUndefined(left);\n const isUndefinedRight = isUndefined(right);\n if (isUndefinedLeft || isUndefinedRight) {\n const indicies = getNearTimeIndex(times, time);\n isUndefinedLeft && (left = indicies[0]);\n isUndefinedRight && (right = indicies[1]);\n }\n\n for (let i = left; i >= 0; --i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n prevTime = times[i];\n prevFrame = frame;\n break;\n }\n }\n const prevValue = prevFrame && prevFrame.raw(...properties);\n\n if (isAccurate && !isRole([properties[0]])) {\n return prevTime === time ? prevValue : undefined;\n }\n if (usePrevValue) {\n return prevValue;\n }\n for (let i = right; i < length; ++i) {\n const frame = this.getFrame(times[i]);\n\n if (frame.has(...properties)) {\n nextTime = times[i];\n nextFrame = frame;\n break;\n }\n }\n const nextValue = nextFrame && nextFrame.raw(...properties);\n\n if (!prevFrame || isUndefined(prevValue)) {\n return nextValue;\n }\n if (!nextFrame || isUndefined(nextValue) || prevValue === nextValue) {\n return prevValue;\n }\n return dotValue(time, Math.max(prevTime, 0), nextTime, prevValue, nextValue, easing);\n }\n private _toKeyframes(duration: number, states: AnimatorState[], direction: DirectionType) {\n const frames: IObject = {};\n const times = this.times.slice();\n\n if (!times.length) {\n return \"\";\n }\n const originalDuration = this.getDuration();\n (!this.getFrame(0)) && times.unshift(0);\n (!this.getFrame(originalDuration)) && times.push(originalDuration);\n const entries = getEntries(times, states);\n const lastEntry = entries[entries.length - 1];\n\n // end delay time\n lastEntry[0] < duration && addEntry(entries, duration, lastEntry[1]);\n let prevTime = -1;\n\n return entries.map(([time, keytime]) => {\n if (!frames[keytime]) {\n frames[keytime] =\n (!this.hasFrame(keytime) || keytime === 0 || keytime === originalDuration ?\n this.getNowFrame(keytime) : this.getNowFrame(keytime, 0, true)).toCSS();\n }\n\n let frameTime = time / duration * 100;\n\n if (frameTime - prevTime < THRESHOLD) {\n frameTime += THRESHOLD;\n }\n prevTime = frameTime;\n return `${Math.min(frameTime, 100)}%{\n ${time === 0 && !isDirectionReverse(0, 1, direction) ? \"\" : frames[keytime]}\n }`;\n }).join(\"\");\n }\n private updateFrameOrders() {\n const nameMap = this.nameMap.orderMap;\n\n this.forEach(frame => {\n frame.setOrderObject(nameMap);\n });\n }\n}\n\nexport default SceneItem;\n","import Animator from \"./Animator\";\nimport SceneItem from \"./SceneItem\";\nimport { SELECTOR, DURATION, DELAY, RUNNING, NAME_SEPARATOR } from \"./consts\";\nimport { playCSS, getRealId, isPausedCSS, isEndedCSS, setPlayCSS } from \"./utils\";\nimport { isFunction, IS_WINDOW, IObject, $, IArrayFormat } from \"@daybrush/utils\";\nimport {\n AnimateElement, SceneState, SceneOptions, EasingType,\n AnimatorState, SceneItemOptions, PlayCondition, NameType\n} from \"./types\";\nimport Frame from \"./Frame\";\nimport OrderMap from \"order-map\";\nimport styled, { InjectResult, StyledInjector } from \"css-styled\";\n/**\n * manage sceneItems and play Scene.\n * @sort 1\n */\nclass Scene extends Animator {\n /**\n * version info\n * @type {string}\n * @example\n * Scene.VERSION // #__VERSION__#\n */\n public static VERSION: string = \"#__VERSION__#\";\n public items: IObject = {};\n public orderMap = new OrderMap(NAME_SEPARATOR);\n public styled: StyledInjector;\n public styledInjector: InjectResult;\n public temp: IObject;\n /**\n * @param - properties\n * @param - options\n * @example\n const scene = new Scene({\n item1: {\n 0: {\n display: \"none\",\n },\n 1: {\n display: \"block\",\n opacity: 0,\n },\n 2: {\n opacity: 1,\n },\n },\n item2: {\n 2: {\n opacity: 1,\n },\n }\n });\n */\n constructor(properties?: { options?: Partial } & IObject, options?: Partial) {\n super();\n this.load(properties, options);\n }\n public getDuration() {\n let time = 0;\n\n this.forEach(item => {\n time = Math.max(time, item.getTotalDuration() / item.getPlaySpeed());\n });\n return time || this.state[DURATION];\n }\n public setDuration(duration: number) {\n const items = this.items;\n const sceneDuration = this.getDuration();\n\n if (duration === 0 || !isFinite(sceneDuration)) {\n return this;\n }\n if (sceneDuration === 0) {\n this.forEach(item => {\n item.setDuration(duration);\n });\n } else {\n const ratio = duration / sceneDuration;\n\n this.forEach(item => {\n item.setDelay(item.getDelay() * ratio);\n item.setDuration(item.getDuration() * ratio);\n });\n }\n super.setDuration(duration);\n return this;\n }\n public getItem(name: number | string): T;\n /**\n * get item in scene by name\n * @param - The item's name\n * @return {Scene | SceneItem} item\n * @example\n const item = scene.getItem(\"item1\")\n */\n public getItem(name: number | string) {\n return this.items[name];\n }\n /**\n * create item in scene\n * @param {} name - name of item to create\n * @param {} options - The option object of SceneItem\n * @return {} Newly created item\n * @example\n const item = scene.newItem(\"item1\")\n */\n public newItem(name: number | string, options: Partial = {}): Scene | SceneItem {\n if (this.items[name]) {\n return this.items[name];\n }\n const item = new SceneItem();\n\n this.setItem(name, item);\n item.setOptions(options);\n\n return item;\n }\n /**\n * remove item in scene\n * @param - name of item to remove\n * @return An instance itself\n * @example\n const item = scene.newItem(\"item1\")\n\n scene.removeItem(\"item1\");\n */\n public removeItem(name: number | string): this {\n delete this.items[name];\n\n this.orderMap.remove([name]);\n return this;\n }\n /**\n * add a sceneItem to the scene\n * @param - name of item to create\n * @param - sceneItem\n * @example\n const item = scene.newItem(\"item1\")\n */\n public setItem(name: number | string, item: Scene | SceneItem) {\n item.setId(name);\n this.items[name] = item;\n\n this.orderMap.add([name]);\n return this;\n }\n public setTime(time: number | string, isTick?: boolean, isParent?: boolean, parentEasing?: EasingType) {\n super.setTime(time, isTick, isParent);\n\n const iterationTime = this.getIterationTime();\n const easing = this.getEasing() || parentEasing;\n const frames: IObject = {};\n\n this.forEach(item => {\n item.setTime(iterationTime * item.getPlaySpeed() - item.getDelay(), isTick, true, easing);\n\n frames[item.getId()] = item.temp;\n });\n this.temp = frames;\n\n /**\n * This event is fired when timeupdate and animate.\n * @event Scene#animate\n * @param {object} param The object of data to be sent to an event.\n * @param {number} param.currentTime The total time that the animator is running.\n * @param {number} param.time The iteration time during duration that the animator is running.\n * @param {object} param.frames frames of that time.\n * @example\nconst scene = new Scene({\n a: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n },\n b: {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n }\n }\n}).on(\"animate\", e => {\n console.log(e.frames);\n // {a: Frame, b: Frame}\n console.log(e.frames.a.get(\"opacity\"));\n});\n */\n this.trigger(\"animate\", {\n frames,\n currentTime: this.getTime(),\n time: iterationTime,\n });\n\n return this;\n }\n /**\n * executes a provided function once for each scene item.\n * @param - Function to execute for each element, taking three arguments\n * @return {Scene} An instance itself\n */\n public forEach(\n func: (\n item: Scene | SceneItem,\n id: string | number,\n index: number,\n items: IObject,\n ) => void,\n ) {\n const items = this.items;\n this.getOrders().forEach((id, index) => {\n func(items[id], id, index, items);\n });\n return this;\n }\n public toCSS(\n playCondition?: PlayCondition,\n duration: number = this.getDuration(), parentStates: AnimatorState[] = []) {\n const totalDuration = !duration || !isFinite(duration) ? 0 : duration;\n const styles: string[] = [];\n const state = this.state;\n\n state[DURATION] = this.getDuration();\n\n this.forEach(item => {\n styles.push(item.toCSS(playCondition, totalDuration, parentStates.concat(state)));\n });\n return styles.join(\"\");\n }\n /**\n * Export the CSS of the items to the style.\n * @param - Add a selector or className to play.\n * @return {Scene} An instance itself\n */\n public exportCSS(\n playCondition?: PlayCondition, duration?: number, parentStates?: AnimatorState[]) {\n const css = this.toCSS(playCondition, duration, parentStates);\n\n if (!parentStates || !parentStates.length) {\n if (this.styledInjector) {\n this.styledInjector.destroy();\n this.styledInjector = null;\n }\n this.styled = styled(css);\n this.styledInjector = this.styled.inject(this.getAnimationElement(), { original: true });\n // && exportCSS(getRealId(this), css);\n }\n return this;\n }\n public append(item: SceneItem | Scene) {\n item.setDelay(item.getDelay() + this.getDuration());\n this.setItem(getRealId(item), item);\n }\n public pauseCSS() {\n return this.forEach(item => {\n item.pauseCSS();\n });\n }\n public pause() {\n super.pause();\n\n isPausedCSS(this) && this.pauseCSS();\n this.forEach(item => {\n item.pause();\n });\n return this;\n }\n public endCSS() {\n this.forEach(item => {\n item.endCSS();\n });\n setPlayCSS(this, false);\n }\n public end() {\n isEndedCSS(this) && this.endCSS();\n super.end();\n return this;\n }\n /**\n * get item orders\n * @example\n scene.getOrders() // => [\"item1\", \"item2\"]\n */\n public getOrders(): NameType[] {\n return this.orderMap.get([]) || [];\n }\n /**\n * set item orders\n * @param - orders\n * @example\n frame.setOrders([\"item2\", \"item1\"]) // => [\"item2\", \"item1\"]\n */\n public setOrders(orders: NameType[]): NameType[] {\n return this.orderMap.set([], orders);\n }\n public getAnimationElement() {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.getAnimationElement();\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n public addPlayClass(isPaused: boolean, playClassName?: string, properties: object = {}) {\n let animtionElement: AnimateElement;\n\n this.forEach(item => {\n const el = item.addPlayClass(isPaused, playClassName, properties);\n\n !animtionElement && (animtionElement = el);\n });\n return animtionElement;\n }\n /**\n * Play using the css animation and keyframes.\n * @param - Check if you want to export css.\n * @param [playClassName=\"startAnimation\"] - Add a class name to play.\n * @param - The shorthand properties for six of the animation properties.\n * @return {Scene} An instance itself\n * @see {@link https://www.w3schools.com/cssref/css3_pr_animation.asp}\n * @example\n scene.playCSS();\n scene.playCSS(false, {\n direction: \"reverse\",\n fillMode: \"forwards\",\n });\n */\n public playCSS(isExportCSS = true, playClassName?: string, properties: Partial = {}) {\n playCSS(this, isExportCSS, playClassName, properties);\n return this;\n }\n public set(properties: any, ...args: any[]): this;\n /**\n * Set properties to the Scene.\n * @param - properties\n * @return An instance itself\n * @example\nscene.set({\n \".a\": {\n 0: {\n opacity: 0,\n },\n 1: {\n opacity: 1,\n },\n },\n});\n// 0\nconsole.log(scene.getItem(\".a\").get(0, \"opacity\"));\n// 1\nconsole.log(scene.getItem(\".a\").get(1, \"opacity\"));\n */\n public set(properties: any) {\n this.load(properties);\n return this;\n }\n /**\n * Clear All Items\n * @return {Scene} An instance itself\n */\n public clear() {\n this.finish();\n this.items = {};\n this.orderMap = new OrderMap(NAME_SEPARATOR);\n\n if (this.styledInjector) {\n this.styledInjector.destroy();\n }\n this.styled = null;\n this.styledInjector = null;\n }\n public load(properties: any = {}, options = properties.options) {\n if (!properties) {\n return this;\n }\n const selector = options && options[SELECTOR] || this.state[SELECTOR];\n for (const name in properties) {\n if (name === \"options\") {\n continue;\n }\n const object = properties[name];\n let item;\n\n if (object instanceof Scene || object instanceof SceneItem) {\n this.setItem(name, object);\n item = object;\n } else if (isFunction(object) && selector) {\n const elements =\n IS_WINDOW\n ? $(`${isFunction(selector) ? selector(name) : name}`, true) as IArrayFormat\n : ([] as AnimateElement[]);\n const length = elements.length;\n const scene = new Scene();\n\n for (let i = 0; i < length; ++i) {\n (scene.newItem(i) as SceneItem).setId().setElement(elements[i]).load(object(i, elements[i]));\n }\n this.setItem(name, scene);\n continue;\n } else {\n item = this.newItem(name);\n item.load(object);\n }\n selector && item.setSelector(selector);\n }\n this.setOptions(options);\n }\n public setOptions(options: Partial = {}): this {\n super.setOptions(options);\n\n const selector = options.selector;\n\n if (selector) {\n this.state[SELECTOR] = selector;\n }\n return this;\n }\n public setSelector(target?: string | boolean | ((id: number | string) => string)) {\n const state = this.state;\n const selector = target || state[SELECTOR];\n\n state[SELECTOR] = selector;\n const isItFunction = isFunction(target);\n if (selector) {\n this.forEach((item, name) => {\n item.setSelector(isItFunction ? (target as (id: number | string) => string)(name) : selector);\n });\n }\n return this;\n }\n public start(delay: number = this.state[DELAY]): boolean {\n const result = super.start(delay);\n\n if (result) {\n this.forEach(item => {\n item.start(0);\n });\n } else {\n this.forEach(item => {\n item.setPlayState(RUNNING);\n });\n }\n return result;\n }\n}\n\nexport default Scene;\n","import { IObject } from \"@daybrush/utils\";\nimport Scene from \"./Scene\";\nimport SceneItem from \"./SceneItem\";\nimport { SceneOptions, SceneItemOptions } from \"./types\";\n\nexport function animate(properties?: IObject, options?: Partial) {\n return new Scene(properties, options).play();\n}\nexport function animateItem(properties?: IObject, options?: Partial) {\n return new SceneItem(properties, options).play();\n}\n","import Scene, * as others from \"./index\";\n\nfor (const name in others) {\n (Scene as any)[name] = (others as any)[name];\n}\n\nexport default Scene;\n"],"names":["cubic","y1","y2","t","t2","bezier","x1","x2","func","x","dx","Math","abs","solveFromX","max","min","easingName","steps","count","position","time","level","floor","STEP_START","STEP_END","LINEAR","EASE","EASE_IN","EASE_OUT","EASE_IN_OUT","PREFIX","DATA_SCENE_ID","TIMING_FUNCTION","ROLES","transform","filter","attribute","html","ALIAS","easing","FIXED","_a","MAXIMUM","THRESHOLD","DURATION","FILL_MODE","DIRECTION","ITERATION_COUNT","DELAY","EASING","PLAY_SPEED","EASING_NAME","PAUSED","ENDED","TIMEUPDATE","PLAY","RUNNING","ITERATION","START_ANIMATION","PAUSE_ANIMATION","ALTERNATE","REVERSE","ALTERNATE_REVERSE","INFINITE","PLAY_STATE","PLAY_CSS","PREV_TIME","TICK_TIME","CURRENT_TIME","SELECTOR","TRANSFORM_NAME","EASINGS","NAME_SEPARATOR","OPTIONS","EVENTS","events","name","callback","once","this","isObject","n","_on","isArray","forEach","_this","push","callback2","_i","args","off","callbacks","index","indexOf","splice","data","target","type","currentTarget","toArray","apply","value","options","setOptions","isString","split","separator","newOptions","length","prefix","suffix","model","PropertyObject","map","v","clone","join","toValue","arrayToColorObject","arr","RGBA","arrayToPropertyObject","toPropertyObject","values","splitComma","splitSpace","exec","text","splitBracket","afterModel","COLOR_MODELS","stringToRGBA","obj","stringToBracketObject","charAt","result","stringToColorObject","isPropertyObject","getType","OBJECT","ARRAY","PROPERTY","STRING","NUMBER","isPureObject","constructor","Object","getNames","names","stack","concat","pop","slice","toFixed","num","round","getValueByNames","properties","i","isInProperties","roles","isCheckTrue","role","isRole","isFixed","setPlayCSS","item","isActivate","state","isPausedCSS","isPaused","isEndedCSS","isEnded","makeId","selector","id","random","IS_WINDOW","$","getRealId","getId","setId","toId","match","playCSS","isExportCSS","playClassName","ANIMATION","getPlayState","className","addPlayClass","setTime","exportCSS","el","animationend","finish","animationstart","trigger","addEvent","animationiteration","duration","getDuration","isZeroDuration","isFinite","removeEvent","currentTime","iterationCount","setIteration","addAnimationEvent","setPlayState","getEasing","curveArray","parseFloat","isDirectionReverse","iteration","iteraiontCount","direction","setters","getters","_super","delay","fillMode","playSpeed","iterationTime","tickTime","prevTime","playState","__extends","setDuration","setEasing","getActiveDuration","Infinity","getTime","toTime","timerId","requestAnimationFrame","tick","start","cancelAnimationFrame","end","pause","isTick","isParent","activeDuration","getUnitTime","calculate","isDelay","getIterationTime","splitUnit","unit","passIterationCount","maxIterationCount","currentIterationTime","setIterationTime","isReverse","isFiniteDuration","now","to","Animator","getter","setter","parent","prototype","camelize","GetterSetter","EventTrigger","toInnerProperties","orders","arrObj","keys","getKeys","sortOrders","replace","merge","from","FUNCTION","getValue","getPropertyName","OrderMap","set","raw","orderMap","get","getObject","setObject","key","children","gets","params","remove","self","firstParam","Frame","_set","toObject","object","size","has","str","splitText","totalLength","matches","trim","styles","splitStyle","stylesLength","isUndefined","frame","setOrderObject","frameProperties","cssObject","FILTER","TRANSFORM","toCSSObject","cssArray","clear","lastParam","add","dotArray","a1","a2","b1","b2","v1","dot","dotObject","a1Type","color1","color2","value1","value2","model1","colorModel","parseInt","dotColor","type1","type2","isFunction1","isFunction2","v2","isNaN","dotNumber","getNearTimeIndex","times","makeAnimationProperties","decamelize","addEntry","entries","keytime","prevEntry","load","originalDuration","ratio_1","items_1","obj_1","time2","items","newFrame","elements","sceneId_1","element","setAttribute","SceneItem","eachTime","realTime","innerValue","value_1","getDelay","frames","hasFrame","getDirection","frameTime","nextTime","needUpdate","getFrame","update","nameMap","updateFrameOrders","removeFrame","append","unshiftTime","firstFrame","unshift","prepend","isStartZero","isFunction","setElement","Element","style","targetFunc","attributes","html_1","innerHTML","cssText","toCSS","fromCSS","parentEasing","getNowFrame","temp","prevNameMap","updateFrame","pushKeys","nextMap","setFrame","addTime","isAccurate","left","right","realEasing","hasName","nowEasing","getNowValue","prevFrame_1","prevOrderMap","keyframes","setTarget","setSelector","playCondition","parentDuration","states","itemState","reversedStates","reverse","superParent","infiniteIndex","findIndex","finiteStates","reduce","prev","cur","find","timingFunction","selectors","sel","selectorCallback","peusdo","KEYFRAMES","_toKeyframes","css","styledInjector","destroy","styled","inject","getAnimationElement","original","pauseCSS","addClass","removeClass","endCSS","hasClass","clientWidth","usePrevValue","prevFrame","nextFrame","isUndefinedLeft","isUndefinedRight","indicies","prevValue","undefined","nextValue","ratio","dotValue","nextEntries","intCount","ceil","currentDuration","lastTime","j","entry","divideTime","getEntries","lastEntry","getTotalDuration","getPlaySpeed","sceneDuration","setDelay","setItem","getOrders","parentStates","totalDuration","animtionElement","Scene","scene","newItem","isItFunction","isProperty","isFixedProperty","fixed","alias","play","others"],"mappings":"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"} \ No newline at end of file