Subversion Repository Public Repository

Nextrek

1
{"uid":"B54FB0D1K9DC1A4671S9BE6E84D78A18EAD1","isLoaded":true,"lastModificationTime":0,"items":{"name":"Component_LayoutBehavior","type":"game_script","order":3,"content":"# ===================================================================\n#\n#   Script: Component_LayoutBehavior\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_LayoutBehavior extends gs.Component_Visual\n    ###*\n    * The base class of all layout-components. A layout-component is used\n    * to layout assigned sub-objects in a specific way depending on the layout-type.\n    * For example: A grid-layout layouts its sub-objects like a grid using rows\n    * and columns. The game object needs a container-component.<br><br>\n    *\n    * A layout can also be configured as scrollable. In that case, layout's content\n    * can be larger than the layout-bounds and is automatically clipped. The content\n    * can be scrolled using mouse-wheel or touch-gesture.\n    *\n    * @module gs\n    * @class Component_LayoutBehavior\n    * @extends gs.Component\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * Content size of the layout.\n        * @property contentSize\n        * @type gs.Size\n        * @readOnly\n        ###\n        @contentSize = width: 0, height: 0\n\n    ###*\n    * Disposes the layout and all its sub-objects.\n    *\n    * @method dispose\n    ###  \n    # FIXME: Is that still necessary? If the parent game object is disposed\n    # all sub-objects are disposed as well.\n    dispose: ->\n        for control in @object.controls\n            control?.dispose()\n    \n    ###*\n    * Initializes the layout.\n    *\n    * @method setup\n    ### \n    setup: ->\n     \n    ###*\n    * Sizes the layout to fit its content.\n    *\n    * @method sizeToFit\n    * @abstract\n    ### \n    sizeToFit: ->\n        \n    ###*\n    * Sort-Function to sort sub-objects by order-index.\n    *\n    * @method sort_\n    * @protected\n    * @param {gs.Object_Base} a Object A\n    * @param {gs.Object_Base} b Object B\n    ###    \n    sort_: (a, b) ->\n        if a.order > b.order\n          return -1\n        else if a.order < b.order\n          return 1\n        else\n          return 0\n    \n    ###*\n    * Updates a specified control.\n    *\n    * @method updateControl\n    * @protected\n    * @param {gs.Object_Base} control The control to update\n    ### \n    updateControl: (control) ->\n        @object.rIndex = Math.max(@object.rIndex, control.rIndex)\n        \n        if control.updateBehavior == ui.UpdateBehavior.CONTINUOUS\n            control.needsUpdate = yes\n            \n        if control.inheritProperties\n            control.ui.enabled = @object.ui.enabled\n            control.opacity = @object.opacity\n            control.zoom = @object.zoom\n            control.color = @object.color\n            control.tone = @object.tone\n            control.angle = @object.angle\n            control.anchor.x = @object.anchor.x\n            control.anchor.y = @object.anchor.y\n            \n            \n        if control.needsUpdate\n            control.needsUpdate = no\n            control.update()\n            control.parent = @object\n            \n        \n        if @object.clipRect?\n            control.clipRect = @object.clipRect\n     \n    ###*\n    * Updates the content size of the layout. Only works if scrolling is\n    * enabled.\n    *\n    * @method updateContentSize\n    * @protected\n    ### \n    updateContentSize: ->\n        if @object.scrollable\n            @contentSize.width = 0\n            @contentSize.height = 0\n            for control in @object.controls\n                if control\n                    @contentSize.width += control.margin.left + control.dstRect.width + control.margin.right\n                    @contentSize.height += control.margin.top + control.dstRect.height + control.margin.bottom\n            \n            @object.contentHeight = @contentSize.height\n            @object.contentWidth = @contentSize.width\n        \n    ###*\n    * Updates scrolling.\n    *\n    * @method updateScroll\n    ###\n    updateScroll: ->\n        if @object.scrollable\n            @object.scrollableHeight = Math.max(0, @contentSize.height - @object.dstRect.height)\n            if Input.Mouse.wheel <= -1\n                @object.scrollOffsetY = Math.max(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, 0)\n               \n            if Input.Mouse.wheel >= 1\n                @object.scrollOffsetY = Math.min(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, @object.scrollableHeight)\n                \n        \n            @object.scrollOffsetY = Math.max(Math.min(@object.scrollOffsetY, @object.scrollableHeight), 0)\n     \n    ###*\n    * Updates the layout's content.\n    *\n    * @method updateContent\n    ###  \n    updateContent: ->\n        \n    ###*\n    * Updates the layout.\n    *\n    * @method update\n    ###    \n    update: ->\n        super\n        \n        @updateContentSize()\n        @updateScroll()\n        \n        \n        #if @object.needsSort\n        #    @object.subObjects.sort(@sort_)\n        #    @object.needsSort = no\n    \n        \ngs.Component_LayoutBehavior = Component_LayoutBehavior","parentId":"01A95DA3K01E8A4CB4SBE17E790BCE1FC035","folder":false,"compiledContent":"var Component_LayoutBehavior,\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_LayoutBehavior = (function(superClass) {\n  extend(Component_LayoutBehavior, superClass);\n\n\n  /**\n  * The base class of all layout-components. A layout-component is used\n  * to layout assigned sub-objects in a specific way depending on the layout-type.\n  * For example: A grid-layout layouts its sub-objects like a grid using rows\n  * and columns. The game object needs a container-component.<br><br>\n  *\n  * A layout can also be configured as scrollable. In that case, layout's content\n  * can be larger than the layout-bounds and is automatically clipped. The content\n  * can be scrolled using mouse-wheel or touch-gesture.\n  *\n  * @module gs\n  * @class Component_LayoutBehavior\n  * @extends gs.Component\n  * @memberof gs\n  * @constructor\n   */\n\n  function Component_LayoutBehavior() {\n\n    /**\n    * Content size of the layout.\n    * @property contentSize\n    * @type gs.Size\n    * @readOnly\n     */\n    this.contentSize = {\n      width: 0,\n      height: 0\n    };\n  }\n\n\n  /**\n  * Disposes the layout and all its sub-objects.\n  *\n  * @method dispose\n   */\n\n  Component_LayoutBehavior.prototype.dispose = function() {\n    var control, i, len, ref, results;\n    ref = this.object.controls;\n    results = [];\n    for (i = 0, len = ref.length; i < len; i++) {\n      control = ref[i];\n      results.push(control != null ? control.dispose() : void 0);\n    }\n    return results;\n  };\n\n\n  /**\n  * Initializes the layout.\n  *\n  * @method setup\n   */\n\n  Component_LayoutBehavior.prototype.setup = function() {};\n\n\n  /**\n  * Sizes the layout to fit its content.\n  *\n  * @method sizeToFit\n  * @abstract\n   */\n\n  Component_LayoutBehavior.prototype.sizeToFit = function() {};\n\n\n  /**\n  * Sort-Function to sort sub-objects by order-index.\n  *\n  * @method sort_\n  * @protected\n  * @param {gs.Object_Base} a Object A\n  * @param {gs.Object_Base} b Object B\n   */\n\n  Component_LayoutBehavior.prototype.sort_ = function(a, b) {\n    if (a.order > b.order) {\n      return -1;\n    } else if (a.order < b.order) {\n      return 1;\n    } else {\n      return 0;\n    }\n  };\n\n\n  /**\n  * Updates a specified control.\n  *\n  * @method updateControl\n  * @protected\n  * @param {gs.Object_Base} control The control to update\n   */\n\n  Component_LayoutBehavior.prototype.updateControl = function(control) {\n    this.object.rIndex = Math.max(this.object.rIndex, control.rIndex);\n    if (control.updateBehavior === ui.UpdateBehavior.CONTINUOUS) {\n      control.needsUpdate = true;\n    }\n    if (control.inheritProperties) {\n      control.ui.enabled = this.object.ui.enabled;\n      control.opacity = this.object.opacity;\n      control.zoom = this.object.zoom;\n      control.color = this.object.color;\n      control.tone = this.object.tone;\n      control.angle = this.object.angle;\n      control.anchor.x = this.object.anchor.x;\n      control.anchor.y = this.object.anchor.y;\n    }\n    if (control.needsUpdate) {\n      control.needsUpdate = false;\n      control.update();\n      control.parent = this.object;\n    }\n    if (this.object.clipRect != null) {\n      return control.clipRect = this.object.clipRect;\n    }\n  };\n\n\n  /**\n  * Updates the content size of the layout. Only works if scrolling is\n  * enabled.\n  *\n  * @method updateContentSize\n  * @protected\n   */\n\n  Component_LayoutBehavior.prototype.updateContentSize = function() {\n    var control, i, len, ref;\n    if (this.object.scrollable) {\n      this.contentSize.width = 0;\n      this.contentSize.height = 0;\n      ref = this.object.controls;\n      for (i = 0, len = ref.length; i < len; i++) {\n        control = ref[i];\n        if (control) {\n          this.contentSize.width += control.margin.left + control.dstRect.width + control.margin.right;\n          this.contentSize.height += control.margin.top + control.dstRect.height + control.margin.bottom;\n        }\n      }\n      this.object.contentHeight = this.contentSize.height;\n      return this.object.contentWidth = this.contentSize.width;\n    }\n  };\n\n\n  /**\n  * Updates scrolling.\n  *\n  * @method updateScroll\n   */\n\n  Component_LayoutBehavior.prototype.updateScroll = function() {\n    if (this.object.scrollable) {\n      this.object.scrollableHeight = Math.max(0, this.contentSize.height - this.object.dstRect.height);\n      if (Input.Mouse.wheel <= -1) {\n        this.object.scrollOffsetY = Math.max(this.object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, 0);\n      }\n      if (Input.Mouse.wheel >= 1) {\n        this.object.scrollOffsetY = Math.min(this.object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, this.object.scrollableHeight);\n      }\n      return this.object.scrollOffsetY = Math.max(Math.min(this.object.scrollOffsetY, this.object.scrollableHeight), 0);\n    }\n  };\n\n\n  /**\n  * Updates the layout's content.\n  *\n  * @method updateContent\n   */\n\n  Component_LayoutBehavior.prototype.updateContent = function() {};\n\n\n  /**\n  * Updates the layout.\n  *\n  * @method update\n   */\n\n  Component_LayoutBehavior.prototype.update = function() {\n    Component_LayoutBehavior.__super__.update.apply(this, arguments);\n    this.updateContentSize();\n    return this.updateScroll();\n  };\n\n  return Component_LayoutBehavior;\n\n})(gs.Component_Visual);\n\ngs.Component_LayoutBehavior = Component_LayoutBehavior;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: Component_LayoutBehavior\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass Component_LayoutBehavior extends gs.Component_Visual\n    ###*\n    * The base class of all layout-components. A layout-component is used\n    * to layout assigned sub-objects in a specific way depending on the layout-type.\n    * For example: A grid-layout layouts its sub-objects like a grid using rows\n    * and columns. The game object needs a container-component.<br><br>\n    *\n    * A layout can also be configured as scrollable. In that case, layout's content\n    * can be larger than the layout-bounds and is automatically clipped. The content\n    * can be scrolled using mouse-wheel or touch-gesture.\n    *\n    * @module gs\n    * @class Component_LayoutBehavior\n    * @extends gs.Component\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * Content size of the layout.\n        * @property contentSize\n        * @type gs.Size\n        * @readOnly\n        ###\n        @contentSize = width: 0, height: 0\n\n    ###*\n    * Disposes the layout and all its sub-objects.\n    *\n    * @method dispose\n    ###  \n    # FIXME: Is that still necessary? If the parent game object is disposed\n    # all sub-objects are disposed as well.\n    dispose: ->\n        for control in @object.controls\n            control?.dispose()\n    \n    ###*\n    * Initializes the layout.\n    *\n    * @method setup\n    ### \n    setup: ->\n     \n    ###*\n    * Sizes the layout to fit its content.\n    *\n    * @method sizeToFit\n    * @abstract\n    ### \n    sizeToFit: ->\n        \n    ###*\n    * Sort-Function to sort sub-objects by order-index.\n    *\n    * @method sort_\n    * @protected\n    * @param {gs.Object_Base} a Object A\n    * @param {gs.Object_Base} b Object B\n    ###    \n    sort_: (a, b) ->\n        if a.order > b.order\n          return -1\n        else if a.order < b.order\n          return 1\n        else\n          return 0\n    \n    ###*\n    * Updates a specified control.\n    *\n    * @method updateControl\n    * @protected\n    * @param {gs.Object_Base} control The control to update\n    ### \n    updateControl: (control) ->\n        @object.rIndex = Math.max(@object.rIndex, control.rIndex)\n        \n        if control.updateBehavior == ui.UpdateBehavior.CONTINUOUS\n            control.needsUpdate = yes\n            \n        if control.inheritProperties\n            control.ui.enabled = @object.ui.enabled\n            control.opacity = @object.opacity\n            control.zoom = @object.zoom\n            control.color = @object.color\n            control.tone = @object.tone\n            control.angle = @object.angle\n            control.anchor.x = @object.anchor.x\n            control.anchor.y = @object.anchor.y\n            \n            \n        if control.needsUpdate\n            control.needsUpdate = no\n            control.update()\n            control.parent = @object\n            \n        \n        if @object.clipRect?\n            control.clipRect = @object.clipRect\n     \n    ###*\n    * Updates the content size of the layout. Only works if scrolling is\n    * enabled.\n    *\n    * @method updateContentSize\n    * @protected\n    ### \n    updateContentSize: ->\n        if @object.scrollable\n            @contentSize.width = 0\n            @contentSize.height = 0\n            for control in @object.controls\n                if control\n                    @contentSize.width += control.margin.left + control.dstRect.width + control.margin.right\n                    @contentSize.height += control.margin.top + control.dstRect.height + control.margin.bottom\n            \n            @object.contentHeight = @contentSize.height\n            @object.contentWidth = @contentSize.width\n        \n    ###*\n    * Updates scrolling.\n    *\n    * @method updateScroll\n    ###\n    updateScroll: ->\n        if @object.scrollable\n            @object.scrollableHeight = Math.max(0, @contentSize.height - @object.dstRect.height)\n            if Input.Mouse.wheel <= -1\n                @object.scrollOffsetY = Math.max(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, 0)\n               \n            if Input.Mouse.wheel >= 1\n                @object.scrollOffsetY = Math.min(@object.scrollOffsetY - Input.Mouse.wheelSpeed * 0.1, @object.scrollableHeight)\n                \n        \n            @object.scrollOffsetY = Math.max(Math.min(@object.scrollOffsetY, @object.scrollableHeight), 0)\n     \n    ###*\n    * Updates the layout's content.\n    *\n    * @method updateContent\n    ###  \n    updateContent: ->\n        \n    ###*\n    * Updates the layout.\n    *\n    * @method update\n    ###    \n    update: ->\n        super\n        \n        @updateContentSize()\n        @updateScroll()\n        \n        \n        #if @object.needsSort\n        #    @object.subObjects.sort(@sort_)\n        #    @object.needsSort = no\n    \n        \ngs.Component_LayoutBehavior = Component_LayoutBehavior"]}\n//# sourceURL=Component_LayoutBehavior_46.js"},"summary":["name","type","order"]}

Commits for Nextrek/s2s/data/B54FB0D1K9DC1A4671S9BE6E84D78A18EAD1.json

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