Subversion Repository Public Repository

Nextrek

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
    "uid": "05564A68K161FA4612S8C50E0584F5DA471D",
    "isLoaded": true,
    "lastModificationTime": 0,
    "items": {
        "name": "Component_ActionHandler",
        "type": "game_script",
        "order": 11,
        "content": "# ===================================================================\n#\n#   Script: Component_ActionHandler\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_ActionHandler extends ui.Component_Handler\n    ###*\n    * Called if this object instance is restored from a data-bundle. It can be used\n    * re-assign event-handler, anonymous functions, etc.\n    * \n    * @method onDataBundleRestore.\n    * @param Object data - The data-bundle\n    * @param gs.ObjectCodecContext context - The codec-context.\n    ###\n    onDataBundleRestore: (data, context) ->\n        @setupEventHandlers()\n        \n    ###*\n    * An action-handler component allows a UI game object to execute\n    * actions. An action can be a method-call of a component or of the scene which\n    * always takes two parameters: Sender and Params. For more info about\n    * UI actions, see help-file.\n    * \n    * @module ui\n    * @class Component_ActionHandler\n    * @extends ui.Component_Handler\n    * @memberof ui\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * @property initialized\n        * @type boolean\n        * @protected\n        ###\n        @initialized = no\n        \n        ###*\n        * Counter for delayed/timed actions.\n        * @property waitCounter\n        * @type number\n        * @protected\n        ###\n        @waitCounter = 0\n        \n        ###*\n        * Indicates if the mouse/touch pointer is inside the UI object's bounds.\n        * @property contains\n        * @type boolean\n        * @protected\n        ###\n        @containsPointer = no\n    \n    \n    ###*\n    * Disposes the component.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        super\n        \n        gs.GlobalEventManager.offByOwner(\"keyUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseMoved\", @object)\n        \n    \n    ###*\n    * Adds event-handler for mouse/touch events to update the component only if \n    * a user-action happened.\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        gs.GlobalEventManager.offByOwner(\"keyUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseMoved\", @object)\n       \n        \n        if @object.focusable\n            gs.GlobalEventManager.on \"keyUp\", ((e) => \n                if Input.release(Input.KEY_RETURN) and @object.ui.focused\n                    @object.needsUpdate = yes\n                    @executeActions()\n            ), null, @object\n        \n        gs.GlobalEventManager.on \"mouseUp\", ((e) => \n            contains = Rect.contains(@object.dstRect.x, @object.dstRect.y, \n                         @object.dstRect.width, @object.dstRect.height,\n                         Input.Mouse.x - @object.origin.x, Input.Mouse.y - @object.origin.y)\n            \n            if contains\n                exec = no\n                actions = actions || @object.actions\n                if actions?\n                    for action in actions\n                        exec = @checkAction(action) and !@checkActionWait(action)\n                        break if exec\n                        \n                if exec\n                    e.breakChain = yes\n                    @executeActions()\n                @object.needsUpdate = yes\n                \n        ), null, @object\n        \n            \n        if @object.actions?.first((a) -> a and (a.event == \"onMouseEnter\" or a.event == \"onMouseLeave\" or a.event == \"onMouseHover\"))\n            gs.GlobalEventManager.on \"mouseMoved\", ((e) =>\n                contains = Rect.contains(@object.dstRect.x, @object.dstRect.y, \n                         @object.dstRect.width, @object.dstRect.height,\n                         Input.Mouse.x - @object.origin.x, Input.Mouse.y - @object.origin.y)\n            \n                if @containsPointer != contains\n                    @containsPointer = contains\n                    @object.needsUpdate = yes\n            ),\n            null, @object\n            \n        @object.events.on \"action\", (e) =>\n            if e.actions or e.action\n                @executeAction(if e.actions? then e.actions[0] else e.action)\n     \n    ###*\n    * Sets up associated actions. Each action is validated and specific default values for the action-target\n    * and other options are set if not specified.\n    *\n    * @method setupActions\n    ###        \n    setupActions: ->\n        if @object.actions?\n            for action in @object.actions\n                continue unless action\n                if not action.event then action.event = \"onAction\"\n                if action.wait? then continue\n                if not action.target? then action.target = @object.controller\n                if typeof action.target == \"string\"\n                    if action.target.contains(\".\")\n                        action.target = ui.Component_FormulaHandler.fieldValue(@object, action.target)\n                    targets = action.target.split(\".\")\n                    target = gs.ObjectManager.current.objectById(targets[0])\n                    if target?\n                        component = target.findComponentById(targets[1])\n                        if not component?\n                            target = target.components.where((v) -> typeof v[action.name] == \"function\").first()\n                        else\n                            target = component\n                    else\n                        target = @object\n                    action.target = target\n                if action.condition?\n                    action.conditions = [action.condition]\n                    delete action.condition\n                \n    ###*\n    * Initializes the action-handler.\n    * \n    * @method setup\n    ###\n    setup: ->\n        @initialized = yes\n        \n        @setupEventHandlers()\n        @setupActions()    \n        \n    ###*\n    * Updates the action-handler.\n    * \n    * @method update\n    ###\n    update: ->\n\n      \n    checkAction: (action) -> (action?.event or action?.events) and @checkObject(action)\n    checkActionWait: (action) ->\n        result = no\n        \n        if action.wait? and action.wait > 0\n            @waitCounter = action.wait\n            action.wait = 0\n            result = yes\n            \n        return result\n    updateActionTarget: (action) ->\n        if not action.target? then action.target = @object.controller\n        if action.target.exec or typeof action.target == \"string\"\n            if action.target.exec\n               action.target = ui.Component_FormulaHandler.fieldValue(@object, action.target)\n            targets = action.target.split(\".\")\n            target = gs.ObjectManager.current.objectById(targets[0])\n            if target?\n                component = target.findComponentById(targets[1])\n                if not component?\n                    target = target.components.where((v) -> typeof v[action.name] == \"function\").first()\n                else\n                    target = component\n            else\n                target = @object\n            action.target = target\n    \n    canExecuteActions: -> @waitCounter <= 0 and @object.ui.enabled and @object.visible         \n    \n    ###*\n    * Executes the specified actions. A single action is only executed if\n    * all assigned events and conditions are true.\n    * \n    * @method executeActions\n    * @return If <b>true</b> there was at least one action executed. Otherwise <b>false</b>\n    ###\n    executeActions: (actions) ->\n        return if not @canExecuteActions()\n        \n        result = no\n        actions = actions || @object.actions\n        if actions?\n            for action in actions\n                continue if not @checkAction(action)\n                break if @checkActionWait(action)\n                    \n                @updateActionTarget(action)\n                @executeAction(action)\n                \n                result = yes\n                \n        return result\n    \n    ###*\n    * Executes the specified action if all assigned events and conditions\n    * are true.\n    * \n    * @method executeAction\n    * @param {Object} action The action to execute.\n    ###            \n    executeAction: (action) ->\n        target = action.target || @object.target\n        \n        if target? \n            AudioManager.playSound(action.sound) if action.sound\n            target[action.name]?(@object, action.params)\n            \nui.Component_ActionHandler = Component_ActionHandler",
        "parentId": "01A95DA3K01E8A4CB4SBE17E790BCE1FC035",
        "folder": false,
        "compiledContent": "var Component_ActionHandler,\n  extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n  hasProp = {}.hasOwnProperty;\n\nComponent_ActionHandler = (function(superClass) {\n  extend(Component_ActionHandler, superClass);\n\n\n  /**\n  * Called if this object instance is restored from a data-bundle. It can be used\n  * re-assign event-handler, anonymous functions, etc.\n  * \n  * @method onDataBundleRestore.\n  * @param Object data - The data-bundle\n  * @param gs.ObjectCodecContext context - The codec-context.\n   */\n\n  Component_ActionHandler.prototype.onDataBundleRestore = function(data, context) {\n    return this.setupEventHandlers();\n  };\n\n\n  /**\n  * An action-handler component allows a UI game object to execute\n  * actions. An action can be a method-call of a component or of the scene which\n  * always takes two parameters: Sender and Params. For more info about\n  * UI actions, see help-file.\n  * \n  * @module ui\n  * @class Component_ActionHandler\n  * @extends ui.Component_Handler\n  * @memberof ui\n  * @constructor\n   */\n\n  function Component_ActionHandler() {\n\n    /**\n    * @property initialized\n    * @type boolean\n    * @protected\n     */\n    this.initialized = false;\n\n    /**\n    * Counter for delayed/timed actions.\n    * @property waitCounter\n    * @type number\n    * @protected\n     */\n    this.waitCounter = 0;\n\n    /**\n    * Indicates if the mouse/touch pointer is inside the UI object's bounds.\n    * @property contains\n    * @type boolean\n    * @protected\n     */\n    this.containsPointer = false;\n  }\n\n\n  /**\n  * Disposes the component.\n  *\n  * @method dispose\n   */\n\n  Component_ActionHandler.prototype.dispose = function() {\n    Component_ActionHandler.__super__.dispose.apply(this, arguments);\n    gs.GlobalEventManager.offByOwner(\"keyUp\", this.object);\n    gs.GlobalEventManager.offByOwner(\"mouseUp\", this.object);\n    return gs.GlobalEventManager.offByOwner(\"mouseMoved\", this.object);\n  };\n\n\n  /**\n  * Adds event-handler for mouse/touch events to update the component only if \n  * a user-action happened.\n  *\n  * @method setupEventHandlers\n   */\n\n  Component_ActionHandler.prototype.setupEventHandlers = function() {\n    var ref;\n    gs.GlobalEventManager.offByOwner(\"keyUp\", this.object);\n    gs.GlobalEventManager.offByOwner(\"mouseUp\", this.object);\n    gs.GlobalEventManager.offByOwner(\"mouseMoved\", this.object);\n    if (this.object.focusable) {\n      gs.GlobalEventManager.on(\"keyUp\", ((function(_this) {\n        return function(e) {\n          if (Input.release(Input.KEY_RETURN) && _this.object.ui.focused) {\n            _this.object.needsUpdate = true;\n            return _this.executeActions();\n          }\n        };\n      })(this)), null, this.object);\n    }\n    gs.GlobalEventManager.on(\"mouseUp\", ((function(_this) {\n      return function(e) {\n        var action, actions, contains, exec, i, len;\n        contains = Rect.contains(_this.object.dstRect.x, _this.object.dstRect.y, _this.object.dstRect.width, _this.object.dstRect.height, Input.Mouse.x - _this.object.origin.x, Input.Mouse.y - _this.object.origin.y);\n        if (contains) {\n          exec = false;\n          actions = actions || _this.object.actions;\n          if (actions != null) {\n            for (i = 0, len = actions.length; i < len; i++) {\n              action = actions[i];\n              exec = _this.checkAction(action) && !_this.checkActionWait(action);\n              if (exec) {\n                break;\n              }\n            }\n          }\n          if (exec) {\n            e.breakChain = true;\n            _this.executeActions();\n          }\n          return _this.object.needsUpdate = true;\n        }\n      };\n    })(this)), null, this.object);\n    if ((ref = this.object.actions) != null ? ref.first(function(a) {\n      return a && (a.event === \"onMouseEnter\" || a.event === \"onMouseLeave\" || a.event === \"onMouseHover\");\n    }) : void 0) {\n      gs.GlobalEventManager.on(\"mouseMoved\", ((function(_this) {\n        return function(e) {\n          var contains;\n          contains = Rect.contains(_this.object.dstRect.x, _this.object.dstRect.y, _this.object.dstRect.width, _this.object.dstRect.height, Input.Mouse.x - _this.object.origin.x, Input.Mouse.y - _this.object.origin.y);\n          if (_this.containsPointer !== contains) {\n            _this.containsPointer = contains;\n            return _this.object.needsUpdate = true;\n          }\n        };\n      })(this)), null, this.object);\n    }\n    return this.object.events.on(\"action\", (function(_this) {\n      return function(e) {\n        if (e.actions || e.action) {\n          return _this.executeAction(e.actions != null ? e.actions[0] : e.action);\n        }\n      };\n    })(this));\n  };\n\n\n  /**\n  * Sets up associated actions. Each action is validated and specific default values for the action-target\n  * and other options are set if not specified.\n  *\n  * @method setupActions\n   */\n\n  Component_ActionHandler.prototype.setupActions = function() {\n    var action, component, i, len, ref, results, target, targets;\n    if (this.object.actions != null) {\n      ref = this.object.actions;\n      results = [];\n      for (i = 0, len = ref.length; i < len; i++) {\n        action = ref[i];\n        if (!action) {\n          continue;\n        }\n        if (!action.event) {\n          action.event = \"onAction\";\n        }\n        if (action.wait != null) {\n          continue;\n        }\n        if (action.target == null) {\n          action.target = this.object.controller;\n        }\n        if (typeof action.target === \"string\") {\n          if (action.target.contains(\".\")) {\n            action.target = ui.Component_FormulaHandler.fieldValue(this.object, action.target);\n          }\n          targets = action.target.split(\".\");\n          target = gs.ObjectManager.current.objectById(targets[0]);\n          if (target != null) {\n            component = target.findComponentById(targets[1]);\n            if (component == null) {\n              target = target.components.where(function(v) {\n                return typeof v[action.name] === \"function\";\n              }).first();\n            } else {\n              target = component;\n            }\n          } else {\n            target = this.object;\n          }\n          action.target = target;\n        }\n        if (action.condition != null) {\n          action.conditions = [action.condition];\n          results.push(delete action.condition);\n        } else {\n          results.push(void 0);\n        }\n      }\n      return results;\n    }\n  };\n\n\n  /**\n  * Initializes the action-handler.\n  * \n  * @method setup\n   */\n\n  Component_ActionHandler.prototype.setup = function() {\n    this.initialized = true;\n    this.setupEventHandlers();\n    return this.setupActions();\n  };\n\n\n  /**\n  * Updates the action-handler.\n  * \n  * @method update\n   */\n\n  Component_ActionHandler.prototype.update = function() {};\n\n  Component_ActionHandler.prototype.checkAction = function(action) {\n    return ((action != null ? action.event : void 0) || (action != null ? action.events : void 0)) && this.checkObject(action);\n  };\n\n  Component_ActionHandler.prototype.checkActionWait = function(action) {\n    var result;\n    result = false;\n    if ((action.wait != null) && action.wait > 0) {\n      this.waitCounter = action.wait;\n      action.wait = 0;\n      result = true;\n    }\n    return result;\n  };\n\n  Component_ActionHandler.prototype.updateActionTarget = function(action) {\n    var component, target, targets;\n    if (action.target == null) {\n      action.target = this.object.controller;\n    }\n    if (action.target.exec || typeof action.target === \"string\") {\n      if (action.target.exec) {\n        action.target = ui.Component_FormulaHandler.fieldValue(this.object, action.target);\n      }\n      targets = action.target.split(\".\");\n      target = gs.ObjectManager.current.objectById(targets[0]);\n      if (target != null) {\n        component = target.findComponentById(targets[1]);\n        if (component == null) {\n          target = target.components.where(function(v) {\n            return typeof v[action.name] === \"function\";\n          }).first();\n        } else {\n          target = component;\n        }\n      } else {\n        target = this.object;\n      }\n      return action.target = target;\n    }\n  };\n\n  Component_ActionHandler.prototype.canExecuteActions = function() {\n    return this.waitCounter <= 0 && this.object.ui.enabled && this.object.visible;\n  };\n\n\n  /**\n  * Executes the specified actions. A single action is only executed if\n  * all assigned events and conditions are true.\n  * \n  * @method executeActions\n  * @return If <b>true</b> there was at least one action executed. Otherwise <b>false</b>\n   */\n\n  Component_ActionHandler.prototype.executeActions = function(actions) {\n    var action, i, len, result;\n    if (!this.canExecuteActions()) {\n      return;\n    }\n    result = false;\n    actions = actions || this.object.actions;\n    if (actions != null) {\n      for (i = 0, len = actions.length; i < len; i++) {\n        action = actions[i];\n        if (!this.checkAction(action)) {\n          continue;\n        }\n        if (this.checkActionWait(action)) {\n          break;\n        }\n        this.updateActionTarget(action);\n        this.executeAction(action);\n        result = true;\n      }\n    }\n    return result;\n  };\n\n\n  /**\n  * Executes the specified action if all assigned events and conditions\n  * are true.\n  * \n  * @method executeAction\n  * @param {Object} action The action to execute.\n   */\n\n  Component_ActionHandler.prototype.executeAction = function(action) {\n    var name, target;\n    target = action.target || this.object.target;\n    if (target != null) {\n      if (action.sound) {\n        AudioManager.playSound(action.sound);\n      }\n      return typeof target[name = action.name] === \"function\" ? target[name](this.object, action.params) : void 0;\n    }\n  };\n\n  return Component_ActionHandler;\n\n})(ui.Component_Handler);\n\nui.Component_ActionHandler = Component_ActionHandler;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_ActionHandler\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_ActionHandler extends ui.Component_Handler\n    ###*\n    * Called if this object instance is restored from a data-bundle. It can be used\n    * re-assign event-handler, anonymous functions, etc.\n    * \n    * @method onDataBundleRestore.\n    * @param Object data - The data-bundle\n    * @param gs.ObjectCodecContext context - The codec-context.\n    ###\n    onDataBundleRestore: (data, context) ->\n        @setupEventHandlers()\n        \n    ###*\n    * An action-handler component allows a UI game object to execute\n    * actions. An action can be a method-call of a component or of the scene which\n    * always takes two parameters: Sender and Params. For more info about\n    * UI actions, see help-file.\n    * \n    * @module ui\n    * @class Component_ActionHandler\n    * @extends ui.Component_Handler\n    * @memberof ui\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * @property initialized\n        * @type boolean\n        * @protected\n        ###\n        @initialized = no\n        \n        ###*\n        * Counter for delayed/timed actions.\n        * @property waitCounter\n        * @type number\n        * @protected\n        ###\n        @waitCounter = 0\n        \n        ###*\n        * Indicates if the mouse/touch pointer is inside the UI object's bounds.\n        * @property contains\n        * @type boolean\n        * @protected\n        ###\n        @containsPointer = no\n    \n    \n    ###*\n    * Disposes the component.\n    *\n    * @method dispose\n    ###\n    dispose: ->\n        super\n        \n        gs.GlobalEventManager.offByOwner(\"keyUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseMoved\", @object)\n        \n    \n    ###*\n    * Adds event-handler for mouse/touch events to update the component only if \n    * a user-action happened.\n    *\n    * @method setupEventHandlers\n    ### \n    setupEventHandlers: ->\n        gs.GlobalEventManager.offByOwner(\"keyUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseUp\", @object)\n        gs.GlobalEventManager.offByOwner(\"mouseMoved\", @object)\n       \n        \n        if @object.focusable\n            gs.GlobalEventManager.on \"keyUp\", ((e) => \n                if Input.release(Input.KEY_RETURN) and @object.ui.focused\n                    @object.needsUpdate = yes\n                    @executeActions()\n            ), null, @object\n        \n        gs.GlobalEventManager.on \"mouseUp\", ((e) => \n            contains = Rect.contains(@object.dstRect.x, @object.dstRect.y, \n                         @object.dstRect.width, @object.dstRect.height,\n                         Input.Mouse.x - @object.origin.x, Input.Mouse.y - @object.origin.y)\n            \n            if contains\n                exec = no\n                actions = actions || @object.actions\n                if actions?\n                    for action in actions\n                        exec = @checkAction(action) and !@checkActionWait(action)\n                        break if exec\n                        \n                if exec\n                    e.breakChain = yes\n                    @executeActions()\n                @object.needsUpdate = yes\n                \n        ), null, @object\n        \n            \n        if @object.actions?.first((a) -> a and (a.event == \"onMouseEnter\" or a.event == \"onMouseLeave\" or a.event == \"onMouseHover\"))\n            gs.GlobalEventManager.on \"mouseMoved\", ((e) =>\n                contains = Rect.contains(@object.dstRect.x, @object.dstRect.y, \n                         @object.dstRect.width, @object.dstRect.height,\n                         Input.Mouse.x - @object.origin.x, Input.Mouse.y - @object.origin.y)\n            \n                if @containsPointer != contains\n                    @containsPointer = contains\n                    @object.needsUpdate = yes\n            ),\n            null, @object\n            \n        @object.events.on \"action\", (e) =>\n            if e.actions or e.action\n                @executeAction(if e.actions? then e.actions[0] else e.action)\n     \n    ###*\n    * Sets up associated actions. Each action is validated and specific default values for the action-target\n    * and other options are set if not specified.\n    *\n    * @method setupActions\n    ###        \n    setupActions: ->\n        if @object.actions?\n            for action in @object.actions\n                continue unless action\n                if not action.event then action.event = \"onAction\"\n                if action.wait? then continue\n                if not action.target? then action.target = @object.controller\n                if typeof action.target == \"string\"\n                    if action.target.contains(\".\")\n                        action.target = ui.Component_FormulaHandler.fieldValue(@object, action.target)\n                    targets = action.target.split(\".\")\n                    target = gs.ObjectManager.current.objectById(targets[0])\n                    if target?\n                        component = target.findComponentById(targets[1])\n                        if not component?\n                            target = target.components.where((v) -> typeof v[action.name] == \"function\").first()\n                        else\n                            target = component\n                    else\n                        target = @object\n                    action.target = target\n                if action.condition?\n                    action.conditions = [action.condition]\n                    delete action.condition\n                \n    ###*\n    * Initializes the action-handler.\n    * \n    * @method setup\n    ###\n    setup: ->\n        @initialized = yes\n        \n        @setupEventHandlers()\n        @setupActions()    \n        \n    ###*\n    * Updates the action-handler.\n    * \n    * @method update\n    ###\n    update: ->\n\n      \n    checkAction: (action) -> (action?.event or action?.events) and @checkObject(action)\n    checkActionWait: (action) ->\n        result = no\n        \n        if action.wait? and action.wait > 0\n            @waitCounter = action.wait\n            action.wait = 0\n            result = yes\n            \n        return result\n    updateActionTarget: (action) ->\n        if not action.target? then action.target = @object.controller\n        if action.target.exec or typeof action.target == \"string\"\n            if action.target.exec\n               action.target = ui.Component_FormulaHandler.fieldValue(@object, action.target)\n            targets = action.target.split(\".\")\n            target = gs.ObjectManager.current.objectById(targets[0])\n            if target?\n                component = target.findComponentById(targets[1])\n                if not component?\n                    target = target.components.where((v) -> typeof v[action.name] == \"function\").first()\n                else\n                    target = component\n            else\n                target = @object\n            action.target = target\n    \n    canExecuteActions: -> @waitCounter <= 0 and @object.ui.enabled and @object.visible         \n    \n    ###*\n    * Executes the specified actions. A single action is only executed if\n    * all assigned events and conditions are true.\n    * \n    * @method executeActions\n    * @return If <b>true</b> there was at least one action executed. Otherwise <b>false</b>\n    ###\n    executeActions: (actions) ->\n        return if not @canExecuteActions()\n        \n        result = no\n        actions = actions || @object.actions\n        if actions?\n            for action in actions\n                continue if not @checkAction(action)\n                break if @checkActionWait(action)\n                    \n                @updateActionTarget(action)\n                @executeAction(action)\n                \n                result = yes\n                \n        return result\n    \n    ###*\n    * Executes the specified action if all assigned events and conditions\n    * are true.\n    * \n    * @method executeAction\n    * @param {Object} action The action to execute.\n    ###            \n    executeAction: (action) ->\n        target = action.target || @object.target\n        \n        if target? \n            AudioManager.playSound(action.sound) if action.sound\n            target[action.name]?(@object, action.params)\n            \nui.Component_ActionHandler = Component_ActionHandler"]}\n//# sourceURL=Component_ActionHandler_125.js"
    },
    "summary": [
        "name",
        "type",
        "order"
    ]
}

Commits for Nextrek/s2s/data/05564A68K161FA4612S8C50E0584F5DA471D.json

Diff revisions: vs.
Revision Author Commited Message
1084 MOliva picture MOliva Fri 11 May, 2018 12:41:55 +0000