aboutsummaryrefslogtreecommitdiff
path: root/js/io/ui/save-as-dialog.reel/save-as-dialog.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/io/ui/save-as-dialog.reel/save-as-dialog.js')
-rw-r--r--js/io/ui/save-as-dialog.reel/save-as-dialog.js79
1 files changed, 43 insertions, 36 deletions
diff --git a/js/io/ui/save-as-dialog.reel/save-as-dialog.js b/js/io/ui/save-as-dialog.reel/save-as-dialog.js
index 81d1afee..5df91ab9 100644
--- a/js/io/ui/save-as-dialog.reel/save-as-dialog.js
+++ b/js/io/ui/save-as-dialog.reel/save-as-dialog.js
@@ -36,7 +36,12 @@ var SaveAsDialog = exports.SaveAsDialog = Montage.create(Component, {
36 writable: true, 36 writable: true,
37 value: null 37 value: null
38 }, 38 },
39 39 prepareForDraw: {
40 value: function() {
41 this.newFileName.value = this.fileName;
42 this.fileInputField.newFileDirectory.value = this.folderUri;
43 }
44 },
40 willDraw: { 45 willDraw: {
41 enumerable: false, 46 enumerable: false,
42 value: function() {} 47 value: function() {}
@@ -51,19 +56,16 @@ var SaveAsDialog = exports.SaveAsDialog = Montage.create(Component, {
51 var self = this; 56 var self = this;
52 this.fileInputField.selectDirectory = true; 57 this.fileInputField.selectDirectory = true;
53 this.fileInputField.pickerName = "saveAsDirectoryPicker"; 58 this.fileInputField.pickerName = "saveAsDirectoryPicker";
54 this.newFileName.value = this.fileName;
55 this.fileInputField.newFileDirectory.value = this.folderUri;
56 59
57 this.newFileName.addEventListener("keyup", function(evt){self.handleNewFileNameOnkeyup(evt);}, false); 60 this.addEventListener("change@newFileName.value", this.handleNewFileNameChange, false);
58 this.newFileName.addEventListener("paste", this, false); 61 this.newFileName.element.addEventListener("keyup", this, false);
59 this.newFileName.addEventListener("search", this, false);
60 this.eventManager.addEventListener("newFileDirectorySet", function(evt){self.handleNewFileDirectorySet(evt);}, false); 62 this.eventManager.addEventListener("newFileDirectorySet", function(evt){self.handleNewFileDirectorySet(evt);}, false);
61
62 this.okButton.addEventListener("click", function(evt){self.handleOkButtonAction(evt);}, false); 63 this.okButton.addEventListener("click", function(evt){self.handleOkButtonAction(evt);}, false);
63 this.cancelButton.addEventListener("click", function(evt){self.handleCancelButtonAction(evt);}, false); 64 this.cancelButton.addEventListener("click", function(evt){self.handleCancelButtonAction(evt);}, false);
64 65
65 this.newFileName.focus(); 66 this.eventManager.addEventListener("enterKey", this, false);
66 this.newFileName.select(); 67 this.eventManager.addEventListener("escKey", this, false);
68
67 69
68 this.enableOk(); 70 this.enableOk();
69 71
@@ -81,52 +83,57 @@ var SaveAsDialog = exports.SaveAsDialog = Montage.create(Component, {
81 } 83 }
82 }, true); 84 }, true);
83 85
86 this.newFileName.element.focus();
87 this.newFileName.element.select();
88
84 } 89 }
85 }, 90 },
86 91
87 handleNewFileDirectorySet:{ 92 handleNewFileDirectorySet:{
88 value:function(evt){ 93 value:function(evt){
89 if(evt.keyCode === 13){ 94 this.folderUri = evt._event.newFileDirectory;
90 if(!this.okButton.hasAttribute("disabled")) this.handleOkButtonAction(evt); 95 if(this.isValidUri(this.folderUri)){
91 }else if(evt.keyCode === 27){ 96 this.enableOk();
92 this.handleCancelButtonAction(evt);
93 }
94 else{
95 this.folderUri = evt._event.newFileDirectory;
96 if(this.isValidUri(this.folderUri)){
97 this.enableOk();
98 }
99 } 97 }
100 } 98 }
101 }, 99 },
102 100
103 handlePaste:{ 101 handleNewFileNameChange:{
104 value:function(evt){
105 evt.preventDefault();
106 evt.target.value = evt.clipboardData.getData("Text");
107 this.handleNewFileNameOnkeyup(evt);
108 }
109 },
110
111 handleNewFileNameOnkeyup:{
112 value:function(evt){ 102 value:function(evt){
113 this.fileName = this.newFileName.value; 103 this.fileName = this.newFileName.value;
114 if(this.isValidFileName(this.fileName)){ 104 if(this.isValidFileName(this.fileName)){
115 this.enableOk(); 105 this.enableOk();
116 } 106 }
117 if(evt.keyCode === 13){ 107 }
118 if(!this.okButton.hasAttribute("disabled")){ 108 },
109
110 handleKeyup:{
111 value: function(evt){
112 if(evt.keyCode === 13){
113 if(!this.okButton.hasAttribute("disabled")){
119 this.handleOkButtonAction(evt); 114 this.handleOkButtonAction(evt);
120 } 115 }
121 }else if(evt.keyCode === 27){ 116 }else if(evt.keyCode === 27){
122 this.handleCancelButtonAction(evt); 117 this.handleCancelButtonAction(evt);
118 }
119 }
120 },
121
122 handleEnterKey:{
123 value: function(evt){
124 if((this.application.ninja.newFileController.saveAsDialog !== null)
125 && !this.okButton.hasAttribute("disabled")){
126
127 this.handleOkButtonAction(evt);
123 } 128 }
124 } 129 }
125 }, 130 },
126 131
127 handleSearch:{ 132 handleEscKey:{
128 value:function(evt){ 133 value: function(evt){
129 this.handleNewFileNameOnkeyup(evt); 134 if(this.application.ninja.newFileController.saveAsDialog !== null){
135 this.handleCancelButtonAction(evt);
136 }
130 } 137 }
131 }, 138 },
132 139