diff options
-rw-r--r-- | bitbake/lib/toaster/toastergui/static/js/importlayer.js | 59 | ||||
-rw-r--r-- | bitbake/lib/toaster/toastergui/static/js/projectpage.js | 66 |
2 files changed, 47 insertions, 78 deletions
diff --git a/bitbake/lib/toaster/toastergui/static/js/importlayer.js b/bitbake/lib/toaster/toastergui/static/js/importlayer.js index 191b30ffee..570ca3369b 100644 --- a/bitbake/lib/toaster/toastergui/static/js/importlayer.js +++ b/bitbake/lib/toaster/toastergui/static/js/importlayer.js | |||
@@ -17,7 +17,9 @@ function importLayerPageInit (ctx) { | |||
17 | var currentLayerDepSelection; | 17 | var currentLayerDepSelection; |
18 | var validLayerName = /^(\w|-)+$/; | 18 | var validLayerName = /^(\w|-)+$/; |
19 | 19 | ||
20 | libtoaster.makeTypeahead(layerDepInput, libtoaster.ctx.layersTypeAheadUrl, { include_added: "true" }, function(item){ | 20 | libtoaster.makeTypeahead(layerDepInput, |
21 | libtoaster.ctx.layersTypeAheadUrl, | ||
22 | { include_added: "true" }, function(item){ | ||
21 | currentLayerDepSelection = item; | 23 | currentLayerDepSelection = item; |
22 | }); | 24 | }); |
23 | 25 | ||
@@ -95,7 +97,8 @@ function importLayerPageInit (ctx) { | |||
95 | 97 | ||
96 | $("#layer-deps-list").append(newLayerDep); | 98 | $("#layer-deps-list").append(newLayerDep); |
97 | 99 | ||
98 | libtoaster.getLayerDepsForProject(currentLayerDepSelection.layerdetailurl, function (data){ | 100 | libtoaster.getLayerDepsForProject(currentLayerDepSelection.layerdetailurl, |
101 | function (data){ | ||
99 | /* These are the dependencies of the layer added as a dependency */ | 102 | /* These are the dependencies of the layer added as a dependency */ |
100 | if (data.list.length > 0) { | 103 | if (data.list.length > 0) { |
101 | currentLayerDepSelection.url = currentLayerDepSelection.layerdetailurl; | 104 | currentLayerDepSelection.url = currentLayerDepSelection.layerdetailurl; |
@@ -150,7 +153,9 @@ function importLayerPageInit (ctx) { | |||
150 | var body = "<strong>"+layer.name+"</strong>'s dependencies ("+ | 153 | var body = "<strong>"+layer.name+"</strong>'s dependencies ("+ |
151 | depNames.join(", ")+"</span>) require some layers that are not added to your project. Select the ones you want to add:</p>"; | 154 | depNames.join(", ")+"</span>) require some layers that are not added to your project. Select the ones you want to add:</p>"; |
152 | 155 | ||
153 | showLayerDepsModal(layer, depDepsArray, title, body, false, function(layerObsList){ | 156 | showLayerDepsModal(layer, |
157 | depDepsArray, | ||
158 | title, body, false, function(layerObsList){ | ||
154 | /* Add the accepted layer dependencies' ids to the allDeps array */ | 159 | /* Add the accepted layer dependencies' ids to the allDeps array */ |
155 | for (var key in layerObsList){ | 160 | for (var key in layerObsList){ |
156 | allDeps.push(layerObsList[key].id); | 161 | allDeps.push(layerObsList[key].id); |
@@ -191,9 +196,8 @@ function importLayerPageInit (ctx) { | |||
191 | if (data.error != "ok") { | 196 | if (data.error != "ok") { |
192 | console.log(data.error); | 197 | console.log(data.error); |
193 | } else { | 198 | } else { |
194 | /* Success layer import now go to the project page */ | 199 | createImportedNotification(data); |
195 | $.cookie('layer-imported-alert', JSON.stringify(data), { path: '/'}); | 200 | window.location.replace(libtoaster.ctx.projectPageUrl); |
196 | window.location.replace(libtoaster.ctx.projectPageUrl+'?notify=layer-imported'); | ||
197 | } | 201 | } |
198 | }, | 202 | }, |
199 | error: function (data) { | 203 | error: function (data) { |
@@ -204,6 +208,30 @@ function importLayerPageInit (ctx) { | |||
204 | } | 208 | } |
205 | }); | 209 | }); |
206 | 210 | ||
211 | /* Layer imported notification */ | ||
212 | function createImportedNotification(imported){ | ||
213 | var message = "Layer imported"; | ||
214 | |||
215 | if (imported.deps_added.length === 0) { | ||
216 | message = "You have imported <strong><a class=\"alert-link\" href=\""+imported.imported_layer.layerdetailurl+"\">"+imported.imported_layer.name+"</a></strong> and added it to your project."; | ||
217 | } else { | ||
218 | |||
219 | var links = "<a href=\""+imported.imported_layer.layerdetailurl+"\">"+imported.imported_layer.name+"</a>, "; | ||
220 | |||
221 | imported.deps_added.map (function(item, index){ | ||
222 | links +='<a href="'+item.layerdetailurl+'">'+item.name+'</a>'; | ||
223 | /*If we're at the last element we don't want the trailing comma */ | ||
224 | if (imported.deps_added[index+1] !== undefined) | ||
225 | links += ', '; | ||
226 | }); | ||
227 | |||
228 | /* Length + 1 here to do deps + the imported layer */ | ||
229 | message = 'You have imported <strong><a href="'+imported.imported_layer.layerdetailurl+'">'+imported.imported_layer.name+'</a></strong> and added <strong>'+(imported.deps_added.length+1)+'</strong> layers to your project: <strong>'+links+'</strong>'; | ||
230 | } | ||
231 | |||
232 | libtoaster.setNotification("layer-imported", message); | ||
233 | } | ||
234 | |||
207 | function enable_import_btn(enabled) { | 235 | function enable_import_btn(enabled) { |
208 | var importAndAddHint = $("#import-and-add-hint"); | 236 | var importAndAddHint = $("#import-and-add-hint"); |
209 | 237 | ||
@@ -230,10 +258,13 @@ function importLayerPageInit (ctx) { | |||
230 | } | 258 | } |
231 | 259 | ||
232 | if (valid) { | 260 | if (valid) { |
233 | if ($("#local-dir-radio").prop("checked") && localDirPath.val().length > 0) { | 261 | if ($("#local-dir-radio").prop("checked") && |
262 | localDirPath.val().length > 0) { | ||
234 | enable_import_btn(true); | 263 | enable_import_btn(true); |
235 | } | 264 | } |
236 | if ($("#git-repo-radio").prop("checked") && vcsURLInput.val().length > 0 && gitRefInput.val().length > 0) { | 265 | |
266 | if ($("#git-repo-radio").prop("checked") && | ||
267 | vcsURLInput.val().length > 0 && gitRefInput.val().length > 0) { | ||
237 | enable_import_btn(true); | 268 | enable_import_btn(true); |
238 | } | 269 | } |
239 | } | 270 | } |
@@ -266,13 +297,13 @@ function importLayerPageInit (ctx) { | |||
266 | } | 297 | } |
267 | 298 | ||
268 | layerNameInput.on('blur', function() { | 299 | layerNameInput.on('blur', function() { |
269 | if (!$(this).val()){ | 300 | if (!$(this).val()){ |
270 | return; | 301 | return; |
271 | } | 302 | } |
272 | var name = $(this).val(); | 303 | var name = $(this).val(); |
273 | 304 | ||
274 | /* Check if the layer name exists */ | 305 | /* Check if the layer name exists */ |
275 | $.getJSON(libtoaster.ctx.layersTypeAheadUrl, | 306 | $.getJSON(libtoaster.ctx.layersTypeAheadUrl, |
276 | { include_added: "true" , search: name, format: "json" }, | 307 | { include_added: "true" , search: name, format: "json" }, |
277 | function(layer) { | 308 | function(layer) { |
278 | if (layer.results.length > 0) { | 309 | if (layer.results.length > 0) { |
diff --git a/bitbake/lib/toaster/toastergui/static/js/projectpage.js b/bitbake/lib/toaster/toastergui/static/js/projectpage.js index 7f19c0d7aa..4536703649 100644 --- a/bitbake/lib/toaster/toastergui/static/js/projectpage.js +++ b/bitbake/lib/toaster/toastergui/static/js/projectpage.js | |||
@@ -50,70 +50,8 @@ function projectPageInit(ctx) { | |||
50 | $("#delete-project-modal .project-name").text(prjInfo.name); | 50 | $("#delete-project-modal .project-name").text(prjInfo.name); |
51 | }); | 51 | }); |
52 | 52 | ||
53 | (function notificationRequest(){ | 53 | if (urlParams.hasOwnProperty('notify') && urlParams.notify === 'new-project'){ |
54 | 54 | $("#project-created-notification").show(); | |
55 | if (urlParams.hasOwnProperty('notify')){ | ||
56 | switch (urlParams.notify){ | ||
57 | case 'new-project': | ||
58 | $("#project-created-notification").show(); | ||
59 | break; | ||
60 | case 'layer-imported': | ||
61 | layerImportedNotification(); | ||
62 | break; | ||
63 | case 'layer-deleted': | ||
64 | layerDeletedNotification(); | ||
65 | default: | ||
66 | break; | ||
67 | } | ||
68 | } | ||
69 | })(); | ||
70 | |||
71 | /* Layer deleted notification */ | ||
72 | function layerDeletedNotification(){ | ||
73 | var layer = $.cookie("layer-deleted"); | ||
74 | |||
75 | if (!layer) | ||
76 | return; | ||
77 | |||
78 | var message = "You have deleted <strong>1</strong> layer from your "; | ||
79 | message += "project: <strong>" + layer + "</strong>"; | ||
80 | |||
81 | libtoaster.showChangeNotification(message); | ||
82 | |||
83 | $.removeCookie("layer-deleted", { path: "/"}); | ||
84 | } | ||
85 | |||
86 | |||
87 | /* Layer imported notification */ | ||
88 | function layerImportedNotification(){ | ||
89 | var imported = $.cookie("layer-imported-alert"); | ||
90 | var message = "Layer imported"; | ||
91 | |||
92 | if (!imported) | ||
93 | return; | ||
94 | else | ||
95 | imported = JSON.parse(imported); | ||
96 | |||
97 | if (imported.deps_added.length === 0) { | ||
98 | message = "You have imported <strong><a class=\"alert-link\" href=\""+imported.imported_layer.layerdetailurl+"\">"+imported.imported_layer.name+"</a></strong> and added it to your project."; | ||
99 | } else { | ||
100 | |||
101 | var links = "<a href=\""+imported.imported_layer.layerdetailurl+"\">"+imported.imported_layer.name+"</a>, "; | ||
102 | |||
103 | imported.deps_added.map (function(item, index){ | ||
104 | links +='<a href="'+item.layerdetailurl+'">'+item.name+'</a>'; | ||
105 | /*If we're at the last element we don't want the trailing comma */ | ||
106 | if (imported.deps_added[index+1] !== undefined) | ||
107 | links += ', '; | ||
108 | }); | ||
109 | |||
110 | /* Length + 1 here to do deps + the imported layer */ | ||
111 | message = 'You have imported <strong><a href="'+imported.imported_layer.layerdetailurl+'">'+imported.imported_layer.name+'</a></strong> and added <strong>'+(imported.deps_added.length+1)+'</strong> layers to your project: <strong>'+links+'</strong>'; | ||
112 | } | ||
113 | |||
114 | libtoaster.showChangeNotification(message); | ||
115 | |||
116 | $.removeCookie("layer-imported-alert", { path: "/"}); | ||
117 | } | 55 | } |
118 | 56 | ||
119 | /* Add/Rm layer functionality */ | 57 | /* Add/Rm layer functionality */ |