SelectionSection.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. import SerializableEditType = require("./SerializableEditType");
  2. import AttributeInfoEdit = require("./AttributeInfoEdit");
  3. import SelectionSectionUI = require("./SelectionSectionUI");
  4. import "./ComponentAttributeUI";
  5. abstract class SelectionSection extends Atomic.UISection {
  6. editType: SerializableEditType;
  7. attrLayout: Atomic.UILayout;
  8. suppressed: boolean = false;
  9. attrEdits: { [name: string]: AttributeInfoEdit } = {};
  10. constructor(editType: SerializableEditType) {
  11. super();
  12. this.editType = editType;
  13. this.text = editType.typeName;
  14. this.value = 1;
  15. this.createUI();
  16. }
  17. refresh() {
  18. for (var name in this.attrEdits) {
  19. this.attrEdits[name].refresh();
  20. }
  21. }
  22. suppress(value: boolean) {
  23. if (this.suppressed == value) {
  24. return;
  25. }
  26. this.suppressed = value;
  27. if (value) {
  28. this.visibility = Atomic.UI_WIDGET_VISIBILITY_GONE;
  29. } else {
  30. this.visibility = Atomic.UI_WIDGET_VISIBILITY_VISIBLE;
  31. }
  32. }
  33. createUI() {
  34. var attrLayout = this.attrLayout = new Atomic.UILayout(Atomic.UI_AXIS_Y);
  35. attrLayout.spacing = 3;
  36. attrLayout.layoutPosition = Atomic.UI_LAYOUT_POSITION_LEFT_TOP;
  37. attrLayout.layoutSize = Atomic.UI_LAYOUT_SIZE_AVAILABLE;
  38. this.contentRoot.addChild(attrLayout);
  39. for (var i in this.editType.attrInfos) {
  40. var attr = this.editType.attrInfos[i];
  41. if (attr.mode & Atomic.AM_NOEDIT)
  42. continue;
  43. var attrEdit = AttributeInfoEdit.createAttrEdit(this.editType, attr);
  44. if (!attrEdit)
  45. continue;
  46. this.attrEdits[attr.name] = attrEdit;
  47. attrLayout.addChild(attrEdit);
  48. }
  49. if (SelectionSection.customSectionUI[this.editType.typeName]) {
  50. var ui = new SelectionSection.customSectionUI[this.editType.typeName]();
  51. ui.createUI(this.editType);
  52. attrLayout.addChild(ui);
  53. }
  54. }
  55. static fontDesc: Atomic.UIFontDescription;
  56. static customSectionUI: { [typeName: string]: typeof SelectionSectionUI } = {};
  57. static registerCustomSectionUI(typeName: string, ui: typeof SelectionSectionUI) {
  58. SelectionSection.customSectionUI[typeName] = ui;
  59. }
  60. private static Ctor = (() => {
  61. var fd = SelectionSection.fontDesc = new Atomic.UIFontDescription();
  62. fd.id = "Vera";
  63. fd.size = 11;
  64. })();
  65. }
  66. export = SelectionSection;