SelectionSection.ts 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  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. customUI: SelectionSectionUI;
  10. attrEdits: { [name: string]: AttributeInfoEdit } = {};
  11. constructor(editType: SerializableEditType) {
  12. super();
  13. this.editType = editType;
  14. this.text = editType.typeName;
  15. this.createUI();
  16. }
  17. refresh() {
  18. for (var name in this.attrEdits) {
  19. this.attrEdits[name].refresh();
  20. }
  21. if (this.customUI)
  22. this.customUI.refresh();
  23. }
  24. suppress(value: boolean) {
  25. if (this.suppressed == value) {
  26. return;
  27. }
  28. this.suppressed = value;
  29. if (value) {
  30. this.visibility = Atomic.UI_WIDGET_VISIBILITY_GONE;
  31. } else {
  32. this.visibility = Atomic.UI_WIDGET_VISIBILITY_VISIBLE;
  33. }
  34. }
  35. updateDynamicAttrInfos(attrInfos: Atomic.AttributeInfo[]) {
  36. Atomic.ui.blockChangedEvents = true;
  37. this.editType.attrInfos = attrInfos;
  38. var attrEdit: AttributeInfoEdit;
  39. var remove: AttributeInfoEdit[] = [];
  40. var addWidget: Atomic.UIWidget;
  41. for (var name in this.attrEdits) {
  42. attrEdit = this.attrEdits[name];
  43. if (attrEdit.attrInfo.dynamic) {
  44. remove.push(attrEdit);
  45. } else {
  46. addWidget = attrEdit;
  47. }
  48. }
  49. for (var i in remove) {
  50. var attrEdit = remove[i];
  51. attrEdit.remove();
  52. delete this.attrEdits[attrEdit.attrInfo.name];
  53. }
  54. for (var i in attrInfos) {
  55. var attr = attrInfos[i];
  56. if (!attr.dynamic) {
  57. continue;
  58. }
  59. if (attr.mode & Atomic.AM_NOEDIT)
  60. continue;
  61. var attrEdit = AttributeInfoEdit.createAttrEdit(this.editType, attr);
  62. if (!attrEdit)
  63. continue;
  64. this.attrEdits[attr.name] = attrEdit;
  65. if (!addWidget) {
  66. this.attrLayout.addChild(attrEdit);
  67. addWidget = attrEdit;
  68. } else {
  69. this.attrLayout.addChildAfter(attrEdit, addWidget);
  70. addWidget = attrEdit;
  71. }
  72. }
  73. this.refresh();
  74. Atomic.ui.blockChangedEvents = false;
  75. }
  76. createUI() {
  77. var attrLayout = this.attrLayout = new Atomic.UILayout(Atomic.UI_AXIS_Y);
  78. attrLayout.spacing = 3;
  79. attrLayout.layoutPosition = Atomic.UI_LAYOUT_POSITION_LEFT_TOP;
  80. attrLayout.layoutSize = Atomic.UI_LAYOUT_SIZE_AVAILABLE;
  81. this.contentRoot.addChild(attrLayout);
  82. for (var i in this.editType.attrInfos) {
  83. var attr = this.editType.attrInfos[i];
  84. if (attr.mode & Atomic.AM_NOEDIT)
  85. continue;
  86. var attrEdit = AttributeInfoEdit.createAttrEdit(this.editType, attr);
  87. if (!attrEdit)
  88. continue;
  89. this.attrEdits[attr.name] = attrEdit;
  90. attrLayout.addChild(attrEdit);
  91. }
  92. if (SelectionSection.customSectionUI[this.editType.typeName]) {
  93. this.customUI = new SelectionSection.customSectionUI[this.editType.typeName]();
  94. this.customUI.createUI(this.editType);
  95. attrLayout.addChild(this.customUI);
  96. }
  97. }
  98. static fontDesc: Atomic.UIFontDescription;
  99. static customSectionUI: { [typeName: string]: typeof SelectionSectionUI } = {};
  100. static registerCustomSectionUI(typeName: string, ui: typeof SelectionSectionUI) {
  101. SelectionSection.customSectionUI[typeName] = ui;
  102. }
  103. private static Ctor = (() => {
  104. var fd = SelectionSection.fontDesc = new Atomic.UIFontDescription();
  105. fd.id = "Vera";
  106. fd.size = 11;
  107. })();
  108. }
  109. export = SelectionSection;