mage-engine 3.21.1 → 3.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.nvmrc ADDED
@@ -0,0 +1 @@
1
+ 14.19.3
package/.prettierrc.js ADDED
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ module.exports = {
4
+ printWidth: 100,
5
+ trailingComma: "all",
6
+ arrowParens: "avoid",
7
+ semi: true,
8
+ tabWidth: 4,
9
+
10
+ overrides: [
11
+ {
12
+ files: ["*.md"],
13
+ options: { printWidth: 120 },
14
+ },
15
+ {
16
+ files: [".toolsharerc"],
17
+ options: { parser: "yaml" },
18
+ },
19
+ ],
20
+ };
package/dist/mage.js CHANGED
@@ -371,28 +371,7 @@ function _createForOfIteratorHelper(o, allowArrayLike) {
371
371
  }
372
372
  }
373
373
  };
374
- }var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
375
-
376
- function getAugmentedNamespace(n) {
377
- if (n.__esModule) return n;
378
- var a = Object.defineProperty({}, '__esModule', {value: true});
379
- Object.keys(n).forEach(function (k) {
380
- var d = Object.getOwnPropertyDescriptor(n, k);
381
- Object.defineProperty(a, k, d.get ? d : {
382
- enumerable: true,
383
- get: function () {
384
- return n[k];
385
- }
386
- });
387
- });
388
- return a;
389
- }var between$1 = {exports: {}};/* Between.js v0.1.2-fix.2 */
390
-
391
- (function (module, exports) {
392
- !function(t,n){module.exports=n();}(commonjsGlobal,function(){function O(t){return (O="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function r(t,n){for(var e=0;e<n.length;e++){var r=n[e];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,r.key,r);}}function n(t,n,e){return n&&r(t.prototype,n),e&&r(t,e),t}function M(t,n,e){return n in t?Object.defineProperty(t,n,{value:e,enumerable:!0,configurable:!0,writable:!0}):t[n]=e,t}function I(t){return (I=Object.getPrototypeOf||function(t){return t.__proto__})(t)}function o(t,n){return (o=Object.setPrototypeOf||function(t,n){return t.__proto__=n,t})(t,n)}function u(t,n,e){return (u="undefined"!=typeof Reflect&&Reflect.construct?Reflect.construct:function(t,n,e){var r=[null];r.push.apply(r,n);var u=new(t.bind.apply(t,r));return e&&o(u,e.prototype),u}).apply(null,arguments)}function _(t){if(void 0===t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return t}var t=function(o){var a={},i=[];(o=o||this).on=function(t,n,e){return (a[t]=a[t]||[]).push([n,e]),o},o.off=function(t,n){t||(a={});for(var e=a[t]||i,r=e.length=n?e.length:0;r--;)n==e[r][0]&&e.splice(r,1);return o},o.emit=function(t){for(var n,e=a[t]||i,r=0<e.length?e.slice(0,e.length):e,u=0;n=r[u++];)n[0].apply(n[1],i.slice.call(arguments,1));return o};};var V=function(t,n,e){return t*(1-e)+n*e},e="undefined"!=typeof window?window:"undefined"!=typeof commonjsGlobal?commonjsGlobal:"undefined"!=typeof self?self:{};function a(t,n){return t(n={exports:{}},n.exports),n.exports}for(var i=a(function(t){var n=t.exports={Linear:{None:function(t){return t}},Quadratic:{In:function(t){return t*t},Out:function(t){return t*(2-t)},InOut:function(t){return (t*=2)<1?.5*t*t:-.5*(--t*(t-2)-1)}},Cubic:{In:function(t){return t*t*t},Out:function(t){return --t*t*t+1},InOut:function(t){return (t*=2)<1?.5*t*t*t:.5*((t-=2)*t*t+2)}},Quartic:{In:function(t){return t*t*t*t},Out:function(t){return 1- --t*t*t*t},InOut:function(t){return (t*=2)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)}},Quintic:{In:function(t){return t*t*t*t*t},Out:function(t){return --t*t*t*t*t+1},InOut:function(t){return (t*=2)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)}},Sinusoidal:{In:function(t){return 1-Math.cos(t*Math.PI/2)},Out:function(t){return Math.sin(t*Math.PI/2)},InOut:function(t){return .5*(1-Math.cos(Math.PI*t))}},Exponential:{In:function(t){return 0===t?0:Math.pow(1024,t-1)},Out:function(t){return 1===t?1:1-Math.pow(2,-10*t)},InOut:function(t){return 0===t?0:1===t?1:(t*=2)<1?.5*Math.pow(1024,t-1):.5*(2-Math.pow(2,-10*(t-1)))}},Circular:{In:function(t){return 1-Math.sqrt(1-t*t)},Out:function(t){return Math.sqrt(1- --t*t)},InOut:function(t){return (t*=2)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)}},Elastic:{In:function(t){var n,e=.1;return 0===t?0:1===t?1:(!e||e<1?(e=1,n=.1):n=.4*Math.asin(1/e)/(2*Math.PI),-e*Math.pow(2,10*(t-=1))*Math.sin((t-n)*(2*Math.PI)/.4))},Out:function(t){var n,e=.1;return 0===t?0:1===t?1:(!e||e<1?(e=1,n=.1):n=.4*Math.asin(1/e)/(2*Math.PI),e*Math.pow(2,-10*t)*Math.sin((t-n)*(2*Math.PI)/.4)+1)},InOut:function(t){var n,e=.1;return 0===t?0:1===t?1:(!e||e<1?(e=1,n=.1):n=.4*Math.asin(1/e)/(2*Math.PI),(t*=2)<1?e*Math.pow(2,10*(t-=1))*Math.sin((t-n)*(2*Math.PI)/.4)*-.5:e*Math.pow(2,-10*(t-=1))*Math.sin((t-n)*(2*Math.PI)/.4)*.5+1)}},Back:{In:function(t){return t*t*(2.70158*t-1.70158)},Out:function(t){return --t*t*(2.70158*t+1.70158)+1},InOut:function(t){var n=2.5949095;return (t*=2)<1?t*t*((n+1)*t-n)*.5:.5*((t-=2)*t*((n+1)*t+n)+2)}},Bounce:{In:function(t){return 1-n.Bounce.Out(1-t)},Out:function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375},InOut:function(t){return t<.5?.5*n.Bounce.In(2*t):.5*n.Bounce.Out(2*t-1)+.5}}};}),c=(i.Linear,i.Quadratic,i.Cubic,i.Quartic,i.Quintic,i.Sinusoidal,i.Exponential,i.Circular,i.Elastic,i.Back,i.Bounce,a(function(a){(function(){var t,n,e,r,u,o;"undefined"!=typeof performance&&null!==performance&&performance.now?a.exports=function(){return performance.now()}:"undefined"!=typeof process&&null!==process&&process.hrtime?(a.exports=function(){return (t()-u)/1e6},n=process.hrtime,r=(t=function(){var t;return 1e9*(t=n())[0]+t[1]})(),o=1e9*process.uptime(),u=r-o):Date.now?(a.exports=function(){return Date.now()-e},e=Date.now()):(a.exports=function(){return (new Date).getTime()-e},e=(new Date).getTime());}).call(e);})),l="undefined"==typeof window?e:window,f=["moz","webkit"],s="AnimationFrame",p=l["request"+s],h=l["cancel"+s]||l["cancelRequest"+s],m=0;!p&&m<f.length;m++)p=l[f[m]+"Request"+s],h=l[f[m]+"Cancel"+s]||l[f[m]+"CancelRequest"+s];if(!p||!h){var d=0,y=0,v=[];p=function(t){if(0===v.length){var n=c(),e=Math.max(0,1e3/60-(n-d));d=e+n,setTimeout(function(){for(var t=v.slice(0),n=v.length=0;n<t.length;n++)if(!t[n].cancelled)try{t[n].callback(d);}catch(t){setTimeout(function(){throw t},0);}},Math.round(e));}return v.push({handle:++y,callback:t,cancelled:!1}),y},h=function(t){for(var n=0;n<v.length;n++)v[n].handle===t&&(v[n].cancelled=!0);};}var b=function(t){return p.call(l,t)};b.cancel=function(){h.apply(l,arguments);},b.polyfill=function(t){t||(t=l),t.requestAnimationFrame=p,t.cancelAnimationFrame=h;};var w,k,P=[],T=Symbol("type"),j=Symbol("start_time"),x=Symbol("completed"),D=Symbol("paused"),g=requestAnimationFrame||b,A=Date.now();!function t(){g(t),w=Date.now(),k=w-A;for(var n=0;n<P.length;n++)P[n][x]||P[n](k,Date.now()-P[n][j]);A=w;}();var E=function(t){function g(e,t){var n,r,u,o;!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,g),u=this,o=I(g).call(this),M(_(_(r=!o||"object"!=typeof o&&"function"!=typeof o?_(u):o)),"update",function(){var e=_(_(r))._updateValue;return function(t,n){r[x]||r[D]||(0===r.localTime&&r.emit("start",r.value,_(_(r))),e(r.ease(r.loopFunction.progress(Math.min(1,(n||r.localTime)/r.duration)))),r.emit("update",r.value,_(_(r)),t),r.localTime>=r.duration&&r.loopFunction.complete(function(){r[x]=!0,r.emit("complete",r.value,_(_(r)));}),r.localTime+=t);}});var a=r.plugin=Object.values(g._plugins).reduce(function(t,n){return t||n&&n.test&&n.test(e)&&n},!1),i=a&&a.name||("object"===O(e)?Array.isArray(e)?"array":"object":"number");if(a){var c=a.initialize(e,t);e=c.startValue,t=c.destValue,r.data=c.data;}switch(Object.assign(_(_(r)),(M(n={duration:1e3,localTime:0,startValue:e,destValue:t,loopMode:"once",loopFunction:g.DEFAULT_LOOP,ease:function(t){return t},value:"array"===i?[].concat(e):"object"===i?Object.assign({},e):e},x,!1),M(n,T,i),M(n,j,Date.now()),M(n,D,!1),n)),r[T]){case"number":r._updateValue=function(t){r.value=V(r.startValue,r.destValue,t);};break;case"array":var l=r.value.length,f=_(_(r)),s=f.startValue,p=f.destValue,h=f.value;r._updateValue=function(t){for(var n=0;n<l;n++)h[n]=V(s[n],p[n],t);};break;case"object":var m=Object.keys(r.startValue),d=m.length,y=_(_(r)),v=y.startValue,b=y.destValue,w=y.value;r._updateValue=function(t){for(var n=0;n<d;n++){var e=m[n];w[e]=V(v[e],b[e],t);}};break;default:r.plugin?r._updateValue=function(t){r.value=r.plugin.interpolate(r.startValue,r.destValue,t,r.data);}:(console.warn("Between: startValue type was unrecognized."),r._updateValue=function(){return null});}return P.push(r.update()),r}return n(g,null,[{key:"between",value:function(){for(var t=arguments.length,n=new Array(t),e=0;e<t;e++)n[e]=arguments[e];return u(g,n)}}]),n(g,[{key:"pause",value:function(){return this[D]=!0,this.emit("pause",this.value,this,k),this}},{key:"play",value:function(){return this[D]=!1,this.emit("play",this.value,this,k),this}},{key:"easing",value:function(t){return this.ease=t,this}},{key:"time",value:function(t){return this.duration=t,this}},{key:"loop",value:function(){for(var t=0<arguments.length&&void 0!==arguments[0]?arguments[0]:"once",n="__loop_".concat(t),e=arguments.length,r=new Array(1<e?e-1:0),u=1;u<e;u++)r[u-1]=arguments[u];return this.loopFunction=n in this?Object.assign({},g.DEFAULT_LOOP,this[n].apply(this,r)):g.DEFAULT_LOOP,this}},{key:"__loop_repeat",value:function(t){var n=this,e=t;return this.times=0,{complete:function(t){n.localTime=0,Number.isInteger(e)&&++n.times===e?t():Number.isInteger(e)||++n.times;}}}},{key:"__loop_bounce",value:function(t){var n=this,e=t,r=1;return this.times=0,{complete:function(t){n.localTime=0,r=-r,Number.isInteger(e)&&++n.times===e?t():Number.isInteger(e)||++n.times;},progress:function(t){return 0<r?t:1-t}}}},{key:"isPaused",get:function(){return this[D]}}]),function(t,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function");o(t.prototype,n&&n.prototype),n&&o(t,n);}(g,t),g}(t);return M(E,"DEFAULT_LOOP",{complete:function(t){return t()},progress:function(t){return t}}),E.Easing=i,E._plugins={},E});
393
- }(between$1));
394
-
395
- var between = between$1.exports;/*! *****************************************************************************
374
+ }/*! *****************************************************************************
396
375
  Copyright (c) Microsoft Corporation. All rights reserved.
397
376
  Licensed under the Apache License, Version 2.0 (the "License"); you may not use
398
377
  this file except in compliance with the License. You may obtain a copy of the
@@ -53990,6 +53969,11 @@ var LABEL_DOMELEMENT_MISSING = "".concat(PREFIX, " Could not create Label, domEl
53990
53969
  value: function __check() {
53991
53970
  return true;
53992
53971
  }
53972
+ }, {
53973
+ key: "__isStatic",
53974
+ value: function __isStatic() {
53975
+ return false;
53976
+ }
53993
53977
  }, {
53994
53978
  key: "__hasStarted",
53995
53979
  value: function __hasStarted() {
@@ -54017,6 +54001,7 @@ var LABEL_DOMELEMENT_MISSING = "".concat(PREFIX, " Could not create Label, domEl
54017
54001
 
54018
54002
  this.__name = name || this.constructor.name;
54019
54003
  this.hasStarted = false;
54004
+ this.isDisposed = false;
54020
54005
  this.options = {};
54021
54006
  }
54022
54007
 
@@ -55356,7 +55341,7 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
55356
55341
  url = url || createURL(base64, sourcemapArg, enableUnicodeArg);
55357
55342
  return new Worker(url, options);
55358
55343
  };
55359
- }var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
    'use strict';

    var LIBRARY_NAME = 'ammo.js';
    var TYPES = {
      BOX: 'BOX',
      SPHERE: 'SPHERE',
      VEHICLE: 'VEHICLE',
      MESH: 'MESH',
      PLAYER: 'PLAYER'
    };
    var DEFAULT_VEHICLE_STATE = {
      vehicleSteering: 0,
      acceleration: false,
      breaking: false,
      right: false,
      left: false
    };
    var DEFAULT_RIGIDBODY_STATE = {
      velocity: {
        x: 0,
        y: 0,
        z: 0
      },
      movement: {
        forward: false,
        backwards: false,
        left: false,
        right: false
      },
      direction: {
        x: 0,
        y: 0,
        z: 0
      }
    };
    var DEFAULT_SCALE = {
      x: 1,
      y: 1,
      z: 1
    };
    var DEFAULT_LINEAR_VELOCITY = {
      x: 0,
      y: 0,
      z: 0
    };
    var DEFAULT_IMPULSE = {
      x: 0,
      y: 0,
      z: 0
    };
    var DISABLE_DEACTIVATION = 4;
    var GRAVITY = {
      x: 0,
      y: -10,
      z: 0
    };
    var FRONT_LEFT = 0;
    var FRONT_RIGHT = 1;
    var BACK_LEFT = 2;
    var BACK_RIGHT = 3;
    var DEFAULT_STEERING_INCREMENT = .04;
    var DEFAULT_STEERING_CLAMP = .5;
    var DEFAULT_MAX_ENGINE_FORCE = 2000;
    var DEFAULT_MAX_BREAKING_FORCE = 100;
    var EXPLOSION_SIZES = {
      SMALL: 4,
      MEDIUM: 6,
      LARGE: 8,
      MASSIVE: 12
    };
    var EXPLOSION_STRENGTHS = {
      VERY_WEAK: 2,
      WEAK: 4,
      MEDIUM: 8,
      LARGE: 16,
      MASSIVE: 32,
      OK_NO: 64
    };

    var PHYSICS_EVENTS = {
      DISPATCH: 'physics:dispatch',
      TERMINATE: 'physics:terminate',
      LOAD: {
        AMMO: 'physics:load:ammo'
      },
      READY: 'physics:ready',
      INIT: 'physics:init',
      UPDATE: 'physics:update',
      ADD: {
        BOX: 'physics:add:box',
        VEHICLE: 'physics:add:vehicle',
        MODEL: 'physics:add:model',
        PLAYER: 'physics:add:player',
        SPHERE: 'physics:add:sphere'
      },
      ELEMENT: {
        DISPOSE: 'physics:element:dispose',
        COLLISION: 'physics:element:collision',
        UPDATE: 'physics:element:update',
        CREATED: 'physics:element:created',
        SET: {
          POSITION: 'physics:element:set:position',
          QUATERNION: 'physics:element:set:quaternion',
          LINEAR_VELOCITY: 'physics:element:set:linear_velocity'
        },
        RESET: 'physics:element:reset',
        APPLY: {
          IMPULSE: 'physics:element:apply:impulse'
        }
      },
      VEHICLE: {
        SET: {
          POSITION: 'physics:vehicle:set:position',
          QUATERNION: 'physics:vehicle:set:quaternion'
        },
        RESET: 'physics:vehicle:reset',
        SPEED: 'physics:vehicle:speed',
        DIRECTION: 'physics:vehicle:direction'
      },
      EFFECTS: {
        EXPLOSION: 'physics:effects:explosion'
      }
    };

    function ownKeys(object, enumerableOnly) {
      var keys = Object.keys(object);

      if (Object.getOwnPropertySymbols) {
        var symbols = Object.getOwnPropertySymbols(object);
        enumerableOnly && (symbols = symbols.filter(function (sym) {
          return Object.getOwnPropertyDescriptor(object, sym).enumerable;
        })), keys.push.apply(keys, symbols);
      }

      return keys;
    }

    function _objectSpread2(target) {
      for (var i = 1; i < arguments.length; i++) {
        var source = null != arguments[i] ? arguments[i] : {};
        i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {
          _defineProperty(target, key, source[key]);
        }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {
          Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
        });
      }

      return target;
    }

    function _classCallCheck(instance, Constructor) {
      if (!(instance instanceof Constructor)) {
        throw new TypeError("Cannot call a class as a 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);
      }
    }

    function _createClass(Constructor, protoProps, staticProps) {
      if (protoProps) _defineProperties(Constructor.prototype, protoProps);
      if (staticProps) _defineProperties(Constructor, staticProps);
      Object.defineProperty(Constructor, "prototype", {
        writable: false
      });
      return Constructor;
    }

    function _defineProperty(obj, key, value) {
      if (key in obj) {
        Object.defineProperty(obj, key, {
          value: value,
          enumerable: true,
          configurable: true,
          writable: true
        });
      } else {
        obj[key] = value;
      }

      return obj;
    }

    var Dispatcher = function Dispatcher() {
      _classCallCheck(this, Dispatcher);

      _defineProperty(this, "sendPhysicsUpdate", function (dt) {
        return postMessage({
          event: PHYSICS_EVENTS.UPDATE,
          dt: dt
        });
      });

      _defineProperty(this, "sendReadyEvent", function () {
        return postMessage({
          event: PHYSICS_EVENTS.READY
        });
      });

      _defineProperty(this, "sendTerminateEvent", function () {
        return postMessage({
          event: PHYSICS_EVENTS.TERMINATE
        });
      });

      _defineProperty(this, "sendBodyUpdate", function (uuid, position, rotation, dt, extraData) {
        return postMessage(_objectSpread2(_objectSpread2({
          event: PHYSICS_EVENTS.ELEMENT.UPDATE,
          uuid: uuid,
          position: {
            x: position.x(),
            y: position.y(),
            z: position.z()
          },
          quaternion: {
            x: rotation.x(),
            y: rotation.y(),
            z: rotation.z(),
            w: rotation.w()
          }
        }, extraData), {}, {
          dt: dt
        }));
      });

      _defineProperty(this, "sendDispatchEvent", function (uuid, eventName, eventData) {
        return postMessage({
          event: PHYSICS_EVENTS.DISPATCH,
          uuid: uuid,
          eventName: eventName,
          eventData: eventData
        });
      });
    };
    var dispatcher$1 = new Dispatcher();

    var applyMatrix4ToVector3 = function applyMatrix4ToVector3(_ref) {
      var _ref$x = _ref.x,
          x = _ref$x === void 0 ? 0 : _ref$x,
          _ref$y = _ref.y,
          y = _ref$y === void 0 ? 0 : _ref$y,
          _ref$z = _ref.z,
          z = _ref$z === void 0 ? 0 : _ref$z;
      var matrix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
      var w = 1 / (matrix[3] * x + matrix[7] * y + matrix[11] * z + matrix[15]);
      return {
        x: (matrix[0] * x + matrix[4] * y + matrix[8] * z + matrix[12]) * w,
        y: (matrix[1] * x + matrix[5] * y + matrix[9] * z + matrix[13]) * w,
        z: (matrix[2] * x + matrix[6] * y + matrix[10] * z + matrix[14]) * w
      };
    };

    var createRigidBody = function createRigidBody(shape, options) {
      var uuid = options.uuid,
          position = options.position,
          quaternion = options.quaternion,
          mass = options.mass,
          friction = options.friction,
          _options$restitution = options.restitution,
          restitution = _options$restitution === void 0 ? .9 : _options$restitution,
          _options$damping = options.damping,
          damping = _options$damping === void 0 ? {
        linear: 0.2,
        angular: 0.2
      } : _options$damping;
      var transform = new Ammo.btTransform();
      transform.setIdentity();
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
      var motionState = new Ammo.btDefaultMotionState(transform);
      var localInertia = new Ammo.btVector3(0, 0, 0);
      shape.calculateLocalInertia(mass, localInertia);
      var rbInfo = new Ammo.btRigidBodyConstructionInfo(mass, motionState, shape, localInertia);
      var body = new Ammo.btRigidBody(rbInfo);

      if (mass > 0) {
        body.setFriction(friction);
        body.setRestitution(restitution);
        body.setDamping(damping.linear, damping.angular);
        body.setActivationState(DISABLE_DEACTIVATION);
      } // storing uuid for future reference


      body.uuid = uuid;
      world.addRigidBody(body);
      return body;
    };
    var addModel = function addModel(options) {
      var uuid = options.uuid,
          vertices = options.vertices,
          matrices = options.matrices,
          indexes = options.indexes,
          position = options.position,
          quaternion = options.quaternion,
          _options$mass = options.mass,
          mass = _options$mass === void 0 ? 0 : _options$mass,
          _options$friction = options.friction,
          friction = _options$friction === void 0 ? 2 : _options$friction;
      var scale = DEFAULT_SCALE;
      var bta = new Ammo.btVector3();
      var btb = new Ammo.btVector3();
      var btc = new Ammo.btVector3();
      var triMesh = new Ammo.btTriangleMesh(true, false);

      for (var i = 0; i < vertices.length; i++) {
        var components = vertices[i];
        var index = indexes[i] ? indexes[i] : null;
        var matrix = Array.from(matrices[i]);

        if (index) {
          for (var j = 0; j < index.length; j += 3) {
            var ai = index[j] * 3;
            var bi = index[j + 1] * 3;
            var ci = index[j + 2] * 3;
            var va = applyMatrix4ToVector3({
              x: components[ai],
              y: components[ai + 1],
              z: components[ai + 2]
            }, matrix);
            var vb = applyMatrix4ToVector3({
              x: components[bi],
              y: components[bi + 1],
              z: components[bi + 2]
            }, matrix);
            var vc = applyMatrix4ToVector3({
              x: components[ci],
              y: components[ci + 1],
              z: components[ci + 2]
            }, matrix);
            bta.setValue(va.x, va.y, va.z);
            btb.setValue(vb.x, vb.y, vb.z);
            btc.setValue(vc.x, vc.y, vc.z);
            triMesh.addTriangle(bta, btb, btc, false);
          }
        } else {
          for (var _j = 0; _j < components.length; _j += 9) {
            var _va = applyMatrix4ToVector3({
              x: components[_j + 0],
              y: components[_j + 1],
              z: components[_j + 2]
            }, matrix);

            var _vb = applyMatrix4ToVector3({
              x: components[_j + 3],
              y: components[_j + 4],
              z: components[_j + 5]
            }, matrix);

            var _vc = applyMatrix4ToVector3({
              x: components[_j + 6],
              y: components[_j + 7],
              z: components[_j + 8]
            }, matrix);

            bta.setValue(_va.x, _va.y, _va.z);
            btb.setValue(_vb.x, _vb.y, _vb.z);
            btc.setValue(_vc.x, _vc.y, _vc.z);
            triMesh.addTriangle(bta, btb, btc, false);
          }
        }
      }

      var localScale = new Ammo.btVector3(scale.x, scale.y, scale.z);
      triMesh.setScaling(localScale);
      Ammo.destroy(localScale);
      var collisionShape = new Ammo.btBvhTriangleMeshShape(triMesh, true, true);
      collisionShape.resources = [triMesh];
      Ammo.destroy(bta);
      Ammo.destroy(btb);
      Ammo.destroy(btc);
      var body = createRigidBody(collisionShape, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      });
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.MESH,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var addBox = function addBox(data) {
      var uuid = data.uuid,
          width = data.width,
          length = data.length,
          height = data.height,
          position = data.position,
          quaternion = data.quaternion,
          _data$mass = data.mass,
          mass = _data$mass === void 0 ? 0 : _data$mass,
          _data$friction = data.friction,
          friction = _data$friction === void 0 ? 2 : _data$friction;
      var geometry = new Ammo.btBoxShape(new Ammo.btVector3(width * 0.5, height * 0.5, length * 0.5));
      var body = createRigidBody(geometry, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      });
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.BOX,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var addSphere = function addSphere(data) {
      var uuid = data.uuid,
          radius = data.radius,
          position = data.position,
          quaternion = data.quaternion,
          _data$mass2 = data.mass,
          mass = _data$mass2 === void 0 ? 0 : _data$mass2,
          _data$friction2 = data.friction,
          friction = _data$friction2 === void 0 ? 2 : _data$friction2;
      var geometry = new Ammo.btSphereShape(radius);
      var body = createRigidBody(geometry, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      });
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.SPHERE,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var setLinearVelocity = function setLinearVelocity(data) {
      var uuid = data.uuid,
          _data$velocity = data.velocity,
          velocity = _data$velocity === void 0 ? DEFAULT_LINEAR_VELOCITY : _data$velocity;

      var _world$getElement = world.getElement(uuid),
          body = _world$getElement.body;

      var motionState = body.getMotionState();

      if (motionState) {
        var linearVelocity = new Ammo.btVector3(velocity.x, velocity.y, velocity.z);
        body.setLinearVelocity(linearVelocity);
        Ammo.destroy(linearVelocity);
      }
    };
    var setPosition = function setPosition(data) {
      var uuid = data.uuid,
          position = data.position;

      var _world$getElement2 = world.getElement(uuid),
          body = _world$getElement2.body;

      var transform = new Ammo.btTransform();
      body.getWorldTransform(transform);
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      body.setWorldTransform(transform);
    };
    var resetElement = function resetElement(data) {
      var uuid = data.uuid,
          position = data.position,
          quaternion = data.quaternion;

      var _world$getElement3 = world.getElement(uuid),
          body = _world$getElement3.body;

      var transform = new Ammo.btTransform();
      body.getWorldTransform(transform);
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
      body.setWorldTransform(transform);
    };
    var applyImpuse = function applyImpuse(_ref) {
      var uuid = _ref.uuid,
          _ref$impulse = _ref.impulse,
          impulse = _ref$impulse === void 0 ? DEFAULT_IMPULSE : _ref$impulse;

      var _world$getElement4 = world.getElement(uuid),
          body = _world$getElement4.body;

      var motionState = body.getMotionState();

      if (motionState) {
        var impulseVector = new Ammo.btVector3(impulse.x, impulse.y, impulse.z);
        body.applyCentralImpulse(impulseVector);
        Ammo.destroy(impulseVector);
      }
    };
    var handleElementUpdate = function handleElementUpdate(_ref2, dt) {
      var body = _ref2.body,
          uuid = _ref2.uuid;
          _ref2.state;
      var motionState = body.getMotionState();

      if (motionState) {
        var transform = new Ammo.btTransform();
        motionState.getWorldTransform(transform);
        var origin = transform.getOrigin();
        var rotation = transform.getRotation();
        dispatcher$1.sendBodyUpdate(uuid, origin, rotation, dt);
        Ammo.destroy(transform);
      }
    };

    var addPlayer = function addPlayer(data) {
      var uuid = data.uuid,
          width = data.width,
          height = data.height,
          position = data.position,
          quaternion = data.quaternion,
          mass = data.mass,
          friction = data.friction;
      var capsule = new Ammo.btCapsuleShape(width, height);
      var body = createRigidBody(capsule, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      }); // disabliing rotation for collisions

      body.setAngularFactor(0);
      world.addRigidBody(body);
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.PLAYER,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var handlePlayerUpdate = function handlePlayerUpdate(_ref, dt) {
      var body = _ref.body,
          uuid = _ref.uuid,
          _ref$state = _ref.state,
          state = _ref$state === void 0 ? DEFAULT_RIGIDBODY_STATE : _ref$state;
      var movement = state.movement;
          state.direction;
          var cameraDirection = state.cameraDirection;
          state.quaternion;
          state.position;
      var MAX_SPEED = 1;
      var walkVelocity = .1;
      var motionState = body.getMotionState();

      if (motionState) {
        var transform = new Ammo.btTransform();
        motionState.getWorldTransform(transform);
        var linearVelocity = body.getLinearVelocity();
        var speed = linearVelocity.length();
        var forwardDir = transform.getBasis().getRow(2);
        forwardDir.normalize();
        var walkDirection = new Ammo.btVector3(0.0, 0.0, 0.0);
        var walkSpeed = walkVelocity * dt;

        if (movement.forward) {
          walkDirection.setX(walkDirection.x() + forwardDir.x()); //walkDirection.setY( walkDirection.y() + forwardDir.y());

          walkDirection.setZ(walkDirection.z() + forwardDir.z());
        }

        if (movement.backwards) {
          walkDirection.setX(walkDirection.x() - forwardDir.x()); //walkDirection.setY( walkDirection.y() - forwardDir.y());

          walkDirection.setZ(walkDirection.z() - forwardDir.z());
        }

        if (!movement.forward && !movement.backwards) {
          linearVelocity.setX(linearVelocity.x() * 0.2);
          linearVelocity.setZ(linearVelocity.z() * 0.2);
        } else if (speed < MAX_SPEED) {
          linearVelocity.setX(linearVelocity.x() + cameraDirection.x * walkSpeed);
          linearVelocity.setZ(linearVelocity.z() + cameraDirection.z * walkSpeed);
        }

        body.setLinearVelocity(linearVelocity);
        body.getMotionState().setWorldTransform(transform);
        body.setCenterOfMassTransform(transform);
        var origin = transform.getOrigin();
        var rotation = transform.getRotation();
        dispatcher.sendBodyUpdate(uuid, origin, rotation, dt);
      }
    };

    var Clock = /*#__PURE__*/function () {
      function Clock() {
        _classCallCheck(this, Clock);

        this.timestamp = null;
      }

      _createClass(Clock, [{
        key: "getDelta",
        value: function getDelta() {
          var time = Date.now();

          if (this.timestamp) {
            var delta = time - this.timestamp;
            this.timestamp = time;
            return delta;
          } else {
            this.timestamp = time;
            return 0;
          }
        }
      }]);

      return Clock;
    }();

    var World = /*#__PURE__*/function () {
      function World() {
        var _this = this;

        _classCallCheck(this, World);

        _defineProperty(this, "init", function (options) {
          var _options$gravity = options.gravity,
              gravity = _options$gravity === void 0 ? GRAVITY : _options$gravity;
          _this.collisionConfiguration = new Ammo.btDefaultCollisionConfiguration();
          _this.dispatcher = new Ammo.btCollisionDispatcher(_this.collisionConfiguration);
          _this.broadphase = new Ammo.btDbvtBroadphase();
          _this.solver = new Ammo.btSequentialImpulseConstraintSolver();
          _this.dynamicsWorld = new Ammo.btDiscreteDynamicsWorld(_this.dispatcher, _this.broadphase, _this.solver, _this.collisionConfiguration);

          _this.dynamicsWorld.setGravity(new Ammo.btVector3(gravity.x, gravity.y, gravity.z)); // this is needed for ghostObject collisions


          _this.dynamicsWorld.getBroadphase().getOverlappingPairCache().setInternalGhostPairCallback(new Ammo.btGhostPairCallback());

          _this.initialised = true;
        });

        _defineProperty(this, "removeElement", function (uuid) {
          if (_this.hasElement(uuid)) {
            _this.elements[uuid].deleted = true;
          }
        });

        _defineProperty(this, "removeDeletedElements", function () {
          return Object.keys(_this.elements).filter(function (uuid) {
            return _this.elements[uuid].deleted;
          }).forEach(function (uuid) {
            delete _this.elements[uuid];
          });
        });

        _defineProperty(this, "hasElement", function (uuid) {
          return Object.keys(_this.elements).includes(uuid);
        });

        _defineProperty(this, "getElement", function (uuid) {
          return _this.elements[uuid];
        });

        _defineProperty(this, "isInitialised", function () {
          return _this.initialised;
        });

        _defineProperty(this, "getDynamicsWorld", function () {
          return _this.dynamicsWorld;
        });

        _defineProperty(this, "addRigidBody", function (body) {
          _this.dynamicsWorld.addRigidBody(body);
        });

        _defineProperty(this, "addAction", function (action) {
          _this.dynamicsWorld.addAction(action);
        });

        _defineProperty(this, "addCollisionObject", function (collisionObject) {
          _this.dynamicsWorld.addCollisionObject(collisionObject);
        });

        _defineProperty(this, "stepSimulation", function (dt) {
          _this.dynamicsWorld.stepSimulation(dt);
        });

        _defineProperty(this, "simulate", function () {
          var dt = _this.clock.getDelta();

          _this.stepSimulation(dt);

          Object.keys(_this.elements).forEach(function (uuid) {
            var element = _this.getElement(uuid);

            if (element) {
              switch (element.type) {
                case TYPES.BOX:
                case TYPES.SPHERE:
                case TYPES.MESH:
                  handleElementUpdate(element, dt);
                  break;

                case TYPES.PLAYER:
                  handlePlayerUpdate(element, dt);
                  break;

                case TYPES.VEHICLE:
                  handleVehicleUpdate(element, dt);
                  break;
              }
            }
          });

          _this.calculateCollisions();

          _this.removeDeletedElements();

          dispatcher$1.sendPhysicsUpdate(dt);
          _this.requestAnimationFrameId = requestAnimationFrame(_this.simulate.bind(_this));
        });

        _defineProperty(this, "calculateCollisions", function () {
          var ammoDispatcher = _this.dynamicsWorld.getDispatcher();

          var numManifolds = ammoDispatcher.getNumManifolds();

          for (var i = 0; i < numManifolds; i++) {
            var contactManifold = ammoDispatcher.getManifoldByIndexInternal(i);
            var rb0 = Ammo.castObject(contactManifold.getBody0(), Ammo.btRigidBody);
            var rb1 = Ammo.castObject(contactManifold.getBody1(), Ammo.btRigidBody);
            var numContacts = contactManifold.getNumContacts(); // this iteration doesn't have uuids

            if (!rb0.uuid || !rb1.uuid) continue;
            var contacts = [];

            for (var j = 0; j < numContacts; j++) {
              var contactPoint = contactManifold.getContactPoint(j);
              var distance = contactPoint.getDistance();
              if (distance > 0.0) continue;
              var velocity0 = rb0.getLinearVelocity();
              var velocity1 = rb1.getLinearVelocity();
              var worldPos0 = contactPoint.get_m_positionWorldOnA();
              var worldPos1 = contactPoint.get_m_positionWorldOnB();
              var localPos0 = contactPoint.get_m_localPointA();
              var localPos1 = contactPoint.get_m_localPointB();
              contacts.push({
                distance: distance,
                elements: [{
                  uuid: rb0.uuid,
                  velocity: {
                    x: velocity0.x(),
                    y: velocity0.y(),
                    z: velocity0.z()
                  },
                  worldPos: {
                    x: worldPos0.x(),
                    y: worldPos0.y(),
                    z: worldPos0.z()
                  },
                  localPos: {
                    x: localPos0.x(),
                    y: localPos0.y(),
                    z: localPos0.z()
                  }
                }, {
                  uuid: rb1.uuid,
                  velocity: {
                    x: velocity1.x(),
                    y: velocity1.y(),
                    z: velocity1.z()
                  },
                  worldPos: {
                    x: worldPos1.x(),
                    y: worldPos1.y(),
                    z: worldPos1.z()
                  },
                  localPos: {
                    x: localPos1.x(),
                    y: localPos1.y(),
                    z: localPos1.z()
                  }
                }]
              });
            }

            dispatcher$1.sendDispatchEvent(rb0.uuid, PHYSICS_EVENTS.ELEMENT.COLLISION, {
              contacts: contacts
            });
            dispatcher$1.sendDispatchEvent(rb1.uuid, PHYSICS_EVENTS.ELEMENT.COLLISION, {
              contacts: contacts
            });
          }
        });

        _defineProperty(this, "addElement", function (data) {
          _this.elements[data.uuid] = data;
        });

        _defineProperty(this, "updateBodyState", function (_ref) {
          var uuid = _ref.uuid,
              state = _ref.state;

          if (_this.hasElement(uuid)) {
            _this.elements[uuid].state = _objectSpread2(_objectSpread2({}, _this.elements[uuid].state), state);
          }
        });

        _defineProperty(this, "terminate", function () {
          Ammo.destroy(_this.dynamicsWorld);
          Ammo.destroy(_this.solver);
          Ammo.destroy(_this.dispatcher);
          Ammo.destroy(_this.collisionConfiguration);
          cancelAnimationFrame(_this.requestAnimationFrameId);
          dispatcher$1.sendTerminateEvent();
        });

        this.elements = {};
        this.initialised = false;
        this.collisionConfiguration = undefined;
        this.dispatcher = undefined;
        this.broadphase = undefined;
        this.solver = undefined;
        this.dynamicsWorld = undefined;
        this.requestAnimationFrameId = null;
        this.clock = new Clock();
      }

      _createClass(World, [{
        key: "disposeBody",
        value: function disposeBody(_ref2) {
          var uuid = _ref2.uuid;
          var element = this.getElement(uuid);
          this.dynamicsWorld.removeRigidBody(element.body);
          this.removeElement(uuid);
          dispatcher$1.sendElementDisposed({
            uuid: uuid
          });
        }
      }]);

      return World;
    }();
    var world = new World();

    var DEFAULT_ROLL_INFLUENCE = 0.2;
    var DEFAULT_FRICTION = 1000;
    var DEFAULT_MASS = 800;
    var addVehicle = function addVehicle(data) {
      var position = data.position,
          quaternion = data.quaternion,
          uuid = data.uuid,
          wheels = data.wheels,
          _data$mass = data.mass,
          mass = _data$mass === void 0 ? DEFAULT_MASS : _data$mass,
          _data$width = data.width,
          width = _data$width === void 0 ? 1.8 : _data$width,
          _data$height = data.height,
          height = _data$height === void 0 ? .6 : _data$height,
          _data$length = data.length,
          length = _data$length === void 0 ? 4 : _data$length,
          _data$friction = data.friction,
          friction = _data$friction === void 0 ? DEFAULT_FRICTION : _data$friction,
          _data$rollInfluence = data.rollInfluence,
          rollInfluence = _data$rollInfluence === void 0 ? DEFAULT_ROLL_INFLUENCE : _data$rollInfluence,
          _data$wheelsOptions = data.wheelsOptions,
          wheelsOptions = _data$wheelsOptions === void 0 ? {} : _data$wheelsOptions,
          _data$suspensions = data.suspensions,
          suspensions = _data$suspensions === void 0 ? {} : _data$suspensions;
      var _wheelsOptions$back = wheelsOptions.back,
          back = _wheelsOptions$back === void 0 ? {} : _wheelsOptions$back,
          _wheelsOptions$front = wheelsOptions.front,
          front = _wheelsOptions$front === void 0 ? {} : _wheelsOptions$front;
      var _back$axisPosition = back.axisPosition,
          axisPositionBack = _back$axisPosition === void 0 ? -1 : _back$axisPosition,
          _back$radius = back.radius,
          wheelRadiusBack = _back$radius === void 0 ? .4 : _back$radius,
          _back$halfTrack = back.halfTrack,
          wheelHalfTrackBack = _back$halfTrack === void 0 ? 1 : _back$halfTrack,
          _back$axisHeight = back.axisHeight,
          wheelAxisHeightBack = _back$axisHeight === void 0 ? .3 : _back$axisHeight;
      var _front$axisPosition = front.axisPosition,
          axisPositionFront = _front$axisPosition === void 0 ? 1.7 : _front$axisPosition,
          _front$radius = front.radius,
          wheelRadiusFront = _front$radius === void 0 ? .4 : _front$radius,
          _front$halfTrack = front.halfTrack,
          wheelHalfTrackFront = _front$halfTrack === void 0 ? 1 : _front$halfTrack,
          _front$axisHeight = front.axisHeight,
          wheelAxisHeightFront = _front$axisHeight === void 0 ? .3 : _front$axisHeight;
      var _suspensions$stiffnes = suspensions.stiffness,
          stiffness = _suspensions$stiffnes === void 0 ? 20.0 : _suspensions$stiffnes,
          _suspensions$damping = suspensions.damping,
          damping = _suspensions$damping === void 0 ? 2.3 : _suspensions$damping,
          _suspensions$compress = suspensions.compression,
          compression = _suspensions$compress === void 0 ? 4.4 : _suspensions$compress,
          _suspensions$restLeng = suspensions.restLength,
          restLength = _suspensions$restLeng === void 0 ? 0.6 : _suspensions$restLeng; // Chassis

      var geometry = new Ammo.btBoxShape(new Ammo.btVector3(width * .5, height * .5, length * .5));
      var transform = new Ammo.btTransform();
      transform.setIdentity();
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
      var motionState = new Ammo.btDefaultMotionState(transform);
      var localInertia = new Ammo.btVector3(0, 0, 0);
      geometry.calculateLocalInertia(mass, localInertia);
      var chassis = new Ammo.btRigidBody(new Ammo.btRigidBodyConstructionInfo(mass, motionState, geometry, localInertia));
      chassis.setActivationState(DISABLE_DEACTIVATION);
      world.addRigidBody(chassis); // Raycast Vehicle

      var tuning = new Ammo.btVehicleTuning();
      var rayCaster = new Ammo.btDefaultVehicleRaycaster(world.getDynamicsWorld());
      var vehicle = new Ammo.btRaycastVehicle(tuning, chassis, rayCaster);
      vehicle.setCoordinateSystem(0, 1, 2);
      world.addAction(vehicle);
      var wheelDirectionCS0 = new Ammo.btVector3(0, -1, 0);
      var wheelAxleCS = new Ammo.btVector3(-1, 0, 0);

      var addWheel = function addWheel(isFront, pos, radius) {
        var wheelInfo = vehicle.addWheel(pos, wheelDirectionCS0, wheelAxleCS, restLength, radius, tuning, isFront);
        wheelInfo.set_m_suspensionStiffness(stiffness);
        wheelInfo.set_m_wheelsDampingRelaxation(damping);
        wheelInfo.set_m_wheelsDampingCompression(compression);
        wheelInfo.set_m_frictionSlip(friction);
        wheelInfo.set_m_rollInfluence(rollInfluence);
      };

      addWheel(true, new Ammo.btVector3(wheelHalfTrackFront, wheelAxisHeightFront, axisPositionFront), wheelRadiusFront);
      addWheel(true, new Ammo.btVector3(-wheelHalfTrackFront, wheelAxisHeightFront, axisPositionFront), wheelRadiusFront);
      addWheel(false, new Ammo.btVector3(-wheelHalfTrackBack, wheelAxisHeightBack, axisPositionBack), wheelRadiusBack);
      addWheel(false, new Ammo.btVector3(wheelHalfTrackBack, wheelAxisHeightBack, axisPositionBack), wheelRadiusBack);
      vehicle.uuid = uuid;
      world.addElement({
        type: TYPES.VEHICLE,
        uuid: uuid,
        vehicle: vehicle,
        wheels: wheels,
        options: data,
        state: DEFAULT_VEHICLE_STATE
      });
    };
    var setVehiclePosition = function setVehiclePosition(data) {
      var uuid = data.uuid,
          position = data.position;
      var element = world.getElement(uuid);

      if (element.type === TYPES.VEHICLE) {
        var body = element.vehicle.getRigidBody();
        var transform = new Ammo.btTransform();
        body.getWorldTransform(transform);
        transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
        body.setWorldTransform(transform);
      }
    };
    var setVehicleQuaternion = function setVehicleQuaternion(data) {
      var uuid = data.uuid,
          quaternion = data.quaternion;
      var element = world.getElement(uuid);

      if (element.type === TYPES.VEHICLE) {
        var body = element.vehicle.getRigidBody();
        var transform = new Ammo.btTransform();
        body.getWorldTransform(transform);
        transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
        body.setWorldTransform(transform);
      }
    };
    var resetVehicle = function resetVehicle(data) {
      var uuid = data.uuid,
          quaternion = data.quaternion,
          position = data.position;
      var element = world.getElement(uuid);

      if (element.type === TYPES.VEHICLE) {
        var body = element.vehicle.getRigidBody();
        var transform = new Ammo.btTransform();
        body.getWorldTransform(transform);
        transform.setIdentity();
        transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
        transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
        body.setWorldTransform(transform);
      }
    };
    var handleVehicleUpdate = function handleVehicleUpdate(_ref, dt) {
      var vehicle = _ref.vehicle,
          wheels = _ref.wheels,
          uuid = _ref.uuid,
          _ref$state = _ref.state,
          state = _ref$state === void 0 ? DEFAULT_VEHICLE_STATE : _ref$state,
          _ref$options = _ref.options,
          options = _ref$options === void 0 ? {} : _ref$options;
      var breakingForce = 0;
      var engineForce = 0;
      var _options$steeringClam = options.steeringClamp,
          steeringClamp = _options$steeringClam === void 0 ? DEFAULT_STEERING_CLAMP : _options$steeringClam,
          _options$steeringIncr = options.steeringIncrement,
          steeringIncrement = _options$steeringIncr === void 0 ? DEFAULT_STEERING_INCREMENT : _options$steeringIncr,
          _options$maxEngineFor = options.maxEngineForce,
          maxEngineForce = _options$maxEngineFor === void 0 ? DEFAULT_MAX_ENGINE_FORCE : _options$maxEngineFor,
          _options$maxBreakingF = options.maxBreakingForce,
          maxBreakingForce = _options$maxBreakingF === void 0 ? DEFAULT_MAX_BREAKING_FORCE : _options$maxBreakingF;

      if (state.acceleration) {
        if (speed < -1) breakingForce = maxBreakingForce;else engineForce = maxEngineForce;
      }

      if (state.braking) {
        if (speed > 1) breakingForce = maxBreakingForce;else engineForce = -maxEngineForce / 2;
      }

      if (state.left) {
        if (state.vehicleSteering < steeringClamp) state.vehicleSteering += steeringIncrement;
      } else {
        if (state.right) {
          if (state.vehicleSteering > -steeringClamp) state.vehicleSteering -= steeringIncrement;
        } else {
          if (state.vehicleSteering < -steeringIncrement) state.vehicleSteering += steeringIncrement;else {
            if (state.vehicleSteering > steeringIncrement) state.vehicleSteering -= steeringIncrement;else {
              state.vehicleSteering = 0;
            }
          }
        }
      }

      vehicle.applyEngineForce(engineForce, BACK_LEFT);
      vehicle.applyEngineForce(engineForce, BACK_RIGHT);
      vehicle.setBrake(breakingForce / 2, FRONT_LEFT);
      vehicle.setBrake(breakingForce / 2, FRONT_RIGHT);
      vehicle.setBrake(breakingForce, BACK_LEFT);
      vehicle.setBrake(breakingForce, BACK_RIGHT);
      vehicle.setSteeringValue(state.vehicleSteering, FRONT_LEFT);
      vehicle.setSteeringValue(state.vehicleSteering, FRONT_RIGHT);
      var tm, p, q, i;
      var n = vehicle.getNumWheels();

      for (i = 0; i < n; i++) {
        vehicle.updateWheelTransform(i, true);
        tm = vehicle.getWheelTransformWS(i);
        p = tm.getOrigin();
        q = tm.getRotation();
        var wheelUUID = wheels[i];
        dispatcher$1.sendBodyUpdate(wheelUUID, p, q, dt);
      }

      tm = vehicle.getChassisWorldTransform();
      p = tm.getOrigin();
      q = tm.getRotation();
      var direction = vehicle.getForwardVector();
      var speed = vehicle.getCurrentSpeedKmHour();
      var extraData = {
        direction: {
          x: direction.x(),
          y: direction.y(),
          z: direction.z()
        },
        speed: speed
      };
      dispatcher$1.sendBodyUpdate(uuid, p, q, dt, extraData);
      world.updateBodyState(uuid, state);
    };

    var createGhostCollider = function createGhostCollider(radius, position) {
      var ghostCollider = new Ammo.btGhostObject();
      var transform = new Ammo.btTransform();
      ghostCollider.setCollisionShape(new Ammo.btSphereShape(radius));
      ghostCollider.getWorldTransform(transform);
      transform.setIdentity();
      transform.setOrigin(position);
      transform.setRotation(new Ammo.btQuaternion(0, 0, 0, 1));
      ghostCollider.setWorldTransform(transform);
      return {
        ghostCollider: ghostCollider,
        transform: transform
      };
    };
    var forEachGhostCollision = function forEachGhostCollision(ghostCollider) {
      var forEachCallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {};
      var collisions = ghostCollider.getNumOverlappingObjects();

      for (var i = 0; i < collisions; i++) {
        var object = Ammo.castObject(ghostCollider.getOverlappingObject(i), Ammo.btRigidBody);
        var transform = new Ammo.btTransform();
        object.getWorldTransform(transform);
        forEachCallback(object, transform, i);
        Ammo.destroy(transform);
      }
    };
    var getExplosionPosition = function getExplosionPosition(uuid, position) {
      var explosionPosition = position;

      if (!explosionPosition) {
        var _world$getElement = world.getElement(uuid),
            body = _world$getElement.body;

        var motionState = body.getMotionState();
        var transform = new Ammo.btTransform();
        motionState.getWorldTransform(transform);
        explosionPosition = transform.getOrigin();
      }

      return explosionPosition;
    };
    var getExplosionImpulse = function getExplosionImpulse(position, explosionPosition, strength) {
      var distance = position.op_sub(explosionPosition);
      distance.normalize();
      var impulse = distance.op_mul(strength);
      impulse.setY(impulse.y() + strength);
      return impulse;
    };
    var createExplosion = function createExplosion(_ref) {
      var uuid = _ref.uuid,
          position = _ref.position,
          _ref$radius = _ref.radius,
          radius = _ref$radius === void 0 ? EXPLOSION_SIZES.SMALL : _ref$radius,
          _ref$strength = _ref.strength,
          strength = _ref$strength === void 0 ? EXPLOSION_STRENGTHS.MEDIUM : _ref$strength;

      try {
        var explosionPosition = getExplosionPosition(uuid, position);

        var _createGhostCollider = createGhostCollider(radius, explosionPosition),
            ghostCollider = _createGhostCollider.ghostCollider,
            transform = _createGhostCollider.transform;

        world.addCollisionObject(ghostCollider);
        forEachGhostCollision(ghostCollider, function (object, objectTransform) {
          var origin = objectTransform.getOrigin();
          object.activate(true);
          object.applyCentralImpulse(getExplosionImpulse(origin, explosionPosition, strength));
        });
        world.getDynamicsWorld().removeCollisionObject(ghostCollider);
        Ammo.destroy(ghostCollider);
        Ammo.destroy(transform);
      } catch (e) {
        console.log(e);
      }
    };

    var handleLoadEvent = function handleLoadEvent(options) {
      return function (Ammo) {
        self.Ammo = Ammo;

        onmessage = function onmessage(_ref) {
          var data = _ref.data;

          switch (data.event) {
            case PHYSICS_EVENTS.ADD.BOX:
              addBox(data);
              break;

            case PHYSICS_EVENTS.ADD.SPHERE:
              addSphere(data);
              break;

            case PHYSICS_EVENTS.ADD.VEHICLE:
              addVehicle(data);
              break;

            case PHYSICS_EVENTS.ADD.MODEL:
              addModel(data);
              break;

            case PHYSICS_EVENTS.ADD.PLAYER:
              addPlayer(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.SET.LINEAR_VELOCITY:
              setLinearVelocity(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.RESET:
              resetElement(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.SET.POSITION:
              setPosition(data);
              break;

            case PHYSICS_EVENTS.VEHICLE.SET.POSITION:
              setVehiclePosition(data);
              break;

            case PHYSICS_EVENTS.VEHICLE.SET.QUATERNION:
              setVehicleQuaternion(data);
              break;

            case PHYSICS_EVENTS.VEHICLE.RESET:
              resetVehicle(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.APPLY.IMPULSE:
              applyImpuse(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.UPDATE:
              world.updateBodyState(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.DISPOSE:
              world.disposeBody(data);
              break;

            case PHYSICS_EVENTS.EFFECTS.EXPLOSION:
              createExplosion(data);
              break;

            case PHYSICS_EVENTS.TERMINATE:
              world.terminate();
              break;
          }
        };

        world.init(options);
        dispatcher$1.sendReadyEvent();
        world.simulate();
      };
    };

    var loadAmmo = function loadAmmo(options) {
      var scriptUrl = options.host + '/' + (options.path || LIBRARY_NAME);
      importScripts(scriptUrl);
      Ammo().then(handleLoadEvent(options));
    };

    onmessage = function onmessage(_ref2) {
      var data = _ref2.data;

      switch (data.event) {
        case PHYSICS_EVENTS.LOAD.AMMO:
          loadAmmo(data);
          break;
      }
    };

})();

', null, false);
55344
+ }var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
    'use strict';

    var LIBRARY_NAME = 'ammo.js';
    var TYPES = {
      BOX: 'BOX',
      SPHERE: 'SPHERE',
      VEHICLE: 'VEHICLE',
      MESH: 'MESH',
      PLAYER: 'PLAYER'
    };
    var DEFAULT_VEHICLE_STATE = {
      vehicleSteering: 0,
      acceleration: false,
      breaking: false,
      right: false,
      left: false
    };
    var DEFAULT_RIGIDBODY_STATE = {
      velocity: {
        x: 0,
        y: 0,
        z: 0
      },
      movement: {
        forward: false,
        backwards: false,
        left: false,
        right: false
      },
      direction: {
        x: 0,
        y: 0,
        z: 0
      }
    };
    var DEFAULT_SCALE = {
      x: 1,
      y: 1,
      z: 1
    };
    var DEFAULT_LINEAR_VELOCITY = {
      x: 0,
      y: 0,
      z: 0
    };
    var DEFAULT_IMPULSE = {
      x: 0,
      y: 0,
      z: 0
    };
    var DISABLE_DEACTIVATION = 4;
    var GRAVITY = {
      x: 0,
      y: -10,
      z: 0
    };
    var FRONT_LEFT = 0;
    var FRONT_RIGHT = 1;
    var BACK_LEFT = 2;
    var BACK_RIGHT = 3;
    var DEFAULT_STEERING_INCREMENT = .04;
    var DEFAULT_STEERING_CLAMP = .5;
    var DEFAULT_MAX_ENGINE_FORCE = 2000;
    var DEFAULT_MAX_BREAKING_FORCE = 100;
    var EXPLOSION_SIZES = {
      SMALL: 4,
      MEDIUM: 6,
      LARGE: 8,
      MASSIVE: 12
    };
    var EXPLOSION_STRENGTHS = {
      VERY_WEAK: 2,
      WEAK: 4,
      MEDIUM: 8,
      LARGE: 16,
      MASSIVE: 32,
      OK_NO: 64
    };

    var PHYSICS_EVENTS = {
      DISPATCH: 'physics:dispatch',
      TERMINATE: 'physics:terminate',
      LOAD: {
        AMMO: 'physics:load:ammo'
      },
      READY: 'physics:ready',
      INIT: 'physics:init',
      UPDATE: 'physics:update',
      ADD: {
        BOX: 'physics:add:box',
        VEHICLE: 'physics:add:vehicle',
        MODEL: 'physics:add:model',
        PLAYER: 'physics:add:player',
        SPHERE: 'physics:add:sphere'
      },
      ELEMENT: {
        DISPOSE: 'physics:element:dispose',
        COLLISION: 'physics:element:collision',
        UPDATE: 'physics:element:update',
        CREATED: 'physics:element:created',
        SET: {
          POSITION: 'physics:element:set:position',
          QUATERNION: 'physics:element:set:quaternion',
          LINEAR_VELOCITY: 'physics:element:set:linear_velocity'
        },
        RESET: 'physics:element:reset',
        APPLY: {
          IMPULSE: 'physics:element:apply:impulse'
        }
      },
      VEHICLE: {
        SET: {
          POSITION: 'physics:vehicle:set:position',
          QUATERNION: 'physics:vehicle:set:quaternion'
        },
        RESET: 'physics:vehicle:reset',
        SPEED: 'physics:vehicle:speed',
        DIRECTION: 'physics:vehicle:direction'
      },
      EFFECTS: {
        EXPLOSION: 'physics:effects:explosion'
      }
    };

    function ownKeys(object, enumerableOnly) {
      var keys = Object.keys(object);

      if (Object.getOwnPropertySymbols) {
        var symbols = Object.getOwnPropertySymbols(object);
        enumerableOnly && (symbols = symbols.filter(function (sym) {
          return Object.getOwnPropertyDescriptor(object, sym).enumerable;
        })), keys.push.apply(keys, symbols);
      }

      return keys;
    }

    function _objectSpread2(target) {
      for (var i = 1; i < arguments.length; i++) {
        var source = null != arguments[i] ? arguments[i] : {};
        i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {
          _defineProperty(target, key, source[key]);
        }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {
          Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
        });
      }

      return target;
    }

    function _classCallCheck(instance, Constructor) {
      if (!(instance instanceof Constructor)) {
        throw new TypeError("Cannot call a class as a 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);
      }
    }

    function _createClass(Constructor, protoProps, staticProps) {
      if (protoProps) _defineProperties(Constructor.prototype, protoProps);
      if (staticProps) _defineProperties(Constructor, staticProps);
      Object.defineProperty(Constructor, "prototype", {
        writable: false
      });
      return Constructor;
    }

    function _defineProperty(obj, key, value) {
      if (key in obj) {
        Object.defineProperty(obj, key, {
          value: value,
          enumerable: true,
          configurable: true,
          writable: true
        });
      } else {
        obj[key] = value;
      }

      return obj;
    }

    var Dispatcher = function Dispatcher() {
      _classCallCheck(this, Dispatcher);

      _defineProperty(this, "sendPhysicsUpdate", function (dt) {
        return postMessage({
          event: PHYSICS_EVENTS.UPDATE,
          dt: dt
        });
      });

      _defineProperty(this, "sendReadyEvent", function () {
        return postMessage({
          event: PHYSICS_EVENTS.READY
        });
      });

      _defineProperty(this, "sendTerminateEvent", function () {
        return postMessage({
          event: PHYSICS_EVENTS.TERMINATE
        });
      });

      _defineProperty(this, "sendBodyUpdate", function (uuid, position, rotation, dt, extraData) {
        return postMessage(_objectSpread2(_objectSpread2({
          event: PHYSICS_EVENTS.ELEMENT.UPDATE,
          uuid: uuid,
          position: {
            x: position.x(),
            y: position.y(),
            z: position.z()
          },
          quaternion: {
            x: rotation.x(),
            y: rotation.y(),
            z: rotation.z(),
            w: rotation.w()
          }
        }, extraData), {}, {
          dt: dt
        }));
      });

      _defineProperty(this, "sendDispatchEvent", function (uuid, eventName, eventData) {
        return postMessage({
          event: PHYSICS_EVENTS.DISPATCH,
          uuid: uuid,
          eventName: eventName,
          eventData: eventData
        });
      });
    };
    var dispatcher$1 = new Dispatcher();

    var applyMatrix4ToVector3 = function applyMatrix4ToVector3(_ref) {
      var _ref$x = _ref.x,
          x = _ref$x === void 0 ? 0 : _ref$x,
          _ref$y = _ref.y,
          y = _ref$y === void 0 ? 0 : _ref$y,
          _ref$z = _ref.z,
          z = _ref$z === void 0 ? 0 : _ref$z;
      var matrix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
      var w = 1 / (matrix[3] * x + matrix[7] * y + matrix[11] * z + matrix[15]);
      return {
        x: (matrix[0] * x + matrix[4] * y + matrix[8] * z + matrix[12]) * w,
        y: (matrix[1] * x + matrix[5] * y + matrix[9] * z + matrix[13]) * w,
        z: (matrix[2] * x + matrix[6] * y + matrix[10] * z + matrix[14]) * w
      };
    };

    var createRigidBody = function createRigidBody(shape, options) {
      var uuid = options.uuid,
          position = options.position,
          quaternion = options.quaternion,
          mass = options.mass,
          friction = options.friction,
          _options$restitution = options.restitution,
          restitution = _options$restitution === void 0 ? .9 : _options$restitution,
          _options$damping = options.damping,
          damping = _options$damping === void 0 ? {
        linear: 0.2,
        angular: 0.2
      } : _options$damping;
      var transform = new Ammo.btTransform();
      transform.setIdentity();
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
      var motionState = new Ammo.btDefaultMotionState(transform);
      var localInertia = new Ammo.btVector3(0, 0, 0);
      shape.calculateLocalInertia(mass, localInertia);
      var rbInfo = new Ammo.btRigidBodyConstructionInfo(mass, motionState, shape, localInertia);
      var body = new Ammo.btRigidBody(rbInfo);

      if (mass > 0) {
        body.setFriction(friction);
        body.setRestitution(restitution);
        body.setDamping(damping.linear, damping.angular);
        body.setActivationState(DISABLE_DEACTIVATION);
      } // storing uuid for future reference


      body.uuid = uuid;
      world.addRigidBody(body);
      return body;
    };
    var addModel = function addModel(options) {
      var uuid = options.uuid,
          vertices = options.vertices,
          matrices = options.matrices,
          indexes = options.indexes,
          position = options.position,
          quaternion = options.quaternion,
          _options$mass = options.mass,
          mass = _options$mass === void 0 ? 0 : _options$mass,
          _options$friction = options.friction,
          friction = _options$friction === void 0 ? 2 : _options$friction;
      var scale = DEFAULT_SCALE;
      var bta = new Ammo.btVector3();
      var btb = new Ammo.btVector3();
      var btc = new Ammo.btVector3();
      var triMesh = new Ammo.btTriangleMesh(true, false);

      for (var i = 0; i < vertices.length; i++) {
        var components = vertices[i];
        var index = indexes[i] ? indexes[i] : null;
        var matrix = Array.from(matrices[i]);

        if (index) {
          for (var j = 0; j < index.length; j += 3) {
            var ai = index[j] * 3;
            var bi = index[j + 1] * 3;
            var ci = index[j + 2] * 3;
            var va = applyMatrix4ToVector3({
              x: components[ai],
              y: components[ai + 1],
              z: components[ai + 2]
            }, matrix);
            var vb = applyMatrix4ToVector3({
              x: components[bi],
              y: components[bi + 1],
              z: components[bi + 2]
            }, matrix);
            var vc = applyMatrix4ToVector3({
              x: components[ci],
              y: components[ci + 1],
              z: components[ci + 2]
            }, matrix);
            bta.setValue(va.x, va.y, va.z);
            btb.setValue(vb.x, vb.y, vb.z);
            btc.setValue(vc.x, vc.y, vc.z);
            triMesh.addTriangle(bta, btb, btc, false);
          }
        } else {
          for (var _j = 0; _j < components.length; _j += 9) {
            var _va = applyMatrix4ToVector3({
              x: components[_j + 0],
              y: components[_j + 1],
              z: components[_j + 2]
            }, matrix);

            var _vb = applyMatrix4ToVector3({
              x: components[_j + 3],
              y: components[_j + 4],
              z: components[_j + 5]
            }, matrix);

            var _vc = applyMatrix4ToVector3({
              x: components[_j + 6],
              y: components[_j + 7],
              z: components[_j + 8]
            }, matrix);

            bta.setValue(_va.x, _va.y, _va.z);
            btb.setValue(_vb.x, _vb.y, _vb.z);
            btc.setValue(_vc.x, _vc.y, _vc.z);
            triMesh.addTriangle(bta, btb, btc, false);
          }
        }
      }

      var localScale = new Ammo.btVector3(scale.x, scale.y, scale.z);
      triMesh.setScaling(localScale);
      Ammo.destroy(localScale);
      var collisionShape = new Ammo.btBvhTriangleMeshShape(triMesh, true, true);
      collisionShape.resources = [triMesh];
      Ammo.destroy(bta);
      Ammo.destroy(btb);
      Ammo.destroy(btc);
      var body = createRigidBody(collisionShape, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      });
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.MESH,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var addBox = function addBox(data) {
      var uuid = data.uuid,
          width = data.width,
          length = data.length,
          height = data.height,
          position = data.position,
          quaternion = data.quaternion,
          _data$mass = data.mass,
          mass = _data$mass === void 0 ? 0 : _data$mass,
          _data$friction = data.friction,
          friction = _data$friction === void 0 ? 2 : _data$friction;
      var geometry = new Ammo.btBoxShape(new Ammo.btVector3(width * 0.5, height * 0.5, length * 0.5));
      var body = createRigidBody(geometry, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      });
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.BOX,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var addSphere = function addSphere(data) {
      var uuid = data.uuid,
          radius = data.radius,
          position = data.position,
          quaternion = data.quaternion,
          _data$mass2 = data.mass,
          mass = _data$mass2 === void 0 ? 0 : _data$mass2,
          _data$friction2 = data.friction,
          friction = _data$friction2 === void 0 ? 2 : _data$friction2;
      var geometry = new Ammo.btSphereShape(radius);
      var body = createRigidBody(geometry, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      });
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.SPHERE,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var setLinearVelocity = function setLinearVelocity(data) {
      var uuid = data.uuid,
          _data$velocity = data.velocity,
          velocity = _data$velocity === void 0 ? DEFAULT_LINEAR_VELOCITY : _data$velocity;

      var _world$getElement = world.getElement(uuid),
          body = _world$getElement.body;

      var motionState = body.getMotionState();

      if (motionState) {
        var linearVelocity = new Ammo.btVector3(velocity.x, velocity.y, velocity.z);
        body.setLinearVelocity(linearVelocity);
        Ammo.destroy(linearVelocity);
      }
    };
    var setPosition = function setPosition(data) {
      var uuid = data.uuid,
          position = data.position;

      var _world$getElement2 = world.getElement(uuid),
          body = _world$getElement2.body;

      var transform = new Ammo.btTransform();
      body.getWorldTransform(transform);
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      body.setWorldTransform(transform);
    };
    var resetElement = function resetElement(data) {
      var uuid = data.uuid,
          position = data.position,
          quaternion = data.quaternion;

      var _world$getElement3 = world.getElement(uuid),
          body = _world$getElement3.body;

      var transform = new Ammo.btTransform();
      body.getWorldTransform(transform);
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
      body.setWorldTransform(transform);
    };
    var applyImpuse = function applyImpuse(_ref) {
      var uuid = _ref.uuid,
          _ref$impulse = _ref.impulse,
          impulse = _ref$impulse === void 0 ? DEFAULT_IMPULSE : _ref$impulse;

      var _world$getElement4 = world.getElement(uuid),
          body = _world$getElement4.body;

      var motionState = body.getMotionState();

      if (motionState) {
        var impulseVector = new Ammo.btVector3(impulse.x, impulse.y, impulse.z);
        body.applyCentralImpulse(impulseVector);
        Ammo.destroy(impulseVector);
      }
    };
    var handleElementUpdate = function handleElementUpdate(_ref2, dt) {
      var body = _ref2.body,
          uuid = _ref2.uuid;
          _ref2.state;
      var motionState = body.getMotionState();

      if (motionState) {
        var transform = new Ammo.btTransform();
        motionState.getWorldTransform(transform);
        var origin = transform.getOrigin();
        var rotation = transform.getRotation();
        dispatcher$1.sendBodyUpdate(uuid, origin, rotation, dt);
        Ammo.destroy(transform);
      }
    };

    var addPlayer = function addPlayer(data) {
      var uuid = data.uuid,
          width = data.width,
          height = data.height,
          position = data.position,
          quaternion = data.quaternion,
          mass = data.mass,
          friction = data.friction;
      var capsule = new Ammo.btCapsuleShape(width, height);
      var body = createRigidBody(capsule, {
        uuid: uuid,
        position: position,
        quaternion: quaternion,
        mass: mass,
        friction: friction
      }); // disabliing rotation for collisions

      body.setAngularFactor(0);
      world.addRigidBody(body);
      world.addElement({
        uuid: uuid,
        body: body,
        type: TYPES.PLAYER,
        state: DEFAULT_RIGIDBODY_STATE
      });
    };
    var handlePlayerUpdate = function handlePlayerUpdate(_ref, dt) {
      var body = _ref.body,
          uuid = _ref.uuid,
          _ref$state = _ref.state,
          state = _ref$state === void 0 ? DEFAULT_RIGIDBODY_STATE : _ref$state;
      var movement = state.movement;
          state.direction;
          var cameraDirection = state.cameraDirection;
          state.quaternion;
          state.position;
      var MAX_SPEED = 1;
      var walkVelocity = .1;
      var motionState = body.getMotionState();

      if (motionState) {
        var transform = new Ammo.btTransform();
        motionState.getWorldTransform(transform);
        var linearVelocity = body.getLinearVelocity();
        var speed = linearVelocity.length();
        var forwardDir = transform.getBasis().getRow(2);
        forwardDir.normalize();
        var walkDirection = new Ammo.btVector3(0.0, 0.0, 0.0);
        var walkSpeed = walkVelocity * dt;

        if (movement.forward) {
          walkDirection.setX(walkDirection.x() + forwardDir.x()); //walkDirection.setY( walkDirection.y() + forwardDir.y());

          walkDirection.setZ(walkDirection.z() + forwardDir.z());
        }

        if (movement.backwards) {
          walkDirection.setX(walkDirection.x() - forwardDir.x()); //walkDirection.setY( walkDirection.y() - forwardDir.y());

          walkDirection.setZ(walkDirection.z() - forwardDir.z());
        }

        if (!movement.forward && !movement.backwards) {
          linearVelocity.setX(linearVelocity.x() * 0.2);
          linearVelocity.setZ(linearVelocity.z() * 0.2);
        } else if (speed < MAX_SPEED) {
          linearVelocity.setX(linearVelocity.x() + cameraDirection.x * walkSpeed);
          linearVelocity.setZ(linearVelocity.z() + cameraDirection.z * walkSpeed);
        }

        body.setLinearVelocity(linearVelocity);
        body.getMotionState().setWorldTransform(transform);
        body.setCenterOfMassTransform(transform);
        var origin = transform.getOrigin();
        var rotation = transform.getRotation();
        dispatcher.sendBodyUpdate(uuid, origin, rotation, dt);
      }
    };

    var requestNextFrame = self.requestAnimationFrame || self.webkitRequestAnimationFrame || self.mozRequestAnimationFrame || self.oRequestAnimationFrame || self.msRequestAnimationFrame || function (callback, element) {
      self.setTimeout(callback, 1000 / 120);
    };

    var Clock = /*#__PURE__*/function () {
      function Clock() {
        _classCallCheck(this, Clock);

        this.timestamp = null;
      }

      _createClass(Clock, [{
        key: "getDelta",
        value: function getDelta() {
          var time = Date.now();

          if (this.timestamp) {
            var delta = time - this.timestamp;
            this.timestamp = time;
            return delta;
          } else {
            this.timestamp = time;
            return 0;
          }
        }
      }]);

      return Clock;
    }();

    var World = /*#__PURE__*/function () {
      function World() {
        var _this = this;

        _classCallCheck(this, World);

        _defineProperty(this, "init", function (options) {
          var _options$gravity = options.gravity,
              gravity = _options$gravity === void 0 ? GRAVITY : _options$gravity;
          _this.collisionConfiguration = new Ammo.btDefaultCollisionConfiguration();
          _this.dispatcher = new Ammo.btCollisionDispatcher(_this.collisionConfiguration);
          _this.broadphase = new Ammo.btDbvtBroadphase();
          _this.solver = new Ammo.btSequentialImpulseConstraintSolver();
          _this.dynamicsWorld = new Ammo.btDiscreteDynamicsWorld(_this.dispatcher, _this.broadphase, _this.solver, _this.collisionConfiguration);

          _this.dynamicsWorld.setGravity(new Ammo.btVector3(gravity.x, gravity.y, gravity.z)); // this is needed for ghostObject collisions


          _this.dynamicsWorld.getBroadphase().getOverlappingPairCache().setInternalGhostPairCallback(new Ammo.btGhostPairCallback());

          _this.initialised = true;
        });

        _defineProperty(this, "removeElement", function (uuid) {
          if (_this.hasElement(uuid)) {
            _this.elements[uuid].deleted = true;
          }
        });

        _defineProperty(this, "removeDeletedElements", function () {
          return Object.keys(_this.elements).filter(function (uuid) {
            return _this.elements[uuid].deleted;
          }).forEach(function (uuid) {
            delete _this.elements[uuid];
          });
        });

        _defineProperty(this, "hasElement", function (uuid) {
          return Object.keys(_this.elements).includes(uuid);
        });

        _defineProperty(this, "getElement", function (uuid) {
          return _this.elements[uuid];
        });

        _defineProperty(this, "isInitialised", function () {
          return _this.initialised;
        });

        _defineProperty(this, "getDynamicsWorld", function () {
          return _this.dynamicsWorld;
        });

        _defineProperty(this, "addRigidBody", function (body) {
          _this.dynamicsWorld.addRigidBody(body);
        });

        _defineProperty(this, "addAction", function (action) {
          _this.dynamicsWorld.addAction(action);
        });

        _defineProperty(this, "addCollisionObject", function (collisionObject) {
          _this.dynamicsWorld.addCollisionObject(collisionObject);
        });

        _defineProperty(this, "stepSimulation", function (dt) {
          _this.dynamicsWorld.stepSimulation(dt);
        });

        _defineProperty(this, "simulate", function () {
          var dt = _this.clock.getDelta();

          _this.stepSimulation(dt);

          Object.keys(_this.elements).forEach(function (uuid) {
            var element = _this.getElement(uuid);

            if (element) {
              switch (element.type) {
                case TYPES.BOX:
                case TYPES.SPHERE:
                case TYPES.MESH:
                  handleElementUpdate(element, dt);
                  break;

                case TYPES.PLAYER:
                  handlePlayerUpdate(element, dt);
                  break;

                case TYPES.VEHICLE:
                  handleVehicleUpdate(element, dt);
                  break;
              }
            }
          });

          _this.calculateCollisions();

          _this.removeDeletedElements();

          dispatcher$1.sendPhysicsUpdate(dt);
          _this.requestAnimationFrameId = requestNextFrame(_this.simulate.bind(_this));
        });

        _defineProperty(this, "calculateCollisions", function () {
          var ammoDispatcher = _this.dynamicsWorld.getDispatcher();

          var numManifolds = ammoDispatcher.getNumManifolds();

          for (var i = 0; i < numManifolds; i++) {
            var contactManifold = ammoDispatcher.getManifoldByIndexInternal(i);
            var rb0 = Ammo.castObject(contactManifold.getBody0(), Ammo.btRigidBody);
            var rb1 = Ammo.castObject(contactManifold.getBody1(), Ammo.btRigidBody);
            var numContacts = contactManifold.getNumContacts(); // this iteration doesn't have uuids

            if (!rb0.uuid || !rb1.uuid) continue;
            var contacts = [];

            for (var j = 0; j < numContacts; j++) {
              var contactPoint = contactManifold.getContactPoint(j);
              var distance = contactPoint.getDistance();
              if (distance > 0.0) continue;
              var velocity0 = rb0.getLinearVelocity();
              var velocity1 = rb1.getLinearVelocity();
              var worldPos0 = contactPoint.get_m_positionWorldOnA();
              var worldPos1 = contactPoint.get_m_positionWorldOnB();
              var localPos0 = contactPoint.get_m_localPointA();
              var localPos1 = contactPoint.get_m_localPointB();
              contacts.push({
                distance: distance,
                elements: [{
                  uuid: rb0.uuid,
                  velocity: {
                    x: velocity0.x(),
                    y: velocity0.y(),
                    z: velocity0.z()
                  },
                  worldPos: {
                    x: worldPos0.x(),
                    y: worldPos0.y(),
                    z: worldPos0.z()
                  },
                  localPos: {
                    x: localPos0.x(),
                    y: localPos0.y(),
                    z: localPos0.z()
                  }
                }, {
                  uuid: rb1.uuid,
                  velocity: {
                    x: velocity1.x(),
                    y: velocity1.y(),
                    z: velocity1.z()
                  },
                  worldPos: {
                    x: worldPos1.x(),
                    y: worldPos1.y(),
                    z: worldPos1.z()
                  },
                  localPos: {
                    x: localPos1.x(),
                    y: localPos1.y(),
                    z: localPos1.z()
                  }
                }]
              });
            }

            dispatcher$1.sendDispatchEvent(rb0.uuid, PHYSICS_EVENTS.ELEMENT.COLLISION, {
              contacts: contacts
            });
            dispatcher$1.sendDispatchEvent(rb1.uuid, PHYSICS_EVENTS.ELEMENT.COLLISION, {
              contacts: contacts
            });
          }
        });

        _defineProperty(this, "addElement", function (data) {
          _this.elements[data.uuid] = data;
        });

        _defineProperty(this, "updateBodyState", function (_ref) {
          var uuid = _ref.uuid,
              state = _ref.state;

          if (_this.hasElement(uuid)) {
            _this.elements[uuid].state = _objectSpread2(_objectSpread2({}, _this.elements[uuid].state), state);
          }
        });

        _defineProperty(this, "terminate", function () {
          Ammo.destroy(_this.dynamicsWorld);
          Ammo.destroy(_this.solver);
          Ammo.destroy(_this.dispatcher);
          Ammo.destroy(_this.collisionConfiguration);
          cancelAnimationFrame(_this.requestAnimationFrameId);
          dispatcher$1.sendTerminateEvent();
        });

        this.elements = {};
        this.initialised = false;
        this.collisionConfiguration = undefined;
        this.dispatcher = undefined;
        this.broadphase = undefined;
        this.solver = undefined;
        this.dynamicsWorld = undefined;
        this.requestAnimationFrameId = null;
        this.clock = new Clock();
      }

      _createClass(World, [{
        key: "disposeBody",
        value: function disposeBody(_ref2) {
          var uuid = _ref2.uuid;
          var element = this.getElement(uuid);
          this.dynamicsWorld.removeRigidBody(element.body);
          this.removeElement(uuid);
          dispatcher$1.sendElementDisposed({
            uuid: uuid
          });
        }
      }]);

      return World;
    }();
    var world = new World();

    var DEFAULT_ROLL_INFLUENCE = 0.2;
    var DEFAULT_FRICTION = 1000;
    var DEFAULT_MASS = 800;
    var addVehicle = function addVehicle(data) {
      var position = data.position,
          quaternion = data.quaternion,
          uuid = data.uuid,
          wheels = data.wheels,
          _data$mass = data.mass,
          mass = _data$mass === void 0 ? DEFAULT_MASS : _data$mass,
          _data$width = data.width,
          width = _data$width === void 0 ? 1.8 : _data$width,
          _data$height = data.height,
          height = _data$height === void 0 ? .6 : _data$height,
          _data$length = data.length,
          length = _data$length === void 0 ? 4 : _data$length,
          _data$friction = data.friction,
          friction = _data$friction === void 0 ? DEFAULT_FRICTION : _data$friction,
          _data$rollInfluence = data.rollInfluence,
          rollInfluence = _data$rollInfluence === void 0 ? DEFAULT_ROLL_INFLUENCE : _data$rollInfluence,
          _data$wheelsOptions = data.wheelsOptions,
          wheelsOptions = _data$wheelsOptions === void 0 ? {} : _data$wheelsOptions,
          _data$suspensions = data.suspensions,
          suspensions = _data$suspensions === void 0 ? {} : _data$suspensions;
      var _wheelsOptions$back = wheelsOptions.back,
          back = _wheelsOptions$back === void 0 ? {} : _wheelsOptions$back,
          _wheelsOptions$front = wheelsOptions.front,
          front = _wheelsOptions$front === void 0 ? {} : _wheelsOptions$front;
      var _back$axisPosition = back.axisPosition,
          axisPositionBack = _back$axisPosition === void 0 ? -1 : _back$axisPosition,
          _back$radius = back.radius,
          wheelRadiusBack = _back$radius === void 0 ? .4 : _back$radius,
          _back$halfTrack = back.halfTrack,
          wheelHalfTrackBack = _back$halfTrack === void 0 ? 1 : _back$halfTrack,
          _back$axisHeight = back.axisHeight,
          wheelAxisHeightBack = _back$axisHeight === void 0 ? .3 : _back$axisHeight;
      var _front$axisPosition = front.axisPosition,
          axisPositionFront = _front$axisPosition === void 0 ? 1.7 : _front$axisPosition,
          _front$radius = front.radius,
          wheelRadiusFront = _front$radius === void 0 ? .4 : _front$radius,
          _front$halfTrack = front.halfTrack,
          wheelHalfTrackFront = _front$halfTrack === void 0 ? 1 : _front$halfTrack,
          _front$axisHeight = front.axisHeight,
          wheelAxisHeightFront = _front$axisHeight === void 0 ? .3 : _front$axisHeight;
      var _suspensions$stiffnes = suspensions.stiffness,
          stiffness = _suspensions$stiffnes === void 0 ? 20.0 : _suspensions$stiffnes,
          _suspensions$damping = suspensions.damping,
          damping = _suspensions$damping === void 0 ? 2.3 : _suspensions$damping,
          _suspensions$compress = suspensions.compression,
          compression = _suspensions$compress === void 0 ? 4.4 : _suspensions$compress,
          _suspensions$restLeng = suspensions.restLength,
          restLength = _suspensions$restLeng === void 0 ? 0.6 : _suspensions$restLeng; // Chassis

      var geometry = new Ammo.btBoxShape(new Ammo.btVector3(width * .5, height * .5, length * .5));
      var transform = new Ammo.btTransform();
      transform.setIdentity();
      transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
      transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
      var motionState = new Ammo.btDefaultMotionState(transform);
      var localInertia = new Ammo.btVector3(0, 0, 0);
      geometry.calculateLocalInertia(mass, localInertia);
      var chassis = new Ammo.btRigidBody(new Ammo.btRigidBodyConstructionInfo(mass, motionState, geometry, localInertia));
      chassis.setActivationState(DISABLE_DEACTIVATION);
      world.addRigidBody(chassis); // Raycast Vehicle

      var tuning = new Ammo.btVehicleTuning();
      var rayCaster = new Ammo.btDefaultVehicleRaycaster(world.getDynamicsWorld());
      var vehicle = new Ammo.btRaycastVehicle(tuning, chassis, rayCaster);
      vehicle.setCoordinateSystem(0, 1, 2);
      world.addAction(vehicle);
      var wheelDirectionCS0 = new Ammo.btVector3(0, -1, 0);
      var wheelAxleCS = new Ammo.btVector3(-1, 0, 0);

      var addWheel = function addWheel(isFront, pos, radius) {
        var wheelInfo = vehicle.addWheel(pos, wheelDirectionCS0, wheelAxleCS, restLength, radius, tuning, isFront);
        wheelInfo.set_m_suspensionStiffness(stiffness);
        wheelInfo.set_m_wheelsDampingRelaxation(damping);
        wheelInfo.set_m_wheelsDampingCompression(compression);
        wheelInfo.set_m_frictionSlip(friction);
        wheelInfo.set_m_rollInfluence(rollInfluence);
      };

      addWheel(true, new Ammo.btVector3(wheelHalfTrackFront, wheelAxisHeightFront, axisPositionFront), wheelRadiusFront);
      addWheel(true, new Ammo.btVector3(-wheelHalfTrackFront, wheelAxisHeightFront, axisPositionFront), wheelRadiusFront);
      addWheel(false, new Ammo.btVector3(-wheelHalfTrackBack, wheelAxisHeightBack, axisPositionBack), wheelRadiusBack);
      addWheel(false, new Ammo.btVector3(wheelHalfTrackBack, wheelAxisHeightBack, axisPositionBack), wheelRadiusBack);
      vehicle.uuid = uuid;
      world.addElement({
        type: TYPES.VEHICLE,
        uuid: uuid,
        vehicle: vehicle,
        wheels: wheels,
        options: data,
        state: DEFAULT_VEHICLE_STATE
      });
    };
    var setVehiclePosition = function setVehiclePosition(data) {
      var uuid = data.uuid,
          position = data.position;
      var element = world.getElement(uuid);

      if (element.type === TYPES.VEHICLE) {
        var body = element.vehicle.getRigidBody();
        var transform = new Ammo.btTransform();
        body.getWorldTransform(transform);
        transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
        body.setWorldTransform(transform);
      }
    };
    var setVehicleQuaternion = function setVehicleQuaternion(data) {
      var uuid = data.uuid,
          quaternion = data.quaternion;
      var element = world.getElement(uuid);

      if (element.type === TYPES.VEHICLE) {
        var body = element.vehicle.getRigidBody();
        var transform = new Ammo.btTransform();
        body.getWorldTransform(transform);
        transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
        body.setWorldTransform(transform);
      }
    };
    var resetVehicle = function resetVehicle(data) {
      var uuid = data.uuid,
          quaternion = data.quaternion,
          position = data.position;
      var element = world.getElement(uuid);

      if (element.type === TYPES.VEHICLE) {
        var body = element.vehicle.getRigidBody();
        var transform = new Ammo.btTransform();
        body.getWorldTransform(transform);
        transform.setIdentity();
        transform.setOrigin(new Ammo.btVector3(position.x, position.y, position.z));
        transform.setRotation(new Ammo.btQuaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w));
        body.setWorldTransform(transform);
      }
    };
    var handleVehicleUpdate = function handleVehicleUpdate(_ref, dt) {
      var vehicle = _ref.vehicle,
          wheels = _ref.wheels,
          uuid = _ref.uuid,
          _ref$state = _ref.state,
          state = _ref$state === void 0 ? DEFAULT_VEHICLE_STATE : _ref$state,
          _ref$options = _ref.options,
          options = _ref$options === void 0 ? {} : _ref$options;
      var breakingForce = 0;
      var engineForce = 0;
      var _options$steeringClam = options.steeringClamp,
          steeringClamp = _options$steeringClam === void 0 ? DEFAULT_STEERING_CLAMP : _options$steeringClam,
          _options$steeringIncr = options.steeringIncrement,
          steeringIncrement = _options$steeringIncr === void 0 ? DEFAULT_STEERING_INCREMENT : _options$steeringIncr,
          _options$maxEngineFor = options.maxEngineForce,
          maxEngineForce = _options$maxEngineFor === void 0 ? DEFAULT_MAX_ENGINE_FORCE : _options$maxEngineFor,
          _options$maxBreakingF = options.maxBreakingForce,
          maxBreakingForce = _options$maxBreakingF === void 0 ? DEFAULT_MAX_BREAKING_FORCE : _options$maxBreakingF;

      if (state.acceleration) {
        if (speed < -1) breakingForce = maxBreakingForce;else engineForce = maxEngineForce;
      }

      if (state.braking) {
        if (speed > 1) breakingForce = maxBreakingForce;else engineForce = -maxEngineForce / 2;
      }

      if (state.left) {
        if (state.vehicleSteering < steeringClamp) state.vehicleSteering += steeringIncrement;
      } else {
        if (state.right) {
          if (state.vehicleSteering > -steeringClamp) state.vehicleSteering -= steeringIncrement;
        } else {
          if (state.vehicleSteering < -steeringIncrement) state.vehicleSteering += steeringIncrement;else {
            if (state.vehicleSteering > steeringIncrement) state.vehicleSteering -= steeringIncrement;else {
              state.vehicleSteering = 0;
            }
          }
        }
      }

      vehicle.applyEngineForce(engineForce, BACK_LEFT);
      vehicle.applyEngineForce(engineForce, BACK_RIGHT);
      vehicle.setBrake(breakingForce / 2, FRONT_LEFT);
      vehicle.setBrake(breakingForce / 2, FRONT_RIGHT);
      vehicle.setBrake(breakingForce, BACK_LEFT);
      vehicle.setBrake(breakingForce, BACK_RIGHT);
      vehicle.setSteeringValue(state.vehicleSteering, FRONT_LEFT);
      vehicle.setSteeringValue(state.vehicleSteering, FRONT_RIGHT);
      var tm, p, q, i;
      var n = vehicle.getNumWheels();

      for (i = 0; i < n; i++) {
        vehicle.updateWheelTransform(i, true);
        tm = vehicle.getWheelTransformWS(i);
        p = tm.getOrigin();
        q = tm.getRotation();
        var wheelUUID = wheels[i];
        dispatcher$1.sendBodyUpdate(wheelUUID, p, q, dt);
      }

      tm = vehicle.getChassisWorldTransform();
      p = tm.getOrigin();
      q = tm.getRotation();
      var direction = vehicle.getForwardVector();
      var speed = vehicle.getCurrentSpeedKmHour();
      var extraData = {
        direction: {
          x: direction.x(),
          y: direction.y(),
          z: direction.z()
        },
        speed: speed
      };
      dispatcher$1.sendBodyUpdate(uuid, p, q, dt, extraData);
      world.updateBodyState(uuid, state);
    };

    var createGhostCollider = function createGhostCollider(radius, position) {
      var ghostCollider = new Ammo.btGhostObject();
      var transform = new Ammo.btTransform();
      ghostCollider.setCollisionShape(new Ammo.btSphereShape(radius));
      ghostCollider.getWorldTransform(transform);
      transform.setIdentity();
      transform.setOrigin(position);
      transform.setRotation(new Ammo.btQuaternion(0, 0, 0, 1));
      ghostCollider.setWorldTransform(transform);
      return {
        ghostCollider: ghostCollider,
        transform: transform
      };
    };
    var forEachGhostCollision = function forEachGhostCollision(ghostCollider) {
      var forEachCallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {};
      var collisions = ghostCollider.getNumOverlappingObjects();

      for (var i = 0; i < collisions; i++) {
        var object = Ammo.castObject(ghostCollider.getOverlappingObject(i), Ammo.btRigidBody);
        var transform = new Ammo.btTransform();
        object.getWorldTransform(transform);
        forEachCallback(object, transform, i);
        Ammo.destroy(transform);
      }
    };
    var getExplosionPosition = function getExplosionPosition(uuid, position) {
      var explosionPosition = position;

      if (!explosionPosition) {
        var _world$getElement = world.getElement(uuid),
            body = _world$getElement.body;

        var motionState = body.getMotionState();
        var transform = new Ammo.btTransform();
        motionState.getWorldTransform(transform);
        explosionPosition = transform.getOrigin();
      }

      return explosionPosition;
    };
    var getExplosionImpulse = function getExplosionImpulse(position, explosionPosition, strength) {
      var distance = position.op_sub(explosionPosition);
      distance.normalize();
      var impulse = distance.op_mul(strength);
      impulse.setY(impulse.y() + strength);
      return impulse;
    };
    var createExplosion = function createExplosion(_ref) {
      var uuid = _ref.uuid,
          position = _ref.position,
          _ref$radius = _ref.radius,
          radius = _ref$radius === void 0 ? EXPLOSION_SIZES.SMALL : _ref$radius,
          _ref$strength = _ref.strength,
          strength = _ref$strength === void 0 ? EXPLOSION_STRENGTHS.MEDIUM : _ref$strength;

      try {
        var explosionPosition = getExplosionPosition(uuid, position);

        var _createGhostCollider = createGhostCollider(radius, explosionPosition),
            ghostCollider = _createGhostCollider.ghostCollider,
            transform = _createGhostCollider.transform;

        world.addCollisionObject(ghostCollider);
        forEachGhostCollision(ghostCollider, function (object, objectTransform) {
          var origin = objectTransform.getOrigin();
          object.activate(true);
          object.applyCentralImpulse(getExplosionImpulse(origin, explosionPosition, strength));
        });
        world.getDynamicsWorld().removeCollisionObject(ghostCollider);
        Ammo.destroy(ghostCollider);
        Ammo.destroy(transform);
      } catch (e) {
        console.log(e);
      }
    };

    var handleLoadEvent = function handleLoadEvent(options) {
      return function (Ammo) {
        self.Ammo = Ammo;

        onmessage = function onmessage(_ref) {
          var data = _ref.data;

          switch (data.event) {
            case PHYSICS_EVENTS.ADD.BOX:
              addBox(data);
              break;

            case PHYSICS_EVENTS.ADD.SPHERE:
              addSphere(data);
              break;

            case PHYSICS_EVENTS.ADD.VEHICLE:
              addVehicle(data);
              break;

            case PHYSICS_EVENTS.ADD.MODEL:
              addModel(data);
              break;

            case PHYSICS_EVENTS.ADD.PLAYER:
              addPlayer(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.SET.LINEAR_VELOCITY:
              setLinearVelocity(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.RESET:
              resetElement(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.SET.POSITION:
              setPosition(data);
              break;

            case PHYSICS_EVENTS.VEHICLE.SET.POSITION:
              setVehiclePosition(data);
              break;

            case PHYSICS_EVENTS.VEHICLE.SET.QUATERNION:
              setVehicleQuaternion(data);
              break;

            case PHYSICS_EVENTS.VEHICLE.RESET:
              resetVehicle(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.APPLY.IMPULSE:
              applyImpuse(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.UPDATE:
              world.updateBodyState(data);
              break;

            case PHYSICS_EVENTS.ELEMENT.DISPOSE:
              world.disposeBody(data);
              break;

            case PHYSICS_EVENTS.EFFECTS.EXPLOSION:
              createExplosion(data);
              break;

            case PHYSICS_EVENTS.TERMINATE:
              world.terminate();
              break;
          }
        };

        world.init(options);
        dispatcher$1.sendReadyEvent();
        world.simulate();
      };
    };

    var loadAmmo = function loadAmmo(options) {
      var scriptUrl = options.host + '/' + (options.path || LIBRARY_NAME);
      importScripts(scriptUrl);
      Ammo().then(handleLoadEvent(options));
    };

    onmessage = function onmessage(_ref2) {
      var data = _ref2.data;

      switch (data.event) {
        case PHYSICS_EVENTS.LOAD.AMMO:
          loadAmmo(data);
          break;
      }
    };

})();

', null, false);
55360
55345
  /* eslint-enable */var PHYSICS_EVENTS = {
55361
55346
  DISPATCH: 'physics:dispatch',
55362
55347
  TERMINATE: 'physics:terminate',
@@ -57751,7 +57736,7 @@ function applyMiddleware() {
57751
57736
 
57752
57737
  var thunk = createThunkMiddleware();
57753
57738
  thunk.withExtraArgument = createThunkMiddleware;var name = "mage-engine";
57754
- var version$1 = "3.21.1";
57739
+ var version$1 = "3.22.0";
57755
57740
  var description = "A WebGL Javascript Game Engine, built on top of THREE.js and many other libraries.";
57756
57741
  var main = "dist/mage.js";
57757
57742
  var author$1 = {
@@ -59984,7 +59969,28 @@ var prepareModel = function prepareModel(model) {
59984
59969
  setUpLightsAndShadows(mesh);
59985
59970
  });
59986
59971
  return model;
59987
- };var LOOPING = {
59972
+ };var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
59973
+
59974
+ function getAugmentedNamespace(n) {
59975
+ if (n.__esModule) return n;
59976
+ var a = Object.defineProperty({}, '__esModule', {value: true});
59977
+ Object.keys(n).forEach(function (k) {
59978
+ var d = Object.getOwnPropertyDescriptor(n, k);
59979
+ Object.defineProperty(a, k, d.get ? d : {
59980
+ enumerable: true,
59981
+ get: function () {
59982
+ return n[k];
59983
+ }
59984
+ });
59985
+ });
59986
+ return a;
59987
+ }var between$1 = {exports: {}};/* Between.js v0.1.2-fix.2 */
59988
+
59989
+ (function (module, exports) {
59990
+ !function(t,n){module.exports=n();}(commonjsGlobal,function(){function O(t){return (O="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function r(t,n){for(var e=0;e<n.length;e++){var r=n[e];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,r.key,r);}}function n(t,n,e){return n&&r(t.prototype,n),e&&r(t,e),t}function M(t,n,e){return n in t?Object.defineProperty(t,n,{value:e,enumerable:!0,configurable:!0,writable:!0}):t[n]=e,t}function I(t){return (I=Object.getPrototypeOf||function(t){return t.__proto__})(t)}function o(t,n){return (o=Object.setPrototypeOf||function(t,n){return t.__proto__=n,t})(t,n)}function u(t,n,e){return (u="undefined"!=typeof Reflect&&Reflect.construct?Reflect.construct:function(t,n,e){var r=[null];r.push.apply(r,n);var u=new(t.bind.apply(t,r));return e&&o(u,e.prototype),u}).apply(null,arguments)}function _(t){if(void 0===t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return t}var t=function(o){var a={},i=[];(o=o||this).on=function(t,n,e){return (a[t]=a[t]||[]).push([n,e]),o},o.off=function(t,n){t||(a={});for(var e=a[t]||i,r=e.length=n?e.length:0;r--;)n==e[r][0]&&e.splice(r,1);return o},o.emit=function(t){for(var n,e=a[t]||i,r=0<e.length?e.slice(0,e.length):e,u=0;n=r[u++];)n[0].apply(n[1],i.slice.call(arguments,1));return o};};var V=function(t,n,e){return t*(1-e)+n*e},e="undefined"!=typeof window?window:"undefined"!=typeof commonjsGlobal?commonjsGlobal:"undefined"!=typeof self?self:{};function a(t,n){return t(n={exports:{}},n.exports),n.exports}for(var i=a(function(t){var n=t.exports={Linear:{None:function(t){return t}},Quadratic:{In:function(t){return t*t},Out:function(t){return t*(2-t)},InOut:function(t){return (t*=2)<1?.5*t*t:-.5*(--t*(t-2)-1)}},Cubic:{In:function(t){return t*t*t},Out:function(t){return --t*t*t+1},InOut:function(t){return (t*=2)<1?.5*t*t*t:.5*((t-=2)*t*t+2)}},Quartic:{In:function(t){return t*t*t*t},Out:function(t){return 1- --t*t*t*t},InOut:function(t){return (t*=2)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)}},Quintic:{In:function(t){return t*t*t*t*t},Out:function(t){return --t*t*t*t*t+1},InOut:function(t){return (t*=2)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)}},Sinusoidal:{In:function(t){return 1-Math.cos(t*Math.PI/2)},Out:function(t){return Math.sin(t*Math.PI/2)},InOut:function(t){return .5*(1-Math.cos(Math.PI*t))}},Exponential:{In:function(t){return 0===t?0:Math.pow(1024,t-1)},Out:function(t){return 1===t?1:1-Math.pow(2,-10*t)},InOut:function(t){return 0===t?0:1===t?1:(t*=2)<1?.5*Math.pow(1024,t-1):.5*(2-Math.pow(2,-10*(t-1)))}},Circular:{In:function(t){return 1-Math.sqrt(1-t*t)},Out:function(t){return Math.sqrt(1- --t*t)},InOut:function(t){return (t*=2)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)}},Elastic:{In:function(t){var n,e=.1;return 0===t?0:1===t?1:(!e||e<1?(e=1,n=.1):n=.4*Math.asin(1/e)/(2*Math.PI),-e*Math.pow(2,10*(t-=1))*Math.sin((t-n)*(2*Math.PI)/.4))},Out:function(t){var n,e=.1;return 0===t?0:1===t?1:(!e||e<1?(e=1,n=.1):n=.4*Math.asin(1/e)/(2*Math.PI),e*Math.pow(2,-10*t)*Math.sin((t-n)*(2*Math.PI)/.4)+1)},InOut:function(t){var n,e=.1;return 0===t?0:1===t?1:(!e||e<1?(e=1,n=.1):n=.4*Math.asin(1/e)/(2*Math.PI),(t*=2)<1?e*Math.pow(2,10*(t-=1))*Math.sin((t-n)*(2*Math.PI)/.4)*-.5:e*Math.pow(2,-10*(t-=1))*Math.sin((t-n)*(2*Math.PI)/.4)*.5+1)}},Back:{In:function(t){return t*t*(2.70158*t-1.70158)},Out:function(t){return --t*t*(2.70158*t+1.70158)+1},InOut:function(t){var n=2.5949095;return (t*=2)<1?t*t*((n+1)*t-n)*.5:.5*((t-=2)*t*((n+1)*t+n)+2)}},Bounce:{In:function(t){return 1-n.Bounce.Out(1-t)},Out:function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375},InOut:function(t){return t<.5?.5*n.Bounce.In(2*t):.5*n.Bounce.Out(2*t-1)+.5}}};}),c=(i.Linear,i.Quadratic,i.Cubic,i.Quartic,i.Quintic,i.Sinusoidal,i.Exponential,i.Circular,i.Elastic,i.Back,i.Bounce,a(function(a){(function(){var t,n,e,r,u,o;"undefined"!=typeof performance&&null!==performance&&performance.now?a.exports=function(){return performance.now()}:"undefined"!=typeof process&&null!==process&&process.hrtime?(a.exports=function(){return (t()-u)/1e6},n=process.hrtime,r=(t=function(){var t;return 1e9*(t=n())[0]+t[1]})(),o=1e9*process.uptime(),u=r-o):Date.now?(a.exports=function(){return Date.now()-e},e=Date.now()):(a.exports=function(){return (new Date).getTime()-e},e=(new Date).getTime());}).call(e);})),l="undefined"==typeof window?e:window,f=["moz","webkit"],s="AnimationFrame",p=l["request"+s],h=l["cancel"+s]||l["cancelRequest"+s],m=0;!p&&m<f.length;m++)p=l[f[m]+"Request"+s],h=l[f[m]+"Cancel"+s]||l[f[m]+"CancelRequest"+s];if(!p||!h){var d=0,y=0,v=[];p=function(t){if(0===v.length){var n=c(),e=Math.max(0,1e3/60-(n-d));d=e+n,setTimeout(function(){for(var t=v.slice(0),n=v.length=0;n<t.length;n++)if(!t[n].cancelled)try{t[n].callback(d);}catch(t){setTimeout(function(){throw t},0);}},Math.round(e));}return v.push({handle:++y,callback:t,cancelled:!1}),y},h=function(t){for(var n=0;n<v.length;n++)v[n].handle===t&&(v[n].cancelled=!0);};}var b=function(t){return p.call(l,t)};b.cancel=function(){h.apply(l,arguments);},b.polyfill=function(t){t||(t=l),t.requestAnimationFrame=p,t.cancelAnimationFrame=h;};var w,k,P=[],T=Symbol("type"),j=Symbol("start_time"),x=Symbol("completed"),D=Symbol("paused"),g=requestAnimationFrame||b,A=Date.now();!function t(){g(t),w=Date.now(),k=w-A;for(var n=0;n<P.length;n++)P[n][x]||P[n](k,Date.now()-P[n][j]);A=w;}();var E=function(t){function g(e,t){var n,r,u,o;!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,g),u=this,o=I(g).call(this),M(_(_(r=!o||"object"!=typeof o&&"function"!=typeof o?_(u):o)),"update",function(){var e=_(_(r))._updateValue;return function(t,n){r[x]||r[D]||(0===r.localTime&&r.emit("start",r.value,_(_(r))),e(r.ease(r.loopFunction.progress(Math.min(1,(n||r.localTime)/r.duration)))),r.emit("update",r.value,_(_(r)),t),r.localTime>=r.duration&&r.loopFunction.complete(function(){r[x]=!0,r.emit("complete",r.value,_(_(r)));}),r.localTime+=t);}});var a=r.plugin=Object.values(g._plugins).reduce(function(t,n){return t||n&&n.test&&n.test(e)&&n},!1),i=a&&a.name||("object"===O(e)?Array.isArray(e)?"array":"object":"number");if(a){var c=a.initialize(e,t);e=c.startValue,t=c.destValue,r.data=c.data;}switch(Object.assign(_(_(r)),(M(n={duration:1e3,localTime:0,startValue:e,destValue:t,loopMode:"once",loopFunction:g.DEFAULT_LOOP,ease:function(t){return t},value:"array"===i?[].concat(e):"object"===i?Object.assign({},e):e},x,!1),M(n,T,i),M(n,j,Date.now()),M(n,D,!1),n)),r[T]){case"number":r._updateValue=function(t){r.value=V(r.startValue,r.destValue,t);};break;case"array":var l=r.value.length,f=_(_(r)),s=f.startValue,p=f.destValue,h=f.value;r._updateValue=function(t){for(var n=0;n<l;n++)h[n]=V(s[n],p[n],t);};break;case"object":var m=Object.keys(r.startValue),d=m.length,y=_(_(r)),v=y.startValue,b=y.destValue,w=y.value;r._updateValue=function(t){for(var n=0;n<d;n++){var e=m[n];w[e]=V(v[e],b[e],t);}};break;default:r.plugin?r._updateValue=function(t){r.value=r.plugin.interpolate(r.startValue,r.destValue,t,r.data);}:(console.warn("Between: startValue type was unrecognized."),r._updateValue=function(){return null});}return P.push(r.update()),r}return n(g,null,[{key:"between",value:function(){for(var t=arguments.length,n=new Array(t),e=0;e<t;e++)n[e]=arguments[e];return u(g,n)}}]),n(g,[{key:"pause",value:function(){return this[D]=!0,this.emit("pause",this.value,this,k),this}},{key:"play",value:function(){return this[D]=!1,this.emit("play",this.value,this,k),this}},{key:"easing",value:function(t){return this.ease=t,this}},{key:"time",value:function(t){return this.duration=t,this}},{key:"loop",value:function(){for(var t=0<arguments.length&&void 0!==arguments[0]?arguments[0]:"once",n="__loop_".concat(t),e=arguments.length,r=new Array(1<e?e-1:0),u=1;u<e;u++)r[u-1]=arguments[u];return this.loopFunction=n in this?Object.assign({},g.DEFAULT_LOOP,this[n].apply(this,r)):g.DEFAULT_LOOP,this}},{key:"__loop_repeat",value:function(t){var n=this,e=t;return this.times=0,{complete:function(t){n.localTime=0,Number.isInteger(e)&&++n.times===e?t():Number.isInteger(e)||++n.times;}}}},{key:"__loop_bounce",value:function(t){var n=this,e=t,r=1;return this.times=0,{complete:function(t){n.localTime=0,r=-r,Number.isInteger(e)&&++n.times===e?t():Number.isInteger(e)||++n.times;},progress:function(t){return 0<r?t:1-t}}}},{key:"isPaused",get:function(){return this[D]}}]),function(t,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function");o(t.prototype,n&&n.prototype),n&&o(t,n);}(g,t),g}(t);return M(E,"DEFAULT_LOOP",{complete:function(t){return t()},progress:function(t){return t}}),E.Easing=i,E._plugins={},E});
59991
+ }(between$1));
59992
+
59993
+ var between = between$1.exports;var LOOPING = {
59988
59994
  BOUNCE: 'bounce',
59989
59995
  REPEAT: 'repeat',
59990
59996
  NONE: false
@@ -60034,15 +60040,15 @@ var tweenTo = function tweenTo(origin, target) {
60034
60040
  function Entity() {
60035
60041
  var _this;
60036
60042
 
60037
- var _options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
60043
+ var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
60038
60044
 
60039
60045
  _classCallCheck(this, Entity);
60040
60046
 
60041
- var _options$serializable = _options.serializable,
60047
+ var _options$serializable = options.serializable,
60042
60048
  serializable = _options$serializable === void 0 ? true : _options$serializable,
60043
- _options$tag = _options.tag,
60044
- tag = _options$tag === void 0 ? '' : _options$tag,
60045
- _options$tags = _options.tags,
60049
+ _options$tag = options.tag,
60050
+ tag = _options$tag === void 0 ? "" : _options$tag,
60051
+ _options$tags = options.tags,
60046
60052
  tags = _options$tags === void 0 ? [] : _options$tags;
60047
60053
  _this = _super.call(this);
60048
60054
 
@@ -60072,18 +60078,21 @@ var tweenTo = function tweenTo(origin, target) {
60072
60078
  });
60073
60079
 
60074
60080
  _defineProperty$1(_assertThisInitialized(_this), "hasScripts", function () {
60075
- return _this.scripts.length > 0;
60081
+ return _this.allScripts().length > 0;
60076
60082
  });
60077
60083
 
60078
- _defineProperty$1(_assertThisInitialized(_this), "parseScripts", function (list, options, enabled) {
60079
- return list.map(function (script, i) {
60080
- return {
60081
- script: script,
60082
- name: script.getName(),
60083
- enabled: enabled,
60084
- options: options[i]
60085
- };
60086
- });
60084
+ _defineProperty$1(_assertThisInitialized(_this), "allScripts", function () {
60085
+ return [].concat(_toConsumableArray(_this.dynamicScripts), _toConsumableArray(_this.staticScripts));
60086
+ });
60087
+
60088
+ _defineProperty$1(_assertThisInitialized(_this), "updateScriptsIndexes", function () {
60089
+ var update = function update(s, i) {
60090
+ return s.index = i;
60091
+ };
60092
+
60093
+ _this.dynamicScripts.forEach(update);
60094
+
60095
+ _this.staticScripts.forEach(update);
60087
60096
  });
60088
60097
 
60089
60098
  _defineProperty$1(_assertThisInitialized(_this), "isMesh", function () {
@@ -60125,12 +60134,13 @@ var tweenTo = function tweenTo(origin, target) {
60125
60134
  }
60126
60135
  });
60127
60136
 
60128
- _this.options = _objectSpread2$1(_objectSpread2$1({}, _options), {}, {
60137
+ _this.options = _objectSpread2$1(_objectSpread2$1({}, options), {}, {
60129
60138
  serializable: serializable,
60130
60139
  tag: tag,
60131
60140
  tags: tags
60132
60141
  });
60133
- _this.scripts = [];
60142
+ _this.dynamicScripts = [];
60143
+ _this.staticScripts = [];
60134
60144
  _this.tags = [];
60135
60145
  _this.children = [];
60136
60146
  _this.isMage = true;
@@ -60156,7 +60166,8 @@ var tweenTo = function tweenTo(origin, target) {
60156
60166
  }, {
60157
60167
  key: "reset",
60158
60168
  value: function reset() {
60159
- this.scripts = [];
60169
+ this.dynamicScripts = [];
60170
+ this.staticScripts = [];
60160
60171
  this.children = [];
60161
60172
  this.isMage = true;
60162
60173
  this.parent = false;
@@ -60290,7 +60301,7 @@ var tweenTo = function tweenTo(origin, target) {
60290
60301
  var index = this.children.findIndex(function (m) {
60291
60302
  return m.equals(element);
60292
60303
  });
60293
- if (index) this.children.splice(index, 1);
60304
+ if (index !== -1) this.children.splice(index, 1);
60294
60305
  } else {
60295
60306
  this.body.remove(element.getBody());
60296
60307
  }
@@ -60363,20 +60374,18 @@ var tweenTo = function tweenTo(origin, target) {
60363
60374
  key: "disposeScripts",
60364
60375
  value: function disposeScripts() {
60365
60376
  if (this.hasScripts()) {
60366
- var length = this.scripts.length;
60377
+ var length = this.allScripts().length;
60367
60378
 
60368
60379
  for (var i = 0; i < length; i++) {
60369
- var _this$scripts$i = this.scripts[i],
60370
- script = _this$scripts$i.script,
60371
- enabled = _this$scripts$i.enabled;
60380
+ var _this$allScripts$i = this.allScripts()[i],
60381
+ script = _this$allScripts$i.script,
60382
+ enabled = _this$allScripts$i.enabled;
60372
60383
 
60373
60384
  if (enabled) {
60374
60385
  script.onDispose();
60375
60386
 
60376
60387
  script.__setStartedFlag(false);
60377
60388
  }
60378
-
60379
- delete this.scripts[i];
60380
60389
  }
60381
60390
  }
60382
60391
  }
@@ -60386,7 +60395,7 @@ var tweenTo = function tweenTo(origin, target) {
60386
60395
  var _this4 = this;
60387
60396
 
60388
60397
  if (this.hasScripts()) {
60389
- this.scripts.forEach(function (_ref4) {
60398
+ this.allScripts().forEach(function (_ref4) {
60390
60399
  var script = _ref4.script,
60391
60400
  enabled = _ref4.enabled,
60392
60401
  options = _ref4.options;
@@ -60403,7 +60412,7 @@ var tweenTo = function tweenTo(origin, target) {
60403
60412
  key: "update",
60404
60413
  value: function update(dt) {
60405
60414
  if (this.hasScripts()) {
60406
- this.scripts.forEach(function (_ref5) {
60415
+ this.dynamicScripts.forEach(function (_ref5) {
60407
60416
  var script = _ref5.script,
60408
60417
  enabled = _ref5.enabled;
60409
60418
 
@@ -60417,7 +60426,7 @@ var tweenTo = function tweenTo(origin, target) {
60417
60426
  key: "onPhysicsUpdate",
60418
60427
  value: function onPhysicsUpdate(dt) {
60419
60428
  if (this.hasScripts()) {
60420
- this.scripts.forEach(function (_ref6) {
60429
+ this.dynamicScripts.forEach(function (_ref6) {
60421
60430
  var script = _ref6.script,
60422
60431
  enabled = _ref6.enabled;
60423
60432
 
@@ -60456,6 +60465,7 @@ var tweenTo = function tweenTo(origin, target) {
60456
60465
  type: ENTITY_EVENTS.DISPOSE
60457
60466
  });
60458
60467
  this.reset();
60468
+ this.disposed = true;
60459
60469
  }
60460
60470
  }, {
60461
60471
  key: "addStateMachine",
@@ -60501,33 +60511,22 @@ var tweenTo = function tweenTo(origin, target) {
60501
60511
  }, {
60502
60512
  key: "getScript",
60503
60513
  value: function getScript(name) {
60504
- var script = this.scripts.filter(function (script) {
60505
- return script.name === name;
60506
- })[0].script;
60507
-
60508
- if (script) {
60509
- return script;
60510
- } else {
60514
+ if (!this.hasScript(name)) {
60511
60515
  console.warn(SCRIPT_NOT_FOUND);
60512
60516
  return false;
60513
60517
  }
60518
+
60519
+ var script = this.allScripts().filter(function (script) {
60520
+ return script.name === name;
60521
+ })[0].script;
60522
+ return script;
60514
60523
  }
60515
60524
  }, {
60516
- key: "addScripts",
60517
- value: function addScripts() {
60518
- var _this6 = this;
60519
-
60520
- var scripts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
60521
- var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
60522
- var enabled = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
60523
- var parsedScripts = this.parseScripts(scripts, options, enabled);
60524
- this.scripts = [].concat(_toConsumableArray(this.scripts), [parsedScripts]);
60525
-
60526
- if (enabled) {
60527
- parsedScripts.forEach(function (parsed) {
60528
- return parsed.start(_this6, parsed.options);
60529
- });
60530
- }
60525
+ key: "hasScript",
60526
+ value: function hasScript(name) {
60527
+ return this.allScripts().filter(function (script) {
60528
+ return script.name === name;
60529
+ }).length;
60531
60530
  }
60532
60531
  }, {
60533
60532
  key: "addScript",
@@ -60538,12 +60537,22 @@ var tweenTo = function tweenTo(origin, target) {
60538
60537
  enabled = _options$enabled === void 0 ? true : _options$enabled;
60539
60538
 
60540
60539
  if (script) {
60541
- this.scripts.push({
60540
+ var payload = {
60542
60541
  script: script,
60543
60542
  name: name,
60544
60543
  enabled: enabled,
60545
60544
  options: options
60546
- });
60545
+ };
60546
+
60547
+ if (script.__isStatic()) {
60548
+ this.staticScripts.push(_objectSpread2$1(_objectSpread2$1({}, payload), {}, {
60549
+ index: this.staticScripts.length
60550
+ }));
60551
+ } else {
60552
+ this.dynamicScripts.push(_objectSpread2$1(_objectSpread2$1({}, payload), {}, {
60553
+ index: this.dynamicScripts.length
60554
+ }));
60555
+ }
60547
60556
 
60548
60557
  if (enabled) {
60549
60558
  script.start(this, options);
@@ -60554,6 +60563,31 @@ var tweenTo = function tweenTo(origin, target) {
60554
60563
 
60555
60564
  return script;
60556
60565
  }
60566
+ }, {
60567
+ key: "removeScript",
60568
+ value: function removeScript(name) {
60569
+ var all = this.allScripts();
60570
+ var allIndex = all.findIndex(function (script) {
60571
+ return script.name === name;
60572
+ });
60573
+ var _all$allIndex = all[allIndex],
60574
+ script = _all$allIndex.script,
60575
+ index = _all$allIndex.index;
60576
+
60577
+ if (script) {
60578
+ script.onDispose();
60579
+
60580
+ if (script.__isStatic()) {
60581
+ this.staticScripts.splice(index, 1);
60582
+ } else {
60583
+ this.dynamicScripts.splice(index, 1);
60584
+ }
60585
+
60586
+ this.updateScriptsIndexes();
60587
+ } else {
60588
+ console.log(SCRIPT_NOT_FOUND);
60589
+ }
60590
+ }
60557
60591
  }, {
60558
60592
  key: "enableScripts",
60559
60593
  value: function enableScripts() {
@@ -60655,7 +60689,7 @@ var tweenTo = function tweenTo(origin, target) {
60655
60689
  value: function getWorldTransform() {
60656
60690
  var position = this.getBody().getWorldPosition(new Vector3$1());
60657
60691
  var quaternion = this.getBody().getWorldQuaternion(new Quaternion(0, 0, 0, 1));
60658
- var rotation = new Euler(0, 0, 0, 'XYZ').setFromQuaternion(quaternion, 'XYZ');
60692
+ var rotation = new Euler(0, 0, 0, "XYZ").setFromQuaternion(quaternion, "XYZ");
60659
60693
  return {
60660
60694
  position: position,
60661
60695
  rotation: rotation,
@@ -60681,7 +60715,7 @@ var tweenTo = function tweenTo(origin, target) {
60681
60715
  }, {
60682
60716
  key: "scaleTo",
60683
60717
  value: function scaleTo() {
60684
- var _this7 = this;
60718
+ var _this6 = this;
60685
60719
 
60686
60720
  var scale = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.getScale();
60687
60721
  var time = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 250;
@@ -60699,7 +60733,7 @@ var tweenTo = function tweenTo(origin, target) {
60699
60733
  }, scale);
60700
60734
 
60701
60735
  var onUpdate = function onUpdate(value) {
60702
- return !_this7.isDisposed() && _this7.setScale(value);
60736
+ return !_this6.isDisposed() && _this6.setScale(value);
60703
60737
  };
60704
60738
 
60705
60739
  return tweenTo({
@@ -60714,7 +60748,7 @@ var tweenTo = function tweenTo(origin, target) {
60714
60748
  }, {
60715
60749
  key: "rotateTo",
60716
60750
  value: function rotateTo() {
60717
- var _this8 = this;
60751
+ var _this7 = this;
60718
60752
 
60719
60753
  var rotation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.getRotation();
60720
60754
  var time = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 250;
@@ -60732,7 +60766,7 @@ var tweenTo = function tweenTo(origin, target) {
60732
60766
  }, rotation);
60733
60767
 
60734
60768
  var onUpdate = function onUpdate(value) {
60735
- return !_this8.isDisposed() && _this8.setRotation(value);
60769
+ return !_this7.isDisposed() && _this7.setRotation(value);
60736
60770
  };
60737
60771
 
60738
60772
  return tweenTo({
@@ -60747,7 +60781,7 @@ var tweenTo = function tweenTo(origin, target) {
60747
60781
  }, {
60748
60782
  key: "goTo",
60749
60783
  value: function goTo() {
60750
- var _this9 = this;
60784
+ var _this8 = this;
60751
60785
 
60752
60786
  var position = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.getPosition();
60753
60787
  var time = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 250;
@@ -60765,7 +60799,7 @@ var tweenTo = function tweenTo(origin, target) {
60765
60799
  }, position);
60766
60800
 
60767
60801
  var onUpdate = function onUpdate(value) {
60768
- return !_this9.isDisposed() && _this9.setPosition(value);
60802
+ return !_this8.isDisposed() && _this8.setPosition(value);
60769
60803
  };
60770
60804
 
60771
60805
  return tweenTo({
@@ -60846,16 +60880,19 @@ var tweenTo = function tweenTo(origin, target) {
60846
60880
  }, {
60847
60881
  key: "mapScriptsToJSON",
60848
60882
  value: function mapScriptsToJSON() {
60849
- this.scripts.reduce(function (acc, _ref8) {
60883
+ this.allScripts().reduce(function (acc, _ref8) {
60850
60884
  var name = _ref8.name,
60851
60885
  _ref8$options = _ref8.options,
60852
- options = _ref8$options === void 0 ? {} : _ref8$options;
60886
+ options = _ref8$options === void 0 ? {} : _ref8$options,
60887
+ script = _ref8.script;
60853
60888
  acc.names.push(name);
60854
60889
  acc.options.push(options);
60890
+ acc.static.push(script.__isStatic());
60855
60891
  return acc;
60856
60892
  }, {
60857
60893
  names: [],
60858
- options: []
60894
+ options: [],
60895
+ static: []
60859
60896
  });
60860
60897
  }
60861
60898
  }, {
@@ -61837,14 +61874,63 @@ var Element$1 = /*#__PURE__*/function (_Entity) {
61837
61874
  }]);
61838
61875
 
61839
61876
  return Camera;
61840
- }(Entity);var Grid = /*#__PURE__*/function (_Element) {
61877
+ }(Entity);var Color = /*#__PURE__*/function () {
61878
+ _createClass(Color, null, [{
61879
+ key: "randomColor",
61880
+ value: function randomColor() {
61881
+ var asNumber = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
61882
+ var letters = '0123456789ABCDEF'.split('');
61883
+ var color = '';
61884
+
61885
+ for (var i = 0; i < 6; i++) {
61886
+ color += letters[Math.floor(Math.random() * 16)];
61887
+ }
61888
+
61889
+ return asNumber ? Number("0x".concat(color)) : "#".concat(color);
61890
+ }
61891
+ }, {
61892
+ key: "componentToHex",
61893
+ value: function componentToHex(c) {
61894
+ var hex = c.toString(16);
61895
+ return hex.length == 1 ? "0" + hex : hex;
61896
+ }
61897
+ }, {
61898
+ key: "gbToHex",
61899
+ value: function gbToHex(r, g, b) {
61900
+ return "0x" + Color.componentToHex(r) + Color.componentToHex(g) + Color.componentToHex(b);
61901
+ }
61902
+ }, {
61903
+ key: "getIntValueFromHex",
61904
+ value: function getIntValueFromHex(hex) {
61905
+ return parseInt(hex, 16);
61906
+ }
61907
+ }]);
61908
+
61909
+ function Color(color) {
61910
+ _classCallCheck(this, Color);
61911
+
61912
+ this.color = new Color$1(color);
61913
+ }
61914
+
61915
+ _createClass(Color, [{
61916
+ key: "getColor",
61917
+ value: function getColor() {
61918
+ return this.color;
61919
+ }
61920
+ }]);
61921
+
61922
+ return Color;
61923
+ }();var Grid = /*#__PURE__*/function (_Element) {
61841
61924
  _inherits(Grid, _Element);
61842
61925
 
61843
61926
  var _super = _createSuper(Grid);
61844
61927
 
61845
- function Grid(size, division, color1, color2) {
61928
+ function Grid(size, division) {
61846
61929
  var _this;
61847
61930
 
61931
+ var color1 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : Color.randomColor(true);
61932
+ var color2 = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : Color.randomColor(true);
61933
+
61848
61934
  _classCallCheck(this, Grid);
61849
61935
 
61850
61936
  var options = {
@@ -61852,7 +61938,7 @@ var Element$1 = /*#__PURE__*/function (_Entity) {
61852
61938
  division: division,
61853
61939
  color1: color1,
61854
61940
  color2: color2,
61855
- name: generateRandomName('GridHelper')
61941
+ name: generateRandomName("GridHelper")
61856
61942
  };
61857
61943
  _this = _super.call(this, options);
61858
61944
  var body = new GridHelper(size, division, color1, color2);
@@ -61970,7 +62056,7 @@ var Axes = /*#__PURE__*/function (_Element) {
61970
62056
  var _this;
61971
62057
 
61972
62058
  var side = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 10;
61973
- var color = arguments.length > 1 ? arguments[1] : undefined;
62059
+ var color = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Color.randomColor(true);
61974
62060
  var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
61975
62061
 
61976
62062
  _classCallCheck(this, Cube);
@@ -62002,7 +62088,7 @@ var Axes = /*#__PURE__*/function (_Element) {
62002
62088
  var _this;
62003
62089
 
62004
62090
  var radius = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 10;
62005
- var color = arguments.length > 1 ? arguments[1] : undefined;
62091
+ var color = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Color.randomColor(true);
62006
62092
  var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
62007
62093
 
62008
62094
  _classCallCheck(this, Sphere);
@@ -62036,8 +62122,8 @@ var Axes = /*#__PURE__*/function (_Element) {
62036
62122
 
62037
62123
  var radiusTop = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 10;
62038
62124
  var radiusBottom = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 10;
62039
- var height = arguments.length > 2 ? arguments[2] : undefined;
62040
- var color = arguments.length > 3 ? arguments[3] : undefined;
62125
+ var height = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 10;
62126
+ var color = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : Color.randomColor(true);
62041
62127
  var options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
62042
62128
 
62043
62129
  _classCallCheck(this, Cylinder);
@@ -62208,24 +62294,23 @@ var Plane = /*#__PURE__*/function (_Element) {
62208
62294
  function Plane(height, width) {
62209
62295
  var _this;
62210
62296
 
62211
- var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
62297
+ var color = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : Color.randomColor(true);
62298
+ var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
62212
62299
 
62213
62300
  _classCallCheck(this, Plane);
62214
62301
 
62215
62302
  _this = _super.call(this, options);
62216
- var _options$color = options.color,
62217
- color = _options$color === void 0 ? 0xfffffff : _options$color,
62218
- _options$transparent = options.transparent,
62303
+ var _options$transparent = options.transparent,
62219
62304
  transparent = _options$transparent === void 0 ? false : _options$transparent,
62220
62305
  _options$opacity = options.opacity,
62221
62306
  opacity = _options$opacity === void 0 ? 1 : _options$opacity;
62222
- material = new MeshBasicMaterial({
62307
+ var material = new MeshBasicMaterial({
62223
62308
  color: color,
62224
62309
  side: DoubleSide,
62225
62310
  transparent: transparent,
62226
62311
  opacity: opacity
62227
62312
  });
62228
- geometry = new PlaneGeometry(width, height);
62313
+ var geometry = new PlaneGeometry(width, height);
62229
62314
 
62230
62315
  _this.setBody({
62231
62316
  geometry: geometry,
@@ -62267,7 +62352,7 @@ var Plane = /*#__PURE__*/function (_Element) {
62267
62352
  var width = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 10;
62268
62353
  var height = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 10;
62269
62354
  var depth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 10;
62270
- var color = arguments.length > 3 ? arguments[3] : undefined;
62355
+ var color = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : Color.randomColor(true);
62271
62356
  var options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
62272
62357
 
62273
62358
  _classCallCheck(this, Box);
@@ -90605,53 +90690,7 @@ var Label = /*#__PURE__*/function (_Element) {
90605
90690
  }]);
90606
90691
 
90607
90692
  return Label;
90608
- }(Element$1);var Color = /*#__PURE__*/function () {
90609
- _createClass(Color, null, [{
90610
- key: "randomColor",
90611
- value: function randomColor() {
90612
- var asNumber = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
90613
- var letters = '0123456789ABCDEF'.split('');
90614
- var color = '';
90615
-
90616
- for (var i = 0; i < 6; i++) {
90617
- color += letters[Math.floor(Math.random() * 16)];
90618
- }
90619
-
90620
- return asNumber ? Number("0x".concat(color)) : "#".concat(color);
90621
- }
90622
- }, {
90623
- key: "componentToHex",
90624
- value: function componentToHex(c) {
90625
- var hex = c.toString(16);
90626
- return hex.length == 1 ? "0" + hex : hex;
90627
- }
90628
- }, {
90629
- key: "gbToHex",
90630
- value: function gbToHex(r, g, b) {
90631
- return "0x" + Color.componentToHex(r) + Color.componentToHex(g) + Color.componentToHex(b);
90632
- }
90633
- }, {
90634
- key: "getIntValueFromHex",
90635
- value: function getIntValueFromHex(hex) {
90636
- return parseInt(hex, 16);
90637
- }
90638
- }]);
90639
-
90640
- function Color(color) {
90641
- _classCallCheck(this, Color);
90642
-
90643
- this.color = new Color$1(color);
90644
- }
90645
-
90646
- _createClass(Color, [{
90647
- key: "getColor",
90648
- value: function getColor() {
90649
- return this.color;
90650
- }
90651
- }]);
90652
-
90653
- return Color;
90654
- }();var DEFAULT_RADIUS = 5;
90693
+ }(Element$1);var DEFAULT_RADIUS = 5;
90655
90694
  var DEFAULT_HEIGHT = 5;
90656
90695
  var DEFAULT_RADIAL_SEGMENTS = 8;
90657
90696
  var DEFAULT_HEIGHT_SEGMENTS = 1;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "mage-engine",
3
- "version": "3.21.1",
3
+ "version": "3.22.0",
4
4
  "description": "A WebGL Javascript Game Engine, built on top of THREE.js and many other libraries.",
5
5
  "main": "dist/mage.js",
6
6
  "author": {