| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- //
- // Copyright (c) 2014-2016 THUNDERBEAST GAMES LLC
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in
- // all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- // THE SOFTWARE.
- //
- import EditorUI = require("ui/EditorUI");
- class CSComponentClassSelector extends Atomic.UIWindow {
- constructor(editField: Atomic.UIEditField, component: AtomicNETScript.CSComponent) {
- super();
- var assemblyFile = component.componentFile;
- this.text = "Select Class: " + assemblyFile.name;
- this.rect = [0, 0, 400, 512];
- var mainLayout = new Atomic.UILayout();
- mainLayout.gravity = Atomic.UI_GRAVITY.UI_GRAVITY_ALL;
- mainLayout.layoutDistribution = Atomic.UI_LAYOUT_DISTRIBUTION.UI_LAYOUT_DISTRIBUTION_AVAILABLE;
- mainLayout.axis = Atomic.UI_AXIS.UI_AXIS_Y;
- this.contentRoot.addChild(mainLayout);
- // really want a grid container
- var scrollContainer = new Atomic.UIScrollContainer();
- scrollContainer.gravity = Atomic.UI_GRAVITY.UI_GRAVITY_ALL;
- scrollContainer.scrollMode = Atomic.UI_SCROLL_MODE.UI_SCROLL_MODE_Y_AUTO;
- scrollContainer.adaptContentSize = true;
- var scrollLayout = new Atomic.UILayout();
- scrollLayout.layoutPosition = Atomic.UI_LAYOUT_POSITION.UI_LAYOUT_POSITION_LEFT_TOP;
- scrollLayout.layoutDistributionPosition = Atomic.UI_LAYOUT_DISTRIBUTION_POSITION.UI_LAYOUT_DISTRIBUTION_POSITION_LEFT_TOP;
- scrollLayout.axis = Atomic.UI_AXIS.UI_AXIS_Y;
- scrollContainer.contentRoot.addChild(scrollLayout);
- var window = this;
- for (var i in assemblyFile.classNames) {
- var classname = assemblyFile.classNames[i];
- var button = new Atomic.UIButton();
- button.text = classname;
- button.onClick = function() {
- editField.text = this.text;
- component.componentClassName = this.text;
- window.close();
- }.bind(button);
- scrollLayout.addChild(button);
- }
- mainLayout.addChild(scrollContainer);
- EditorUI.getMainFrame().addChild(this);
- this.center();
- this.subscribeToEvent(Atomic.UIWidgetEvent((data) => this.handleWidgetEvent(data)));
- }
- handleWidgetEvent(ev: Atomic.UIWidgetEvent) {
- if (ev.type == Atomic.UI_EVENT_TYPE.UI_EVENT_TYPE_CLICK) {
- if (ev.target != this && !this.isAncestorOf(ev.target)) {
- //this.close();
- }
- }
- return false;
- }
- }
- export = CSComponentClassSelector;
|