demgirlz/demweb/static/js/waveform-playlist.var.js

10559 lines
294 KiB
JavaScript

var WaveformPlaylist =
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId])
/******/ return installedModules[moduleId].exports;
/******/
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ exports: {},
/******/ id: moduleId,
/******/ loaded: false
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.loaded = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "/waveform-playlist/js/";
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.init = init;
exports.default = function () {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var ee = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (0, _eventEmitter2.default)();
return init(options, ee);
};
var _lodash = __webpack_require__(1);
var _lodash2 = _interopRequireDefault(_lodash);
var _createElement = __webpack_require__(3);
var _createElement2 = _interopRequireDefault(_createElement);
var _eventEmitter = __webpack_require__(16);
var _eventEmitter2 = _interopRequireDefault(_eventEmitter);
var _Playlist = __webpack_require__(37);
var _Playlist2 = _interopRequireDefault(_Playlist);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function init() {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var ee = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (0, _eventEmitter2.default)();
if (options.container === undefined) {
throw new Error('DOM element container must be given.');
}
window.OfflineAudioContext = window.OfflineAudioContext || window.webkitOfflineAudioContext;
window.AudioContext = window.AudioContext || window.webkitAudioContext;
var audioContext = new window.AudioContext();
var defaults = {
ac: audioContext,
sampleRate: audioContext.sampleRate,
samplesPerPixel: 4096,
mono: true,
fadeType: 'logarithmic',
exclSolo: false,
timescale: false,
controls: {
show: false,
width: 150,
widgets: {
muteOrSolo: true,
volume: true,
stereoPan: true,
collapse: true,
remove: true,
info: true
}
},
colors: {
waveOutlineColor: 'white',
timeColor: 'grey',
fadeColor: 'black'
},
seekStyle: 'line',
waveHeight: 128,
collapsedWaveHeight: 30,
state: 'cursor',
zoomLevels: [512, 1024, 2048, 4096],
annotationList: {
annotations: [],
controls: [],
editable: false,
linkEndpoints: false,
isContinuousPlay: false
},
isAutomaticScroll: false
};
var config = (0, _lodash2.default)({}, options, defaults);
var zoomIndex = config.zoomLevels.indexOf(config.samplesPerPixel);
if (zoomIndex === -1) {
throw new Error('initial samplesPerPixel must be included in array zoomLevels');
}
var playlist = new _Playlist2.default();
playlist.setSampleRate(config.sampleRate);
playlist.setSamplesPerPixel(config.samplesPerPixel);
playlist.setAudioContext(config.ac);
playlist.setEventEmitter(ee);
playlist.setUpEventEmitter();
playlist.setTimeSelection(0, 0);
playlist.setState(config.state);
playlist.setControlOptions(config.controls);
playlist.setWaveHeight(config.waveHeight);
playlist.setCollapsedWaveHeight(config.collapsedWaveHeight);
playlist.setColors(config.colors);
playlist.setZoomLevels(config.zoomLevels);
playlist.setZoomIndex(zoomIndex);
playlist.setMono(config.mono);
playlist.setExclSolo(config.exclSolo);
playlist.setShowTimeScale(config.timescale);
playlist.setSeekStyle(config.seekStyle);
playlist.setAnnotations(config.annotationList);
playlist.isAutomaticScroll = config.isAutomaticScroll;
playlist.isContinuousPlay = config.isContinuousPlay;
playlist.linkedEndpoints = config.linkedEndpoints;
// take care of initial virtual dom rendering.
var tree = playlist.render();
var rootNode = (0, _createElement2.default)(tree);
config.container.appendChild(rootNode);
playlist.tree = tree;
playlist.rootNode = rootNode;
return playlist;
}
/***/ }),
/* 1 */
/***/ (function(module, exports, __webpack_require__) {
/* WEBPACK VAR INJECTION */(function(global, module) {/**
* Lodash (Custom Build) <https://lodash.com/>
* Build: `lodash modularize exports="npm" -o ./`
* Copyright OpenJS Foundation and other contributors <https://openjsf.org/>
* Released under MIT license <https://lodash.com/license>
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
* Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
*/
/** Used as the size to enable large array optimizations. */
var LARGE_ARRAY_SIZE = 200;
/** Used to stand-in for `undefined` hash values. */
var HASH_UNDEFINED = '__lodash_hash_undefined__';
/** Used to detect hot functions by number of calls within a span of milliseconds. */
var HOT_COUNT = 800,
HOT_SPAN = 16;
/** Used as references for various `Number` constants. */
var MAX_SAFE_INTEGER = 9007199254740991;
/** `Object#toString` result references. */
var argsTag = '[object Arguments]',
arrayTag = '[object Array]',
asyncTag = '[object AsyncFunction]',
boolTag = '[object Boolean]',
dateTag = '[object Date]',
errorTag = '[object Error]',
funcTag = '[object Function]',
genTag = '[object GeneratorFunction]',
mapTag = '[object Map]',
numberTag = '[object Number]',
nullTag = '[object Null]',
objectTag = '[object Object]',
proxyTag = '[object Proxy]',
regexpTag = '[object RegExp]',
setTag = '[object Set]',
stringTag = '[object String]',
undefinedTag = '[object Undefined]',
weakMapTag = '[object WeakMap]';
var arrayBufferTag = '[object ArrayBuffer]',
dataViewTag = '[object DataView]',
float32Tag = '[object Float32Array]',
float64Tag = '[object Float64Array]',
int8Tag = '[object Int8Array]',
int16Tag = '[object Int16Array]',
int32Tag = '[object Int32Array]',
uint8Tag = '[object Uint8Array]',
uint8ClampedTag = '[object Uint8ClampedArray]',
uint16Tag = '[object Uint16Array]',
uint32Tag = '[object Uint32Array]';
/**
* Used to match `RegExp`
* [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
*/
var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
/** Used to detect host constructors (Safari). */
var reIsHostCtor = /^\[object .+?Constructor\]$/;
/** Used to detect unsigned integer values. */
var reIsUint = /^(?:0|[1-9]\d*)$/;
/** Used to identify `toStringTag` values of typed arrays. */
var typedArrayTags = {};
typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =
typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =
typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =
typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =
typedArrayTags[uint32Tag] = true;
typedArrayTags[argsTag] = typedArrayTags[arrayTag] =
typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =
typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =
typedArrayTags[errorTag] = typedArrayTags[funcTag] =
typedArrayTags[mapTag] = typedArrayTags[numberTag] =
typedArrayTags[objectTag] = typedArrayTags[regexpTag] =
typedArrayTags[setTag] = typedArrayTags[stringTag] =
typedArrayTags[weakMapTag] = false;
/** Detect free variable `global` from Node.js. */
var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;
/** Detect free variable `self`. */
var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
/** Used as a reference to the global object. */
var root = freeGlobal || freeSelf || Function('return this')();
/** Detect free variable `exports`. */
var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;
/** Detect free variable `module`. */
var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;
/** Detect the popular CommonJS extension `module.exports`. */
var moduleExports = freeModule && freeModule.exports === freeExports;
/** Detect free variable `process` from Node.js. */
var freeProcess = moduleExports && freeGlobal.process;
/** Used to access faster Node.js helpers. */
var nodeUtil = (function() {
try {
// Use `util.types` for Node.js 10+.
var types = freeModule && freeModule.require && freeModule.require('util').types;
if (types) {
return types;
}
// Legacy `process.binding('util')` for Node.js < 10.
return freeProcess && freeProcess.binding && freeProcess.binding('util');
} catch (e) {}
}());
/* Node.js helper references. */
var nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;
/**
* A faster alternative to `Function#apply`, this function invokes `func`
* with the `this` binding of `thisArg` and the arguments of `args`.
*
* @private
* @param {Function} func The function to invoke.
* @param {*} thisArg The `this` binding of `func`.
* @param {Array} args The arguments to invoke `func` with.
* @returns {*} Returns the result of `func`.
*/
function apply(func, thisArg, args) {
switch (args.length) {
case 0: return func.call(thisArg);
case 1: return func.call(thisArg, args[0]);
case 2: return func.call(thisArg, args[0], args[1]);
case 3: return func.call(thisArg, args[0], args[1], args[2]);
}
return func.apply(thisArg, args);
}
/**
* The base implementation of `_.times` without support for iteratee shorthands
* or max array length checks.
*
* @private
* @param {number} n The number of times to invoke `iteratee`.
* @param {Function} iteratee The function invoked per iteration.
* @returns {Array} Returns the array of results.
*/
function baseTimes(n, iteratee) {
var index = -1,
result = Array(n);
while (++index < n) {
result[index] = iteratee(index);
}
return result;
}
/**
* The base implementation of `_.unary` without support for storing metadata.
*
* @private
* @param {Function} func The function to cap arguments for.
* @returns {Function} Returns the new capped function.
*/
function baseUnary(func) {
return function(value) {
return func(value);
};
}
/**
* Gets the value at `key` of `object`.
*
* @private
* @param {Object} [object] The object to query.
* @param {string} key The key of the property to get.
* @returns {*} Returns the property value.
*/
function getValue(object, key) {
return object == null ? undefined : object[key];
}
/**
* Creates a unary function that invokes `func` with its argument transformed.
*
* @private
* @param {Function} func The function to wrap.
* @param {Function} transform The argument transform.
* @returns {Function} Returns the new function.
*/
function overArg(func, transform) {
return function(arg) {
return func(transform(arg));
};
}
/** Used for built-in method references. */
var arrayProto = Array.prototype,
funcProto = Function.prototype,
objectProto = Object.prototype;
/** Used to detect overreaching core-js shims. */
var coreJsData = root['__core-js_shared__'];
/** Used to resolve the decompiled source of functions. */
var funcToString = funcProto.toString;
/** Used to check objects for own properties. */
var hasOwnProperty = objectProto.hasOwnProperty;
/** Used to detect methods masquerading as native. */
var maskSrcKey = (function() {
var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');
return uid ? ('Symbol(src)_1.' + uid) : '';
}());
/**
* Used to resolve the
* [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
* of values.
*/
var nativeObjectToString = objectProto.toString;
/** Used to infer the `Object` constructor. */
var objectCtorString = funcToString.call(Object);
/** Used to detect if a method is native. */
var reIsNative = RegExp('^' +
funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&')
.replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
);
/** Built-in value references. */
var Buffer = moduleExports ? root.Buffer : undefined,
Symbol = root.Symbol,
Uint8Array = root.Uint8Array,
allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,
getPrototype = overArg(Object.getPrototypeOf, Object),
objectCreate = Object.create,
propertyIsEnumerable = objectProto.propertyIsEnumerable,
splice = arrayProto.splice,
symToStringTag = Symbol ? Symbol.toStringTag : undefined;
var defineProperty = (function() {
try {
var func = getNative(Object, 'defineProperty');
func({}, '', {});
return func;
} catch (e) {}
}());
/* Built-in method references for those with the same name as other `lodash` methods. */
var nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,
nativeMax = Math.max,
nativeNow = Date.now;
/* Built-in method references that are verified to be native. */
var Map = getNative(root, 'Map'),
nativeCreate = getNative(Object, 'create');
/**
* The base implementation of `_.create` without support for assigning
* properties to the created object.
*
* @private
* @param {Object} proto The object to inherit from.
* @returns {Object} Returns the new object.
*/
var baseCreate = (function() {
function object() {}
return function(proto) {
if (!isObject(proto)) {
return {};
}
if (objectCreate) {
return objectCreate(proto);
}
object.prototype = proto;
var result = new object;
object.prototype = undefined;
return result;
};
}());
/**
* Creates a hash object.
*
* @private
* @constructor
* @param {Array} [entries] The key-value pairs to cache.
*/
function Hash(entries) {
var index = -1,
length = entries == null ? 0 : entries.length;
this.clear();
while (++index < length) {
var entry = entries[index];
this.set(entry[0], entry[1]);
}
}
/**
* Removes all key-value entries from the hash.
*
* @private
* @name clear
* @memberOf Hash
*/
function hashClear() {
this.__data__ = nativeCreate ? nativeCreate(null) : {};
this.size = 0;
}
/**
* Removes `key` and its value from the hash.
*
* @private
* @name delete
* @memberOf Hash
* @param {Object} hash The hash to modify.
* @param {string} key The key of the value to remove.
* @returns {boolean} Returns `true` if the entry was removed, else `false`.
*/
function hashDelete(key) {
var result = this.has(key) && delete this.__data__[key];
this.size -= result ? 1 : 0;
return result;
}
/**
* Gets the hash value for `key`.
*
* @private
* @name get
* @memberOf Hash
* @param {string} key The key of the value to get.
* @returns {*} Returns the entry value.
*/
function hashGet(key) {
var data = this.__data__;
if (nativeCreate) {
var result = data[key];
return result === HASH_UNDEFINED ? undefined : result;
}
return hasOwnProperty.call(data, key) ? data[key] : undefined;
}
/**
* Checks if a hash value for `key` exists.
*
* @private
* @name has
* @memberOf Hash
* @param {string} key The key of the entry to check.
* @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
*/
function hashHas(key) {
var data = this.__data__;
return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);
}
/**
* Sets the hash `key` to `value`.
*
* @private
* @name set
* @memberOf Hash
* @param {string} key The key of the value to set.
* @param {*} value The value to set.
* @returns {Object} Returns the hash instance.
*/
function hashSet(key, value) {
var data = this.__data__;
this.size += this.has(key) ? 0 : 1;
data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;
return this;
}
// Add methods to `Hash`.
Hash.prototype.clear = hashClear;
Hash.prototype['delete'] = hashDelete;
Hash.prototype.get = hashGet;
Hash.prototype.has = hashHas;
Hash.prototype.set = hashSet;
/**
* Creates an list cache object.
*
* @private
* @constructor
* @param {Array} [entries] The key-value pairs to cache.
*/
function ListCache(entries) {
var index = -1,
length = entries == null ? 0 : entries.length;
this.clear();
while (++index < length) {
var entry = entries[index];
this.set(entry[0], entry[1]);
}
}
/**
* Removes all key-value entries from the list cache.
*
* @private
* @name clear
* @memberOf ListCache
*/
function listCacheClear() {
this.__data__ = [];
this.size = 0;
}
/**
* Removes `key` and its value from the list cache.
*
* @private
* @name delete
* @memberOf ListCache
* @param {string} key The key of the value to remove.
* @returns {boolean} Returns `true` if the entry was removed, else `false`.
*/
function listCacheDelete(key) {
var data = this.__data__,
index = assocIndexOf(data, key);
if (index < 0) {
return false;
}
var lastIndex = data.length - 1;
if (index == lastIndex) {
data.pop();
} else {
splice.call(data, index, 1);
}
--this.size;
return true;
}
/**
* Gets the list cache value for `key`.
*
* @private
* @name get
* @memberOf ListCache
* @param {string} key The key of the value to get.
* @returns {*} Returns the entry value.
*/
function listCacheGet(key) {
var data = this.__data__,
index = assocIndexOf(data, key);
return index < 0 ? undefined : data[index][1];
}
/**
* Checks if a list cache value for `key` exists.
*
* @private
* @name has
* @memberOf ListCache
* @param {string} key The key of the entry to check.
* @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
*/
function listCacheHas(key) {
return assocIndexOf(this.__data__, key) > -1;
}
/**
* Sets the list cache `key` to `value`.
*
* @private
* @name set
* @memberOf ListCache
* @param {string} key The key of the value to set.
* @param {*} value The value to set.
* @returns {Object} Returns the list cache instance.
*/
function listCacheSet(key, value) {
var data = this.__data__,
index = assocIndexOf(data, key);
if (index < 0) {
++this.size;
data.push([key, value]);
} else {
data[index][1] = value;
}
return this;
}
// Add methods to `ListCache`.
ListCache.prototype.clear = listCacheClear;
ListCache.prototype['delete'] = listCacheDelete;
ListCache.prototype.get = listCacheGet;
ListCache.prototype.has = listCacheHas;
ListCache.prototype.set = listCacheSet;
/**
* Creates a map cache object to store key-value pairs.
*
* @private
* @constructor
* @param {Array} [entries] The key-value pairs to cache.
*/
function MapCache(entries) {
var index = -1,
length = entries == null ? 0 : entries.length;
this.clear();
while (++index < length) {
var entry = entries[index];
this.set(entry[0], entry[1]);
}
}
/**
* Removes all key-value entries from the map.
*
* @private
* @name clear
* @memberOf MapCache
*/
function mapCacheClear() {
this.size = 0;
this.__data__ = {
'hash': new Hash,
'map': new (Map || ListCache),
'string': new Hash
};
}
/**
* Removes `key` and its value from the map.
*
* @private
* @name delete
* @memberOf MapCache
* @param {string} key The key of the value to remove.
* @returns {boolean} Returns `true` if the entry was removed, else `false`.
*/
function mapCacheDelete(key) {
var result = getMapData(this, key)['delete'](key);
this.size -= result ? 1 : 0;
return result;
}
/**
* Gets the map value for `key`.
*
* @private
* @name get
* @memberOf MapCache
* @param {string} key The key of the value to get.
* @returns {*} Returns the entry value.
*/
function mapCacheGet(key) {
return getMapData(this, key).get(key);
}
/**
* Checks if a map value for `key` exists.
*
* @private
* @name has
* @memberOf MapCache
* @param {string} key The key of the entry to check.
* @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
*/
function mapCacheHas(key) {
return getMapData(this, key).has(key);
}
/**
* Sets the map `key` to `value`.
*
* @private
* @name set
* @memberOf MapCache
* @param {string} key The key of the value to set.
* @param {*} value The value to set.
* @returns {Object} Returns the map cache instance.
*/
function mapCacheSet(key, value) {
var data = getMapData(this, key),
size = data.size;
data.set(key, value);
this.size += data.size == size ? 0 : 1;
return this;
}
// Add methods to `MapCache`.
MapCache.prototype.clear = mapCacheClear;
MapCache.prototype['delete'] = mapCacheDelete;
MapCache.prototype.get = mapCacheGet;
MapCache.prototype.has = mapCacheHas;
MapCache.prototype.set = mapCacheSet;
/**
* Creates a stack cache object to store key-value pairs.
*
* @private
* @constructor
* @param {Array} [entries] The key-value pairs to cache.
*/
function Stack(entries) {
var data = this.__data__ = new ListCache(entries);
this.size = data.size;
}
/**
* Removes all key-value entries from the stack.
*
* @private
* @name clear
* @memberOf Stack
*/
function stackClear() {
this.__data__ = new ListCache;
this.size = 0;
}
/**
* Removes `key` and its value from the stack.
*
* @private
* @name delete
* @memberOf Stack
* @param {string} key The key of the value to remove.
* @returns {boolean} Returns `true` if the entry was removed, else `false`.
*/
function stackDelete(key) {
var data = this.__data__,
result = data['delete'](key);
this.size = data.size;
return result;
}
/**
* Gets the stack value for `key`.
*
* @private
* @name get
* @memberOf Stack
* @param {string} key The key of the value to get.
* @returns {*} Returns the entry value.
*/
function stackGet(key) {
return this.__data__.get(key);
}
/**
* Checks if a stack value for `key` exists.
*
* @private
* @name has
* @memberOf Stack
* @param {string} key The key of the entry to check.
* @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
*/
function stackHas(key) {
return this.__data__.has(key);
}
/**
* Sets the stack `key` to `value`.
*
* @private
* @name set
* @memberOf Stack
* @param {string} key The key of the value to set.
* @param {*} value The value to set.
* @returns {Object} Returns the stack cache instance.
*/
function stackSet(key, value) {
var data = this.__data__;
if (data instanceof ListCache) {
var pairs = data.__data__;
if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {
pairs.push([key, value]);
this.size = ++data.size;
return this;
}
data = this.__data__ = new MapCache(pairs);
}
data.set(key, value);
this.size = data.size;
return this;
}
// Add methods to `Stack`.
Stack.prototype.clear = stackClear;
Stack.prototype['delete'] = stackDelete;
Stack.prototype.get = stackGet;
Stack.prototype.has = stackHas;
Stack.prototype.set = stackSet;
/**
* Creates an array of the enumerable property names of the array-like `value`.
*
* @private
* @param {*} value The value to query.
* @param {boolean} inherited Specify returning inherited property names.
* @returns {Array} Returns the array of property names.
*/
function arrayLikeKeys(value, inherited) {
var isArr = isArray(value),
isArg = !isArr && isArguments(value),
isBuff = !isArr && !isArg && isBuffer(value),
isType = !isArr && !isArg && !isBuff && isTypedArray(value),
skipIndexes = isArr || isArg || isBuff || isType,
result = skipIndexes ? baseTimes(value.length, String) : [],
length = result.length;
for (var key in value) {
if ((inherited || hasOwnProperty.call(value, key)) &&
!(skipIndexes && (
// Safari 9 has enumerable `arguments.length` in strict mode.
key == 'length' ||
// Node.js 0.10 has enumerable non-index properties on buffers.
(isBuff && (key == 'offset' || key == 'parent')) ||
// PhantomJS 2 has enumerable non-index properties on typed arrays.
(isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||
// Skip index properties.
isIndex(key, length)
))) {
result.push(key);
}
}
return result;
}
/**
* This function is like `assignValue` except that it doesn't assign
* `undefined` values.
*
* @private
* @param {Object} object The object to modify.
* @param {string} key The key of the property to assign.
* @param {*} value The value to assign.
*/
function assignMergeValue(object, key, value) {
if ((value !== undefined && !eq(object[key], value)) ||
(value === undefined && !(key in object))) {
baseAssignValue(object, key, value);
}
}
/**
* Assigns `value` to `key` of `object` if the existing value is not equivalent
* using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
* for equality comparisons.
*
* @private
* @param {Object} object The object to modify.
* @param {string} key The key of the property to assign.
* @param {*} value The value to assign.
*/
function assignValue(object, key, value) {
var objValue = object[key];
if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||
(value === undefined && !(key in object))) {
baseAssignValue(object, key, value);
}
}
/**
* Gets the index at which the `key` is found in `array` of key-value pairs.
*
* @private
* @param {Array} array The array to inspect.
* @param {*} key The key to search for.
* @returns {number} Returns the index of the matched value, else `-1`.
*/
function assocIndexOf(array, key) {
var length = array.length;
while (length--) {
if (eq(array[length][0], key)) {
return length;
}
}
return -1;
}
/**
* The base implementation of `assignValue` and `assignMergeValue` without
* value checks.
*
* @private
* @param {Object} object The object to modify.
* @param {string} key The key of the property to assign.
* @param {*} value The value to assign.
*/
function baseAssignValue(object, key, value) {
if (key == '__proto__' && defineProperty) {
defineProperty(object, key, {
'configurable': true,
'enumerable': true,
'value': value,
'writable': true
});
} else {
object[key] = value;
}
}
/**
* The base implementation of `baseForOwn` which iterates over `object`
* properties returned by `keysFunc` and invokes `iteratee` for each property.
* Iteratee functions may exit iteration early by explicitly returning `false`.
*
* @private
* @param {Object} object The object to iterate over.
* @param {Function} iteratee The function invoked per iteration.
* @param {Function} keysFunc The function to get the keys of `object`.
* @returns {Object} Returns `object`.
*/
var baseFor = createBaseFor();
/**
* The base implementation of `getTag` without fallbacks for buggy environments.
*
* @private
* @param {*} value The value to query.
* @returns {string} Returns the `toStringTag`.
*/
function baseGetTag(value) {
if (value == null) {
return value === undefined ? undefinedTag : nullTag;
}
return (symToStringTag && symToStringTag in Object(value))
? getRawTag(value)
: objectToString(value);
}
/**
* The base implementation of `_.isArguments`.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an `arguments` object,
*/
function baseIsArguments(value) {
return isObjectLike(value) && baseGetTag(value) == argsTag;
}
/**
* The base implementation of `_.isNative` without bad shim checks.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a native function,
* else `false`.
*/
function baseIsNative(value) {
if (!isObject(value) || isMasked(value)) {
return false;
}
var pattern = isFunction(value) ? reIsNative : reIsHostCtor;
return pattern.test(toSource(value));
}
/**
* The base implementation of `_.isTypedArray` without Node.js optimizations.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a typed array, else `false`.
*/
function baseIsTypedArray(value) {
return isObjectLike(value) &&
isLength(value.length) && !!typedArrayTags[baseGetTag(value)];
}
/**
* The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.
*
* @private
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
*/
function baseKeysIn(object) {
if (!isObject(object)) {
return nativeKeysIn(object);
}
var isProto = isPrototype(object),
result = [];
for (var key in object) {
if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {
result.push(key);
}
}
return result;
}
/**
* The base implementation of `_.merge` without support for multiple sources.
*
* @private
* @param {Object} object The destination object.
* @param {Object} source The source object.
* @param {number} srcIndex The index of `source`.
* @param {Function} [customizer] The function to customize merged values.
* @param {Object} [stack] Tracks traversed source values and their merged
* counterparts.
*/
function baseMerge(object, source, srcIndex, customizer, stack) {
if (object === source) {
return;
}
baseFor(source, function(srcValue, key) {
stack || (stack = new Stack);
if (isObject(srcValue)) {
baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);
}
else {
var newValue = customizer
? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)
: undefined;
if (newValue === undefined) {
newValue = srcValue;
}
assignMergeValue(object, key, newValue);
}
}, keysIn);
}
/**
* A specialized version of `baseMerge` for arrays and objects which performs
* deep merges and tracks traversed objects enabling objects with circular
* references to be merged.
*
* @private
* @param {Object} object The destination object.
* @param {Object} source The source object.
* @param {string} key The key of the value to merge.
* @param {number} srcIndex The index of `source`.
* @param {Function} mergeFunc The function to merge values.
* @param {Function} [customizer] The function to customize assigned values.
* @param {Object} [stack] Tracks traversed source values and their merged
* counterparts.
*/
function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {
var objValue = safeGet(object, key),
srcValue = safeGet(source, key),
stacked = stack.get(srcValue);
if (stacked) {
assignMergeValue(object, key, stacked);
return;
}
var newValue = customizer
? customizer(objValue, srcValue, (key + ''), object, source, stack)
: undefined;
var isCommon = newValue === undefined;
if (isCommon) {
var isArr = isArray(srcValue),
isBuff = !isArr && isBuffer(srcValue),
isTyped = !isArr && !isBuff && isTypedArray(srcValue);
newValue = srcValue;
if (isArr || isBuff || isTyped) {
if (isArray(objValue)) {
newValue = objValue;
}
else if (isArrayLikeObject(objValue)) {
newValue = copyArray(objValue);
}
else if (isBuff) {
isCommon = false;
newValue = cloneBuffer(srcValue, true);
}
else if (isTyped) {
isCommon = false;
newValue = cloneTypedArray(srcValue, true);
}
else {
newValue = [];
}
}
else if (isPlainObject(srcValue) || isArguments(srcValue)) {
newValue = objValue;
if (isArguments(objValue)) {
newValue = toPlainObject(objValue);
}
else if (!isObject(objValue) || isFunction(objValue)) {
newValue = initCloneObject(srcValue);
}
}
else {
isCommon = false;
}
}
if (isCommon) {
// Recursively merge objects and arrays (susceptible to call stack limits).
stack.set(srcValue, newValue);
mergeFunc(newValue, srcValue, srcIndex, customizer, stack);
stack['delete'](srcValue);
}
assignMergeValue(object, key, newValue);
}
/**
* The base implementation of `_.rest` which doesn't validate or coerce arguments.
*
* @private
* @param {Function} func The function to apply a rest parameter to.
* @param {number} [start=func.length-1] The start position of the rest parameter.
* @returns {Function} Returns the new function.
*/
function baseRest(func, start) {
return setToString(overRest(func, start, identity), func + '');
}
/**
* The base implementation of `setToString` without support for hot loop shorting.
*
* @private
* @param {Function} func The function to modify.
* @param {Function} string The `toString` result.
* @returns {Function} Returns `func`.
*/
var baseSetToString = !defineProperty ? identity : function(func, string) {
return defineProperty(func, 'toString', {
'configurable': true,
'enumerable': false,
'value': constant(string),
'writable': true
});
};
/**
* Creates a clone of `buffer`.
*
* @private
* @param {Buffer} buffer The buffer to clone.
* @param {boolean} [isDeep] Specify a deep clone.
* @returns {Buffer} Returns the cloned buffer.
*/
function cloneBuffer(buffer, isDeep) {
if (isDeep) {
return buffer.slice();
}
var length = buffer.length,
result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);
buffer.copy(result);
return result;
}
/**
* Creates a clone of `arrayBuffer`.
*
* @private
* @param {ArrayBuffer} arrayBuffer The array buffer to clone.
* @returns {ArrayBuffer} Returns the cloned array buffer.
*/
function cloneArrayBuffer(arrayBuffer) {
var result = new arrayBuffer.constructor(arrayBuffer.byteLength);
new Uint8Array(result).set(new Uint8Array(arrayBuffer));
return result;
}
/**
* Creates a clone of `typedArray`.
*
* @private
* @param {Object} typedArray The typed array to clone.
* @param {boolean} [isDeep] Specify a deep clone.
* @returns {Object} Returns the cloned typed array.
*/
function cloneTypedArray(typedArray, isDeep) {
var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;
return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);
}
/**
* Copies the values of `source` to `array`.
*
* @private
* @param {Array} source The array to copy values from.
* @param {Array} [array=[]] The array to copy values to.
* @returns {Array} Returns `array`.
*/
function copyArray(source, array) {
var index = -1,
length = source.length;
array || (array = Array(length));
while (++index < length) {
array[index] = source[index];
}
return array;
}
/**
* Copies properties of `source` to `object`.
*
* @private
* @param {Object} source The object to copy properties from.
* @param {Array} props The property identifiers to copy.
* @param {Object} [object={}] The object to copy properties to.
* @param {Function} [customizer] The function to customize copied values.
* @returns {Object} Returns `object`.
*/
function copyObject(source, props, object, customizer) {
var isNew = !object;
object || (object = {});
var index = -1,
length = props.length;
while (++index < length) {
var key = props[index];
var newValue = customizer
? customizer(object[key], source[key], key, object, source)
: undefined;
if (newValue === undefined) {
newValue = source[key];
}
if (isNew) {
baseAssignValue(object, key, newValue);
} else {
assignValue(object, key, newValue);
}
}
return object;
}
/**
* Creates a function like `_.assign`.
*
* @private
* @param {Function} assigner The function to assign values.
* @returns {Function} Returns the new assigner function.
*/
function createAssigner(assigner) {
return baseRest(function(object, sources) {
var index = -1,
length = sources.length,
customizer = length > 1 ? sources[length - 1] : undefined,
guard = length > 2 ? sources[2] : undefined;
customizer = (assigner.length > 3 && typeof customizer == 'function')
? (length--, customizer)
: undefined;
if (guard && isIterateeCall(sources[0], sources[1], guard)) {
customizer = length < 3 ? undefined : customizer;
length = 1;
}
object = Object(object);
while (++index < length) {
var source = sources[index];
if (source) {
assigner(object, source, index, customizer);
}
}
return object;
});
}
/**
* Creates a base function for methods like `_.forIn` and `_.forOwn`.
*
* @private
* @param {boolean} [fromRight] Specify iterating from right to left.
* @returns {Function} Returns the new base function.
*/
function createBaseFor(fromRight) {
return function(object, iteratee, keysFunc) {
var index = -1,
iterable = Object(object),
props = keysFunc(object),
length = props.length;
while (length--) {
var key = props[fromRight ? length : ++index];
if (iteratee(iterable[key], key, iterable) === false) {
break;
}
}
return object;
};
}
/**
* Used by `_.defaultsDeep` to customize its `_.merge` use to merge source
* objects into destination objects that are passed thru.
*
* @private
* @param {*} objValue The destination value.
* @param {*} srcValue The source value.
* @param {string} key The key of the property to merge.
* @param {Object} object The parent object of `objValue`.
* @param {Object} source The parent object of `srcValue`.
* @param {Object} [stack] Tracks traversed source values and their merged
* counterparts.
* @returns {*} Returns the value to assign.
*/
function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {
if (isObject(objValue) && isObject(srcValue)) {
// Recursively merge objects and arrays (susceptible to call stack limits).
stack.set(srcValue, objValue);
baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);
stack['delete'](srcValue);
}
return objValue;
}
/**
* Gets the data for `map`.
*
* @private
* @param {Object} map The map to query.
* @param {string} key The reference key.
* @returns {*} Returns the map data.
*/
function getMapData(map, key) {
var data = map.__data__;
return isKeyable(key)
? data[typeof key == 'string' ? 'string' : 'hash']
: data.map;
}
/**
* Gets the native function at `key` of `object`.
*
* @private
* @param {Object} object The object to query.
* @param {string} key The key of the method to get.
* @returns {*} Returns the function if it's native, else `undefined`.
*/
function getNative(object, key) {
var value = getValue(object, key);
return baseIsNative(value) ? value : undefined;
}
/**
* A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.
*
* @private
* @param {*} value The value to query.
* @returns {string} Returns the raw `toStringTag`.
*/
function getRawTag(value) {
var isOwn = hasOwnProperty.call(value, symToStringTag),
tag = value[symToStringTag];
try {
value[symToStringTag] = undefined;
var unmasked = true;
} catch (e) {}
var result = nativeObjectToString.call(value);
if (unmasked) {
if (isOwn) {
value[symToStringTag] = tag;
} else {
delete value[symToStringTag];
}
}
return result;
}
/**
* Initializes an object clone.
*
* @private
* @param {Object} object The object to clone.
* @returns {Object} Returns the initialized clone.
*/
function initCloneObject(object) {
return (typeof object.constructor == 'function' && !isPrototype(object))
? baseCreate(getPrototype(object))
: {};
}
/**
* Checks if `value` is a valid array-like index.
*
* @private
* @param {*} value The value to check.
* @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
* @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
*/
function isIndex(value, length) {
var type = typeof value;
length = length == null ? MAX_SAFE_INTEGER : length;
return !!length &&
(type == 'number' ||
(type != 'symbol' && reIsUint.test(value))) &&
(value > -1 && value % 1 == 0 && value < length);
}
/**
* Checks if the given arguments are from an iteratee call.
*
* @private
* @param {*} value The potential iteratee value argument.
* @param {*} index The potential iteratee index or key argument.
* @param {*} object The potential iteratee object argument.
* @returns {boolean} Returns `true` if the arguments are from an iteratee call,
* else `false`.
*/
function isIterateeCall(value, index, object) {
if (!isObject(object)) {
return false;
}
var type = typeof index;
if (type == 'number'
? (isArrayLike(object) && isIndex(index, object.length))
: (type == 'string' && index in object)
) {
return eq(object[index], value);
}
return false;
}
/**
* Checks if `value` is suitable for use as unique object key.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is suitable, else `false`.
*/
function isKeyable(value) {
var type = typeof value;
return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')
? (value !== '__proto__')
: (value === null);
}
/**
* Checks if `func` has its source masked.
*
* @private
* @param {Function} func The function to check.
* @returns {boolean} Returns `true` if `func` is masked, else `false`.
*/
function isMasked(func) {
return !!maskSrcKey && (maskSrcKey in func);
}
/**
* Checks if `value` is likely a prototype object.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
*/
function isPrototype(value) {
var Ctor = value && value.constructor,
proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;
return value === proto;
}
/**
* This function is like
* [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
* except that it includes inherited enumerable properties.
*
* @private
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
*/
function nativeKeysIn(object) {
var result = [];
if (object != null) {
for (var key in Object(object)) {
result.push(key);
}
}
return result;
}
/**
* Converts `value` to a string using `Object.prototype.toString`.
*
* @private
* @param {*} value The value to convert.
* @returns {string} Returns the converted string.
*/
function objectToString(value) {
return nativeObjectToString.call(value);
}
/**
* A specialized version of `baseRest` which transforms the rest array.
*
* @private
* @param {Function} func The function to apply a rest parameter to.
* @param {number} [start=func.length-1] The start position of the rest parameter.
* @param {Function} transform The rest array transform.
* @returns {Function} Returns the new function.
*/
function overRest(func, start, transform) {
start = nativeMax(start === undefined ? (func.length - 1) : start, 0);
return function() {
var args = arguments,
index = -1,
length = nativeMax(args.length - start, 0),
array = Array(length);
while (++index < length) {
array[index] = args[start + index];
}
index = -1;
var otherArgs = Array(start + 1);
while (++index < start) {
otherArgs[index] = args[index];
}
otherArgs[start] = transform(array);
return apply(func, this, otherArgs);
};
}
/**
* Gets the value at `key`, unless `key` is "__proto__" or "constructor".
*
* @private
* @param {Object} object The object to query.
* @param {string} key The key of the property to get.
* @returns {*} Returns the property value.
*/
function safeGet(object, key) {
if (key === 'constructor' && typeof object[key] === 'function') {
return;
}
if (key == '__proto__') {
return;
}
return object[key];
}
/**
* Sets the `toString` method of `func` to return `string`.
*
* @private
* @param {Function} func The function to modify.
* @param {Function} string The `toString` result.
* @returns {Function} Returns `func`.
*/
var setToString = shortOut(baseSetToString);
/**
* Creates a function that'll short out and invoke `identity` instead
* of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`
* milliseconds.
*
* @private
* @param {Function} func The function to restrict.
* @returns {Function} Returns the new shortable function.
*/
function shortOut(func) {
var count = 0,
lastCalled = 0;
return function() {
var stamp = nativeNow(),
remaining = HOT_SPAN - (stamp - lastCalled);
lastCalled = stamp;
if (remaining > 0) {
if (++count >= HOT_COUNT) {
return arguments[0];
}
} else {
count = 0;
}
return func.apply(undefined, arguments);
};
}
/**
* Converts `func` to its source code.
*
* @private
* @param {Function} func The function to convert.
* @returns {string} Returns the source code.
*/
function toSource(func) {
if (func != null) {
try {
return funcToString.call(func);
} catch (e) {}
try {
return (func + '');
} catch (e) {}
}
return '';
}
/**
* Performs a
* [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
* comparison between two values to determine if they are equivalent.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to compare.
* @param {*} other The other value to compare.
* @returns {boolean} Returns `true` if the values are equivalent, else `false`.
* @example
*
* var object = { 'a': 1 };
* var other = { 'a': 1 };
*
* _.eq(object, object);
* // => true
*
* _.eq(object, other);
* // => false
*
* _.eq('a', 'a');
* // => true
*
* _.eq('a', Object('a'));
* // => false
*
* _.eq(NaN, NaN);
* // => true
*/
function eq(value, other) {
return value === other || (value !== value && other !== other);
}
/**
* Checks if `value` is likely an `arguments` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an `arguments` object,
* else `false`.
* @example
*
* _.isArguments(function() { return arguments; }());
* // => true
*
* _.isArguments([1, 2, 3]);
* // => false
*/
var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {
return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&
!propertyIsEnumerable.call(value, 'callee');
};
/**
* Checks if `value` is classified as an `Array` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an array, else `false`.
* @example
*
* _.isArray([1, 2, 3]);
* // => true
*
* _.isArray(document.body.children);
* // => false
*
* _.isArray('abc');
* // => false
*
* _.isArray(_.noop);
* // => false
*/
var isArray = Array.isArray;
/**
* Checks if `value` is array-like. A value is considered array-like if it's
* not a function and has a `value.length` that's an integer greater than or
* equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is array-like, else `false`.
* @example
*
* _.isArrayLike([1, 2, 3]);
* // => true
*
* _.isArrayLike(document.body.children);
* // => true
*
* _.isArrayLike('abc');
* // => true
*
* _.isArrayLike(_.noop);
* // => false
*/
function isArrayLike(value) {
return value != null && isLength(value.length) && !isFunction(value);
}
/**
* This method is like `_.isArrayLike` except that it also checks if `value`
* is an object.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an array-like object,
* else `false`.
* @example
*
* _.isArrayLikeObject([1, 2, 3]);
* // => true
*
* _.isArrayLikeObject(document.body.children);
* // => true
*
* _.isArrayLikeObject('abc');
* // => false
*
* _.isArrayLikeObject(_.noop);
* // => false
*/
function isArrayLikeObject(value) {
return isObjectLike(value) && isArrayLike(value);
}
/**
* Checks if `value` is a buffer.
*
* @static
* @memberOf _
* @since 4.3.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a buffer, else `false`.
* @example
*
* _.isBuffer(new Buffer(2));
* // => true
*
* _.isBuffer(new Uint8Array(2));
* // => false
*/
var isBuffer = nativeIsBuffer || stubFalse;
/**
* Checks if `value` is classified as a `Function` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a function, else `false`.
* @example
*
* _.isFunction(_);
* // => true
*
* _.isFunction(/abc/);
* // => false
*/
function isFunction(value) {
if (!isObject(value)) {
return false;
}
// The use of `Object#toString` avoids issues with the `typeof` operator
// in Safari 9 which returns 'object' for typed arrays and other constructors.
var tag = baseGetTag(value);
return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;
}
/**
* Checks if `value` is a valid array-like length.
*
* **Note:** This method is loosely based on
* [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
* @example
*
* _.isLength(3);
* // => true
*
* _.isLength(Number.MIN_VALUE);
* // => false
*
* _.isLength(Infinity);
* // => false
*
* _.isLength('3');
* // => false
*/
function isLength(value) {
return typeof value == 'number' &&
value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
}
/**
* Checks if `value` is the
* [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
* of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an object, else `false`.
* @example
*
* _.isObject({});
* // => true
*
* _.isObject([1, 2, 3]);
* // => true
*
* _.isObject(_.noop);
* // => true
*
* _.isObject(null);
* // => false
*/
function isObject(value) {
var type = typeof value;
return value != null && (type == 'object' || type == 'function');
}
/**
* Checks if `value` is object-like. A value is object-like if it's not `null`
* and has a `typeof` result of "object".
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is object-like, else `false`.
* @example
*
* _.isObjectLike({});
* // => true
*
* _.isObjectLike([1, 2, 3]);
* // => true
*
* _.isObjectLike(_.noop);
* // => false
*
* _.isObjectLike(null);
* // => false
*/
function isObjectLike(value) {
return value != null && typeof value == 'object';
}
/**
* Checks if `value` is a plain object, that is, an object created by the
* `Object` constructor or one with a `[[Prototype]]` of `null`.
*
* @static
* @memberOf _
* @since 0.8.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a plain object, else `false`.
* @example
*
* function Foo() {
* this.a = 1;
* }
*
* _.isPlainObject(new Foo);
* // => false
*
* _.isPlainObject([1, 2, 3]);
* // => false
*
* _.isPlainObject({ 'x': 0, 'y': 0 });
* // => true
*
* _.isPlainObject(Object.create(null));
* // => true
*/
function isPlainObject(value) {
if (!isObjectLike(value) || baseGetTag(value) != objectTag) {
return false;
}
var proto = getPrototype(value);
if (proto === null) {
return true;
}
var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;
return typeof Ctor == 'function' && Ctor instanceof Ctor &&
funcToString.call(Ctor) == objectCtorString;
}
/**
* Checks if `value` is classified as a typed array.
*
* @static
* @memberOf _
* @since 3.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a typed array, else `false`.
* @example
*
* _.isTypedArray(new Uint8Array);
* // => true
*
* _.isTypedArray([]);
* // => false
*/
var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;
/**
* Converts `value` to a plain object flattening inherited enumerable string
* keyed properties of `value` to own properties of the plain object.
*
* @static
* @memberOf _
* @since 3.0.0
* @category Lang
* @param {*} value The value to convert.
* @returns {Object} Returns the converted plain object.
* @example
*
* function Foo() {
* this.b = 2;
* }
*
* Foo.prototype.c = 3;
*
* _.assign({ 'a': 1 }, new Foo);
* // => { 'a': 1, 'b': 2 }
*
* _.assign({ 'a': 1 }, _.toPlainObject(new Foo));
* // => { 'a': 1, 'b': 2, 'c': 3 }
*/
function toPlainObject(value) {
return copyObject(value, keysIn(value));
}
/**
* This method is like `_.defaults` except that it recursively assigns
* default properties.
*
* **Note:** This method mutates `object`.
*
* @static
* @memberOf _
* @since 3.10.0
* @category Object
* @param {Object} object The destination object.
* @param {...Object} [sources] The source objects.
* @returns {Object} Returns `object`.
* @see _.defaults
* @example
*
* _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });
* // => { 'a': { 'b': 2, 'c': 3 } }
*/
var defaultsDeep = baseRest(function(args) {
args.push(undefined, customDefaultsMerge);
return apply(mergeWith, undefined, args);
});
/**
* Creates an array of the own and inherited enumerable property names of `object`.
*
* **Note:** Non-object values are coerced to objects.
*
* @static
* @memberOf _
* @since 3.0.0
* @category Object
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
* @example
*
* function Foo() {
* this.a = 1;
* this.b = 2;
* }
*
* Foo.prototype.c = 3;
*
* _.keysIn(new Foo);
* // => ['a', 'b', 'c'] (iteration order is not guaranteed)
*/
function keysIn(object) {
return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);
}
/**
* This method is like `_.merge` except that it accepts `customizer` which
* is invoked to produce the merged values of the destination and source
* properties. If `customizer` returns `undefined`, merging is handled by the
* method instead. The `customizer` is invoked with six arguments:
* (objValue, srcValue, key, object, source, stack).
*
* **Note:** This method mutates `object`.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Object
* @param {Object} object The destination object.
* @param {...Object} sources The source objects.
* @param {Function} customizer The function to customize assigned values.
* @returns {Object} Returns `object`.
* @example
*
* function customizer(objValue, srcValue) {
* if (_.isArray(objValue)) {
* return objValue.concat(srcValue);
* }
* }
*
* var object = { 'a': [1], 'b': [2] };
* var other = { 'a': [3], 'b': [4] };
*
* _.mergeWith(object, other, customizer);
* // => { 'a': [1, 3], 'b': [2, 4] }
*/
var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {
baseMerge(object, source, srcIndex, customizer);
});
/**
* Creates a function that returns `value`.
*
* @static
* @memberOf _
* @since 2.4.0
* @category Util
* @param {*} value The value to return from the new function.
* @returns {Function} Returns the new constant function.
* @example
*
* var objects = _.times(2, _.constant({ 'a': 1 }));
*
* console.log(objects);
* // => [{ 'a': 1 }, { 'a': 1 }]
*
* console.log(objects[0] === objects[1]);
* // => true
*/
function constant(value) {
return function() {
return value;
};
}
/**
* This method returns the first argument it receives.
*
* @static
* @since 0.1.0
* @memberOf _
* @category Util
* @param {*} value Any value.
* @returns {*} Returns `value`.
* @example
*
* var object = { 'a': 1 };
*
* console.log(_.identity(object) === object);
* // => true
*/
function identity(value) {
return value;
}
/**
* This method returns `false`.
*
* @static
* @memberOf _
* @since 4.13.0
* @category Util
* @returns {boolean} Returns `false`.
* @example
*
* _.times(2, _.stubFalse);
* // => [false, false]
*/
function stubFalse() {
return false;
}
module.exports = defaultsDeep;
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()), __webpack_require__(2)(module)))
/***/ }),
/* 2 */
/***/ (function(module, exports) {
module.exports = function(module) {
if(!module.webpackPolyfill) {
module.deprecate = function() {};
module.paths = [];
// module.parent = undefined by default
module.children = [];
module.webpackPolyfill = 1;
}
return module;
}
/***/ }),
/* 3 */
/***/ (function(module, exports, __webpack_require__) {
var createElement = __webpack_require__(4)
module.exports = createElement
/***/ }),
/* 4 */
/***/ (function(module, exports, __webpack_require__) {
var document = __webpack_require__(5)
var applyProperties = __webpack_require__(7)
var isVNode = __webpack_require__(10)
var isVText = __webpack_require__(12)
var isWidget = __webpack_require__(13)
var handleThunk = __webpack_require__(14)
module.exports = createElement
function createElement(vnode, opts) {
var doc = opts ? opts.document || document : document
var warn = opts ? opts.warn : null
vnode = handleThunk(vnode).a
if (isWidget(vnode)) {
return vnode.init()
} else if (isVText(vnode)) {
return doc.createTextNode(vnode.text)
} else if (!isVNode(vnode)) {
if (warn) {
warn("Item is not a valid virtual dom node", vnode)
}
return null
}
var node = (vnode.namespace === null) ?
doc.createElement(vnode.tagName) :
doc.createElementNS(vnode.namespace, vnode.tagName)
var props = vnode.properties
applyProperties(node, props)
var children = vnode.children
for (var i = 0; i < children.length; i++) {
var childNode = createElement(children[i], opts)
if (childNode) {
node.appendChild(childNode)
}
}
return node
}
/***/ }),
/* 5 */
/***/ (function(module, exports, __webpack_require__) {
/* WEBPACK VAR INJECTION */(function(global) {var topLevel = typeof global !== 'undefined' ? global :
typeof window !== 'undefined' ? window : {}
var minDoc = __webpack_require__(6);
var doccy;
if (typeof document !== 'undefined') {
doccy = document;
} else {
doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'];
if (!doccy) {
doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'] = minDoc;
}
}
module.exports = doccy;
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
/***/ }),
/* 6 */
/***/ (function(module, exports) {
/* (ignored) */
/***/ }),
/* 7 */
/***/ (function(module, exports, __webpack_require__) {
var isObject = __webpack_require__(8)
var isHook = __webpack_require__(9)
module.exports = applyProperties
function applyProperties(node, props, previous) {
for (var propName in props) {
var propValue = props[propName]
if (propValue === undefined) {
removeProperty(node, propName, propValue, previous);
} else if (isHook(propValue)) {
removeProperty(node, propName, propValue, previous)
if (propValue.hook) {
propValue.hook(node,
propName,
previous ? previous[propName] : undefined)
}
} else {
if (isObject(propValue)) {
patchObject(node, props, previous, propName, propValue);
} else {
node[propName] = propValue
}
}
}
}
function removeProperty(node, propName, propValue, previous) {
if (previous) {
var previousValue = previous[propName]
if (!isHook(previousValue)) {
if (propName === "attributes") {
for (var attrName in previousValue) {
node.removeAttribute(attrName)
}
} else if (propName === "style") {
for (var i in previousValue) {
node.style[i] = ""
}
} else if (typeof previousValue === "string") {
node[propName] = ""
} else {
node[propName] = null
}
} else if (previousValue.unhook) {
previousValue.unhook(node, propName, propValue)
}
}
}
function patchObject(node, props, previous, propName, propValue) {
var previousValue = previous ? previous[propName] : undefined
// Set attributes
if (propName === "attributes") {
for (var attrName in propValue) {
var attrValue = propValue[attrName]
if (attrValue === undefined) {
node.removeAttribute(attrName)
} else {
node.setAttribute(attrName, attrValue)
}
}
return
}
if(previousValue && isObject(previousValue) &&
getPrototype(previousValue) !== getPrototype(propValue)) {
node[propName] = propValue
return
}
if (!isObject(node[propName])) {
node[propName] = {}
}
var replacer = propName === "style" ? "" : undefined
for (var k in propValue) {
var value = propValue[k]
node[propName][k] = (value === undefined) ? replacer : value
}
}
function getPrototype(value) {
if (Object.getPrototypeOf) {
return Object.getPrototypeOf(value)
} else if (value.__proto__) {
return value.__proto__
} else if (value.constructor) {
return value.constructor.prototype
}
}
/***/ }),
/* 8 */
/***/ (function(module, exports) {
"use strict";
module.exports = function isObject(x) {
return typeof x === "object" && x !== null;
};
/***/ }),
/* 9 */
/***/ (function(module, exports) {
module.exports = isHook
function isHook(hook) {
return hook &&
(typeof hook.hook === "function" && !hook.hasOwnProperty("hook") ||
typeof hook.unhook === "function" && !hook.hasOwnProperty("unhook"))
}
/***/ }),
/* 10 */
/***/ (function(module, exports, __webpack_require__) {
var version = __webpack_require__(11)
module.exports = isVirtualNode
function isVirtualNode(x) {
return x && x.type === "VirtualNode" && x.version === version
}
/***/ }),
/* 11 */
/***/ (function(module, exports) {
module.exports = "2"
/***/ }),
/* 12 */
/***/ (function(module, exports, __webpack_require__) {
var version = __webpack_require__(11)
module.exports = isVirtualText
function isVirtualText(x) {
return x && x.type === "VirtualText" && x.version === version
}
/***/ }),
/* 13 */
/***/ (function(module, exports) {
module.exports = isWidget
function isWidget(w) {
return w && w.type === "Widget"
}
/***/ }),
/* 14 */
/***/ (function(module, exports, __webpack_require__) {
var isVNode = __webpack_require__(10)
var isVText = __webpack_require__(12)
var isWidget = __webpack_require__(13)
var isThunk = __webpack_require__(15)
module.exports = handleThunk
function handleThunk(a, b) {
var renderedA = a
var renderedB = b
if (isThunk(b)) {
renderedB = renderThunk(b, a)
}
if (isThunk(a)) {
renderedA = renderThunk(a, null)
}
return {
a: renderedA,
b: renderedB
}
}
function renderThunk(thunk, previous) {
var renderedThunk = thunk.vnode
if (!renderedThunk) {
renderedThunk = thunk.vnode = thunk.render(previous)
}
if (!(isVNode(renderedThunk) ||
isVText(renderedThunk) ||
isWidget(renderedThunk))) {
throw new Error("thunk did not return a valid node");
}
return renderedThunk
}
/***/ }),
/* 15 */
/***/ (function(module, exports) {
module.exports = isThunk
function isThunk(t) {
return t && t.type === "Thunk"
}
/***/ }),
/* 16 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
var d = __webpack_require__(17)
, callable = __webpack_require__(36)
, apply = Function.prototype.apply, call = Function.prototype.call
, create = Object.create, defineProperty = Object.defineProperty
, defineProperties = Object.defineProperties
, hasOwnProperty = Object.prototype.hasOwnProperty
, descriptor = { configurable: true, enumerable: false, writable: true }
, on, once, off, emit, methods, descriptors, base;
on = function (type, listener) {
var data;
callable(listener);
if (!hasOwnProperty.call(this, '__ee__')) {
data = descriptor.value = create(null);
defineProperty(this, '__ee__', descriptor);
descriptor.value = null;
} else {
data = this.__ee__;
}
if (!data[type]) data[type] = listener;
else if (typeof data[type] === 'object') data[type].push(listener);
else data[type] = [data[type], listener];
return this;
};
once = function (type, listener) {
var once, self;
callable(listener);
self = this;
on.call(this, type, once = function () {
off.call(self, type, once);
apply.call(listener, this, arguments);
});
once.__eeOnceListener__ = listener;
return this;
};
off = function (type, listener) {
var data, listeners, candidate, i;
callable(listener);
if (!hasOwnProperty.call(this, '__ee__')) return this;
data = this.__ee__;
if (!data[type]) return this;
listeners = data[type];
if (typeof listeners === 'object') {
for (i = 0; (candidate = listeners[i]); ++i) {
if ((candidate === listener) ||
(candidate.__eeOnceListener__ === listener)) {
if (listeners.length === 2) data[type] = listeners[i ? 0 : 1];
else listeners.splice(i, 1);
}
}
} else {
if ((listeners === listener) ||
(listeners.__eeOnceListener__ === listener)) {
delete data[type];
}
}
return this;
};
emit = function (type) {
var i, l, listener, listeners, args;
if (!hasOwnProperty.call(this, '__ee__')) return;
listeners = this.__ee__[type];
if (!listeners) return;
if (typeof listeners === 'object') {
l = arguments.length;
args = new Array(l - 1);
for (i = 1; i < l; ++i) args[i - 1] = arguments[i];
listeners = listeners.slice();
for (i = 0; (listener = listeners[i]); ++i) {
apply.call(listener, this, args);
}
} else {
switch (arguments.length) {
case 1:
call.call(listeners, this);
break;
case 2:
call.call(listeners, this, arguments[1]);
break;
case 3:
call.call(listeners, this, arguments[1], arguments[2]);
break;
default:
l = arguments.length;
args = new Array(l - 1);
for (i = 1; i < l; ++i) {
args[i - 1] = arguments[i];
}
apply.call(listeners, this, args);
}
}
};
methods = {
on: on,
once: once,
off: off,
emit: emit
};
descriptors = {
on: d(on),
once: d(once),
off: d(off),
emit: d(emit)
};
base = defineProperties({}, descriptors);
module.exports = exports = function (o) {
return (o == null) ? create(base) : defineProperties(Object(o), descriptors);
};
exports.methods = methods;
/***/ }),
/* 17 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isValue = __webpack_require__(18)
, isPlainFunction = __webpack_require__(19)
, assign = __webpack_require__(23)
, normalizeOpts = __webpack_require__(32)
, contains = __webpack_require__(33);
var d = (module.exports = function (dscr, value/*, options*/) {
var c, e, w, options, desc;
if (arguments.length < 2 || typeof dscr !== "string") {
options = value;
value = dscr;
dscr = null;
} else {
options = arguments[2];
}
if (isValue(dscr)) {
c = contains.call(dscr, "c");
e = contains.call(dscr, "e");
w = contains.call(dscr, "w");
} else {
c = w = true;
e = false;
}
desc = { value: value, configurable: c, enumerable: e, writable: w };
return !options ? desc : assign(normalizeOpts(options), desc);
});
d.gs = function (dscr, get, set/*, options*/) {
var c, e, options, desc;
if (typeof dscr !== "string") {
options = set;
set = get;
get = dscr;
dscr = null;
} else {
options = arguments[3];
}
if (!isValue(get)) {
get = undefined;
} else if (!isPlainFunction(get)) {
options = get;
get = set = undefined;
} else if (!isValue(set)) {
set = undefined;
} else if (!isPlainFunction(set)) {
options = set;
set = undefined;
}
if (isValue(dscr)) {
c = contains.call(dscr, "c");
e = contains.call(dscr, "e");
} else {
c = true;
e = false;
}
desc = { get: get, set: set, configurable: c, enumerable: e };
return !options ? desc : assign(normalizeOpts(options), desc);
};
/***/ }),
/* 18 */
/***/ (function(module, exports) {
"use strict";
// ES3 safe
var _undefined = void 0;
module.exports = function (value) { return value !== _undefined && value !== null; };
/***/ }),
/* 19 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isFunction = __webpack_require__(20);
var classRe = /^\s*class[\s{/}]/, functionToString = Function.prototype.toString;
module.exports = function (value) {
if (!isFunction(value)) return false;
if (classRe.test(functionToString.call(value))) return false;
return true;
};
/***/ }),
/* 20 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isPrototype = __webpack_require__(21);
module.exports = function (value) {
if (typeof value !== "function") return false;
if (!hasOwnProperty.call(value, "length")) return false;
try {
if (typeof value.length !== "number") return false;
if (typeof value.call !== "function") return false;
if (typeof value.apply !== "function") return false;
} catch (error) {
return false;
}
return !isPrototype(value);
};
/***/ }),
/* 21 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isObject = __webpack_require__(22);
module.exports = function (value) {
if (!isObject(value)) return false;
try {
if (!value.constructor) return false;
return value.constructor.prototype === value;
} catch (error) {
return false;
}
};
/***/ }),
/* 22 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isValue = __webpack_require__(18);
// prettier-ignore
var possibleTypes = { "object": true, "function": true, "undefined": true /* document.all */ };
module.exports = function (value) {
if (!isValue(value)) return false;
return hasOwnProperty.call(possibleTypes, typeof value);
};
/***/ }),
/* 23 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
module.exports = __webpack_require__(24)() ? Object.assign : __webpack_require__(25);
/***/ }),
/* 24 */
/***/ (function(module, exports) {
"use strict";
module.exports = function () {
var assign = Object.assign, obj;
if (typeof assign !== "function") return false;
obj = { foo: "raz" };
assign(obj, { bar: "dwa" }, { trzy: "trzy" });
return obj.foo + obj.bar + obj.trzy === "razdwatrzy";
};
/***/ }),
/* 25 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var keys = __webpack_require__(26)
, value = __webpack_require__(31)
, max = Math.max;
module.exports = function (dest, src/*, …srcn*/) {
var error, i, length = max(arguments.length, 2), assign;
dest = Object(value(dest));
assign = function (key) {
try {
dest[key] = src[key];
} catch (e) {
if (!error) error = e;
}
};
for (i = 1; i < length; ++i) {
src = arguments[i];
keys(src).forEach(assign);
}
if (error !== undefined) throw error;
return dest;
};
/***/ }),
/* 26 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
module.exports = __webpack_require__(27)() ? Object.keys : __webpack_require__(28);
/***/ }),
/* 27 */
/***/ (function(module, exports) {
"use strict";
module.exports = function () {
try {
Object.keys("primitive");
return true;
} catch (e) {
return false;
}
};
/***/ }),
/* 28 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isValue = __webpack_require__(29);
var keys = Object.keys;
module.exports = function (object) { return keys(isValue(object) ? Object(object) : object); };
/***/ }),
/* 29 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _undefined = __webpack_require__(30)(); // Support ES3 engines
module.exports = function (val) { return val !== _undefined && val !== null; };
/***/ }),
/* 30 */
/***/ (function(module, exports) {
"use strict";
// eslint-disable-next-line no-empty-function
module.exports = function () {};
/***/ }),
/* 31 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isValue = __webpack_require__(29);
module.exports = function (value) {
if (!isValue(value)) throw new TypeError("Cannot use null or undefined");
return value;
};
/***/ }),
/* 32 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isValue = __webpack_require__(29);
var forEach = Array.prototype.forEach, create = Object.create;
var process = function (src, obj) {
var key;
for (key in src) obj[key] = src[key];
};
// eslint-disable-next-line no-unused-vars
module.exports = function (opts1/*, …options*/) {
var result = create(null);
forEach.call(arguments, function (options) {
if (!isValue(options)) return;
process(Object(options), result);
});
return result;
};
/***/ }),
/* 33 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
module.exports = __webpack_require__(34)() ? String.prototype.contains : __webpack_require__(35);
/***/ }),
/* 34 */
/***/ (function(module, exports) {
"use strict";
var str = "razdwatrzy";
module.exports = function () {
if (typeof str.contains !== "function") return false;
return str.contains("dwa") === true && str.contains("foo") === false;
};
/***/ }),
/* 35 */
/***/ (function(module, exports) {
"use strict";
var indexOf = String.prototype.indexOf;
module.exports = function (searchString/*, position*/) {
return indexOf.call(this, searchString, arguments[1]) > -1;
};
/***/ }),
/* 36 */
/***/ (function(module, exports) {
"use strict";
module.exports = function (fn) {
if (typeof fn !== "function") throw new TypeError(fn + " is not a function");
return fn;
};
/***/ }),
/* 37 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _lodash = __webpack_require__(1);
var _lodash2 = _interopRequireDefault(_lodash);
var _h = __webpack_require__(38);
var _h2 = _interopRequireDefault(_h);
var _diff = __webpack_require__(50);
var _diff2 = _interopRequireDefault(_diff);
var _patch = __webpack_require__(54);
var _patch2 = _interopRequireDefault(_patch);
var _inlineWorker = __webpack_require__(59);
var _inlineWorker2 = _interopRequireDefault(_inlineWorker);
var _conversions = __webpack_require__(60);
var _LoaderFactory = __webpack_require__(61);
var _LoaderFactory2 = _interopRequireDefault(_LoaderFactory);
var _ScrollHook = __webpack_require__(66);
var _ScrollHook2 = _interopRequireDefault(_ScrollHook);
var _TimeScale = __webpack_require__(67);
var _TimeScale2 = _interopRequireDefault(_TimeScale);
var _Track = __webpack_require__(69);
var _Track2 = _interopRequireDefault(_Track);
var _Playout = __webpack_require__(87);
var _Playout2 = _interopRequireDefault(_Playout);
var _AnnotationList = __webpack_require__(88);
var _AnnotationList2 = _interopRequireDefault(_AnnotationList);
var _recorderWorker = __webpack_require__(94);
var _recorderWorker2 = _interopRequireDefault(_recorderWorker);
var _exportWavWorker = __webpack_require__(95);
var _exportWavWorker2 = _interopRequireDefault(_exportWavWorker);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class() {
_classCallCheck(this, _class);
this.tracks = [];
this.soloedTracks = [];
this.mutedTracks = [];
this.collapsedTracks = [];
this.playoutPromises = [];
this.cursor = 0;
this.playbackSeconds = 0;
this.duration = 0;
this.scrollLeft = 0;
this.scrollTimer = undefined;
this.showTimescale = false;
// whether a user is scrolling the waveform
this.isScrolling = false;
this.fadeType = 'logarithmic';
this.masterGain = 1;
this.annotations = [];
this.durationFormat = 'hh:mm:ss.uuu';
this.isAutomaticScroll = false;
this.resetDrawTimer = undefined;
}
// TODO extract into a plugin
_createClass(_class, [{
key: 'initExporter',
value: function initExporter() {
this.exportWorker = new _inlineWorker2.default(_exportWavWorker2.default);
}
// TODO extract into a plugin
}, {
key: 'initRecorder',
value: function initRecorder(stream) {
var _this = this;
this.mediaRecorder = new MediaRecorder(stream);
this.mediaRecorder.onstart = function () {
var track = new _Track2.default();
track.setName('Recording');
track.setEnabledStates();
track.setEventEmitter(_this.ee);
_this.recordingTrack = track;
_this.tracks.push(track);
_this.chunks = [];
_this.working = false;
};
this.mediaRecorder.ondataavailable = function (e) {
_this.chunks.push(e.data);
// throttle peaks calculation
if (!_this.working) {
var recording = new Blob(_this.chunks, { type: 'audio/ogg; codecs=opus' });
var loader = _LoaderFactory2.default.createLoader(recording, _this.ac);
loader.load().then(function (audioBuffer) {
// ask web worker for peaks.
_this.recorderWorker.postMessage({
samples: audioBuffer.getChannelData(0),
samplesPerPixel: _this.samplesPerPixel
});
_this.recordingTrack.setCues(0, audioBuffer.duration);
_this.recordingTrack.setBuffer(audioBuffer);
_this.recordingTrack.setPlayout(new _Playout2.default(_this.ac, audioBuffer));
_this.adjustDuration();
}).catch(function () {
_this.working = false;
});
_this.working = true;
}
};
this.mediaRecorder.onstop = function () {
_this.chunks = [];
_this.working = false;
};
this.recorderWorker = new _inlineWorker2.default(_recorderWorker2.default);
// use a worker for calculating recording peaks.
this.recorderWorker.onmessage = function (e) {
_this.recordingTrack.setPeaks(e.data);
_this.working = false;
_this.drawRequest();
};
}
}, {
key: 'setShowTimeScale',
value: function setShowTimeScale(show) {
this.showTimescale = show;
}
}, {
key: 'setMono',
value: function setMono(mono) {
this.mono = mono;
}
}, {
key: 'setExclSolo',
value: function setExclSolo(exclSolo) {
this.exclSolo = exclSolo;
}
}, {
key: 'setSeekStyle',
value: function setSeekStyle(style) {
this.seekStyle = style;
}
}, {
key: 'getSeekStyle',
value: function getSeekStyle() {
return this.seekStyle;
}
}, {
key: 'setSampleRate',
value: function setSampleRate(sampleRate) {
this.sampleRate = sampleRate;
}
}, {
key: 'setSamplesPerPixel',
value: function setSamplesPerPixel(samplesPerPixel) {
this.samplesPerPixel = samplesPerPixel;
}
}, {
key: 'setAudioContext',
value: function setAudioContext(ac) {
this.ac = ac;
}
}, {
key: 'setControlOptions',
value: function setControlOptions(controlOptions) {
this.controls = controlOptions;
}
}, {
key: 'setWaveHeight',
value: function setWaveHeight(height) {
this.waveHeight = height;
}
}, {
key: 'setCollapsedWaveHeight',
value: function setCollapsedWaveHeight(height) {
this.collapsedWaveHeight = height;
}
}, {
key: 'setColors',
value: function setColors(colors) {
this.colors = colors;
}
}, {
key: 'setAnnotations',
value: function setAnnotations(config) {
var controlWidth = this.controls.show ? this.controls.width : 0;
this.annotationList = new _AnnotationList2.default(this, config.annotations, config.controls, config.editable, config.linkEndpoints, config.isContinuousPlay, controlWidth);
}
}, {
key: 'setEventEmitter',
value: function setEventEmitter(ee) {
this.ee = ee;
}
}, {
key: 'getEventEmitter',
value: function getEventEmitter() {
return this.ee;
}
}, {
key: 'setUpEventEmitter',
value: function setUpEventEmitter() {
var _this2 = this;
var ee = this.ee;
ee.on('automaticscroll', function (val) {
_this2.isAutomaticScroll = val;
});
ee.on('durationformat', function (format) {
_this2.durationFormat = format;
_this2.drawRequest();
});
ee.on('select', function (start, end, track) {
if (_this2.isPlaying()) {
_this2.lastSeeked = start;
_this2.pausedAt = undefined;
_this2.restartPlayFrom(start);
} else {
// reset if it was paused.
_this2.seek(start, end, track);
_this2.ee.emit('timeupdate', start);
_this2.drawRequest();
}
});
ee.on('startaudiorendering', function (type) {
_this2.startOfflineRender(type);
});
ee.on('statechange', function (state) {
_this2.setState(state);
_this2.drawRequest();
});
ee.on('shift', function (deltaTime, track) {
track.setStartTime(track.getStartTime() + deltaTime);
_this2.adjustDuration();
_this2.drawRequest();
});
ee.on('record', function () {
_this2.record();
});
ee.on('play', function (start, end) {
_this2.play(start, end);
});
ee.on('pause', function () {
_this2.pause();
});
ee.on('stop', function () {
_this2.stop();
});
ee.on('rewind', function () {
_this2.rewind();
});
ee.on('fastforward', function () {
_this2.fastForward();
});
ee.on('clear', function () {
_this2.clear().then(function () {
_this2.drawRequest();
});
});
ee.on('solo', function (track) {
_this2.soloTrack(track);
_this2.adjustTrackPlayout();
_this2.drawRequest();
});
ee.on('mute', function (track) {
_this2.muteTrack(track);
_this2.adjustTrackPlayout();
_this2.drawRequest();
});
ee.on('removeTrack', function (track) {
_this2.removeTrack(track);
_this2.adjustTrackPlayout();
_this2.drawRequest();
});
ee.on('changeTrackView', function (track, opts) {
_this2.collapseTrack(track, opts);
_this2.drawRequest();
});
ee.on('volumechange', function (volume, track) {
track.setGainLevel(volume / 100);
_this2.drawRequest();
});
ee.on('mastervolumechange', function (volume) {
_this2.masterGain = volume / 100;
_this2.tracks.forEach(function (track) {
track.setMasterGainLevel(_this2.masterGain);
});
});
ee.on('fadein', function (duration, track) {
track.setFadeIn(duration, _this2.fadeType);
_this2.drawRequest();
});
ee.on('fadeout', function (duration, track) {
track.setFadeOut(duration, _this2.fadeType);
_this2.drawRequest();
});
ee.on('stereopan', function (panvalue, track) {
track.setStereoPanValue(panvalue);
_this2.drawRequest();
});
ee.on('fadetype', function (type) {
_this2.fadeType = type;
});
ee.on('newtrack', function (file) {
_this2.load([{
src: file,
name: file.name
}]);
});
ee.on('trim', function () {
var track = _this2.getActiveTrack();
var timeSelection = _this2.getTimeSelection();
track.trim(timeSelection.start, timeSelection.end);
track.calculatePeaks(_this2.samplesPerPixel, _this2.sampleRate);
_this2.setTimeSelection(0, 0);
_this2.drawRequest();
});
ee.on('zoomin', function () {
var zoomIndex = Math.max(0, _this2.zoomIndex - 1);
var zoom = _this2.zoomLevels[zoomIndex];
if (zoom !== _this2.samplesPerPixel) {
_this2.setZoom(zoom);
_this2.drawRequest();
}
});
ee.on('zoomout', function () {
var zoomIndex = Math.min(_this2.zoomLevels.length - 1, _this2.zoomIndex + 1);
var zoom = _this2.zoomLevels[zoomIndex];
if (zoom !== _this2.samplesPerPixel) {
_this2.setZoom(zoom);
_this2.drawRequest();
}
});
ee.on('scroll', function () {
_this2.isScrolling = true;
_this2.drawRequest();
clearTimeout(_this2.scrollTimer);
_this2.scrollTimer = setTimeout(function () {
_this2.isScrolling = false;
}, 200);
});
}
}, {
key: 'load',
value: function load(trackList) {
var _this3 = this;
var loadPromises = trackList.map(function (trackInfo) {
var loader = _LoaderFactory2.default.createLoader(trackInfo.src, _this3.ac, _this3.ee);
return loader.load();
});
return Promise.all(loadPromises).then(function (audioBuffers) {
_this3.ee.emit('audiosourcesloaded');
var tracks = audioBuffers.map(function (audioBuffer, index) {
var info = trackList[index];
var name = info.name || 'Untitled';
var infostr = info.info || undefined;
var start = info.start || 0;
var states = info.states || {};
var fadeIn = info.fadeIn;
var fadeOut = info.fadeOut;
var cueIn = info.cuein || 0;
var cueOut = info.cueout || audioBuffer.duration;
var gain = info.gain || 1;
var muted = info.muted || false;
var soloed = info.soloed || false;
var selection = info.selected;
var peaks = info.peaks || { type: 'WebAudio', mono: _this3.mono };
var customClass = info.customClass || undefined;
var waveOutlineColor = info.waveOutlineColor || undefined;
var stereoPan = info.stereoPan || 0;
// webaudio specific playout for now.
var playout = new _Playout2.default(_this3.ac, audioBuffer);
var track = new _Track2.default();
track.src = info.src;
track.setBuffer(audioBuffer);
track.setName(name);
track.setInfo(infostr);
track.setEventEmitter(_this3.ee);
track.setEnabledStates(states);
track.setCues(cueIn, cueOut);
track.setCustomClass(customClass);
track.setWaveOutlineColor(waveOutlineColor);
if (fadeIn !== undefined) {
track.setFadeIn(fadeIn.duration, fadeIn.shape);
}
if (fadeOut !== undefined) {
track.setFadeOut(fadeOut.duration, fadeOut.shape);
}
if (selection !== undefined) {
_this3.setActiveTrack(track);
_this3.setTimeSelection(selection.start, selection.end);
}
if (peaks !== undefined) {
track.setPeakData(peaks);
}
track.setState(_this3.getState());
track.setStartTime(start);
track.setPlayout(playout);
track.setGainLevel(gain);
track.setStereoPanValue(stereoPan);
if (muted) {
_this3.muteTrack(track);
}
if (soloed) {
_this3.soloTrack(track);
}
// extract peaks with AudioContext for now.
track.calculatePeaks(_this3.samplesPerPixel, _this3.sampleRate);
return track;
});
_this3.tracks = _this3.tracks.concat(tracks);
_this3.adjustDuration();
_this3.draw(_this3.render());
_this3.ee.emit('audiosourcesrendered');
}).catch(function (e) {
_this3.ee.emit('audiosourceserror', e);
});
}
/*
track instance of Track.
*/
}, {
key: 'setActiveTrack',
value: function setActiveTrack(track) {
this.activeTrack = track;
}
}, {
key: 'getActiveTrack',
value: function getActiveTrack() {
return this.activeTrack;
}
}, {
key: 'isSegmentSelection',
value: function isSegmentSelection() {
return this.timeSelection.start !== this.timeSelection.end;
}
/*
start, end in seconds.
*/
}, {
key: 'setTimeSelection',
value: function setTimeSelection() {
var start = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
var end = arguments[1];
this.timeSelection = {
start: start,
end: end === undefined ? start : end
};
this.cursor = start;
}
}, {
key: 'startOfflineRender',
value: function startOfflineRender(type) {
var _this4 = this;
if (this.isRendering) {
return;
}
this.isRendering = true;
var duration = this.duration;
var startTime = 0;
var endTime = 0;
if (this.isSegmentSelection()) {
var segment = this.getTimeSelection();
startTime = segment.start;
endTime = segment.end;
duration = endTime - startTime;
}
this.offlineAudioContext = new OfflineAudioContext(1, 44100 * duration, 44100);
var currentTime = this.offlineAudioContext.currentTime;
this.tracks.forEach(function (track) {
track.setOfflinePlayout(new _Playout2.default(_this4.offlineAudioContext, track.buffer));
track.schedulePlay(currentTime, startTime, endTime, {
shouldPlay: _this4.shouldTrackPlay(track),
masterGain: 1,
isOffline: true
});
});
/*
TODO cleanup of different audio playouts handling.
*/
this.offlineAudioContext.startRendering().then(function (audioBuffer) {
if (type === 'buffer') {
_this4.ee.emit('audiorenderingfinished', type, audioBuffer);
_this4.isRendering = false;
return;
}
if (type === 'wav') {
_this4.exportWorker.postMessage({
command: 'init',
config: {
sampleRate: 44100,
stereo: false
}
});
// callback for `exportWAV`
_this4.exportWorker.onmessage = function (e) {
_this4.ee.emit('audiorenderingfinished', type, e.data);
_this4.isRendering = false;
// clear out the buffer for next renderings.
_this4.exportWorker.postMessage({
command: 'clear'
});
};
// send the channel data from our buffer to the worker
_this4.exportWorker.postMessage({
command: 'record',
buffer: [audioBuffer.getChannelData(0)]
});
// ask the worker for a WAV
_this4.exportWorker.postMessage({
command: 'exportWAV',
type: 'audio/wav'
});
}
}).catch(function (e) {
throw e;
});
}
}, {
key: 'getTimeSelection',
value: function getTimeSelection() {
return this.timeSelection;
}
}, {
key: 'setState',
value: function setState(state) {
this.state = state;
this.tracks.forEach(function (track) {
track.setState(state);
});
}
}, {
key: 'getState',
value: function getState() {
return this.state;
}
}, {
key: 'setZoomIndex',
value: function setZoomIndex(index) {
this.zoomIndex = index;
}
}, {
key: 'setZoomLevels',
value: function setZoomLevels(levels) {
this.zoomLevels = levels;
}
}, {
key: 'setZoom',
value: function setZoom(zoom) {
var _this5 = this;
this.samplesPerPixel = zoom;
this.zoomIndex = this.zoomLevels.indexOf(zoom);
this.tracks.forEach(function (track) {
track.calculatePeaks(zoom, _this5.sampleRate);
});
}
}, {
key: 'muteTrack',
value: function muteTrack(track) {
var index = this.mutedTracks.indexOf(track);
if (index > -1) {
this.mutedTracks.splice(index, 1);
} else {
this.mutedTracks.push(track);
}
}
}, {
key: 'soloTrack',
value: function soloTrack(track) {
var index = this.soloedTracks.indexOf(track);
if (index > -1) {
this.soloedTracks.splice(index, 1);
} else if (this.exclSolo) {
this.soloedTracks = [track];
} else {
this.soloedTracks.push(track);
}
}
}, {
key: 'collapseTrack',
value: function collapseTrack(track, opts) {
if (opts.collapsed) {
this.collapsedTracks.push(track);
} else {
var index = this.collapsedTracks.indexOf(track);
if (index > -1) {
this.collapsedTracks.splice(index, 1);
}
}
}
}, {
key: 'removeTrack',
value: function removeTrack(track) {
if (track.isPlaying()) {
track.scheduleStop();
}
var trackLists = [this.mutedTracks, this.soloedTracks, this.collapsedTracks, this.tracks];
trackLists.forEach(function (list) {
var index = list.indexOf(track);
if (index > -1) {
list.splice(index, 1);
}
});
}
}, {
key: 'adjustTrackPlayout',
value: function adjustTrackPlayout() {
var _this6 = this;
this.tracks.forEach(function (track) {
track.setShouldPlay(_this6.shouldTrackPlay(track));
});
}
}, {
key: 'adjustDuration',
value: function adjustDuration() {
this.duration = this.tracks.reduce(function (duration, track) {
return Math.max(duration, track.getEndTime());
}, 0);
}
}, {
key: 'shouldTrackPlay',
value: function shouldTrackPlay(track) {
var shouldPlay = void 0;
// if there are solo tracks, only they should play.
if (this.soloedTracks.length > 0) {
shouldPlay = false;
if (this.soloedTracks.indexOf(track) > -1) {
shouldPlay = true;
}
} else {
// play all tracks except any muted tracks.
shouldPlay = true;
if (this.mutedTracks.indexOf(track) > -1) {
shouldPlay = false;
}
}
return shouldPlay;
}
}, {
key: 'isPlaying',
value: function isPlaying() {
return this.tracks.reduce(function (isPlaying, track) {
return isPlaying || track.isPlaying();
}, false);
}
/*
* returns the current point of time in the playlist in seconds.
*/
}, {
key: 'getCurrentTime',
value: function getCurrentTime() {
var cursorPos = this.lastSeeked || this.pausedAt || this.cursor;
return cursorPos + this.getElapsedTime();
}
}, {
key: 'getElapsedTime',
value: function getElapsedTime() {
return this.ac.currentTime - this.lastPlay;
}
}, {
key: 'setMasterGain',
value: function setMasterGain(gain) {
this.ee.emit('mastervolumechange', gain);
}
}, {
key: 'restartPlayFrom',
value: function restartPlayFrom(start, end) {
this.stopAnimation();
this.tracks.forEach(function (editor) {
editor.scheduleStop();
});
return Promise.all(this.playoutPromises).then(this.play.bind(this, start, end));
}
}, {
key: 'play',
value: function play(startTime, endTime) {
var _this7 = this;
clearTimeout(this.resetDrawTimer);
var currentTime = this.ac.currentTime;
var selected = this.getTimeSelection();
var playoutPromises = [];
var start = startTime || this.pausedAt || this.cursor;
var end = endTime;
if (!end && selected.end !== selected.start && selected.end > start) {
end = selected.end;
}
if (this.isPlaying()) {
return this.restartPlayFrom(start, end);
}
this.tracks.forEach(function (track) {
track.setState('cursor');
playoutPromises.push(track.schedulePlay(currentTime, start, end, {
shouldPlay: _this7.shouldTrackPlay(track),
masterGain: _this7.masterGain
}));
});
this.lastPlay = currentTime;
// use these to track when the playlist has fully stopped.
this.playoutPromises = playoutPromises;
this.startAnimation(start);
return Promise.all(this.playoutPromises);
}
}, {
key: 'pause',
value: function pause() {
if (!this.isPlaying()) {
return Promise.all(this.playoutPromises);
}
this.pausedAt = this.getCurrentTime();
return this.playbackReset();
}
}, {
key: 'stop',
value: function stop() {
if (this.mediaRecorder && this.mediaRecorder.state === 'recording') {
this.mediaRecorder.stop();
}
this.pausedAt = undefined;
this.playbackSeconds = 0;
return this.playbackReset();
}
}, {
key: 'playbackReset',
value: function playbackReset() {
var _this8 = this;
this.lastSeeked = undefined;
this.stopAnimation();
this.tracks.forEach(function (track) {
track.scheduleStop();
track.setState(_this8.getState());
});
this.drawRequest();
return Promise.all(this.playoutPromises);
}
}, {
key: 'rewind',
value: function rewind() {
var _this9 = this;
return this.stop().then(function () {
_this9.scrollLeft = 0;
_this9.ee.emit('select', 0, 0);
});
}
}, {
key: 'fastForward',
value: function fastForward() {
var _this10 = this;
return this.stop().then(function () {
if (_this10.viewDuration < _this10.duration) {
_this10.scrollLeft = _this10.duration - _this10.viewDuration;
} else {
_this10.scrollLeft = 0;
}
_this10.ee.emit('select', _this10.duration, _this10.duration);
});
}
}, {
key: 'clear',
value: function clear() {
var _this11 = this;
return this.stop().then(function () {
_this11.tracks = [];
_this11.soloedTracks = [];
_this11.mutedTracks = [];
_this11.playoutPromises = [];
_this11.cursor = 0;
_this11.playbackSeconds = 0;
_this11.duration = 0;
_this11.scrollLeft = 0;
_this11.seek(0, 0, undefined);
});
}
}, {
key: 'record',
value: function record() {
var _this12 = this;
var playoutPromises = [];
this.mediaRecorder.start(300);
this.tracks.forEach(function (track) {
track.setState('none');
playoutPromises.push(track.schedulePlay(_this12.ac.currentTime, 0, undefined, {
shouldPlay: _this12.shouldTrackPlay(track)
}));
});
this.playoutPromises = playoutPromises;
}
}, {
key: 'startAnimation',
value: function startAnimation(startTime) {
var _this13 = this;
this.lastDraw = this.ac.currentTime;
this.animationRequest = window.requestAnimationFrame(function () {
_this13.updateEditor(startTime);
});
}
}, {
key: 'stopAnimation',
value: function stopAnimation() {
window.cancelAnimationFrame(this.animationRequest);
this.lastDraw = undefined;
}
}, {
key: 'seek',
value: function seek(start, end, track) {
if (this.isPlaying()) {
this.lastSeeked = start;
this.pausedAt = undefined;
this.restartPlayFrom(start);
} else {
// reset if it was paused.
this.setActiveTrack(track || this.tracks[0]);
this.pausedAt = start;
this.setTimeSelection(start, end);
if (this.getSeekStyle() === 'fill') {
this.playbackSeconds = start;
}
}
}
/*
* Animation function for the playlist.
* Keep under 16.7 milliseconds based on a typical screen refresh rate of 60fps.
*/
}, {
key: 'updateEditor',
value: function updateEditor(cursor) {
var _this14 = this;
var currentTime = this.ac.currentTime;
var selection = this.getTimeSelection();
var cursorPos = cursor || this.cursor;
var elapsed = currentTime - this.lastDraw;
if (this.isPlaying()) {
var playbackSeconds = cursorPos + elapsed;
this.ee.emit('timeupdate', playbackSeconds);
this.animationRequest = window.requestAnimationFrame(function () {
_this14.updateEditor(playbackSeconds);
});
this.playbackSeconds = playbackSeconds;
this.draw(this.render());
this.lastDraw = currentTime;
} else {
if (cursorPos + elapsed >= (this.isSegmentSelection() ? selection.end : this.duration)) {
this.ee.emit('finished');
}
this.stopAnimation();
this.resetDrawTimer = setTimeout(function () {
_this14.pausedAt = undefined;
_this14.lastSeeked = undefined;
_this14.setState(_this14.getState());
_this14.playbackSeconds = 0;
_this14.draw(_this14.render());
}, 0);
}
}
}, {
key: 'drawRequest',
value: function drawRequest() {
var _this15 = this;
window.requestAnimationFrame(function () {
_this15.draw(_this15.render());
});
}
}, {
key: 'draw',
value: function draw(newTree) {
var patches = (0, _diff2.default)(this.tree, newTree);
this.rootNode = (0, _patch2.default)(this.rootNode, patches);
this.tree = newTree;
// use for fast forwarding.
this.viewDuration = (0, _conversions.pixelsToSeconds)(this.rootNode.clientWidth - this.controls.width, this.samplesPerPixel, this.sampleRate);
}
}, {
key: 'getTrackRenderData',
value: function getTrackRenderData() {
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var defaults = {
height: this.waveHeight,
resolution: this.samplesPerPixel,
sampleRate: this.sampleRate,
controls: this.controls,
isActive: false,
timeSelection: this.getTimeSelection(),
playlistLength: this.duration,
playbackSeconds: this.playbackSeconds,
colors: this.colors
};
return (0, _lodash2.default)({}, data, defaults);
}
}, {
key: 'isActiveTrack',
value: function isActiveTrack(track) {
var activeTrack = this.getActiveTrack();
if (this.isSegmentSelection()) {
return activeTrack === track;
}
return true;
}
}, {
key: 'renderAnnotations',
value: function renderAnnotations() {
return this.annotationList.render();
}
}, {
key: 'renderTimeScale',
value: function renderTimeScale() {
var controlWidth = this.controls.show ? this.controls.width : 0;
var timeScale = new _TimeScale2.default(this.duration, this.scrollLeft, this.samplesPerPixel, this.sampleRate, controlWidth, this.colors);
return timeScale.render();
}
}, {
key: 'renderTrackSection',
value: function renderTrackSection() {
var _this16 = this;
var trackElements = this.tracks.map(function (track) {
var collapsed = _this16.collapsedTracks.indexOf(track) > -1;
return track.render(_this16.getTrackRenderData({
isActive: _this16.isActiveTrack(track),
shouldPlay: _this16.shouldTrackPlay(track),
soloed: _this16.soloedTracks.indexOf(track) > -1,
muted: _this16.mutedTracks.indexOf(track) > -1,
collapsed: collapsed,
height: collapsed ? _this16.collapsedWaveHeight : _this16.waveHeight
}));
});
return (0, _h2.default)('div.playlist-tracks', {
attributes: {
style: 'overflow: auto;'
},
onscroll: function onscroll(e) {
_this16.scrollLeft = (0, _conversions.pixelsToSeconds)(e.target.scrollLeft, _this16.samplesPerPixel, _this16.sampleRate);
_this16.ee.emit('scroll');
},
hook: new _ScrollHook2.default(this)
}, trackElements);
}
}, {
key: 'render',
value: function render() {
var containerChildren = [];
if (this.showTimescale) {
containerChildren.push(this.renderTimeScale());
}
containerChildren.push(this.renderTrackSection());
if (this.annotationList.length) {
containerChildren.push(this.renderAnnotations());
}
return (0, _h2.default)('div.playlist', {
attributes: {
style: 'overflow: hidden; position: relative;'
}
}, containerChildren);
}
}, {
key: 'getInfo',
value: function getInfo() {
var info = [];
this.tracks.forEach(function (track) {
info.push(track.getTrackDetails());
});
return info;
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 38 */
/***/ (function(module, exports, __webpack_require__) {
var h = __webpack_require__(39)
module.exports = h
/***/ }),
/* 39 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
var isArray = __webpack_require__(40);
var VNode = __webpack_require__(41);
var VText = __webpack_require__(42);
var isVNode = __webpack_require__(10);
var isVText = __webpack_require__(12);
var isWidget = __webpack_require__(13);
var isHook = __webpack_require__(9);
var isVThunk = __webpack_require__(15);
var parseTag = __webpack_require__(43);
var softSetHook = __webpack_require__(45);
var evHook = __webpack_require__(46);
module.exports = h;
function h(tagName, properties, children) {
var childNodes = [];
var tag, props, key, namespace;
if (!children && isChildren(properties)) {
children = properties;
props = {};
}
props = props || properties || {};
tag = parseTag(tagName, props);
// support keys
if (props.hasOwnProperty('key')) {
key = props.key;
props.key = undefined;
}
// support namespace
if (props.hasOwnProperty('namespace')) {
namespace = props.namespace;
props.namespace = undefined;
}
// fix cursor bug
if (tag === 'INPUT' &&
!namespace &&
props.hasOwnProperty('value') &&
props.value !== undefined &&
!isHook(props.value)
) {
props.value = softSetHook(props.value);
}
transformProperties(props);
if (children !== undefined && children !== null) {
addChild(children, childNodes, tag, props);
}
return new VNode(tag, props, childNodes, key, namespace);
}
function addChild(c, childNodes, tag, props) {
if (typeof c === 'string') {
childNodes.push(new VText(c));
} else if (typeof c === 'number') {
childNodes.push(new VText(String(c)));
} else if (isChild(c)) {
childNodes.push(c);
} else if (isArray(c)) {
for (var i = 0; i < c.length; i++) {
addChild(c[i], childNodes, tag, props);
}
} else if (c === null || c === undefined) {
return;
} else {
throw UnexpectedVirtualElement({
foreignObject: c,
parentVnode: {
tagName: tag,
properties: props
}
});
}
}
function transformProperties(props) {
for (var propName in props) {
if (props.hasOwnProperty(propName)) {
var value = props[propName];
if (isHook(value)) {
continue;
}
if (propName.substr(0, 3) === 'ev-') {
// add ev-foo support
props[propName] = evHook(value);
}
}
}
}
function isChild(x) {
return isVNode(x) || isVText(x) || isWidget(x) || isVThunk(x);
}
function isChildren(x) {
return typeof x === 'string' || isArray(x) || isChild(x);
}
function UnexpectedVirtualElement(data) {
var err = new Error();
err.type = 'virtual-hyperscript.unexpected.virtual-element';
err.message = 'Unexpected virtual child passed to h().\n' +
'Expected a VNode / Vthunk / VWidget / string but:\n' +
'got:\n' +
errorString(data.foreignObject) +
'.\n' +
'The parent vnode is:\n' +
errorString(data.parentVnode)
'\n' +
'Suggested fix: change your `h(..., [ ... ])` callsite.';
err.foreignObject = data.foreignObject;
err.parentVnode = data.parentVnode;
return err;
}
function errorString(obj) {
try {
return JSON.stringify(obj, null, ' ');
} catch (e) {
return String(obj);
}
}
/***/ }),
/* 40 */
/***/ (function(module, exports) {
var nativeIsArray = Array.isArray
var toString = Object.prototype.toString
module.exports = nativeIsArray || isArray
function isArray(obj) {
return toString.call(obj) === "[object Array]"
}
/***/ }),
/* 41 */
/***/ (function(module, exports, __webpack_require__) {
var version = __webpack_require__(11)
var isVNode = __webpack_require__(10)
var isWidget = __webpack_require__(13)
var isThunk = __webpack_require__(15)
var isVHook = __webpack_require__(9)
module.exports = VirtualNode
var noProperties = {}
var noChildren = []
function VirtualNode(tagName, properties, children, key, namespace) {
this.tagName = tagName
this.properties = properties || noProperties
this.children = children || noChildren
this.key = key != null ? String(key) : undefined
this.namespace = (typeof namespace === "string") ? namespace : null
var count = (children && children.length) || 0
var descendants = 0
var hasWidgets = false
var hasThunks = false
var descendantHooks = false
var hooks
for (var propName in properties) {
if (properties.hasOwnProperty(propName)) {
var property = properties[propName]
if (isVHook(property) && property.unhook) {
if (!hooks) {
hooks = {}
}
hooks[propName] = property
}
}
}
for (var i = 0; i < count; i++) {
var child = children[i]
if (isVNode(child)) {
descendants += child.count || 0
if (!hasWidgets && child.hasWidgets) {
hasWidgets = true
}
if (!hasThunks && child.hasThunks) {
hasThunks = true
}
if (!descendantHooks && (child.hooks || child.descendantHooks)) {
descendantHooks = true
}
} else if (!hasWidgets && isWidget(child)) {
if (typeof child.destroy === "function") {
hasWidgets = true
}
} else if (!hasThunks && isThunk(child)) {
hasThunks = true;
}
}
this.count = count + descendants
this.hasWidgets = hasWidgets
this.hasThunks = hasThunks
this.hooks = hooks
this.descendantHooks = descendantHooks
}
VirtualNode.prototype.version = version
VirtualNode.prototype.type = "VirtualNode"
/***/ }),
/* 42 */
/***/ (function(module, exports, __webpack_require__) {
var version = __webpack_require__(11)
module.exports = VirtualText
function VirtualText(text) {
this.text = String(text)
}
VirtualText.prototype.version = version
VirtualText.prototype.type = "VirtualText"
/***/ }),
/* 43 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
var split = __webpack_require__(44);
var classIdSplit = /([\.#]?[a-zA-Z0-9\u007F-\uFFFF_:-]+)/;
var notClassId = /^\.|#/;
module.exports = parseTag;
function parseTag(tag, props) {
if (!tag) {
return 'DIV';
}
var noId = !(props.hasOwnProperty('id'));
var tagParts = split(tag, classIdSplit);
var tagName = null;
if (notClassId.test(tagParts[1])) {
tagName = 'DIV';
}
var classes, part, type, i;
for (i = 0; i < tagParts.length; i++) {
part = tagParts[i];
if (!part) {
continue;
}
type = part.charAt(0);
if (!tagName) {
tagName = part;
} else if (type === '.') {
classes = classes || [];
classes.push(part.substring(1, part.length));
} else if (type === '#' && noId) {
props.id = part.substring(1, part.length);
}
}
if (classes) {
if (props.className) {
classes.push(props.className);
}
props.className = classes.join(' ');
}
return props.namespace ? tagName : tagName.toUpperCase();
}
/***/ }),
/* 44 */
/***/ (function(module, exports) {
/*!
* Cross-Browser Split 1.1.1
* Copyright 2007-2012 Steven Levithan <stevenlevithan.com>
* Available under the MIT License
* ECMAScript compliant, uniform cross-browser split method
*/
/**
* Splits a string into an array of strings using a regex or string separator. Matches of the
* separator are not included in the result array. However, if `separator` is a regex that contains
* capturing groups, backreferences are spliced into the result each time `separator` is matched.
* Fixes browser bugs compared to the native `String.prototype.split` and can be used reliably
* cross-browser.
* @param {String} str String to split.
* @param {RegExp|String} separator Regex or string to use for separating the string.
* @param {Number} [limit] Maximum number of items to include in the result array.
* @returns {Array} Array of substrings.
* @example
*
* // Basic use
* split('a b c d', ' ');
* // -> ['a', 'b', 'c', 'd']
*
* // With limit
* split('a b c d', ' ', 2);
* // -> ['a', 'b']
*
* // Backreferences in result array
* split('..word1 word2..', /([a-z]+)(\d+)/i);
* // -> ['..', 'word', '1', ' ', 'word', '2', '..']
*/
module.exports = (function split(undef) {
var nativeSplit = String.prototype.split,
compliantExecNpcg = /()??/.exec("")[1] === undef,
// NPCG: nonparticipating capturing group
self;
self = function(str, separator, limit) {
// If `separator` is not a regex, use `nativeSplit`
if (Object.prototype.toString.call(separator) !== "[object RegExp]") {
return nativeSplit.call(str, separator, limit);
}
var output = [],
flags = (separator.ignoreCase ? "i" : "") + (separator.multiline ? "m" : "") + (separator.extended ? "x" : "") + // Proposed for ES6
(separator.sticky ? "y" : ""),
// Firefox 3+
lastLastIndex = 0,
// Make `global` and avoid `lastIndex` issues by working with a copy
separator = new RegExp(separator.source, flags + "g"),
separator2, match, lastIndex, lastLength;
str += ""; // Type-convert
if (!compliantExecNpcg) {
// Doesn't need flags gy, but they don't hurt
separator2 = new RegExp("^" + separator.source + "$(?!\\s)", flags);
}
/* Values for `limit`, per the spec:
* If undefined: 4294967295 // Math.pow(2, 32) - 1
* If 0, Infinity, or NaN: 0
* If positive number: limit = Math.floor(limit); if (limit > 4294967295) limit -= 4294967296;
* If negative number: 4294967296 - Math.floor(Math.abs(limit))
* If other: Type-convert, then use the above rules
*/
limit = limit === undef ? -1 >>> 0 : // Math.pow(2, 32) - 1
limit >>> 0; // ToUint32(limit)
while (match = separator.exec(str)) {
// `separator.lastIndex` is not reliable cross-browser
lastIndex = match.index + match[0].length;
if (lastIndex > lastLastIndex) {
output.push(str.slice(lastLastIndex, match.index));
// Fix browsers whose `exec` methods don't consistently return `undefined` for
// nonparticipating capturing groups
if (!compliantExecNpcg && match.length > 1) {
match[0].replace(separator2, function() {
for (var i = 1; i < arguments.length - 2; i++) {
if (arguments[i] === undef) {
match[i] = undef;
}
}
});
}
if (match.length > 1 && match.index < str.length) {
Array.prototype.push.apply(output, match.slice(1));
}
lastLength = match[0].length;
lastLastIndex = lastIndex;
if (output.length >= limit) {
break;
}
}
if (separator.lastIndex === match.index) {
separator.lastIndex++; // Avoid an infinite loop
}
}
if (lastLastIndex === str.length) {
if (lastLength || !separator.test("")) {
output.push("");
}
} else {
output.push(str.slice(lastLastIndex));
}
return output.length > limit ? output.slice(0, limit) : output;
};
return self;
})();
/***/ }),
/* 45 */
/***/ (function(module, exports) {
'use strict';
module.exports = SoftSetHook;
function SoftSetHook(value) {
if (!(this instanceof SoftSetHook)) {
return new SoftSetHook(value);
}
this.value = value;
}
SoftSetHook.prototype.hook = function (node, propertyName) {
if (node[propertyName] !== this.value) {
node[propertyName] = this.value;
}
};
/***/ }),
/* 46 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
var EvStore = __webpack_require__(47);
module.exports = EvHook;
function EvHook(value) {
if (!(this instanceof EvHook)) {
return new EvHook(value);
}
this.value = value;
}
EvHook.prototype.hook = function (node, propertyName) {
var es = EvStore(node);
var propName = propertyName.substr(3);
es[propName] = this.value;
};
EvHook.prototype.unhook = function(node, propertyName) {
var es = EvStore(node);
var propName = propertyName.substr(3);
es[propName] = undefined;
};
/***/ }),
/* 47 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
var OneVersionConstraint = __webpack_require__(48);
var MY_VERSION = '7';
OneVersionConstraint('ev-store', MY_VERSION);
var hashKey = '__EV_STORE_KEY@' + MY_VERSION;
module.exports = EvStore;
function EvStore(elem) {
var hash = elem[hashKey];
if (!hash) {
hash = elem[hashKey] = {};
}
return hash;
}
/***/ }),
/* 48 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
var Individual = __webpack_require__(49);
module.exports = OneVersion;
function OneVersion(moduleName, version, defaultValue) {
var key = '__INDIVIDUAL_ONE_VERSION_' + moduleName;
var enforceKey = key + '_ENFORCE_SINGLETON';
var versionValue = Individual(enforceKey, version);
if (versionValue !== version) {
throw new Error('Can only have one copy of ' +
moduleName + '.\n' +
'You already have version ' + versionValue +
' installed.\n' +
'This means you cannot install version ' + version);
}
return Individual(key, defaultValue);
}
/***/ }),
/* 49 */
/***/ (function(module, exports) {
/* WEBPACK VAR INJECTION */(function(global) {'use strict';
/*global window, global*/
var root = typeof window !== 'undefined' ?
window : typeof global !== 'undefined' ?
global : {};
module.exports = Individual;
function Individual(key, value) {
if (key in root) {
return root[key];
}
root[key] = value;
return value;
}
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
/***/ }),
/* 50 */
/***/ (function(module, exports, __webpack_require__) {
var diff = __webpack_require__(51)
module.exports = diff
/***/ }),
/* 51 */
/***/ (function(module, exports, __webpack_require__) {
var isArray = __webpack_require__(40)
var VPatch = __webpack_require__(52)
var isVNode = __webpack_require__(10)
var isVText = __webpack_require__(12)
var isWidget = __webpack_require__(13)
var isThunk = __webpack_require__(15)
var handleThunk = __webpack_require__(14)
var diffProps = __webpack_require__(53)
module.exports = diff
function diff(a, b) {
var patch = { a: a }
walk(a, b, patch, 0)
return patch
}
function walk(a, b, patch, index) {
if (a === b) {
return
}
var apply = patch[index]
var applyClear = false
if (isThunk(a) || isThunk(b)) {
thunks(a, b, patch, index)
} else if (b == null) {
// If a is a widget we will add a remove patch for it
// Otherwise any child widgets/hooks must be destroyed.
// This prevents adding two remove patches for a widget.
if (!isWidget(a)) {
clearState(a, patch, index)
apply = patch[index]
}
apply = appendPatch(apply, new VPatch(VPatch.REMOVE, a, b))
} else if (isVNode(b)) {
if (isVNode(a)) {
if (a.tagName === b.tagName &&
a.namespace === b.namespace &&
a.key === b.key) {
var propsPatch = diffProps(a.properties, b.properties)
if (propsPatch) {
apply = appendPatch(apply,
new VPatch(VPatch.PROPS, a, propsPatch))
}
apply = diffChildren(a, b, patch, apply, index)
} else {
apply = appendPatch(apply, new VPatch(VPatch.VNODE, a, b))
applyClear = true
}
} else {
apply = appendPatch(apply, new VPatch(VPatch.VNODE, a, b))
applyClear = true
}
} else if (isVText(b)) {
if (!isVText(a)) {
apply = appendPatch(apply, new VPatch(VPatch.VTEXT, a, b))
applyClear = true
} else if (a.text !== b.text) {
apply = appendPatch(apply, new VPatch(VPatch.VTEXT, a, b))
}
} else if (isWidget(b)) {
if (!isWidget(a)) {
applyClear = true
}
apply = appendPatch(apply, new VPatch(VPatch.WIDGET, a, b))
}
if (apply) {
patch[index] = apply
}
if (applyClear) {
clearState(a, patch, index)
}
}
function diffChildren(a, b, patch, apply, index) {
var aChildren = a.children
var orderedSet = reorder(aChildren, b.children)
var bChildren = orderedSet.children
var aLen = aChildren.length
var bLen = bChildren.length
var len = aLen > bLen ? aLen : bLen
for (var i = 0; i < len; i++) {
var leftNode = aChildren[i]
var rightNode = bChildren[i]
index += 1
if (!leftNode) {
if (rightNode) {
// Excess nodes in b need to be added
apply = appendPatch(apply,
new VPatch(VPatch.INSERT, null, rightNode))
}
} else {
walk(leftNode, rightNode, patch, index)
}
if (isVNode(leftNode) && leftNode.count) {
index += leftNode.count
}
}
if (orderedSet.moves) {
// Reorder nodes last
apply = appendPatch(apply, new VPatch(
VPatch.ORDER,
a,
orderedSet.moves
))
}
return apply
}
function clearState(vNode, patch, index) {
// TODO: Make this a single walk, not two
unhook(vNode, patch, index)
destroyWidgets(vNode, patch, index)
}
// Patch records for all destroyed widgets must be added because we need
// a DOM node reference for the destroy function
function destroyWidgets(vNode, patch, index) {
if (isWidget(vNode)) {
if (typeof vNode.destroy === "function") {
patch[index] = appendPatch(
patch[index],
new VPatch(VPatch.REMOVE, vNode, null)
)
}
} else if (isVNode(vNode) && (vNode.hasWidgets || vNode.hasThunks)) {
var children = vNode.children
var len = children.length
for (var i = 0; i < len; i++) {
var child = children[i]
index += 1
destroyWidgets(child, patch, index)
if (isVNode(child) && child.count) {
index += child.count
}
}
} else if (isThunk(vNode)) {
thunks(vNode, null, patch, index)
}
}
// Create a sub-patch for thunks
function thunks(a, b, patch, index) {
var nodes = handleThunk(a, b)
var thunkPatch = diff(nodes.a, nodes.b)
if (hasPatches(thunkPatch)) {
patch[index] = new VPatch(VPatch.THUNK, null, thunkPatch)
}
}
function hasPatches(patch) {
for (var index in patch) {
if (index !== "a") {
return true
}
}
return false
}
// Execute hooks when two nodes are identical
function unhook(vNode, patch, index) {
if (isVNode(vNode)) {
if (vNode.hooks) {
patch[index] = appendPatch(
patch[index],
new VPatch(
VPatch.PROPS,
vNode,
undefinedKeys(vNode.hooks)
)
)
}
if (vNode.descendantHooks || vNode.hasThunks) {
var children = vNode.children
var len = children.length
for (var i = 0; i < len; i++) {
var child = children[i]
index += 1
unhook(child, patch, index)
if (isVNode(child) && child.count) {
index += child.count
}
}
}
} else if (isThunk(vNode)) {
thunks(vNode, null, patch, index)
}
}
function undefinedKeys(obj) {
var result = {}
for (var key in obj) {
result[key] = undefined
}
return result
}
// List diff, naive left to right reordering
function reorder(aChildren, bChildren) {
// O(M) time, O(M) memory
var bChildIndex = keyIndex(bChildren)
var bKeys = bChildIndex.keys
var bFree = bChildIndex.free
if (bFree.length === bChildren.length) {
return {
children: bChildren,
moves: null
}
}
// O(N) time, O(N) memory
var aChildIndex = keyIndex(aChildren)
var aKeys = aChildIndex.keys
var aFree = aChildIndex.free
if (aFree.length === aChildren.length) {
return {
children: bChildren,
moves: null
}
}
// O(MAX(N, M)) memory
var newChildren = []
var freeIndex = 0
var freeCount = bFree.length
var deletedItems = 0
// Iterate through a and match a node in b
// O(N) time,
for (var i = 0 ; i < aChildren.length; i++) {
var aItem = aChildren[i]
var itemIndex
if (aItem.key) {
if (bKeys.hasOwnProperty(aItem.key)) {
// Match up the old keys
itemIndex = bKeys[aItem.key]
newChildren.push(bChildren[itemIndex])
} else {
// Remove old keyed items
itemIndex = i - deletedItems++
newChildren.push(null)
}
} else {
// Match the item in a with the next free item in b
if (freeIndex < freeCount) {
itemIndex = bFree[freeIndex++]
newChildren.push(bChildren[itemIndex])
} else {
// There are no free items in b to match with
// the free items in a, so the extra free nodes
// are deleted.
itemIndex = i - deletedItems++
newChildren.push(null)
}
}
}
var lastFreeIndex = freeIndex >= bFree.length ?
bChildren.length :
bFree[freeIndex]
// Iterate through b and append any new keys
// O(M) time
for (var j = 0; j < bChildren.length; j++) {
var newItem = bChildren[j]
if (newItem.key) {
if (!aKeys.hasOwnProperty(newItem.key)) {
// Add any new keyed items
// We are adding new items to the end and then sorting them
// in place. In future we should insert new items in place.
newChildren.push(newItem)
}
} else if (j >= lastFreeIndex) {
// Add any leftover non-keyed items
newChildren.push(newItem)
}
}
var simulate = newChildren.slice()
var simulateIndex = 0
var removes = []
var inserts = []
var simulateItem
for (var k = 0; k < bChildren.length;) {
var wantedItem = bChildren[k]
simulateItem = simulate[simulateIndex]
// remove items
while (simulateItem === null && simulate.length) {
removes.push(remove(simulate, simulateIndex, null))
simulateItem = simulate[simulateIndex]
}
if (!simulateItem || simulateItem.key !== wantedItem.key) {
// if we need a key in this position...
if (wantedItem.key) {
if (simulateItem && simulateItem.key) {
// if an insert doesn't put this key in place, it needs to move
if (bKeys[simulateItem.key] !== k + 1) {
removes.push(remove(simulate, simulateIndex, simulateItem.key))
simulateItem = simulate[simulateIndex]
// if the remove didn't put the wanted item in place, we need to insert it
if (!simulateItem || simulateItem.key !== wantedItem.key) {
inserts.push({key: wantedItem.key, to: k})
}
// items are matching, so skip ahead
else {
simulateIndex++
}
}
else {
inserts.push({key: wantedItem.key, to: k})
}
}
else {
inserts.push({key: wantedItem.key, to: k})
}
k++
}
// a key in simulate has no matching wanted key, remove it
else if (simulateItem && simulateItem.key) {
removes.push(remove(simulate, simulateIndex, simulateItem.key))
}
}
else {
simulateIndex++
k++
}
}
// remove all the remaining nodes from simulate
while(simulateIndex < simulate.length) {
simulateItem = simulate[simulateIndex]
removes.push(remove(simulate, simulateIndex, simulateItem && simulateItem.key))
}
// If the only moves we have are deletes then we can just
// let the delete patch remove these items.
if (removes.length === deletedItems && !inserts.length) {
return {
children: newChildren,
moves: null
}
}
return {
children: newChildren,
moves: {
removes: removes,
inserts: inserts
}
}
}
function remove(arr, index, key) {
arr.splice(index, 1)
return {
from: index,
key: key
}
}
function keyIndex(children) {
var keys = {}
var free = []
var length = children.length
for (var i = 0; i < length; i++) {
var child = children[i]
if (child.key) {
keys[child.key] = i
} else {
free.push(i)
}
}
return {
keys: keys, // A hash of key name to index
free: free // An array of unkeyed item indices
}
}
function appendPatch(apply, patch) {
if (apply) {
if (isArray(apply)) {
apply.push(patch)
} else {
apply = [apply, patch]
}
return apply
} else {
return patch
}
}
/***/ }),
/* 52 */
/***/ (function(module, exports, __webpack_require__) {
var version = __webpack_require__(11)
VirtualPatch.NONE = 0
VirtualPatch.VTEXT = 1
VirtualPatch.VNODE = 2
VirtualPatch.WIDGET = 3
VirtualPatch.PROPS = 4
VirtualPatch.ORDER = 5
VirtualPatch.INSERT = 6
VirtualPatch.REMOVE = 7
VirtualPatch.THUNK = 8
module.exports = VirtualPatch
function VirtualPatch(type, vNode, patch) {
this.type = Number(type)
this.vNode = vNode
this.patch = patch
}
VirtualPatch.prototype.version = version
VirtualPatch.prototype.type = "VirtualPatch"
/***/ }),
/* 53 */
/***/ (function(module, exports, __webpack_require__) {
var isObject = __webpack_require__(8)
var isHook = __webpack_require__(9)
module.exports = diffProps
function diffProps(a, b) {
var diff
for (var aKey in a) {
if (!(aKey in b)) {
diff = diff || {}
diff[aKey] = undefined
}
var aValue = a[aKey]
var bValue = b[aKey]
if (aValue === bValue) {
continue
} else if (isObject(aValue) && isObject(bValue)) {
if (getPrototype(bValue) !== getPrototype(aValue)) {
diff = diff || {}
diff[aKey] = bValue
} else if (isHook(bValue)) {
diff = diff || {}
diff[aKey] = bValue
} else {
var objectDiff = diffProps(aValue, bValue)
if (objectDiff) {
diff = diff || {}
diff[aKey] = objectDiff
}
}
} else {
diff = diff || {}
diff[aKey] = bValue
}
}
for (var bKey in b) {
if (!(bKey in a)) {
diff = diff || {}
diff[bKey] = b[bKey]
}
}
return diff
}
function getPrototype(value) {
if (Object.getPrototypeOf) {
return Object.getPrototypeOf(value)
} else if (value.__proto__) {
return value.__proto__
} else if (value.constructor) {
return value.constructor.prototype
}
}
/***/ }),
/* 54 */
/***/ (function(module, exports, __webpack_require__) {
var patch = __webpack_require__(55)
module.exports = patch
/***/ }),
/* 55 */
/***/ (function(module, exports, __webpack_require__) {
var document = __webpack_require__(5)
var isArray = __webpack_require__(40)
var render = __webpack_require__(4)
var domIndex = __webpack_require__(56)
var patchOp = __webpack_require__(57)
module.exports = patch
function patch(rootNode, patches, renderOptions) {
renderOptions = renderOptions || {}
renderOptions.patch = renderOptions.patch && renderOptions.patch !== patch
? renderOptions.patch
: patchRecursive
renderOptions.render = renderOptions.render || render
return renderOptions.patch(rootNode, patches, renderOptions)
}
function patchRecursive(rootNode, patches, renderOptions) {
var indices = patchIndices(patches)
if (indices.length === 0) {
return rootNode
}
var index = domIndex(rootNode, patches.a, indices)
var ownerDocument = rootNode.ownerDocument
if (!renderOptions.document && ownerDocument !== document) {
renderOptions.document = ownerDocument
}
for (var i = 0; i < indices.length; i++) {
var nodeIndex = indices[i]
rootNode = applyPatch(rootNode,
index[nodeIndex],
patches[nodeIndex],
renderOptions)
}
return rootNode
}
function applyPatch(rootNode, domNode, patchList, renderOptions) {
if (!domNode) {
return rootNode
}
var newNode
if (isArray(patchList)) {
for (var i = 0; i < patchList.length; i++) {
newNode = patchOp(patchList[i], domNode, renderOptions)
if (domNode === rootNode) {
rootNode = newNode
}
}
} else {
newNode = patchOp(patchList, domNode, renderOptions)
if (domNode === rootNode) {
rootNode = newNode
}
}
return rootNode
}
function patchIndices(patches) {
var indices = []
for (var key in patches) {
if (key !== "a") {
indices.push(Number(key))
}
}
return indices
}
/***/ }),
/* 56 */
/***/ (function(module, exports) {
// Maps a virtual DOM tree onto a real DOM tree in an efficient manner.
// We don't want to read all of the DOM nodes in the tree so we use
// the in-order tree indexing to eliminate recursion down certain branches.
// We only recurse into a DOM node if we know that it contains a child of
// interest.
var noChild = {}
module.exports = domIndex
function domIndex(rootNode, tree, indices, nodes) {
if (!indices || indices.length === 0) {
return {}
} else {
indices.sort(ascending)
return recurse(rootNode, tree, indices, nodes, 0)
}
}
function recurse(rootNode, tree, indices, nodes, rootIndex) {
nodes = nodes || {}
if (rootNode) {
if (indexInRange(indices, rootIndex, rootIndex)) {
nodes[rootIndex] = rootNode
}
var vChildren = tree.children
if (vChildren) {
var childNodes = rootNode.childNodes
for (var i = 0; i < tree.children.length; i++) {
rootIndex += 1
var vChild = vChildren[i] || noChild
var nextIndex = rootIndex + (vChild.count || 0)
// skip recursion down the tree if there are no nodes down here
if (indexInRange(indices, rootIndex, nextIndex)) {
recurse(childNodes[i], vChild, indices, nodes, rootIndex)
}
rootIndex = nextIndex
}
}
}
return nodes
}
// Binary search for an index in the interval [left, right]
function indexInRange(indices, left, right) {
if (indices.length === 0) {
return false
}
var minIndex = 0
var maxIndex = indices.length - 1
var currentIndex
var currentItem
while (minIndex <= maxIndex) {
currentIndex = ((maxIndex + minIndex) / 2) >> 0
currentItem = indices[currentIndex]
if (minIndex === maxIndex) {
return currentItem >= left && currentItem <= right
} else if (currentItem < left) {
minIndex = currentIndex + 1
} else if (currentItem > right) {
maxIndex = currentIndex - 1
} else {
return true
}
}
return false;
}
function ascending(a, b) {
return a > b ? 1 : -1
}
/***/ }),
/* 57 */
/***/ (function(module, exports, __webpack_require__) {
var applyProperties = __webpack_require__(7)
var isWidget = __webpack_require__(13)
var VPatch = __webpack_require__(52)
var updateWidget = __webpack_require__(58)
module.exports = applyPatch
function applyPatch(vpatch, domNode, renderOptions) {
var type = vpatch.type
var vNode = vpatch.vNode
var patch = vpatch.patch
switch (type) {
case VPatch.REMOVE:
return removeNode(domNode, vNode)
case VPatch.INSERT:
return insertNode(domNode, patch, renderOptions)
case VPatch.VTEXT:
return stringPatch(domNode, vNode, patch, renderOptions)
case VPatch.WIDGET:
return widgetPatch(domNode, vNode, patch, renderOptions)
case VPatch.VNODE:
return vNodePatch(domNode, vNode, patch, renderOptions)
case VPatch.ORDER:
reorderChildren(domNode, patch)
return domNode
case VPatch.PROPS:
applyProperties(domNode, patch, vNode.properties)
return domNode
case VPatch.THUNK:
return replaceRoot(domNode,
renderOptions.patch(domNode, patch, renderOptions))
default:
return domNode
}
}
function removeNode(domNode, vNode) {
var parentNode = domNode.parentNode
if (parentNode) {
parentNode.removeChild(domNode)
}
destroyWidget(domNode, vNode);
return null
}
function insertNode(parentNode, vNode, renderOptions) {
var newNode = renderOptions.render(vNode, renderOptions)
if (parentNode) {
parentNode.appendChild(newNode)
}
return parentNode
}
function stringPatch(domNode, leftVNode, vText, renderOptions) {
var newNode
if (domNode.nodeType === 3) {
domNode.replaceData(0, domNode.length, vText.text)
newNode = domNode
} else {
var parentNode = domNode.parentNode
newNode = renderOptions.render(vText, renderOptions)
if (parentNode && newNode !== domNode) {
parentNode.replaceChild(newNode, domNode)
}
}
return newNode
}
function widgetPatch(domNode, leftVNode, widget, renderOptions) {
var updating = updateWidget(leftVNode, widget)
var newNode
if (updating) {
newNode = widget.update(leftVNode, domNode) || domNode
} else {
newNode = renderOptions.render(widget, renderOptions)
}
var parentNode = domNode.parentNode
if (parentNode && newNode !== domNode) {
parentNode.replaceChild(newNode, domNode)
}
if (!updating) {
destroyWidget(domNode, leftVNode)
}
return newNode
}
function vNodePatch(domNode, leftVNode, vNode, renderOptions) {
var parentNode = domNode.parentNode
var newNode = renderOptions.render(vNode, renderOptions)
if (parentNode && newNode !== domNode) {
parentNode.replaceChild(newNode, domNode)
}
return newNode
}
function destroyWidget(domNode, w) {
if (typeof w.destroy === "function" && isWidget(w)) {
w.destroy(domNode)
}
}
function reorderChildren(domNode, moves) {
var childNodes = domNode.childNodes
var keyMap = {}
var node
var remove
var insert
for (var i = 0; i < moves.removes.length; i++) {
remove = moves.removes[i]
node = childNodes[remove.from]
if (remove.key) {
keyMap[remove.key] = node
}
domNode.removeChild(node)
}
var length = childNodes.length
for (var j = 0; j < moves.inserts.length; j++) {
insert = moves.inserts[j]
node = keyMap[insert.key]
// this is the weirdest bug i've ever seen in webkit
domNode.insertBefore(node, insert.to >= length++ ? null : childNodes[insert.to])
}
}
function replaceRoot(oldRoot, newRoot) {
if (oldRoot && newRoot && oldRoot !== newRoot && oldRoot.parentNode) {
oldRoot.parentNode.replaceChild(newRoot, oldRoot)
}
return newRoot;
}
/***/ }),
/* 58 */
/***/ (function(module, exports, __webpack_require__) {
var isWidget = __webpack_require__(13)
module.exports = updateWidget
function updateWidget(a, b) {
if (isWidget(a) && isWidget(b)) {
if ("name" in a && "name" in b) {
return a.id === b.id
} else {
return a.init === b.init
}
}
return false
}
/***/ }),
/* 59 */
/***/ (function(module, exports) {
/* WEBPACK VAR INJECTION */(function(global) {var WORKER_ENABLED = !!(global === global.window && global.URL && global.Blob && global.Worker);
function InlineWorker(func, self) {
var _this = this;
var functionBody;
self = self || {};
if (WORKER_ENABLED) {
functionBody = func.toString().trim().match(
/^function\s*\w*\s*\([\w\s,]*\)\s*{([\w\W]*?)}$/
)[1];
return new global.Worker(global.URL.createObjectURL(
new global.Blob([ functionBody ], { type: "text/javascript" })
));
}
function postMessage(data) {
setTimeout(function() {
_this.onmessage({ data: data });
}, 0);
}
this.self = self;
this.self.postMessage = postMessage;
setTimeout(func.bind(self, self), 0);
}
InlineWorker.prototype.postMessage = function postMessage(data) {
var _this = this;
setTimeout(function() {
_this.self.onmessage({ data: data });
}, 0);
};
module.exports = InlineWorker;
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
/***/ }),
/* 60 */
/***/ (function(module, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.samplesToSeconds = samplesToSeconds;
exports.secondsToSamples = secondsToSamples;
exports.samplesToPixels = samplesToPixels;
exports.pixelsToSamples = pixelsToSamples;
exports.pixelsToSeconds = pixelsToSeconds;
exports.secondsToPixels = secondsToPixels;
function samplesToSeconds(samples, sampleRate) {
return samples / sampleRate;
}
function secondsToSamples(seconds, sampleRate) {
return Math.ceil(seconds * sampleRate);
}
function samplesToPixels(samples, resolution) {
return Math.floor(samples / resolution);
}
function pixelsToSamples(pixels, resolution) {
return Math.floor(pixels * resolution);
}
function pixelsToSeconds(pixels, resolution, sampleRate) {
return pixels * resolution / sampleRate;
}
function secondsToPixels(seconds, resolution, sampleRate) {
return Math.ceil(seconds * sampleRate / resolution);
}
/***/ }),
/* 61 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _BlobLoader = __webpack_require__(62);
var _BlobLoader2 = _interopRequireDefault(_BlobLoader);
var _IdentityLoader = __webpack_require__(64);
var _IdentityLoader2 = _interopRequireDefault(_IdentityLoader);
var _XHRLoader = __webpack_require__(65);
var _XHRLoader2 = _interopRequireDefault(_XHRLoader);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class() {
_classCallCheck(this, _class);
}
_createClass(_class, null, [{
key: 'createLoader',
value: function createLoader(src, audioContext, ee) {
if (src instanceof Blob) {
return new _BlobLoader2.default(src, audioContext, ee);
} else if (src instanceof AudioBuffer) {
return new _IdentityLoader2.default(src, audioContext, ee);
} else if (typeof src === 'string') {
return new _XHRLoader2.default(src, audioContext, ee);
}
throw new Error('Unsupported src type');
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 62 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };
var _Loader2 = __webpack_require__(63);
var _Loader3 = _interopRequireDefault(_Loader2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var _class = function (_Loader) {
_inherits(_class, _Loader);
function _class() {
_classCallCheck(this, _class);
return _possibleConstructorReturn(this, (_class.__proto__ || Object.getPrototypeOf(_class)).apply(this, arguments));
}
_createClass(_class, [{
key: 'load',
/*
* Loads an audio file via a FileReader
*/
value: function load() {
var _this2 = this;
return new Promise(function (resolve, reject) {
if (_this2.src.type.match(/audio.*/) ||
// added for problems with Firefox mime types + ogg.
_this2.src.type.match(/video\/ogg/)) {
var fr = new FileReader();
fr.readAsArrayBuffer(_this2.src);
fr.addEventListener('progress', function (e) {
_get(_class.prototype.__proto__ || Object.getPrototypeOf(_class.prototype), 'fileProgress', _this2).call(_this2, e);
});
fr.addEventListener('load', function (e) {
var decoderPromise = _get(_class.prototype.__proto__ || Object.getPrototypeOf(_class.prototype), 'fileLoad', _this2).call(_this2, e);
decoderPromise.then(function (audioBuffer) {
resolve(audioBuffer);
}).catch(reject);
});
fr.addEventListener('error', reject);
} else {
reject(Error('Unsupported file type ' + _this2.src.type));
}
});
}
}]);
return _class;
}(_Loader3.default);
exports.default = _class;
/***/ }),
/* 63 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.STATE_FINISHED = exports.STATE_DECODING = exports.STATE_LOADING = exports.STATE_UNINITIALIZED = undefined;
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _eventEmitter = __webpack_require__(16);
var _eventEmitter2 = _interopRequireDefault(_eventEmitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var STATE_UNINITIALIZED = exports.STATE_UNINITIALIZED = 0;
var STATE_LOADING = exports.STATE_LOADING = 1;
var STATE_DECODING = exports.STATE_DECODING = 2;
var STATE_FINISHED = exports.STATE_FINISHED = 3;
var _class = function () {
function _class(src, audioContext) {
var ee = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : (0, _eventEmitter2.default)();
_classCallCheck(this, _class);
this.src = src;
this.ac = audioContext;
this.audioRequestState = STATE_UNINITIALIZED;
this.ee = ee;
}
_createClass(_class, [{
key: 'setStateChange',
value: function setStateChange(state) {
this.audioRequestState = state;
this.ee.emit('audiorequeststatechange', this.audioRequestState, this.src);
}
}, {
key: 'fileProgress',
value: function fileProgress(e) {
var percentComplete = 0;
if (this.audioRequestState === STATE_UNINITIALIZED) {
this.setStateChange(STATE_LOADING);
}
if (e.lengthComputable) {
percentComplete = e.loaded / e.total * 100;
}
this.ee.emit('loadprogress', percentComplete, this.src);
}
}, {
key: 'fileLoad',
value: function fileLoad(e) {
var _this = this;
var audioData = e.target.response || e.target.result;
if (audioData.byteLength > 16) {
var view = new DataView(audioData);
var wanted = "DEMOPUSHEADER_V2";
var success = true;
for (var i = 0, n = 16; i < n; i++) {
var c = view.getUint8(i);
if (c != wanted.charCodeAt(i)) {
success = false;
}
}
if (success) {
return this.fileLoad_custom(audioData);
}
}
this.setStateChange(STATE_DECODING);
return new Promise(function (resolve, reject) {
_this.ac.decodeAudioData(audioData, function (audioBuffer) {
_this.audioBuffer = audioBuffer;
_this.setStateChange(STATE_FINISHED);
resolve(audioBuffer);
}, function (err) {
if (err === null) {
// Safari issues with null error
reject(Error('MediaDecodeAudioDataUnknownContentType'));
} else {
reject(err);
}
});
});
}
}, {
key: 'fileLoad_custom',
value: function fileLoad_custom(demopusData) {
var _this2 = this;
this.setStateChange(STATE_DECODING);
var promises = [];
var view = new DataView(demopusData);
var ofs = 16; // skip header
var channels = 1;
var sampleRate = view.getUint32(ofs, true);
ofs += 4;
var numSamples = Number(view.getBigUint64(ofs, true));
ofs += 8;
// output sample rate != input sample rate
numSamples *= this.ac.sampleRate / sampleRate;
var audioBuffer = this.ac.createBuffer(channels, numSamples, this.ac.sampleRate);
while (ofs < demopusData.byteLength) {
var samplesOfs = Number(view.getBigUint64(ofs, true));
ofs += 8;
samplesOfs *= this.ac.sampleRate / sampleRate;
if (ofs >= demopusData.byteLength) {
break;
}
var dataLen = view.getUint32(ofs, true);
ofs += 4;
var opusData = demopusData.slice(ofs, ofs + dataLen);
ofs += dataLen;
var promise = this.ac.decodeAudioData(opusData, function (decoded) {
var buf = decoded.getChannelData(0);
audioBuffer.copyToChannel(buf, 0, this);
return decoded.length;
}.bind(samplesOfs), function (err) {
if (err === null) {
// Safari issues with null error
return Error('MediaDecodeAudioDataUnknownContentType');
} else {
return err;
}
});
promises.push(promise);
}
return new Promise(function (resolve, reject) {
Promise.all(promises).then(function (result) {
_this2.setStateChange(STATE_FINISHED);
resolve(audioBuffer);
});
});
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 64 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _Loader2 = __webpack_require__(63);
var _Loader3 = _interopRequireDefault(_Loader2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var IdentityLoader = function (_Loader) {
_inherits(IdentityLoader, _Loader);
function IdentityLoader() {
_classCallCheck(this, IdentityLoader);
return _possibleConstructorReturn(this, (IdentityLoader.__proto__ || Object.getPrototypeOf(IdentityLoader)).apply(this, arguments));
}
_createClass(IdentityLoader, [{
key: 'load',
value: function load() {
return Promise.resolve(this.src);
}
}]);
return IdentityLoader;
}(_Loader3.default);
exports.default = IdentityLoader;
/***/ }),
/* 65 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };
var _Loader2 = __webpack_require__(63);
var _Loader3 = _interopRequireDefault(_Loader2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var _class = function (_Loader) {
_inherits(_class, _Loader);
function _class() {
_classCallCheck(this, _class);
return _possibleConstructorReturn(this, (_class.__proto__ || Object.getPrototypeOf(_class)).apply(this, arguments));
}
_createClass(_class, [{
key: 'load',
/**
* Loads an audio file via XHR.
*/
value: function load() {
var _this2 = this;
return new Promise(function (resolve, reject) {
var xhr = new XMLHttpRequest();
xhr.open('GET', _this2.src, true);
xhr.responseType = 'arraybuffer';
xhr.send();
xhr.addEventListener('progress', function (e) {
_get(_class.prototype.__proto__ || Object.getPrototypeOf(_class.prototype), 'fileProgress', _this2).call(_this2, e);
});
xhr.addEventListener('load', function (e) {
var decoderPromise = _get(_class.prototype.__proto__ || Object.getPrototypeOf(_class.prototype), 'fileLoad', _this2).call(_this2, e);
decoderPromise.then(function (audioBuffer) {
resolve(audioBuffer);
}).catch(reject);
});
xhr.addEventListener('error', function () {
reject(Error('Track ' + _this2.src + ' failed to load'));
});
});
}
}]);
return _class;
}(_Loader3.default);
exports.default = _class;
/***/ }),
/* 66 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/*
* virtual-dom hook for scrolling the track container.
*/
var _class = function () {
function _class(playlist) {
_classCallCheck(this, _class);
this.playlist = playlist;
}
_createClass(_class, [{
key: 'hook',
value: function hook(node) {
var playlist = this.playlist;
if (!playlist.isScrolling) {
var el = node;
if (playlist.isAutomaticScroll) {
var rect = node.getBoundingClientRect();
var controlWidth = playlist.controls.show ? playlist.controls.width : 0;
var width = (0, _conversions.pixelsToSeconds)(rect.width - controlWidth, playlist.samplesPerPixel, playlist.sampleRate);
var timePoint = playlist.isPlaying() ? playlist.playbackSeconds : playlist.getTimeSelection().start;
if (timePoint < playlist.scrollLeft || timePoint >= playlist.scrollLeft + width) {
playlist.scrollLeft = Math.min(timePoint, playlist.duration - width);
}
}
var left = (0, _conversions.secondsToPixels)(playlist.scrollLeft, playlist.samplesPerPixel, playlist.sampleRate);
el.scrollLeft = left;
}
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 67 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _h = __webpack_require__(38);
var _h2 = _interopRequireDefault(_h);
var _conversions = __webpack_require__(60);
var _TimeScaleHook = __webpack_require__(68);
var _TimeScaleHook2 = _interopRequireDefault(_TimeScaleHook);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var TimeScale = function () {
function TimeScale(duration, offset, samplesPerPixel, sampleRate) {
var marginLeft = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0;
var colors = arguments[5];
_classCallCheck(this, TimeScale);
this.duration = duration;
this.offset = offset;
this.samplesPerPixel = samplesPerPixel;
this.sampleRate = sampleRate;
this.marginLeft = marginLeft;
this.colors = colors;
this.timeinfo = {
20000: {
marker: 30000,
bigStep: 10000,
smallStep: 5000,
secondStep: 5
},
12000: {
marker: 15000,
bigStep: 5000,
smallStep: 1000,
secondStep: 1
},
10000: {
marker: 10000,
bigStep: 5000,
smallStep: 1000,
secondStep: 1
},
5000: {
marker: 5000,
bigStep: 1000,
smallStep: 500,
secondStep: 1 / 2
},
2500: {
marker: 2000,
bigStep: 1000,
smallStep: 500,
secondStep: 1 / 2
},
1500: {
marker: 2000,
bigStep: 1000,
smallStep: 200,
secondStep: 1 / 5
},
700: {
marker: 1000,
bigStep: 500,
smallStep: 100,
secondStep: 1 / 10
}
};
}
_createClass(TimeScale, [{
key: 'getScaleInfo',
value: function getScaleInfo(resolution) {
var keys = Object.keys(this.timeinfo).map(function (item) {
return parseInt(item, 10);
});
// make sure keys are numerically sorted.
keys = keys.sort(function (a, b) {
return a - b;
});
for (var i = 0; i < keys.length; i += 1) {
if (resolution <= keys[i]) {
return this.timeinfo[keys[i]];
}
}
return this.timeinfo[keys[0]];
}
/*
Return time in format mm:ss
*/
}, {
key: 'render',
value: function render() {
var widthX = (0, _conversions.secondsToPixels)(this.duration, this.samplesPerPixel, this.sampleRate);
var pixPerSec = this.sampleRate / this.samplesPerPixel;
var pixOffset = (0, _conversions.secondsToPixels)(this.offset, this.samplesPerPixel, this.sampleRate);
var scaleInfo = this.getScaleInfo(this.samplesPerPixel);
var canvasInfo = {};
var timeMarkers = [];
var end = widthX + pixOffset;
var counter = 0;
for (var i = 0; i < end; i += pixPerSec * scaleInfo.secondStep) {
var pixIndex = Math.floor(i);
var pix = pixIndex - pixOffset;
if (pixIndex >= pixOffset) {
// put a timestamp every 30 seconds.
if (scaleInfo.marker && counter % scaleInfo.marker === 0) {
timeMarkers.push((0, _h2.default)('div.time', {
attributes: {
style: 'position: absolute; left: ' + pix + 'px;'
}
}, [TimeScale.formatTime(counter)]));
canvasInfo[pix] = 10;
} else if (scaleInfo.bigStep && counter % scaleInfo.bigStep === 0) {
canvasInfo[pix] = 5;
} else if (scaleInfo.smallStep && counter % scaleInfo.smallStep === 0) {
canvasInfo[pix] = 2;
}
}
counter += 1000 * scaleInfo.secondStep;
}
return (0, _h2.default)('div.playlist-time-scale', {
attributes: {
style: 'position: relative; left: 0; right: 0; margin-left: ' + this.marginLeft + 'px;'
}
}, [timeMarkers, (0, _h2.default)('canvas', {
attributes: {
width: widthX,
height: 30,
style: 'position: absolute; left: 0; right: 0; top: 0; bottom: 0;'
},
hook: new _TimeScaleHook2.default(canvasInfo, this.offset, this.samplesPerPixel, this.duration, this.colors)
})]);
}
}], [{
key: 'formatTime',
value: function formatTime(milliseconds) {
var seconds = milliseconds / 1000;
var s = seconds % 60;
var m = (seconds - s) / 60;
if (s < 10) {
s = '0' + s;
}
return m + ':' + s;
}
}]);
return TimeScale;
}();
exports.default = TimeScale;
/***/ }),
/* 68 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/*
* virtual-dom hook for rendering the time scale canvas.
*/
var _class = function () {
function _class(tickInfo, offset, samplesPerPixel, duration, colors) {
_classCallCheck(this, _class);
this.tickInfo = tickInfo;
this.offset = offset;
this.samplesPerPixel = samplesPerPixel;
this.duration = duration;
this.colors = colors;
}
_createClass(_class, [{
key: 'hook',
value: function hook(canvas, prop, prev) {
var _this = this;
// canvas is up to date
if (prev !== undefined && prev.offset === this.offset && prev.duration === this.duration && prev.samplesPerPixel === this.samplesPerPixel) {
return;
}
var width = canvas.width;
var height = canvas.height;
var ctx = canvas.getContext('2d');
ctx.clearRect(0, 0, width, height);
ctx.fillStyle = this.colors.timeColor;
Object.keys(this.tickInfo).forEach(function (x) {
var scaleHeight = _this.tickInfo[x];
var scaleY = height - scaleHeight;
ctx.fillRect(x, scaleY, 1, scaleHeight);
});
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 69 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _lodash = __webpack_require__(70);
var _lodash2 = _interopRequireDefault(_lodash);
var _lodash3 = __webpack_require__(71);
var _lodash4 = _interopRequireDefault(_lodash3);
var _uuid = __webpack_require__(72);
var _uuid2 = _interopRequireDefault(_uuid);
var _h = __webpack_require__(38);
var _h2 = _interopRequireDefault(_h);
var _webaudioPeaks = __webpack_require__(74);
var _webaudioPeaks2 = _interopRequireDefault(_webaudioPeaks);
var _fadeMaker = __webpack_require__(75);
var _conversions = __webpack_require__(60);
var _states = __webpack_require__(77);
var _states2 = _interopRequireDefault(_states);
var _CanvasHook = __webpack_require__(83);
var _CanvasHook2 = _interopRequireDefault(_CanvasHook);
var _FadeCanvasHook = __webpack_require__(84);
var _FadeCanvasHook2 = _interopRequireDefault(_FadeCanvasHook);
var _VolumeSliderHook = __webpack_require__(85);
var _VolumeSliderHook2 = _interopRequireDefault(_VolumeSliderHook);
var _StereoPanSliderHook = __webpack_require__(86);
var _StereoPanSliderHook2 = _interopRequireDefault(_StereoPanSliderHook);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var MAX_CANVAS_WIDTH = 1000;
var _class = function () {
function _class() {
_classCallCheck(this, _class);
this.name = 'Untitled';
this.info = undefined;
this.customClass = undefined;
this.waveOutlineColor = undefined;
this.gain = 1;
this.fades = {};
this.peakData = {
type: 'WebAudio',
mono: false
};
this.cueIn = 0;
this.cueOut = 0;
this.duration = 0;
this.startTime = 0;
this.endTime = 0;
this.stereoPan = 0;
}
_createClass(_class, [{
key: 'setEventEmitter',
value: function setEventEmitter(ee) {
this.ee = ee;
}
}, {
key: 'setName',
value: function setName(name) {
this.name = name;
}
}, {
key: 'setInfo',
value: function setInfo(info) {
this.info = info;
}
}, {
key: 'setCustomClass',
value: function setCustomClass(className) {
this.customClass = className;
}
}, {
key: 'setWaveOutlineColor',
value: function setWaveOutlineColor(color) {
this.waveOutlineColor = color;
}
}, {
key: 'setCues',
value: function setCues(cueIn, cueOut) {
if (cueOut < cueIn) {
throw new Error('cue out cannot be less than cue in');
}
this.cueIn = cueIn;
this.cueOut = cueOut;
this.duration = this.cueOut - this.cueIn;
this.endTime = this.startTime + this.duration;
}
/*
* start, end in seconds relative to the entire playlist.
*/
}, {
key: 'trim',
value: function trim(start, end) {
var trackStart = this.getStartTime();
var trackEnd = this.getEndTime();
var offset = this.cueIn - trackStart;
if (trackStart <= start && trackEnd >= start || trackStart <= end && trackEnd >= end) {
var cueIn = start < trackStart ? trackStart : start;
var cueOut = end > trackEnd ? trackEnd : end;
this.setCues(cueIn + offset, cueOut + offset);
if (start > trackStart) {
this.setStartTime(start);
}
}
}
}, {
key: 'setStartTime',
value: function setStartTime(start) {
this.startTime = start;
this.endTime = start + this.duration;
}
}, {
key: 'setPlayout',
value: function setPlayout(playout) {
this.playout = playout;
}
}, {
key: 'setOfflinePlayout',
value: function setOfflinePlayout(playout) {
this.offlinePlayout = playout;
}
}, {
key: 'setEnabledStates',
value: function setEnabledStates() {
var enabledStates = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var defaultStatesEnabled = {
cursor: true,
fadein: true,
fadeout: true,
select: true,
shift: true
};
this.enabledStates = (0, _lodash2.default)({}, defaultStatesEnabled, enabledStates);
}
}, {
key: 'setFadeIn',
value: function setFadeIn(duration) {
var shape = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'logarithmic';
if (duration > this.duration) {
throw new Error('Invalid Fade In');
}
var fade = {
shape: shape,
start: 0,
end: duration
};
if (this.fadeIn) {
this.removeFade(this.fadeIn);
this.fadeIn = undefined;
}
this.fadeIn = this.saveFade(_fadeMaker.FADEIN, fade.shape, fade.start, fade.end);
}
}, {
key: 'setFadeOut',
value: function setFadeOut(duration) {
var shape = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'logarithmic';
if (duration > this.duration) {
throw new Error('Invalid Fade Out');
}
var fade = {
shape: shape,
start: this.duration - duration,
end: this.duration
};
if (this.fadeOut) {
this.removeFade(this.fadeOut);
this.fadeOut = undefined;
}
this.fadeOut = this.saveFade(_fadeMaker.FADEOUT, fade.shape, fade.start, fade.end);
}
}, {
key: 'saveFade',
value: function saveFade(type, shape, start, end) {
var id = _uuid2.default.v4();
this.fades[id] = {
type: type,
shape: shape,
start: start,
end: end
};
return id;
}
}, {
key: 'removeFade',
value: function removeFade(id) {
delete this.fades[id];
}
}, {
key: 'setBuffer',
value: function setBuffer(buffer) {
this.buffer = buffer;
}
}, {
key: 'setPeakData',
value: function setPeakData(data) {
this.peakData = data;
}
}, {
key: 'calculatePeaks',
value: function calculatePeaks(samplesPerPixel, sampleRate) {
var cueIn = (0, _conversions.secondsToSamples)(this.cueIn, sampleRate);
var cueOut = (0, _conversions.secondsToSamples)(this.cueOut, sampleRate);
this.setPeaks((0, _webaudioPeaks2.default)(this.buffer, samplesPerPixel, this.peakData.mono, cueIn, cueOut));
}
}, {
key: 'setPeaks',
value: function setPeaks(peaks) {
this.peaks = peaks;
}
}, {
key: 'setState',
value: function setState(state) {
this.state = state;
if (this.state && this.enabledStates[this.state]) {
var StateClass = _states2.default[this.state];
this.stateObj = new StateClass(this);
} else {
this.stateObj = undefined;
}
}
}, {
key: 'getStartTime',
value: function getStartTime() {
return this.startTime;
}
}, {
key: 'getEndTime',
value: function getEndTime() {
return this.endTime;
}
}, {
key: 'getDuration',
value: function getDuration() {
return this.duration;
}
}, {
key: 'isPlaying',
value: function isPlaying() {
return this.playout.isPlaying();
}
}, {
key: 'setShouldPlay',
value: function setShouldPlay(bool) {
this.playout.setShouldPlay(bool);
}
}, {
key: 'setGainLevel',
value: function setGainLevel(level) {
this.gain = level;
this.playout.setVolumeGainLevel(level);
}
}, {
key: 'setMasterGainLevel',
value: function setMasterGainLevel(level) {
this.playout.setMasterGainLevel(level);
}
}, {
key: 'setStereoPanValue',
value: function setStereoPanValue(value) {
this.stereoPan = value;
this.playout.setStereoPanValue(value);
}
/*
startTime, endTime in seconds (float).
segment is for a highlighted section in the UI.
returns a Promise that will resolve when the AudioBufferSource
is either stopped or plays out naturally.
*/
}, {
key: 'schedulePlay',
value: function schedulePlay(now, startTime, endTime, config) {
var start = void 0;
var duration = void 0;
var when = now;
var segment = endTime ? endTime - startTime : undefined;
var defaultOptions = {
shouldPlay: true,
masterGain: 1,
isOffline: false
};
var options = (0, _lodash2.default)({}, defaultOptions, config);
var playoutSystem = options.isOffline ? this.offlinePlayout : this.playout;
// 1) track has no content to play.
// 2) track does not play in this selection.
if (this.endTime <= startTime || segment && startTime + segment < this.startTime) {
// return a resolved promise since this track is technically "stopped".
return Promise.resolve();
}
// track should have something to play if it gets here.
// the track starts in the future or on the cursor position
if (this.startTime >= startTime) {
start = 0;
// schedule additional delay for this audio node.
when += this.startTime - startTime;
if (endTime) {
segment -= this.startTime - startTime;
duration = Math.min(segment, this.duration);
} else {
duration = this.duration;
}
} else {
start = startTime - this.startTime;
if (endTime) {
duration = Math.min(segment, this.duration - start);
} else {
duration = this.duration - start;
}
}
start += this.cueIn;
var relPos = startTime - this.startTime;
var sourcePromise = playoutSystem.setUpSource();
// param relPos: cursor position in seconds relative to this track.
// can be negative if the cursor is placed before the start of this track etc.
(0, _lodash4.default)(this.fades, function (fade) {
var fadeStart = void 0;
var fadeDuration = void 0;
// only apply fade if it's ahead of the cursor.
if (relPos < fade.end) {
if (relPos <= fade.start) {
fadeStart = now + (fade.start - relPos);
fadeDuration = fade.end - fade.start;
} else if (relPos > fade.start && relPos < fade.end) {
fadeStart = now - (relPos - fade.start);
fadeDuration = fade.end - fade.start;
}
switch (fade.type) {
case _fadeMaker.FADEIN:
{
playoutSystem.applyFadeIn(fadeStart, fadeDuration, fade.shape);
break;
}
case _fadeMaker.FADEOUT:
{
playoutSystem.applyFadeOut(fadeStart, fadeDuration, fade.shape);
break;
}
default:
{
throw new Error('Invalid fade type saved on track.');
}
}
}
});
playoutSystem.setVolumeGainLevel(this.gain);
playoutSystem.setShouldPlay(options.shouldPlay);
playoutSystem.setMasterGainLevel(options.masterGain);
playoutSystem.setStereoPanValue(this.stereoPan);
playoutSystem.play(when, start, duration);
return sourcePromise;
}
}, {
key: 'scheduleStop',
value: function scheduleStop() {
var when = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
this.playout.stop(when);
}
}, {
key: 'renderOverlay',
value: function renderOverlay(data) {
var _this = this;
var channelPixels = (0, _conversions.secondsToPixels)(data.playlistLength, data.resolution, data.sampleRate);
var config = {
attributes: {
style: 'position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: ' + channelPixels + 'px; z-index: 9;'
}
};
var overlayClass = '';
if (this.stateObj) {
this.stateObj.setup(data.resolution, data.sampleRate);
var StateClass = _states2.default[this.state];
var events = StateClass.getEvents();
events.forEach(function (event) {
config['on' + event] = _this.stateObj[event].bind(_this.stateObj);
});
overlayClass = StateClass.getClass();
}
// use this overlay for track event cursor position calculations.
return (0, _h2.default)('div.playlist-overlay' + overlayClass, config);
}
}, {
key: 'renderControls',
value: function renderControls(data) {
var _this2 = this;
var muteClass = data.muted ? '.active' : '';
var soloClass = data.soloed ? '.active' : '';
var isCollapsed = data.collapsed;
var numChan = this.peaks.data.length;
var widgets = data.controls.widgets;
var removeTrack = (0, _h2.default)('button.btn.btn-danger.btn-sm.track-remove', {
attributes: {
type: 'button',
title: 'Remove track'
},
onclick: function onclick() {
_this2.ee.emit('removeTrack', _this2);
}
}, [(0, _h2.default)('i.fas.fa-times')]);
var trackName = (0, _h2.default)('span', [this.name]);
var collapseTrack = (0, _h2.default)('button.btn.btn-info.btn-sm.track-collapse', {
attributes: {
type: 'button',
title: isCollapsed ? 'Expand track' : 'Collapse track'
},
onclick: function onclick() {
_this2.ee.emit('changeTrackView', _this2, {
collapsed: !isCollapsed
});
}
}, [(0, _h2.default)('i.fas.' + (isCollapsed ? 'fa-caret-down' : 'fa-caret-up'))]);
var headerChildren = [];
if (widgets.remove) {
headerChildren.push(removeTrack);
}
headerChildren.push(trackName);
if (widgets.collapse) {
headerChildren.push(collapseTrack);
}
var controls = [(0, _h2.default)('div.track-header', headerChildren)];
if (!isCollapsed) {
if (widgets.muteOrSolo) {
controls.push((0, _h2.default)('div.btn-group', [(0, _h2.default)('button.btn.btn-outline-dark.btn-xs.btn-mute' + muteClass, {
attributes: {
type: 'button'
},
onclick: function onclick() {
_this2.ee.emit('mute', _this2);
}
}, ['Mute']), (0, _h2.default)('button.btn.btn-outline-dark.btn-xs.btn-solo' + soloClass, {
onclick: function onclick() {
_this2.ee.emit('solo', _this2);
}
}, ['Solo'])]));
}
if (widgets.volume) {
controls.push((0, _h2.default)('label.volume', [(0, _h2.default)('input.volume-slider', {
attributes: {
'aria-label': 'Track volume control',
type: 'range',
min: 0,
max: 100,
value: 100
},
hook: new _VolumeSliderHook2.default(this.gain),
oninput: function oninput(e) {
_this2.ee.emit('volumechange', e.target.value, _this2);
}
})]));
}
if (widgets.stereoPan) {
controls.push((0, _h2.default)('label.stereopan', [(0, _h2.default)('input.stereopan-slider', {
attributes: {
'aria-label': 'Track stereo pan control',
type: 'range',
min: -100,
max: 100,
value: 100
},
hook: new _StereoPanSliderHook2.default(this.stereoPan),
oninput: function oninput(e) {
_this2.ee.emit('stereopan', e.target.value / 100, _this2);
}
})]));
}
if (widgets.info) {
controls.push((0, _h2.default)('label.info', [this.info]));
}
}
return (0, _h2.default)('div.controls', {
attributes: {
style: 'height: ' + numChan * data.height + 'px; width: ' + data.controls.width + 'px; position: absolute; left: 0; z-index: 10;'
}
}, controls);
}
}, {
key: 'render',
value: function render(data) {
var _this3 = this;
var width = this.peaks.length;
var playbackX = (0, _conversions.secondsToPixels)(data.playbackSeconds, data.resolution, data.sampleRate);
var startX = (0, _conversions.secondsToPixels)(this.startTime, data.resolution, data.sampleRate);
var endX = (0, _conversions.secondsToPixels)(this.endTime, data.resolution, data.sampleRate);
var progressWidth = 0;
var numChan = this.peaks.data.length;
var scale = Math.floor(window.devicePixelRatio);
if (playbackX > 0 && playbackX > startX) {
if (playbackX < endX) {
progressWidth = playbackX - startX;
} else {
progressWidth = width;
}
}
var waveformChildren = [(0, _h2.default)('div.cursor', {
attributes: {
style: 'position: absolute; width: 1px; margin: 0; padding: 0; top: 0; left: ' + playbackX + 'px; bottom: 0; z-index: 5;'
}
})];
var channels = Object.keys(this.peaks.data).map(function (channelNum) {
var channelChildren = [(0, _h2.default)('div.channel-progress', {
attributes: {
style: 'position: absolute; width: ' + progressWidth + 'px; height: ' + data.height + 'px; z-index: 2;'
}
})];
var offset = 0;
var totalWidth = width;
var peaks = _this3.peaks.data[channelNum];
while (totalWidth > 0) {
var currentWidth = Math.min(totalWidth, MAX_CANVAS_WIDTH);
var canvasColor = _this3.waveOutlineColor ? _this3.waveOutlineColor : data.colors.waveOutlineColor;
channelChildren.push((0, _h2.default)('canvas', {
attributes: {
width: currentWidth * scale,
height: data.height * scale,
style: 'float: left; position: relative; margin: 0; padding: 0; z-index: 3; width: ' + currentWidth + 'px; height: ' + data.height + 'px;'
},
hook: new _CanvasHook2.default(peaks, offset, _this3.peaks.bits, canvasColor, scale, data.height)
}));
totalWidth -= currentWidth;
offset += MAX_CANVAS_WIDTH;
}
// if there are fades, display them.
if (_this3.fadeIn) {
var fadeIn = _this3.fades[_this3.fadeIn];
var fadeWidth = (0, _conversions.secondsToPixels)(fadeIn.end - fadeIn.start, data.resolution, data.sampleRate);
channelChildren.push((0, _h2.default)('div.wp-fade.wp-fadein', {
attributes: {
style: 'position: absolute; height: ' + data.height + 'px; width: ' + fadeWidth + 'px; top: 0; left: 0; z-index: 4;'
}
}, [(0, _h2.default)('canvas', {
attributes: {
width: fadeWidth,
height: data.height
},
hook: new _FadeCanvasHook2.default(fadeIn.type, fadeIn.shape, fadeIn.end - fadeIn.start, data.resolution)
})]));
}
if (_this3.fadeOut) {
var fadeOut = _this3.fades[_this3.fadeOut];
var _fadeWidth = (0, _conversions.secondsToPixels)(fadeOut.end - fadeOut.start, data.resolution, data.sampleRate);
channelChildren.push((0, _h2.default)('div.wp-fade.wp-fadeout', {
attributes: {
style: 'position: absolute; height: ' + data.height + 'px; width: ' + _fadeWidth + 'px; top: 0; right: 0; z-index: 4;'
}
}, [(0, _h2.default)('canvas', {
attributes: {
width: _fadeWidth,
height: data.height
},
hook: new _FadeCanvasHook2.default(fadeOut.type, fadeOut.shape, fadeOut.end - fadeOut.start, data.resolution)
})]));
}
return (0, _h2.default)('div.channel.channel-' + channelNum, {
attributes: {
style: 'height: ' + data.height + 'px; width: ' + width + 'px; top: ' + channelNum * data.height + 'px; left: ' + startX + 'px; position: absolute; margin: 0; padding: 0; z-index: 1;'
}
}, channelChildren);
});
waveformChildren.push(channels);
waveformChildren.push(this.renderOverlay(data));
// draw cursor selection on active track.
if (data.isActive === true) {
var cStartX = (0, _conversions.secondsToPixels)(data.timeSelection.start, data.resolution, data.sampleRate);
var cEndX = (0, _conversions.secondsToPixels)(data.timeSelection.end, data.resolution, data.sampleRate);
var cWidth = cEndX - cStartX + 1;
var cClassName = cWidth > 1 ? '.segment' : '.point';
waveformChildren.push((0, _h2.default)('div.selection' + cClassName, {
attributes: {
style: 'position: absolute; width: ' + cWidth + 'px; bottom: 0; top: 0; left: ' + cStartX + 'px; z-index: 4;'
}
}));
}
var waveform = (0, _h2.default)('div.waveform', {
attributes: {
style: 'height: ' + numChan * data.height + 'px; position: relative;'
}
}, waveformChildren);
var channelChildren = [];
var channelMargin = 0;
if (data.controls.show) {
channelChildren.push(this.renderControls(data));
channelMargin = data.controls.width;
}
channelChildren.push(waveform);
var audibleClass = data.shouldPlay ? '' : '.silent';
var customClass = this.customClass === undefined ? '' : '.' + this.customClass;
return (0, _h2.default)('div.channel-wrapper' + audibleClass + customClass, {
attributes: {
style: 'margin-left: ' + channelMargin + 'px; height: ' + data.height * numChan + 'px;'
}
}, channelChildren);
}
}, {
key: 'getTrackDetails',
value: function getTrackDetails() {
var info = {
src: this.src,
start: this.startTime,
end: this.endTime,
name: this.name,
info: this.info,
customClass: this.customClass,
cuein: this.cueIn,
cueout: this.cueOut,
stereoPan: this.stereoPan,
gain: this.gain
};
if (this.fadeIn) {
var fadeIn = this.fades[this.fadeIn];
info.fadeIn = {
shape: fadeIn.shape,
duration: fadeIn.end - fadeIn.start
};
}
if (this.fadeOut) {
var fadeOut = this.fades[this.fadeOut];
info.fadeOut = {
shape: fadeOut.shape,
duration: fadeOut.end - fadeOut.start
};
}
return info;
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 70 */
/***/ (function(module, exports) {
/**
* lodash (Custom Build) <https://lodash.com/>
* Build: `lodash modularize exports="npm" -o ./`
* Copyright jQuery Foundation and other contributors <https://jquery.org/>
* Released under MIT license <https://lodash.com/license>
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
* Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
*/
/** Used as references for various `Number` constants. */
var MAX_SAFE_INTEGER = 9007199254740991;
/** `Object#toString` result references. */
var argsTag = '[object Arguments]',
funcTag = '[object Function]',
genTag = '[object GeneratorFunction]';
/** Used to detect unsigned integer values. */
var reIsUint = /^(?:0|[1-9]\d*)$/;
/**
* A faster alternative to `Function#apply`, this function invokes `func`
* with the `this` binding of `thisArg` and the arguments of `args`.
*
* @private
* @param {Function} func The function to invoke.
* @param {*} thisArg The `this` binding of `func`.
* @param {Array} args The arguments to invoke `func` with.
* @returns {*} Returns the result of `func`.
*/
function apply(func, thisArg, args) {
switch (args.length) {
case 0: return func.call(thisArg);
case 1: return func.call(thisArg, args[0]);
case 2: return func.call(thisArg, args[0], args[1]);
case 3: return func.call(thisArg, args[0], args[1], args[2]);
}
return func.apply(thisArg, args);
}
/**
* The base implementation of `_.times` without support for iteratee shorthands
* or max array length checks.
*
* @private
* @param {number} n The number of times to invoke `iteratee`.
* @param {Function} iteratee The function invoked per iteration.
* @returns {Array} Returns the array of results.
*/
function baseTimes(n, iteratee) {
var index = -1,
result = Array(n);
while (++index < n) {
result[index] = iteratee(index);
}
return result;
}
/**
* Creates a unary function that invokes `func` with its argument transformed.
*
* @private
* @param {Function} func The function to wrap.
* @param {Function} transform The argument transform.
* @returns {Function} Returns the new function.
*/
function overArg(func, transform) {
return function(arg) {
return func(transform(arg));
};
}
/** Used for built-in method references. */
var objectProto = Object.prototype;
/** Used to check objects for own properties. */
var hasOwnProperty = objectProto.hasOwnProperty;
/**
* Used to resolve the
* [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
* of values.
*/
var objectToString = objectProto.toString;
/** Built-in value references. */
var propertyIsEnumerable = objectProto.propertyIsEnumerable;
/* Built-in method references for those with the same name as other `lodash` methods. */
var nativeKeys = overArg(Object.keys, Object),
nativeMax = Math.max;
/** Detect if properties shadowing those on `Object.prototype` are non-enumerable. */
var nonEnumShadows = !propertyIsEnumerable.call({ 'valueOf': 1 }, 'valueOf');
/**
* Creates an array of the enumerable property names of the array-like `value`.
*
* @private
* @param {*} value The value to query.
* @param {boolean} inherited Specify returning inherited property names.
* @returns {Array} Returns the array of property names.
*/
function arrayLikeKeys(value, inherited) {
// Safari 8.1 makes `arguments.callee` enumerable in strict mode.
// Safari 9 makes `arguments.length` enumerable in strict mode.
var result = (isArray(value) || isArguments(value))
? baseTimes(value.length, String)
: [];
var length = result.length,
skipIndexes = !!length;
for (var key in value) {
if ((inherited || hasOwnProperty.call(value, key)) &&
!(skipIndexes && (key == 'length' || isIndex(key, length)))) {
result.push(key);
}
}
return result;
}
/**
* Assigns `value` to `key` of `object` if the existing value is not equivalent
* using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
* for equality comparisons.
*
* @private
* @param {Object} object The object to modify.
* @param {string} key The key of the property to assign.
* @param {*} value The value to assign.
*/
function assignValue(object, key, value) {
var objValue = object[key];
if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||
(value === undefined && !(key in object))) {
object[key] = value;
}
}
/**
* The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
*
* @private
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
*/
function baseKeys(object) {
if (!isPrototype(object)) {
return nativeKeys(object);
}
var result = [];
for (var key in Object(object)) {
if (hasOwnProperty.call(object, key) && key != 'constructor') {
result.push(key);
}
}
return result;
}
/**
* The base implementation of `_.rest` which doesn't validate or coerce arguments.
*
* @private
* @param {Function} func The function to apply a rest parameter to.
* @param {number} [start=func.length-1] The start position of the rest parameter.
* @returns {Function} Returns the new function.
*/
function baseRest(func, start) {
start = nativeMax(start === undefined ? (func.length - 1) : start, 0);
return function() {
var args = arguments,
index = -1,
length = nativeMax(args.length - start, 0),
array = Array(length);
while (++index < length) {
array[index] = args[start + index];
}
index = -1;
var otherArgs = Array(start + 1);
while (++index < start) {
otherArgs[index] = args[index];
}
otherArgs[start] = array;
return apply(func, this, otherArgs);
};
}
/**
* Copies properties of `source` to `object`.
*
* @private
* @param {Object} source The object to copy properties from.
* @param {Array} props The property identifiers to copy.
* @param {Object} [object={}] The object to copy properties to.
* @param {Function} [customizer] The function to customize copied values.
* @returns {Object} Returns `object`.
*/
function copyObject(source, props, object, customizer) {
object || (object = {});
var index = -1,
length = props.length;
while (++index < length) {
var key = props[index];
var newValue = customizer
? customizer(object[key], source[key], key, object, source)
: undefined;
assignValue(object, key, newValue === undefined ? source[key] : newValue);
}
return object;
}
/**
* Creates a function like `_.assign`.
*
* @private
* @param {Function} assigner The function to assign values.
* @returns {Function} Returns the new assigner function.
*/
function createAssigner(assigner) {
return baseRest(function(object, sources) {
var index = -1,
length = sources.length,
customizer = length > 1 ? sources[length - 1] : undefined,
guard = length > 2 ? sources[2] : undefined;
customizer = (assigner.length > 3 && typeof customizer == 'function')
? (length--, customizer)
: undefined;
if (guard && isIterateeCall(sources[0], sources[1], guard)) {
customizer = length < 3 ? undefined : customizer;
length = 1;
}
object = Object(object);
while (++index < length) {
var source = sources[index];
if (source) {
assigner(object, source, index, customizer);
}
}
return object;
});
}
/**
* Checks if `value` is a valid array-like index.
*
* @private
* @param {*} value The value to check.
* @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
* @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
*/
function isIndex(value, length) {
length = length == null ? MAX_SAFE_INTEGER : length;
return !!length &&
(typeof value == 'number' || reIsUint.test(value)) &&
(value > -1 && value % 1 == 0 && value < length);
}
/**
* Checks if the given arguments are from an iteratee call.
*
* @private
* @param {*} value The potential iteratee value argument.
* @param {*} index The potential iteratee index or key argument.
* @param {*} object The potential iteratee object argument.
* @returns {boolean} Returns `true` if the arguments are from an iteratee call,
* else `false`.
*/
function isIterateeCall(value, index, object) {
if (!isObject(object)) {
return false;
}
var type = typeof index;
if (type == 'number'
? (isArrayLike(object) && isIndex(index, object.length))
: (type == 'string' && index in object)
) {
return eq(object[index], value);
}
return false;
}
/**
* Checks if `value` is likely a prototype object.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
*/
function isPrototype(value) {
var Ctor = value && value.constructor,
proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;
return value === proto;
}
/**
* Performs a
* [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
* comparison between two values to determine if they are equivalent.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to compare.
* @param {*} other The other value to compare.
* @returns {boolean} Returns `true` if the values are equivalent, else `false`.
* @example
*
* var object = { 'a': 1 };
* var other = { 'a': 1 };
*
* _.eq(object, object);
* // => true
*
* _.eq(object, other);
* // => false
*
* _.eq('a', 'a');
* // => true
*
* _.eq('a', Object('a'));
* // => false
*
* _.eq(NaN, NaN);
* // => true
*/
function eq(value, other) {
return value === other || (value !== value && other !== other);
}
/**
* Checks if `value` is likely an `arguments` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an `arguments` object,
* else `false`.
* @example
*
* _.isArguments(function() { return arguments; }());
* // => true
*
* _.isArguments([1, 2, 3]);
* // => false
*/
function isArguments(value) {
// Safari 8.1 makes `arguments.callee` enumerable in strict mode.
return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&
(!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);
}
/**
* Checks if `value` is classified as an `Array` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an array, else `false`.
* @example
*
* _.isArray([1, 2, 3]);
* // => true
*
* _.isArray(document.body.children);
* // => false
*
* _.isArray('abc');
* // => false
*
* _.isArray(_.noop);
* // => false
*/
var isArray = Array.isArray;
/**
* Checks if `value` is array-like. A value is considered array-like if it's
* not a function and has a `value.length` that's an integer greater than or
* equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is array-like, else `false`.
* @example
*
* _.isArrayLike([1, 2, 3]);
* // => true
*
* _.isArrayLike(document.body.children);
* // => true
*
* _.isArrayLike('abc');
* // => true
*
* _.isArrayLike(_.noop);
* // => false
*/
function isArrayLike(value) {
return value != null && isLength(value.length) && !isFunction(value);
}
/**
* This method is like `_.isArrayLike` except that it also checks if `value`
* is an object.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an array-like object,
* else `false`.
* @example
*
* _.isArrayLikeObject([1, 2, 3]);
* // => true
*
* _.isArrayLikeObject(document.body.children);
* // => true
*
* _.isArrayLikeObject('abc');
* // => false
*
* _.isArrayLikeObject(_.noop);
* // => false
*/
function isArrayLikeObject(value) {
return isObjectLike(value) && isArrayLike(value);
}
/**
* Checks if `value` is classified as a `Function` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a function, else `false`.
* @example
*
* _.isFunction(_);
* // => true
*
* _.isFunction(/abc/);
* // => false
*/
function isFunction(value) {
// The use of `Object#toString` avoids issues with the `typeof` operator
// in Safari 8-9 which returns 'object' for typed array and other constructors.
var tag = isObject(value) ? objectToString.call(value) : '';
return tag == funcTag || tag == genTag;
}
/**
* Checks if `value` is a valid array-like length.
*
* **Note:** This method is loosely based on
* [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
* @example
*
* _.isLength(3);
* // => true
*
* _.isLength(Number.MIN_VALUE);
* // => false
*
* _.isLength(Infinity);
* // => false
*
* _.isLength('3');
* // => false
*/
function isLength(value) {
return typeof value == 'number' &&
value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
}
/**
* Checks if `value` is the
* [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
* of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an object, else `false`.
* @example
*
* _.isObject({});
* // => true
*
* _.isObject([1, 2, 3]);
* // => true
*
* _.isObject(_.noop);
* // => true
*
* _.isObject(null);
* // => false
*/
function isObject(value) {
var type = typeof value;
return !!value && (type == 'object' || type == 'function');
}
/**
* Checks if `value` is object-like. A value is object-like if it's not `null`
* and has a `typeof` result of "object".
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is object-like, else `false`.
* @example
*
* _.isObjectLike({});
* // => true
*
* _.isObjectLike([1, 2, 3]);
* // => true
*
* _.isObjectLike(_.noop);
* // => false
*
* _.isObjectLike(null);
* // => false
*/
function isObjectLike(value) {
return !!value && typeof value == 'object';
}
/**
* Assigns own enumerable string keyed properties of source objects to the
* destination object. Source objects are applied from left to right.
* Subsequent sources overwrite property assignments of previous sources.
*
* **Note:** This method mutates `object` and is loosely based on
* [`Object.assign`](https://mdn.io/Object/assign).
*
* @static
* @memberOf _
* @since 0.10.0
* @category Object
* @param {Object} object The destination object.
* @param {...Object} [sources] The source objects.
* @returns {Object} Returns `object`.
* @see _.assignIn
* @example
*
* function Foo() {
* this.a = 1;
* }
*
* function Bar() {
* this.c = 3;
* }
*
* Foo.prototype.b = 2;
* Bar.prototype.d = 4;
*
* _.assign({ 'a': 0 }, new Foo, new Bar);
* // => { 'a': 1, 'c': 3 }
*/
var assign = createAssigner(function(object, source) {
if (nonEnumShadows || isPrototype(source) || isArrayLike(source)) {
copyObject(source, keys(source), object);
return;
}
for (var key in source) {
if (hasOwnProperty.call(source, key)) {
assignValue(object, key, source[key]);
}
}
});
/**
* Creates an array of the own enumerable property names of `object`.
*
* **Note:** Non-object values are coerced to objects. See the
* [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
* for more details.
*
* @static
* @since 0.1.0
* @memberOf _
* @category Object
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
* @example
*
* function Foo() {
* this.a = 1;
* this.b = 2;
* }
*
* Foo.prototype.c = 3;
*
* _.keys(new Foo);
* // => ['a', 'b'] (iteration order is not guaranteed)
*
* _.keys('hi');
* // => ['0', '1']
*/
function keys(object) {
return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
}
module.exports = assign;
/***/ }),
/* 71 */
/***/ (function(module, exports) {
/**
* lodash (Custom Build) <https://lodash.com/>
* Build: `lodash modularize exports="npm" -o ./`
* Copyright jQuery Foundation and other contributors <https://jquery.org/>
* Released under MIT license <https://lodash.com/license>
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
* Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
*/
/** Used as references for various `Number` constants. */
var MAX_SAFE_INTEGER = 9007199254740991;
/** `Object#toString` result references. */
var argsTag = '[object Arguments]',
funcTag = '[object Function]',
genTag = '[object GeneratorFunction]';
/** Used to detect unsigned integer values. */
var reIsUint = /^(?:0|[1-9]\d*)$/;
/**
* The base implementation of `_.times` without support for iteratee shorthands
* or max array length checks.
*
* @private
* @param {number} n The number of times to invoke `iteratee`.
* @param {Function} iteratee The function invoked per iteration.
* @returns {Array} Returns the array of results.
*/
function baseTimes(n, iteratee) {
var index = -1,
result = Array(n);
while (++index < n) {
result[index] = iteratee(index);
}
return result;
}
/**
* Creates a unary function that invokes `func` with its argument transformed.
*
* @private
* @param {Function} func The function to wrap.
* @param {Function} transform The argument transform.
* @returns {Function} Returns the new function.
*/
function overArg(func, transform) {
return function(arg) {
return func(transform(arg));
};
}
/** Used for built-in method references. */
var objectProto = Object.prototype;
/** Used to check objects for own properties. */
var hasOwnProperty = objectProto.hasOwnProperty;
/**
* Used to resolve the
* [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
* of values.
*/
var objectToString = objectProto.toString;
/** Built-in value references. */
var propertyIsEnumerable = objectProto.propertyIsEnumerable;
/* Built-in method references for those with the same name as other `lodash` methods. */
var nativeKeys = overArg(Object.keys, Object);
/**
* Creates an array of the enumerable property names of the array-like `value`.
*
* @private
* @param {*} value The value to query.
* @param {boolean} inherited Specify returning inherited property names.
* @returns {Array} Returns the array of property names.
*/
function arrayLikeKeys(value, inherited) {
// Safari 8.1 makes `arguments.callee` enumerable in strict mode.
// Safari 9 makes `arguments.length` enumerable in strict mode.
var result = (isArray(value) || isArguments(value))
? baseTimes(value.length, String)
: [];
var length = result.length,
skipIndexes = !!length;
for (var key in value) {
if ((inherited || hasOwnProperty.call(value, key)) &&
!(skipIndexes && (key == 'length' || isIndex(key, length)))) {
result.push(key);
}
}
return result;
}
/**
* The base implementation of `baseForOwn` which iterates over `object`
* properties returned by `keysFunc` and invokes `iteratee` for each property.
* Iteratee functions may exit iteration early by explicitly returning `false`.
*
* @private
* @param {Object} object The object to iterate over.
* @param {Function} iteratee The function invoked per iteration.
* @param {Function} keysFunc The function to get the keys of `object`.
* @returns {Object} Returns `object`.
*/
var baseFor = createBaseFor();
/**
* The base implementation of `_.forOwn` without support for iteratee shorthands.
*
* @private
* @param {Object} object The object to iterate over.
* @param {Function} iteratee The function invoked per iteration.
* @returns {Object} Returns `object`.
*/
function baseForOwn(object, iteratee) {
return object && baseFor(object, iteratee, keys);
}
/**
* The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
*
* @private
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
*/
function baseKeys(object) {
if (!isPrototype(object)) {
return nativeKeys(object);
}
var result = [];
for (var key in Object(object)) {
if (hasOwnProperty.call(object, key) && key != 'constructor') {
result.push(key);
}
}
return result;
}
/**
* Creates a base function for methods like `_.forIn` and `_.forOwn`.
*
* @private
* @param {boolean} [fromRight] Specify iterating from right to left.
* @returns {Function} Returns the new base function.
*/
function createBaseFor(fromRight) {
return function(object, iteratee, keysFunc) {
var index = -1,
iterable = Object(object),
props = keysFunc(object),
length = props.length;
while (length--) {
var key = props[fromRight ? length : ++index];
if (iteratee(iterable[key], key, iterable) === false) {
break;
}
}
return object;
};
}
/**
* Checks if `value` is a valid array-like index.
*
* @private
* @param {*} value The value to check.
* @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
* @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
*/
function isIndex(value, length) {
length = length == null ? MAX_SAFE_INTEGER : length;
return !!length &&
(typeof value == 'number' || reIsUint.test(value)) &&
(value > -1 && value % 1 == 0 && value < length);
}
/**
* Checks if `value` is likely a prototype object.
*
* @private
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
*/
function isPrototype(value) {
var Ctor = value && value.constructor,
proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;
return value === proto;
}
/**
* Checks if `value` is likely an `arguments` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an `arguments` object,
* else `false`.
* @example
*
* _.isArguments(function() { return arguments; }());
* // => true
*
* _.isArguments([1, 2, 3]);
* // => false
*/
function isArguments(value) {
// Safari 8.1 makes `arguments.callee` enumerable in strict mode.
return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&
(!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);
}
/**
* Checks if `value` is classified as an `Array` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an array, else `false`.
* @example
*
* _.isArray([1, 2, 3]);
* // => true
*
* _.isArray(document.body.children);
* // => false
*
* _.isArray('abc');
* // => false
*
* _.isArray(_.noop);
* // => false
*/
var isArray = Array.isArray;
/**
* Checks if `value` is array-like. A value is considered array-like if it's
* not a function and has a `value.length` that's an integer greater than or
* equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is array-like, else `false`.
* @example
*
* _.isArrayLike([1, 2, 3]);
* // => true
*
* _.isArrayLike(document.body.children);
* // => true
*
* _.isArrayLike('abc');
* // => true
*
* _.isArrayLike(_.noop);
* // => false
*/
function isArrayLike(value) {
return value != null && isLength(value.length) && !isFunction(value);
}
/**
* This method is like `_.isArrayLike` except that it also checks if `value`
* is an object.
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an array-like object,
* else `false`.
* @example
*
* _.isArrayLikeObject([1, 2, 3]);
* // => true
*
* _.isArrayLikeObject(document.body.children);
* // => true
*
* _.isArrayLikeObject('abc');
* // => false
*
* _.isArrayLikeObject(_.noop);
* // => false
*/
function isArrayLikeObject(value) {
return isObjectLike(value) && isArrayLike(value);
}
/**
* Checks if `value` is classified as a `Function` object.
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a function, else `false`.
* @example
*
* _.isFunction(_);
* // => true
*
* _.isFunction(/abc/);
* // => false
*/
function isFunction(value) {
// The use of `Object#toString` avoids issues with the `typeof` operator
// in Safari 8-9 which returns 'object' for typed array and other constructors.
var tag = isObject(value) ? objectToString.call(value) : '';
return tag == funcTag || tag == genTag;
}
/**
* Checks if `value` is a valid array-like length.
*
* **Note:** This method is loosely based on
* [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
* @example
*
* _.isLength(3);
* // => true
*
* _.isLength(Number.MIN_VALUE);
* // => false
*
* _.isLength(Infinity);
* // => false
*
* _.isLength('3');
* // => false
*/
function isLength(value) {
return typeof value == 'number' &&
value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
}
/**
* Checks if `value` is the
* [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
* of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
*
* @static
* @memberOf _
* @since 0.1.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is an object, else `false`.
* @example
*
* _.isObject({});
* // => true
*
* _.isObject([1, 2, 3]);
* // => true
*
* _.isObject(_.noop);
* // => true
*
* _.isObject(null);
* // => false
*/
function isObject(value) {
var type = typeof value;
return !!value && (type == 'object' || type == 'function');
}
/**
* Checks if `value` is object-like. A value is object-like if it's not `null`
* and has a `typeof` result of "object".
*
* @static
* @memberOf _
* @since 4.0.0
* @category Lang
* @param {*} value The value to check.
* @returns {boolean} Returns `true` if `value` is object-like, else `false`.
* @example
*
* _.isObjectLike({});
* // => true
*
* _.isObjectLike([1, 2, 3]);
* // => true
*
* _.isObjectLike(_.noop);
* // => false
*
* _.isObjectLike(null);
* // => false
*/
function isObjectLike(value) {
return !!value && typeof value == 'object';
}
/**
* Iterates over own enumerable string keyed properties of an object and
* invokes `iteratee` for each property. The iteratee is invoked with three
* arguments: (value, key, object). Iteratee functions may exit iteration
* early by explicitly returning `false`.
*
* @static
* @memberOf _
* @since 0.3.0
* @category Object
* @param {Object} object The object to iterate over.
* @param {Function} [iteratee=_.identity] The function invoked per iteration.
* @returns {Object} Returns `object`.
* @see _.forOwnRight
* @example
*
* function Foo() {
* this.a = 1;
* this.b = 2;
* }
*
* Foo.prototype.c = 3;
*
* _.forOwn(new Foo, function(value, key) {
* console.log(key);
* });
* // => Logs 'a' then 'b' (iteration order is not guaranteed).
*/
function forOwn(object, iteratee) {
return object && baseForOwn(object, typeof iteratee == 'function' ? iteratee : identity);
}
/**
* Creates an array of the own enumerable property names of `object`.
*
* **Note:** Non-object values are coerced to objects. See the
* [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
* for more details.
*
* @static
* @since 0.1.0
* @memberOf _
* @category Object
* @param {Object} object The object to query.
* @returns {Array} Returns the array of property names.
* @example
*
* function Foo() {
* this.a = 1;
* this.b = 2;
* }
*
* Foo.prototype.c = 3;
*
* _.keys(new Foo);
* // => ['a', 'b'] (iteration order is not guaranteed)
*
* _.keys('hi');
* // => ['0', '1']
*/
function keys(object) {
return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
}
/**
* This method returns the first argument it receives.
*
* @static
* @since 0.1.0
* @memberOf _
* @category Util
* @param {*} value Any value.
* @returns {*} Returns `value`.
* @example
*
* var object = { 'a': 1 };
*
* console.log(_.identity(object) === object);
* // => true
*/
function identity(value) {
return value;
}
module.exports = forOwn;
/***/ }),
/* 72 */
/***/ (function(module, exports, __webpack_require__) {
// uuid.js
//
// Copyright (c) 2010-2012 Robert Kieffer
// MIT License - http://opensource.org/licenses/mit-license.php
// Unique ID creation requires a high quality random # generator. We feature
// detect to determine the best RNG source, normalizing to a function that
// returns 128-bits of randomness, since that's what's usually required
var _rng = __webpack_require__(73);
// Maps for number <-> hex string conversion
var _byteToHex = [];
var _hexToByte = {};
for (var i = 0; i < 256; i++) {
_byteToHex[i] = (i + 0x100).toString(16).substr(1);
_hexToByte[_byteToHex[i]] = i;
}
// **`parse()` - Parse a UUID into it's component bytes**
function parse(s, buf, offset) {
var i = (buf && offset) || 0, ii = 0;
buf = buf || [];
s.toLowerCase().replace(/[0-9a-f]{2}/g, function(oct) {
if (ii < 16) { // Don't overflow!
buf[i + ii++] = _hexToByte[oct];
}
});
// Zero out remaining bytes if string was short
while (ii < 16) {
buf[i + ii++] = 0;
}
return buf;
}
// **`unparse()` - Convert UUID byte array (ala parse()) into a string**
function unparse(buf, offset) {
var i = offset || 0, bth = _byteToHex;
return bth[buf[i++]] + bth[buf[i++]] +
bth[buf[i++]] + bth[buf[i++]] + '-' +
bth[buf[i++]] + bth[buf[i++]] + '-' +
bth[buf[i++]] + bth[buf[i++]] + '-' +
bth[buf[i++]] + bth[buf[i++]] + '-' +
bth[buf[i++]] + bth[buf[i++]] +
bth[buf[i++]] + bth[buf[i++]] +
bth[buf[i++]] + bth[buf[i++]];
}
// **`v1()` - Generate time-based UUID**
//
// Inspired by https://github.com/LiosK/UUID.js
// and http://docs.python.org/library/uuid.html
// random #'s we need to init node and clockseq
var _seedBytes = _rng();
// Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)
var _nodeId = [
_seedBytes[0] | 0x01,
_seedBytes[1], _seedBytes[2], _seedBytes[3], _seedBytes[4], _seedBytes[5]
];
// Per 4.2.2, randomize (14 bit) clockseq
var _clockseq = (_seedBytes[6] << 8 | _seedBytes[7]) & 0x3fff;
// Previous uuid creation time
var _lastMSecs = 0, _lastNSecs = 0;
// See https://github.com/broofa/node-uuid for API details
function v1(options, buf, offset) {
var i = buf && offset || 0;
var b = buf || [];
options = options || {};
var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq;
// UUID timestamps are 100 nano-second units since the Gregorian epoch,
// (1582-10-15 00:00). JSNumbers aren't precise enough for this, so
// time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'
// (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.
var msecs = options.msecs !== undefined ? options.msecs : new Date().getTime();
// Per 4.2.1.2, use count of uuid's generated during the current clock
// cycle to simulate higher resolution clock
var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1;
// Time since last uuid creation (in msecs)
var dt = (msecs - _lastMSecs) + (nsecs - _lastNSecs)/10000;
// Per 4.2.1.2, Bump clockseq on clock regression
if (dt < 0 && options.clockseq === undefined) {
clockseq = clockseq + 1 & 0x3fff;
}
// Reset nsecs if clock regresses (new clockseq) or we've moved onto a new
// time interval
if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {
nsecs = 0;
}
// Per 4.2.1.2 Throw error if too many uuids are requested
if (nsecs >= 10000) {
throw new Error('uuid.v1(): Can\'t create more than 10M uuids/sec');
}
_lastMSecs = msecs;
_lastNSecs = nsecs;
_clockseq = clockseq;
// Per 4.1.4 - Convert from unix epoch to Gregorian epoch
msecs += 12219292800000;
// `time_low`
var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;
b[i++] = tl >>> 24 & 0xff;
b[i++] = tl >>> 16 & 0xff;
b[i++] = tl >>> 8 & 0xff;
b[i++] = tl & 0xff;
// `time_mid`
var tmh = (msecs / 0x100000000 * 10000) & 0xfffffff;
b[i++] = tmh >>> 8 & 0xff;
b[i++] = tmh & 0xff;
// `time_high_and_version`
b[i++] = tmh >>> 24 & 0xf | 0x10; // include version
b[i++] = tmh >>> 16 & 0xff;
// `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)
b[i++] = clockseq >>> 8 | 0x80;
// `clock_seq_low`
b[i++] = clockseq & 0xff;
// `node`
var node = options.node || _nodeId;
for (var n = 0; n < 6; n++) {
b[i + n] = node[n];
}
return buf ? buf : unparse(b);
}
// **`v4()` - Generate random UUID**
// See https://github.com/broofa/node-uuid for API details
function v4(options, buf, offset) {
// Deprecated - 'format' argument, as supported in v1.2
var i = buf && offset || 0;
if (typeof(options) == 'string') {
buf = options == 'binary' ? new Array(16) : null;
options = null;
}
options = options || {};
var rnds = options.random || (options.rng || _rng)();
// Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
rnds[6] = (rnds[6] & 0x0f) | 0x40;
rnds[8] = (rnds[8] & 0x3f) | 0x80;
// Copy bytes to buffer, if provided
if (buf) {
for (var ii = 0; ii < 16; ii++) {
buf[i + ii] = rnds[ii];
}
}
return buf || unparse(rnds);
}
// Export public API
var uuid = v4;
uuid.v1 = v1;
uuid.v4 = v4;
uuid.parse = parse;
uuid.unparse = unparse;
module.exports = uuid;
/***/ }),
/* 73 */
/***/ (function(module, exports) {
/* WEBPACK VAR INJECTION */(function(global) {
var rng;
var crypto = global.crypto || global.msCrypto; // for IE 11
if (crypto && crypto.getRandomValues) {
// WHATWG crypto-based RNG - http://wiki.whatwg.org/wiki/Crypto
// Moderately fast, high quality
var _rnds8 = new Uint8Array(16);
rng = function whatwgRNG() {
crypto.getRandomValues(_rnds8);
return _rnds8;
};
}
if (!rng) {
// Math.random()-based (RNG)
//
// If all else fails, use Math.random(). It's fast, but is of unspecified
// quality.
var _rnds = new Array(16);
rng = function() {
for (var i = 0, r; i < 16; i++) {
if ((i & 0x03) === 0) r = Math.random() * 0x100000000;
_rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;
}
return _rnds;
};
}
module.exports = rng;
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
/***/ }),
/* 74 */
/***/ (function(module, exports) {
'use strict';
//http://jsperf.com/typed-array-min-max/2
//plain for loop for finding min/max is way faster than anything else.
/**
* @param {TypedArray} array - Subarray of audio to calculate peaks from.
*/
function findMinMax(array) {
var min = Infinity;
var max = -Infinity;
var i = 0;
var len = array.length;
var curr;
for(; i < len; i++) {
curr = array[i];
if (min > curr) {
min = curr;
}
if (max < curr) {
max = curr;
}
}
return {
min: min,
max: max
};
}
/**
* @param {Number} n - peak to convert from float to Int8, Int16 etc.
* @param {Number} bits - convert to #bits two's complement signed integer
*/
function convert(n, bits) {
var max = Math.pow(2, bits-1);
var v = n < 0 ? n * max : n * max - 1;
return Math.max(-max, Math.min(max-1, v));
}
/**
* @param {TypedArray} channel - Audio track frames to calculate peaks from.
* @param {Number} samplesPerPixel - Audio frames per peak
*/
function extractPeaks(channel, samplesPerPixel, bits) {
var i;
var chanLength = channel.length;
var numPeaks = Math.ceil(chanLength / samplesPerPixel);
var start;
var end;
var segment;
var max;
var min;
var extrema;
//create interleaved array of min,max
var peaks = new (new Function(`return Int${bits}Array`)())(numPeaks*2);
for (i = 0; i < numPeaks; i++) {
start = i * samplesPerPixel;
end = (i + 1) * samplesPerPixel > chanLength ? chanLength : (i + 1) * samplesPerPixel;
segment = channel.subarray(start, end);
extrema = findMinMax(segment);
min = convert(extrema.min, bits);
max = convert(extrema.max, bits);
peaks[i*2] = min;
peaks[i*2+1] = max;
}
return peaks;
}
function makeMono(channelPeaks, bits) {
var numChan = channelPeaks.length;
var weight = 1 / numChan;
var numPeaks = channelPeaks[0].length / 2;
var c = 0;
var i = 0;
var min;
var max;
var peaks = new (new Function(`return Int${bits}Array`)())(numPeaks*2);
for (i = 0; i < numPeaks; i++) {
min = 0;
max = 0;
for (c = 0; c < numChan; c++) {
min += weight * channelPeaks[c][i*2];
max += weight * channelPeaks[c][i*2+1];
}
peaks[i*2] = min;
peaks[i*2+1] = max;
}
//return in array so channel number counts still work.
return [peaks];
}
/**
* @param {AudioBuffer,TypedArray} source - Source of audio samples for peak calculations.
* @param {Number} samplesPerPixel - Number of audio samples per peak.
* @param {Number} cueIn - index in channel to start peak calculations from.
* @param {Number} cueOut - index in channel to end peak calculations from (non-inclusive).
*/
module.exports = function(source, samplesPerPixel, isMono, cueIn, cueOut, bits) {
samplesPerPixel = samplesPerPixel || 10000;
bits = bits || 8;
if (isMono === null || isMono === undefined) {
isMono = true;
}
if ([8, 16, 32].indexOf(bits) < 0) {
throw new Error("Invalid number of bits specified for peaks.");
}
var numChan = source.numberOfChannels;
var peaks = [];
var c;
var numPeaks;
var channel;
var slice;
if (typeof source.subarray === "undefined") {
for (c = 0; c < numChan; c++) {
channel = source.getChannelData(c);
cueIn = cueIn || 0;
cueOut = cueOut || channel.length;
slice = channel.subarray(cueIn, cueOut);
peaks.push(extractPeaks(slice, samplesPerPixel, bits));
}
}
else {
cueIn = cueIn || 0;
cueOut = cueOut || source.length;
peaks.push(extractPeaks(source.subarray(cueIn, cueOut), samplesPerPixel, bits));
}
if (isMono && peaks.length > 1) {
peaks = makeMono(peaks, bits);
}
numPeaks = peaks[0].length / 2;
return {
length: numPeaks,
data: peaks,
bits: bits
};
};
/***/ }),
/* 75 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.FADEOUT = exports.FADEIN = exports.LOGARITHMIC = exports.EXPONENTIAL = exports.LINEAR = exports.SCURVE = undefined;
exports.createFadeIn = createFadeIn;
exports.createFadeOut = createFadeOut;
var _fadeCurves = __webpack_require__(76);
var SCURVE = exports.SCURVE = "sCurve";
var LINEAR = exports.LINEAR = "linear";
var EXPONENTIAL = exports.EXPONENTIAL = "exponential";
var LOGARITHMIC = exports.LOGARITHMIC = "logarithmic";
var FADEIN = exports.FADEIN = "FadeIn";
var FADEOUT = exports.FADEOUT = "FadeOut";
function sCurveFadeIn(start, duration) {
var curve = (0, _fadeCurves.sCurve)(10000, 1);
this.setValueCurveAtTime(curve, start, duration);
}
function sCurveFadeOut(start, duration) {
var curve = (0, _fadeCurves.sCurve)(10000, -1);
this.setValueCurveAtTime(curve, start, duration);
}
function linearFadeIn(start, duration) {
this.linearRampToValueAtTime(0, start);
this.linearRampToValueAtTime(1, start + duration);
}
function linearFadeOut(start, duration) {
this.linearRampToValueAtTime(1, start);
this.linearRampToValueAtTime(0, start + duration);
}
function exponentialFadeIn(start, duration) {
this.exponentialRampToValueAtTime(0.01, start);
this.exponentialRampToValueAtTime(1, start + duration);
}
function exponentialFadeOut(start, duration) {
this.exponentialRampToValueAtTime(1, start);
this.exponentialRampToValueAtTime(0.01, start + duration);
}
function logarithmicFadeIn(start, duration) {
var curve = (0, _fadeCurves.logarithmic)(10000, 10, 1);
this.setValueCurveAtTime(curve, start, duration);
}
function logarithmicFadeOut(start, duration) {
var curve = (0, _fadeCurves.logarithmic)(10000, 10, -1);
this.setValueCurveAtTime(curve, start, duration);
}
function createFadeIn(gain, shape, start, duration) {
switch (shape) {
case SCURVE:
sCurveFadeIn.call(gain, start, duration);
break;
case LINEAR:
linearFadeIn.call(gain, start, duration);
break;
case EXPONENTIAL:
exponentialFadeIn.call(gain, start, duration);
break;
case LOGARITHMIC:
logarithmicFadeIn.call(gain, start, duration);
break;
default:
throw new Error("Unsupported Fade type");
}
}
function createFadeOut(gain, shape, start, duration) {
switch (shape) {
case SCURVE:
sCurveFadeOut.call(gain, start, duration);
break;
case LINEAR:
linearFadeOut.call(gain, start, duration);
break;
case EXPONENTIAL:
exponentialFadeOut.call(gain, start, duration);
break;
case LOGARITHMIC:
logarithmicFadeOut.call(gain, start, duration);
break;
default:
throw new Error("Unsupported Fade type");
}
}
/***/ }),
/* 76 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.linear = linear;
exports.exponential = exponential;
exports.sCurve = sCurve;
exports.logarithmic = logarithmic;
function linear(length, rotation) {
var curve = new Float32Array(length),
i,
x,
scale = length - 1;
for (i = 0; i < length; i++) {
x = i / scale;
if (rotation > 0) {
curve[i] = x;
} else {
curve[i] = 1 - x;
}
}
return curve;
}
function exponential(length, rotation) {
var curve = new Float32Array(length),
i,
x,
scale = length - 1,
index;
for (i = 0; i < length; i++) {
x = i / scale;
index = rotation > 0 ? i : length - 1 - i;
curve[index] = Math.exp(2 * x - 1) / Math.exp(1);
}
return curve;
}
//creating a curve to simulate an S-curve with setValueCurveAtTime.
function sCurve(length, rotation) {
var curve = new Float32Array(length),
i,
phase = rotation > 0 ? Math.PI / 2 : -(Math.PI / 2);
for (i = 0; i < length; ++i) {
curve[i] = Math.sin(Math.PI * i / length - phase) / 2 + 0.5;
}
return curve;
}
//creating a curve to simulate a logarithmic curve with setValueCurveAtTime.
function logarithmic(length, base, rotation) {
var curve = new Float32Array(length),
index,
x = 0,
i;
for (i = 0; i < length; i++) {
//index for the curve array.
index = rotation > 0 ? i : length - 1 - i;
x = i / length;
curve[index] = Math.log(1 + base * x) / Math.log(1 + base);
}
return curve;
}
/***/ }),
/* 77 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _CursorState = __webpack_require__(78);
var _CursorState2 = _interopRequireDefault(_CursorState);
var _SelectState = __webpack_require__(79);
var _SelectState2 = _interopRequireDefault(_SelectState);
var _ShiftState = __webpack_require__(80);
var _ShiftState2 = _interopRequireDefault(_ShiftState);
var _FadeInState = __webpack_require__(81);
var _FadeInState2 = _interopRequireDefault(_FadeInState);
var _FadeOutState = __webpack_require__(82);
var _FadeOutState2 = _interopRequireDefault(_FadeOutState);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
cursor: _CursorState2.default,
select: _SelectState2.default,
shift: _ShiftState2.default,
fadein: _FadeInState2.default,
fadeout: _FadeOutState2.default
};
/***/ }),
/* 78 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(track) {
_classCallCheck(this, _class);
this.track = track;
}
_createClass(_class, [{
key: 'setup',
value: function setup(samplesPerPixel, sampleRate) {
this.samplesPerPixel = samplesPerPixel;
this.sampleRate = sampleRate;
}
}, {
key: 'click',
value: function click(e) {
e.preventDefault();
var startX = e.offsetX;
var startTime = (0, _conversions.pixelsToSeconds)(startX, this.samplesPerPixel, this.sampleRate);
this.track.ee.emit('select', startTime, startTime, this.track);
}
}], [{
key: 'getClass',
value: function getClass() {
return '.state-cursor';
}
}, {
key: 'getEvents',
value: function getEvents() {
return ['click'];
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 79 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(track) {
_classCallCheck(this, _class);
this.track = track;
this.active = false;
}
_createClass(_class, [{
key: 'setup',
value: function setup(samplesPerPixel, sampleRate) {
this.samplesPerPixel = samplesPerPixel;
this.sampleRate = sampleRate;
}
}, {
key: 'emitSelection',
value: function emitSelection(x) {
var minX = Math.min(x, this.startX);
var maxX = Math.max(x, this.startX);
var startTime = (0, _conversions.pixelsToSeconds)(minX, this.samplesPerPixel, this.sampleRate);
var endTime = (0, _conversions.pixelsToSeconds)(maxX, this.samplesPerPixel, this.sampleRate);
this.track.ee.emit('select', startTime, endTime, this.track);
}
}, {
key: 'complete',
value: function complete(x) {
this.emitSelection(x);
this.active = false;
}
}, {
key: 'mousedown',
value: function mousedown(e) {
e.preventDefault();
this.active = true;
this.startX = e.offsetX;
var startTime = (0, _conversions.pixelsToSeconds)(this.startX, this.samplesPerPixel, this.sampleRate);
this.track.ee.emit('select', startTime, startTime, this.track);
}
}, {
key: 'mousemove',
value: function mousemove(e) {
if (this.active) {
e.preventDefault();
this.emitSelection(e.offsetX);
}
}
}, {
key: 'mouseup',
value: function mouseup(e) {
if (this.active) {
e.preventDefault();
this.complete(e.offsetX);
}
}
}, {
key: 'mouseleave',
value: function mouseleave(e) {
if (this.active) {
e.preventDefault();
this.complete(e.offsetX);
}
}
}], [{
key: 'getClass',
value: function getClass() {
return '.state-select';
}
}, {
key: 'getEvents',
value: function getEvents() {
return ['mousedown', 'mousemove', 'mouseup', 'mouseleave'];
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 80 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(track) {
_classCallCheck(this, _class);
this.track = track;
this.active = false;
}
_createClass(_class, [{
key: 'setup',
value: function setup(samplesPerPixel, sampleRate) {
this.samplesPerPixel = samplesPerPixel;
this.sampleRate = sampleRate;
}
}, {
key: 'emitShift',
value: function emitShift(x) {
var deltaX = x - this.prevX;
var deltaTime = (0, _conversions.pixelsToSeconds)(deltaX, this.samplesPerPixel, this.sampleRate);
this.prevX = x;
this.track.ee.emit('shift', deltaTime, this.track);
}
}, {
key: 'complete',
value: function complete(x) {
this.emitShift(x);
this.active = false;
}
}, {
key: 'mousedown',
value: function mousedown(e) {
e.preventDefault();
this.active = true;
this.el = e.target;
this.prevX = e.offsetX;
}
}, {
key: 'mousemove',
value: function mousemove(e) {
if (this.active) {
e.preventDefault();
this.emitShift(e.offsetX);
}
}
}, {
key: 'mouseup',
value: function mouseup(e) {
if (this.active) {
e.preventDefault();
this.complete(e.offsetX);
}
}
}, {
key: 'mouseleave',
value: function mouseleave(e) {
if (this.active) {
e.preventDefault();
this.complete(e.offsetX);
}
}
}], [{
key: 'getClass',
value: function getClass() {
return '.state-shift';
}
}, {
key: 'getEvents',
value: function getEvents() {
return ['mousedown', 'mousemove', 'mouseup', 'mouseleave'];
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 81 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(track) {
_classCallCheck(this, _class);
this.track = track;
}
_createClass(_class, [{
key: 'setup',
value: function setup(samplesPerPixel, sampleRate) {
this.samplesPerPixel = samplesPerPixel;
this.sampleRate = sampleRate;
}
}, {
key: 'click',
value: function click(e) {
var startX = e.offsetX;
var time = (0, _conversions.pixelsToSeconds)(startX, this.samplesPerPixel, this.sampleRate);
if (time > this.track.getStartTime() && time < this.track.getEndTime()) {
this.track.ee.emit('fadein', time - this.track.getStartTime(), this.track);
}
}
}], [{
key: 'getClass',
value: function getClass() {
return '.state-fadein';
}
}, {
key: 'getEvents',
value: function getEvents() {
return ['click'];
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 82 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(track) {
_classCallCheck(this, _class);
this.track = track;
}
_createClass(_class, [{
key: 'setup',
value: function setup(samplesPerPixel, sampleRate) {
this.samplesPerPixel = samplesPerPixel;
this.sampleRate = sampleRate;
}
}, {
key: 'click',
value: function click(e) {
var startX = e.offsetX;
var time = (0, _conversions.pixelsToSeconds)(startX, this.samplesPerPixel, this.sampleRate);
if (time > this.track.getStartTime() && time < this.track.getEndTime()) {
this.track.ee.emit('fadeout', this.track.getEndTime() - time, this.track);
}
}
}], [{
key: 'getClass',
value: function getClass() {
return '.state-fadeout';
}
}, {
key: 'getEvents',
value: function getEvents() {
return ['click'];
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 83 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/*
* virtual-dom hook for drawing to the canvas element.
*/
var CanvasHook = function () {
function CanvasHook(peaks, offset, bits, color, scale, height) {
_classCallCheck(this, CanvasHook);
this.peaks = peaks;
// http://stackoverflow.com/questions/6081483/maximum-size-of-a-canvas-element
this.offset = offset;
this.color = color;
this.bits = bits;
this.scale = scale;
this.height = height;
}
_createClass(CanvasHook, [{
key: 'hook',
value: function hook(canvas, prop, prev) {
// canvas is up to date
if (prev !== undefined && prev.peaks === this.peaks && prev.scale === this.scale && prev.height === this.height) {
return;
}
var scale = this.scale;
var len = canvas.width / scale;
var cc = canvas.getContext('2d');
var h2 = canvas.height / scale / 2;
var maxValue = Math.pow(2, this.bits - 1);
cc.clearRect(0, 0, canvas.width, canvas.height);
cc.save();
cc.fillStyle = this.color;
cc.scale(scale, scale);
for (var i = 0; i < len; i += 1) {
var minPeak = this.peaks[(i + this.offset) * 2] / maxValue;
var maxPeak = this.peaks[(i + this.offset) * 2 + 1] / maxValue;
CanvasHook.drawFrame(cc, h2, i, minPeak, maxPeak);
}
cc.restore();
}
}], [{
key: 'drawFrame',
value: function drawFrame(cc, h2, x, minPeak, maxPeak) {
var min = Math.abs(minPeak * h2);
var max = Math.abs(maxPeak * h2);
// draw max
cc.fillRect(x, 0, 1, h2 - max);
// draw min
cc.fillRect(x, h2 + min, 1, h2 - min);
}
}]);
return CanvasHook;
}();
exports.default = CanvasHook;
/***/ }),
/* 84 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _fadeMaker = __webpack_require__(75);
var _fadeCurves = __webpack_require__(76);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/*
* virtual-dom hook for drawing the fade curve to the canvas element.
*/
var FadeCanvasHook = function () {
function FadeCanvasHook(type, shape, duration, samplesPerPixel) {
_classCallCheck(this, FadeCanvasHook);
this.type = type;
this.shape = shape;
this.duration = duration;
this.samplesPerPixel = samplesPerPixel;
}
_createClass(FadeCanvasHook, [{
key: 'hook',
value: function hook(canvas, prop, prev) {
// node is up to date.
if (prev !== undefined && prev.shape === this.shape && prev.type === this.type && prev.duration === this.duration && prev.samplesPerPixel === this.samplesPerPixel) {
return;
}
var ctx = canvas.getContext('2d');
var width = canvas.width;
var height = canvas.height;
var curve = FadeCanvasHook.createCurve(this.shape, this.type, width);
var len = curve.length;
var y = height - curve[0] * height;
ctx.clearRect(0, 0, canvas.width, canvas.height);
ctx.save();
ctx.strokeStyle = 'black';
ctx.beginPath();
ctx.moveTo(0, y);
for (var i = 1; i < len; i += 1) {
y = height - curve[i] * height;
ctx.lineTo(i, y);
}
ctx.stroke();
ctx.restore();
}
}], [{
key: 'createCurve',
value: function createCurve(shape, type, width) {
var reflection = void 0;
var curve = void 0;
switch (type) {
case _fadeMaker.FADEIN:
{
reflection = 1;
break;
}
case _fadeMaker.FADEOUT:
{
reflection = -1;
break;
}
default:
{
throw new Error('Unsupported fade type.');
}
}
switch (shape) {
case _fadeMaker.SCURVE:
{
curve = (0, _fadeCurves.sCurve)(width, reflection);
break;
}
case _fadeMaker.LINEAR:
{
curve = (0, _fadeCurves.linear)(width, reflection);
break;
}
case _fadeMaker.EXPONENTIAL:
{
curve = (0, _fadeCurves.exponential)(width, reflection);
break;
}
case _fadeMaker.LOGARITHMIC:
{
curve = (0, _fadeCurves.logarithmic)(width, 10, reflection);
break;
}
default:
{
throw new Error('Unsupported fade shape');
}
}
return curve;
}
}]);
return FadeCanvasHook;
}();
exports.default = FadeCanvasHook;
/***/ }),
/* 85 */
/***/ (function(module, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/* eslint-disable no-param-reassign */
/*
* virtual-dom hook for setting the volume input programmatically.
*/
var _class = function () {
function _class(gain) {
_classCallCheck(this, _class);
this.gain = gain;
}
_createClass(_class, [{
key: "hook",
value: function hook(volumeInput) {
volumeInput.value = this.gain * 100;
volumeInput.title = this.gain * 100 + "% volume";
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 86 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/* eslint-disable no-param-reassign */
/*
* virtual-dom hook for setting the stereoPan input programmatically.
*/
var _class = function () {
function _class(stereoPan) {
_classCallCheck(this, _class);
this.stereoPan = stereoPan;
}
_createClass(_class, [{
key: 'hook',
value: function hook(stereoPanInput) {
stereoPanInput.value = this.stereoPan * 100;
var panOrientation = void 0;
if (this.stereoPan === 0) {
panOrientation = 'Center';
} else if (this.stereoPan < 0) {
panOrientation = 'Left';
} else {
panOrientation = 'Right';
}
var percentage = Math.abs(this.stereoPan * 100) + '% ';
stereoPanInput.title = 'Pan: ' + (this.stereoPan !== 0 ? percentage : '') + panOrientation;
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 87 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _fadeMaker = __webpack_require__(75);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(ac, buffer) {
_classCallCheck(this, _class);
this.ac = ac;
this.gain = 1;
this.buffer = buffer;
this.destination = this.ac.destination;
this.ac.createStereoPanner = ac.createStereoPanner || ac.createPanner;
}
_createClass(_class, [{
key: 'applyFade',
value: function applyFade(type, start, duration) {
var shape = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'logarithmic';
if (type === _fadeMaker.FADEIN) {
(0, _fadeMaker.createFadeIn)(this.fadeGain.gain, shape, start, duration);
} else if (type === _fadeMaker.FADEOUT) {
(0, _fadeMaker.createFadeOut)(this.fadeGain.gain, shape, start, duration);
} else {
throw new Error('Unsupported fade type');
}
}
}, {
key: 'applyFadeIn',
value: function applyFadeIn(start, duration) {
var shape = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'logarithmic';
this.applyFade(_fadeMaker.FADEIN, start, duration, shape);
}
}, {
key: 'applyFadeOut',
value: function applyFadeOut(start, duration) {
var shape = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'logarithmic';
this.applyFade(_fadeMaker.FADEOUT, start, duration, shape);
}
}, {
key: 'isPlaying',
value: function isPlaying() {
return this.source !== undefined;
}
}, {
key: 'getDuration',
value: function getDuration() {
return this.buffer.duration;
}
}, {
key: 'setAudioContext',
value: function setAudioContext(ac) {
this.ac = ac;
this.ac.createStereoPanner = ac.createStereoPanner || ac.createPanner;
this.destination = this.ac.destination;
}
}, {
key: 'setUpSource',
value: function setUpSource() {
var _this = this;
this.source = this.ac.createBufferSource();
this.source.buffer = this.buffer;
var sourcePromise = new Promise(function (resolve) {
// keep track of the buffer state.
_this.source.onended = function () {
_this.source.disconnect();
_this.fadeGain.disconnect();
_this.volumeGain.disconnect();
_this.shouldPlayGain.disconnect();
_this.panner.disconnect();
_this.masterGain.disconnect();
_this.source = undefined;
_this.fadeGain = undefined;
_this.volumeGain = undefined;
_this.shouldPlayGain = undefined;
_this.panner = undefined;
_this.masterGain = undefined;
resolve();
};
});
this.fadeGain = this.ac.createGain();
// used for track volume slider
this.volumeGain = this.ac.createGain();
// used for solo/mute
this.shouldPlayGain = this.ac.createGain();
this.masterGain = this.ac.createGain();
this.panner = this.ac.createStereoPanner();
this.source.connect(this.fadeGain);
this.fadeGain.connect(this.volumeGain);
this.volumeGain.connect(this.shouldPlayGain);
this.shouldPlayGain.connect(this.masterGain);
this.masterGain.connect(this.panner);
this.panner.connect(this.destination);
return sourcePromise;
}
}, {
key: 'setVolumeGainLevel',
value: function setVolumeGainLevel(level) {
if (this.volumeGain) {
this.volumeGain.gain.value = level;
}
}
}, {
key: 'setShouldPlay',
value: function setShouldPlay(bool) {
if (this.shouldPlayGain) {
this.shouldPlayGain.gain.value = bool ? 1 : 0;
}
}
}, {
key: 'setMasterGainLevel',
value: function setMasterGainLevel(level) {
if (this.masterGain) {
this.masterGain.gain.value = level;
}
}
}, {
key: 'setStereoPanValue',
value: function setStereoPanValue(value) {
var pan = value === undefined ? 0 : value;
if (this.panner) {
if (this.panner.pan !== undefined) {
this.panner.pan.value = pan;
} else {
this.panner.panningModel = 'equalpower';
this.panner.setPosition(pan, 0, 1 - Math.abs(pan));
}
}
}
/*
source.start is picky when passing the end time.
If rounding error causes a number to make the source think
it is playing slightly more samples than it has it won't play at all.
Unfortunately it doesn't seem to work if you just give it a start time.
*/
}, {
key: 'play',
value: function play(when, start, duration) {
this.source.start(when, start, duration);
}
}, {
key: 'stop',
value: function stop() {
var when = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
if (this.source) {
this.source.stop(when);
}
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 88 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _h = __webpack_require__(38);
var _h2 = _interopRequireDefault(_h);
var _aeneas = __webpack_require__(89);
var _aeneas2 = _interopRequireDefault(_aeneas);
var _aeneas3 = __webpack_require__(90);
var _aeneas4 = _interopRequireDefault(_aeneas3);
var _conversions = __webpack_require__(60);
var _DragInteraction = __webpack_require__(91);
var _DragInteraction2 = _interopRequireDefault(_DragInteraction);
var _ScrollTopHook = __webpack_require__(92);
var _ScrollTopHook2 = _interopRequireDefault(_ScrollTopHook);
var _timeformat = __webpack_require__(93);
var _timeformat2 = _interopRequireDefault(_timeformat);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var AnnotationList = function () {
function AnnotationList(playlist, annotations) {
var controls = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
var editable = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
var linkEndpoints = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
var isContinuousPlay = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
var marginLeft = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : 0;
_classCallCheck(this, AnnotationList);
this.playlist = playlist;
this.marginLeft = marginLeft;
this.resizeHandlers = [];
this.editable = editable;
this.annotations = annotations.map(function (a) {
return (
// TODO support different formats later on.
(0, _aeneas2.default)(a)
);
});
this.setupInteractions();
this.controls = controls;
this.setupEE(playlist.ee);
// TODO actually make a real plugin system that's not terrible.
this.playlist.isContinuousPlay = isContinuousPlay;
this.playlist.linkEndpoints = linkEndpoints;
this.length = this.annotations.length;
}
_createClass(AnnotationList, [{
key: 'setupInteractions',
value: function setupInteractions() {
var _this = this;
this.annotations.forEach(function (a, i) {
var leftShift = new _DragInteraction2.default(_this.playlist, {
direction: 'left',
index: i
});
var rightShift = new _DragInteraction2.default(_this.playlist, {
direction: 'right',
index: i
});
_this.resizeHandlers.push(leftShift);
_this.resizeHandlers.push(rightShift);
});
}
}, {
key: 'setupEE',
value: function setupEE(ee) {
var _this2 = this;
ee.on('dragged', function (deltaTime, data) {
var annotationIndex = data.index;
var annotations = _this2.annotations;
var note = annotations[annotationIndex];
// resizing to the left
if (data.direction === 'left') {
var originalVal = note.start;
note.start += deltaTime;
if (note.start < 0) {
note.start = 0;
}
if (annotationIndex && annotations[annotationIndex - 1].end > note.start) {
annotations[annotationIndex - 1].end = note.start;
}
if (_this2.playlist.linkEndpoints && annotationIndex && annotations[annotationIndex - 1].end === originalVal) {
annotations[annotationIndex - 1].end = note.start;
}
} else {
// resizing to the right
var _originalVal = note.end;
note.end += deltaTime;
if (note.end > _this2.playlist.duration) {
note.end = _this2.playlist.duration;
}
if (annotationIndex < annotations.length - 1 && annotations[annotationIndex + 1].start < note.end) {
annotations[annotationIndex + 1].start = note.end;
}
if (_this2.playlist.linkEndpoints && annotationIndex < annotations.length - 1 && annotations[annotationIndex + 1].start === _originalVal) {
annotations[annotationIndex + 1].start = note.end;
}
}
_this2.playlist.drawRequest();
});
ee.on('continuousplay', function (val) {
_this2.playlist.isContinuousPlay = val;
});
ee.on('linkendpoints', function (val) {
_this2.playlist.linkEndpoints = val;
});
ee.on('annotationsrequest', function () {
_this2.export();
});
return ee;
}
}, {
key: 'export',
value: function _export() {
var output = this.annotations.map(function (a) {
return (0, _aeneas4.default)(a);
});
var dataStr = 'data:text/json;charset=utf-8,' + encodeURIComponent(JSON.stringify(output));
var a = document.createElement('a');
document.body.appendChild(a);
a.href = dataStr;
a.download = 'annotations.json';
a.click();
document.body.removeChild(a);
}
}, {
key: 'renderResizeLeft',
value: function renderResizeLeft(i) {
var events = _DragInteraction2.default.getEvents();
var config = {
attributes: {
style: 'position: absolute; height: 30px; width: 10px; top: 0; left: -2px',
draggable: true
}
};
var handler = this.resizeHandlers[i * 2];
events.forEach(function (event) {
config['on' + event] = handler[event].bind(handler);
});
return (0, _h2.default)('div.resize-handle.resize-w', config);
}
}, {
key: 'renderResizeRight',
value: function renderResizeRight(i) {
var events = _DragInteraction2.default.getEvents();
var config = {
attributes: {
style: 'position: absolute; height: 30px; width: 10px; top: 0; right: -2px',
draggable: true
}
};
var handler = this.resizeHandlers[i * 2 + 1];
events.forEach(function (event) {
config['on' + event] = handler[event].bind(handler);
});
return (0, _h2.default)('div.resize-handle.resize-e', config);
}
}, {
key: 'renderControls',
value: function renderControls(note, i) {
var _this3 = this;
// seems to be a bug with references, or I'm missing something.
var that = this;
return this.controls.map(function (ctrl) {
return (0, _h2.default)('i.' + ctrl.class, {
attributes: {
title: ctrl.title
},
onclick: function onclick() {
ctrl.action(note, i, that.annotations, {
linkEndpoints: that.playlist.linkEndpoints
});
_this3.setupInteractions();
that.playlist.drawRequest();
}
});
});
}
}, {
key: 'render',
value: function render() {
var _this4 = this;
var boxes = (0, _h2.default)('div.annotations-boxes', {
attributes: {
style: 'height: 30px; position: relative; margin-left: ' + this.marginLeft + 'px;'
}
}, this.annotations.map(function (note, i) {
var samplesPerPixel = _this4.playlist.samplesPerPixel;
var sampleRate = _this4.playlist.sampleRate;
var pixPerSec = sampleRate / samplesPerPixel;
var pixOffset = (0, _conversions.secondsToPixels)(_this4.playlist.scrollLeft, samplesPerPixel, sampleRate);
var left = Math.floor(note.start * pixPerSec - pixOffset);
var width = Math.ceil(note.end * pixPerSec - note.start * pixPerSec);
return (0, _h2.default)('div.annotation-box', {
attributes: {
style: 'position: absolute; height: 30px; width: ' + width + 'px; left: ' + left + 'px',
'data-id': note.id
}
}, [_this4.renderResizeLeft(i), (0, _h2.default)('span.id', {
onclick: function onclick() {
var start = _this4.annotations[i].start;
var end = _this4.annotations[i].end;
if (_this4.playlist.isContinuousPlay) {
_this4.playlist.seek(start, start);
_this4.playlist.ee.emit('play', start);
} else {
_this4.playlist.seek(start, end);
_this4.playlist.ee.emit('play', start, end);
}
}
}, [note.id]), _this4.renderResizeRight(i)]);
}));
var boxesWrapper = (0, _h2.default)('div.annotations-boxes-wrapper', {
attributes: {
style: 'overflow: hidden;'
}
}, [boxes]);
var text = (0, _h2.default)('div.annotations-text', {
hook: new _ScrollTopHook2.default()
}, this.annotations.map(function (note, i) {
var format = (0, _timeformat2.default)(_this4.playlist.durationFormat);
var start = format(note.start);
var end = format(note.end);
var segmentClass = '';
if (_this4.playlist.isPlaying() && _this4.playlist.playbackSeconds >= note.start && _this4.playlist.playbackSeconds <= note.end) {
segmentClass = '.current';
}
var editableConfig = {
attributes: {
contenteditable: true
},
oninput: function oninput(e) {
// needed currently for references
// eslint-disable-next-line no-param-reassign
note.lines = [e.target.innerText];
},
onkeypress: function onkeypress(e) {
if (e.which === 13 || e.keyCode === 13) {
e.target.blur();
e.preventDefault();
}
}
};
var linesConfig = _this4.editable ? editableConfig : {};
return (0, _h2.default)('div.annotation' + segmentClass, [(0, _h2.default)('span.annotation-id', [note.id]), (0, _h2.default)('span.annotation-start', [start]), (0, _h2.default)('span.annotation-end', [end]), (0, _h2.default)('span.annotation-lines', linesConfig, [note.lines]), (0, _h2.default)('span.annotation-actions', _this4.renderControls(note, i))]);
}));
return (0, _h2.default)('div.annotations', [boxesWrapper, text]);
}
}]);
return AnnotationList;
}();
exports.default = AnnotationList;
/***/ }),
/* 89 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = function (aeneas) {
var annotation = {
id: aeneas.id || _uuid2.default.v4(),
start: Number(aeneas.begin) || 0,
end: Number(aeneas.end) || 0,
lines: aeneas.lines || [''],
lang: aeneas.language || 'en'
};
return annotation;
};
var _uuid = __webpack_require__(72);
var _uuid2 = _interopRequireDefault(_uuid);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/***/ }),
/* 90 */
/***/ (function(module, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = function (annotation) {
return {
begin: String(annotation.start.toFixed(3)),
end: String(annotation.end.toFixed(3)),
id: String(annotation.id),
language: annotation.lang,
lines: annotation.lines
};
};
/***/ }),
/* 91 */
/***/ (function(module, exports, __webpack_require__) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _conversions = __webpack_require__(60);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var _class = function () {
function _class(playlist) {
var _this = this;
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
_classCallCheck(this, _class);
this.playlist = playlist;
this.data = data;
this.active = false;
this.ondragover = function (e) {
if (_this.active) {
e.preventDefault();
_this.emitDrag(e.clientX);
}
};
}
_createClass(_class, [{
key: 'emitDrag',
value: function emitDrag(x) {
var deltaX = x - this.prevX;
// emit shift event if not 0
if (deltaX) {
var deltaTime = (0, _conversions.pixelsToSeconds)(deltaX, this.playlist.samplesPerPixel, this.playlist.sampleRate);
this.prevX = x;
this.playlist.ee.emit('dragged', deltaTime, this.data);
}
}
}, {
key: 'complete',
value: function complete() {
this.active = false;
document.removeEventListener('dragover', this.ondragover);
}
}, {
key: 'dragstart',
value: function dragstart(e) {
var ev = e;
this.active = true;
this.prevX = e.clientX;
ev.dataTransfer.dropEffect = 'move';
ev.dataTransfer.effectAllowed = 'move';
ev.dataTransfer.setData('text/plain', '');
document.addEventListener('dragover', this.ondragover);
}
}, {
key: 'dragend',
value: function dragend(e) {
if (this.active) {
e.preventDefault();
this.complete();
}
}
}], [{
key: 'getClass',
value: function getClass() {
return '.shift';
}
}, {
key: 'getEvents',
value: function getEvents() {
return ['dragstart', 'dragend'];
}
}]);
return _class;
}();
exports.default = _class;
/***/ }),
/* 92 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
/*
* virtual-dom hook for scrolling to the text annotation.
*/
var Hook = function ScrollTopHook() {};
Hook.prototype.hook = function hook(node) {
var el = node.querySelector('.current');
if (el) {
var box = node.getBoundingClientRect();
var row = el.getBoundingClientRect();
var diff = row.top - box.top;
var list = node;
list.scrollTop += diff;
}
};
exports.default = Hook;
/***/ }),
/* 93 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = function (format) {
function clockFormat(seconds, decimals) {
var hours = parseInt(seconds / 3600, 10) % 24;
var minutes = parseInt(seconds / 60, 10) % 60;
var secs = (seconds % 60).toFixed(decimals);
var sHours = hours < 10 ? '0' + hours : hours;
var sMinutes = minutes < 10 ? '0' + minutes : minutes;
var sSeconds = secs < 10 ? '0' + secs : secs;
return sHours + ':' + sMinutes + ':' + sSeconds;
}
var formats = {
seconds: function seconds(_seconds) {
return _seconds.toFixed(0);
},
thousandths: function thousandths(seconds) {
return seconds.toFixed(3);
},
'hh:mm:ss': function hhmmss(seconds) {
return clockFormat(seconds, 0);
},
'hh:mm:ss.u': function hhmmssu(seconds) {
return clockFormat(seconds, 1);
},
'hh:mm:ss.uu': function hhmmssuu(seconds) {
return clockFormat(seconds, 2);
},
'hh:mm:ss.uuu': function hhmmssuuu(seconds) {
return clockFormat(seconds, 3);
}
};
return formats[format];
};
/***/ }),
/* 94 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = function () {
// http://jsperf.com/typed-array-min-max/2
// plain for loop for finding min/max is way faster than anything else.
/**
* @param {TypedArray} array - Subarray of audio to calculate peaks from.
*/
function findMinMax(array) {
var min = Infinity;
var max = -Infinity;
var curr = void 0;
for (var i = 0; i < array.length; i += 1) {
curr = array[i];
if (min > curr) {
min = curr;
}
if (max < curr) {
max = curr;
}
}
return {
min: min,
max: max
};
}
/**
* @param {Number} n - peak to convert from float to Int8, Int16 etc.
* @param {Number} bits - convert to #bits two's complement signed integer
*/
function convert(n, bits) {
var max = Math.pow(2, bits - 1);
var v = n < 0 ? n * max : n * max - 1;
return Math.max(-max, Math.min(max - 1, v));
}
/**
* @param {TypedArray} channel - Audio track frames to calculate peaks from.
* @param {Number} samplesPerPixel - Audio frames per peak
*/
function extractPeaks(channel, samplesPerPixel, bits) {
var chanLength = channel.length;
var numPeaks = Math.ceil(chanLength / samplesPerPixel);
var start = void 0;
var end = void 0;
var segment = void 0;
var max = void 0;
var min = void 0;
var extrema = void 0;
// create interleaved array of min,max
var peaks = new self['Int' + bits + 'Array'](numPeaks * 2);
for (var i = 0; i < numPeaks; i += 1) {
start = i * samplesPerPixel;
end = (i + 1) * samplesPerPixel > chanLength ? chanLength : (i + 1) * samplesPerPixel;
segment = channel.subarray(start, end);
extrema = findMinMax(segment);
min = convert(extrema.min, bits);
max = convert(extrema.max, bits);
peaks[i * 2] = min;
peaks[i * 2 + 1] = max;
}
return peaks;
}
/**
* @param {TypedArray} source - Source of audio samples for peak calculations.
* @param {Number} samplesPerPixel - Number of audio samples per peak.
* @param {Number} cueIn - index in channel to start peak calculations from.
* @param {Number} cueOut - index in channel to end peak calculations from (non-inclusive).
*/
function audioPeaks(source) {
var samplesPerPixel = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 10000;
var bits = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 8;
if ([8, 16, 32].indexOf(bits) < 0) {
throw new Error('Invalid number of bits specified for peaks.');
}
var peaks = [];
var start = 0;
var end = source.length;
peaks.push(extractPeaks(source.subarray(start, end), samplesPerPixel, bits));
var length = peaks[0].length / 2;
return {
bits: bits,
length: length,
data: peaks
};
}
onmessage = function onmessage(e) {
var peaks = audioPeaks(e.data.samples, e.data.samplesPerPixel);
postMessage(peaks);
};
};
/***/ }),
/* 95 */
/***/ (function(module, exports) {
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = function () {
var recLength = 0;
var recBuffersL = [];
var recBuffersR = [];
var sampleRate = void 0;
var stereo = void 0;
function init(config) {
sampleRate = config.sampleRate;
stereo = config.stereo;
}
function record(inputBuffer) {
recBuffersL.push(inputBuffer[0]);
if (stereo) {
recBuffersR.push(inputBuffer[1]);
}
recLength += inputBuffer[0].length;
}
function writeString(view, offset, string) {
for (var i = 0; i < string.length; i += 1) {
view.setUint8(offset + i, string.charCodeAt(i));
}
}
function floatTo16BitPCM(output, offset, input) {
var writeOffset = offset;
for (var i = 0; i < input.length; i += 1, writeOffset += 2) {
var s = Math.max(-1, Math.min(1, input[i]));
output.setInt16(writeOffset, s < 0 ? s * 0x8000 : s * 0x7FFF, true);
}
}
function encodeWAV(samples) {
var numChannels = stereo ? 2 : 1;
var buffer = new ArrayBuffer(44 + samples.length * 2);
var view = new DataView(buffer);
/* RIFF identifier */
writeString(view, 0, 'RIFF');
/* file length */
view.setUint32(4, 36 + samples.length * 2, true);
/* RIFF type */
writeString(view, 8, 'WAVE');
/* format chunk identifier */
writeString(view, 12, 'fmt ');
/* format chunk length */
view.setUint32(16, 16, true);
/* sample format (raw) */
view.setUint16(20, 1, true);
/* channel count */
view.setUint16(22, numChannels, true);
/* sample rate */
view.setUint32(24, sampleRate, true);
/* byte rate (sample rate * channel count * bytes per sample) */
view.setUint32(28, sampleRate * numChannels * 2, true);
/* block align (channel count * bytes per sample) */
view.setUint16(32, numChannels * 2, true);
/* bits per sample */
view.setUint16(34, 16, true);
/* data chunk identifier */
writeString(view, 36, 'data');
/* data chunk length */
view.setUint32(40, samples.length * 2, true);
floatTo16BitPCM(view, 44, samples);
return view;
}
function mergeBuffers(recBuffers, length) {
var result = new Float32Array(length);
var offset = 0;
for (var i = 0; i < recBuffers.length; i += 1) {
result.set(recBuffers[i], offset);
offset += recBuffers[i].length;
}
return result;
}
function interleave(inputL, inputR) {
var length = inputL.length + inputR.length;
var result = new Float32Array(length);
var index = 0;
var inputIndex = 0;
while (index < length) {
result[index += 1] = inputL[inputIndex];
result[index += 1] = inputR[inputIndex];
inputIndex += 1;
}
return result;
}
function exportWAV(type) {
var bufferL = mergeBuffers(recBuffersL, recLength);
var interleaved = bufferL;
if (stereo) {
var bufferR = mergeBuffers(recBuffersR, recLength);
interleaved = interleave(bufferL, bufferR);
}
var dataview = encodeWAV(interleaved);
var audioBlob = new Blob([dataview], { type: type });
postMessage(audioBlob);
}
function clear() {
recLength = 0;
recBuffersL = [];
recBuffersR = [];
}
onmessage = function onmessage(e) {
switch (e.data.command) {
case 'init':
{
init(e.data.config);
break;
}
case 'record':
{
record(e.data.buffer);
break;
}
case 'exportWAV':
{
exportWAV(e.data.type);
break;
}
case 'clear':
{
clear();
break;
}
default:
{
throw new Error('Unknown export worker command');
}
}
};
};
/***/ })
/******/ ]);
//# sourceMappingURL=waveform-playlist.var.js.map