CreateProject.ts 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. //
  2. // Copyright (c) 2014-2015, THUNDERBEAST GAMES LLC All rights reserved
  3. // LICENSE: Atomic Game Engine Editor and Tools EULA
  4. // Please see LICENSE_ATOMIC_EDITOR_AND_TOOLS.md in repository root for
  5. // license information: https://github.com/AtomicGameEngine/AtomicGameEngine
  6. //
  7. import EditorEvents = require("../../editor/EditorEvents");
  8. import EditorUI = require("../EditorUI");
  9. import ModalWindow = require("./ModalWindow");
  10. import ProjectTemplates = require("../resources/ProjectTemplates");
  11. class CreateProject extends ModalWindow {
  12. constructor(projectTemplate: ProjectTemplates.ProjectTemplateDefinition) {
  13. super();
  14. this.projectTemplate = projectTemplate;
  15. this.init("Create Project", "AtomicEditor/editor/ui/createproject.tb.txt");
  16. this.projectPathField = <Atomic.UIEditField>this.getWidget("project_path");
  17. this.projectNameField = <Atomic.UIEditField>this.getWidget("project_name");
  18. this.projectLanguageField = <Atomic.UISelectDropdown>this.getWidget("project_language");
  19. this.image = <Atomic.UIImageWidget>this.getWidget("project_image");
  20. if (!projectTemplate.screenshot)
  21. this.image.visibility = Atomic.UI_WIDGET_VISIBILITY_GONE;
  22. else
  23. this.image.image = projectTemplate.screenshot;
  24. var fileSystem = Atomic.getFileSystem();
  25. var userDocuments = fileSystem.userDocumentsDir;
  26. if (Atomic.platform == "MacOSX") {
  27. userDocuments += "Documents/AtomicProjects";
  28. } else {
  29. userDocuments += "AtomicProjects";
  30. }
  31. this.projectPathField.text = userDocuments;
  32. this.populateLanguageSelectionList();
  33. this.resizeToFitContent();
  34. this.center();
  35. }
  36. tryProjectCreate(): boolean {
  37. var name = this.projectNameField.text.trim();
  38. if (!name) {
  39. EditorUI.showModalError("New Project Editor Error", "Please enter a project name");
  40. return false;
  41. }
  42. var folder = this.projectPathField.text.trim();
  43. if (!folder) {
  44. EditorUI.showModalError("New Project Editor Error", "Please choose a root project folder");
  45. return false;
  46. }
  47. folder += "/" + name;
  48. var fileSystem = Atomic.getFileSystem();
  49. if (fileSystem.dirExists(folder) || fileSystem.fileExists(folder)) {
  50. var message = folder + " exists\n\nPlease choose a different root folder or project name";
  51. EditorUI.showModalError("New Project Editor Error", message);
  52. return false;
  53. }
  54. folder = Atomic.addTrailingSlash(folder);
  55. if (!fileSystem.dirExists(folder)) {
  56. var utils = new Editor.FileUtils();
  57. utils.createDirs(folder);
  58. utils.createDirs(folder + "Cache");
  59. if (!fileSystem.dirExists(folder)) {
  60. var message = "Unable to create folder: " + folder + "\n\nPlease choose a different root folder or project name";
  61. EditorUI.showModalError("New Project Editor Error", message);
  62. return false;
  63. }
  64. }
  65. // Do the creation!
  66. let templateDetail: ProjectTemplates.ProjectTemplateDetail;
  67. let selectedLanguage = this.projectLanguageField.text;
  68. for (let i = 0; i < this.projectTemplate.templates.length; i++) {
  69. if (this.projectTemplate.templates[i].language === selectedLanguage) {
  70. templateDetail = this.projectTemplate.templates[i];
  71. break;
  72. }
  73. }
  74. if (templateDetail) {
  75. fileSystem.copyDir(templateDetail.folder + "Resources", folder + "Resources");
  76. var file = new Atomic.File(folder + name + ".atomic", Atomic.FILE_WRITE);
  77. file.close();
  78. this.hide();
  79. this.sendEvent(EditorEvents.LoadProject, { path: folder });
  80. return true;
  81. } else {
  82. return false;
  83. }
  84. }
  85. handleWidgetEvent(ev: Atomic.UIWidgetEvent) {
  86. if (ev.type == Atomic.UI_EVENT_TYPE_CLICK) {
  87. var id = ev.target.id;
  88. if (id == "cancel") {
  89. this.hide();
  90. return true;
  91. }
  92. else if (id == "choose_path") {
  93. var utils = new Editor.FileUtils();
  94. var path = utils.newProjectFileDialog();
  95. if (path.length)
  96. this.projectPathField.text = path;
  97. return true;
  98. }
  99. else if (id == "create") {
  100. this.tryProjectCreate();
  101. return true;
  102. }
  103. }
  104. }
  105. /**
  106. * Queries the json file for languages that are available to this template and populates the
  107. * list.
  108. */
  109. populateLanguageSelectionList() {
  110. this.projectLanguageFieldSource.clear();
  111. this.projectTemplate.templates.forEach(templateDetail => {
  112. this.projectLanguageFieldSource.addItem(new Atomic.UISelectItem(templateDetail.language));
  113. });
  114. this.projectLanguageField.source = this.projectLanguageFieldSource;
  115. this.projectLanguageField.value = 0;
  116. }
  117. projectPathField: Atomic.UIEditField;
  118. projectNameField: Atomic.UIEditField;
  119. projectLanguageField: Atomic.UISelectDropdown;
  120. projectLanguageFieldSource: Atomic.UISelectItemSource = new Atomic.UISelectItemSource();
  121. image: Atomic.UIImageWidget;
  122. projectTemplate: ProjectTemplates.ProjectTemplateDefinition;
  123. }
  124. export = CreateProject;