| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  | define([ | 
					
						
							|  |  |  |   'jquery', | 
					
						
							| 
									
										
										
										
											2015-02-11 14:45:59 +08:00
										 |  |  |   'jstree', | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  |   'underscore', | 
					
						
							|  |  |  |   'backbone', | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |   'common' | 
					
						
							| 
									
										
										
										
											2015-02-11 14:45:59 +08:00
										 |  |  |   ], function($, jstree, _, Backbone, Common) { | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  |     'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var FileTree = { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |         renderFileTree: function() { | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |         // only list dirs
 | 
					
						
							|  |  |  |         renderDirTree: function($container, $form, initial_data) { | 
					
						
							|  |  |  |             $container.jstree({ | 
					
						
							|  |  |  |                 'core': { | 
					
						
							|  |  |  |                     'data': function(node, callback) { | 
					
						
							|  |  |  |                         if (node.id == "#") { | 
					
						
							|  |  |  |                             callback(initial_data); | 
					
						
							|  |  |  |                         } else { | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                             var repo_id; | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                             var node_path = node.data.path; | 
					
						
							|  |  |  |                             if (node.parents.length == 1) { // parents: ['#']
 | 
					
						
							|  |  |  |                                 repo_id = node.data.repo_id; | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                             } else { | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                                 repo_id = $container.jstree('get_node', node.parents[node.parents.length - 2]).data.repo_id; | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                             } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                             $.ajax({ | 
					
						
							|  |  |  |                                 url: Common.getUrl({name: 'get_dirents', repo_id: repo_id}) | 
					
						
							|  |  |  |                                 + '?path=' + encodeURIComponent(node_path) + '&dir_only=true', | 
					
						
							|  |  |  |                                 cache: false, | 
					
						
							|  |  |  |                                 dataType: 'json', | 
					
						
							|  |  |  |                                 success: function(data) { // data: [{'name': ''}, ...]
 | 
					
						
							|  |  |  |                                     if (data.length) { | 
					
						
							|  |  |  |                                         for (var i = 0, len = data.length; i < len; i++) { | 
					
						
							|  |  |  |                                             node.children.push({ | 
					
						
							|  |  |  |                                                 'text': Common.HTMLescape(data[i].name), | 
					
						
							|  |  |  |                                                 'data': { | 
					
						
							|  |  |  |                                                     'path': node_path + data[i].name + '/', | 
					
						
							|  |  |  |                                                 }, | 
					
						
							|  |  |  |                                                 'children': true | 
					
						
							|  |  |  |                                             }); | 
					
						
							|  |  |  |                                         } | 
					
						
							|  |  |  |                                     } | 
					
						
							|  |  |  |                                 }, | 
					
						
							|  |  |  |                                 complete: function() { | 
					
						
							|  |  |  |                                     callback(node.children); | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                                 } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                             }); | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                         } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     'multiple': false, // only 1 folder is allowed to be selected at one time
 | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                     'animation': 100 | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |             }) | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |             .on('select_node.jstree', function(e, data) { | 
					
						
							|  |  |  |                 var node = data.node; | 
					
						
							|  |  |  |                 var repo_id; | 
					
						
							|  |  |  |                 if (node.parents.length == 1) { // parents: ['#']
 | 
					
						
							|  |  |  |                     repo_id = node.data.repo_id; | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                     repo_id = $container.jstree('get_node', node.parents[node.parents.length - 2]).data.repo_id; | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                 $('input[name="dst_repo"]', $form).val(repo_id); | 
					
						
							|  |  |  |                 $('input[name="dst_path"]', $form).val(node.data.path); | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |             }); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |         renderTreeForPath: function(options) { | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |             var _this = this; | 
					
						
							|  |  |  |             var $form = options.$form, | 
					
						
							|  |  |  |                 $container = options.$container; | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |             var repo_name = options.repo_name, | 
					
						
							| 
									
										
										
										
											2015-02-06 14:25:36 +08:00
										 |  |  |                 repo_id = options.repo_id; | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |             var path = options.path; | 
					
						
							|  |  |  |             if (path != '/') { | 
					
						
							|  |  |  |                 path += '/'; | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |             var json_data = []; | 
					
						
							|  |  |  |             var root_node = { | 
					
						
							|  |  |  |                 'text': Common.HTMLescape(repo_name), | 
					
						
							|  |  |  |                 'data': { | 
					
						
							|  |  |  |                     'repo_id': repo_id, | 
					
						
							|  |  |  |                     'path': '/' | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 'children': [], | 
					
						
							|  |  |  |                 'state': { | 
					
						
							|  |  |  |                     'opened': true | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |             json_data.push(root_node); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |             $.ajax({ | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                 url: Common.getUrl({name: 'get_dirents', repo_id: repo_id}) | 
					
						
							|  |  |  |                 + '?path=' + encodeURIComponent(path) + '&dir_only=true&all_dir=true', | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                 cache: false, | 
					
						
							|  |  |  |                 dataType: 'json', | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                 success: function(data) { // data: [{'name': '', 'parent_dir':''}, ...]
 | 
					
						
							|  |  |  |                     if (data.length) { | 
					
						
							|  |  |  |                         var node, node_path; | 
					
						
							|  |  |  |                         var nodes_with_children = []; | 
					
						
							|  |  |  |                         for (var i = 0, len = data.length; i < len; i++) { | 
					
						
							|  |  |  |                             node_path = data[i].parent_dir + data[i].name + '/'; | 
					
						
							|  |  |  |                             node = { | 
					
						
							|  |  |  |                                 'text': Common.HTMLescape(data[i].name), | 
					
						
							|  |  |  |                                 'data': { | 
					
						
							|  |  |  |                                     'path': node_path | 
					
						
							|  |  |  |                                 } | 
					
						
							|  |  |  |                             }; | 
					
						
							|  |  |  |                             if (path.indexOf(node_path) == 0) { | 
					
						
							|  |  |  |                                 $.extend(node, { | 
					
						
							|  |  |  |                                     'children': [], | 
					
						
							|  |  |  |                                     'state': { | 
					
						
							|  |  |  |                                         'opened': true | 
					
						
							|  |  |  |                                     } | 
					
						
							|  |  |  |                                 }); | 
					
						
							|  |  |  |                                 nodes_with_children.push(node); | 
					
						
							|  |  |  |                             } else { | 
					
						
							|  |  |  |                                 $.extend(node, { | 
					
						
							|  |  |  |                                     'children': true | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                                 }); | 
					
						
							|  |  |  |                             } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                             if (data[i].parent_dir == '/') { | 
					
						
							|  |  |  |                                 root_node.children.push(node); | 
					
						
							|  |  |  |                             } else { | 
					
						
							|  |  |  |                                 for (var j = 0, lenn = nodes_with_children.length; j < lenn; j++) { | 
					
						
							|  |  |  |                                     if (data[i].parent_dir == nodes_with_children[j].data.path) { | 
					
						
							|  |  |  |                                         nodes_with_children[j].children.push(node); | 
					
						
							|  |  |  |                                         break; | 
					
						
							|  |  |  |                                     } | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                                 } | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                 complete: function() { | 
					
						
							|  |  |  |                     _this.renderDirTree($container, $form, json_data); | 
					
						
							| 
									
										
										
										
											2015-01-28 21:18:18 +08:00
										 |  |  |                 } | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  |         prepareOtherReposTree: function(options) { | 
					
						
							|  |  |  |             var _this = this; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |             $('#other-repos .hd').click(function() { | 
					
						
							|  |  |  |                 var $span = $('span', $(this)), | 
					
						
							|  |  |  |                     $form = $('#mv-form'), | 
					
						
							|  |  |  |                     $loading_tip = $(this).next(), | 
					
						
							|  |  |  |                     $container = $("#other-repos-dirs"); | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                 if ($span.hasClass('icon-caret-right')) { | 
					
						
							|  |  |  |                     $span.attr('class','icon-caret-down'); | 
					
						
							|  |  |  |                     $loading_tip.show(); | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  |                     $.ajax({ | 
					
						
							|  |  |  |                         url: Common.getUrl({name:'unenc_rw_repos'}), | 
					
						
							|  |  |  |                         cache: false, | 
					
						
							|  |  |  |                         dataType: 'json', | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                         success: function(data) { // data: [{'id':'', 'name':''}, ...]
 | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  |                             var other_repos = []; | 
					
						
							|  |  |  |                             var cur_repo_id = options.cur_repo_id; | 
					
						
							|  |  |  |                             for (var i = 0, len = data.length; i < len; i++) { | 
					
						
							|  |  |  |                                 if (data[i].id != cur_repo_id) { | 
					
						
							|  |  |  |                                     other_repos.push({ | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                                     'text': Common.HTMLescape(data[i].name), | 
					
						
							|  |  |  |                                     'data': { | 
					
						
							|  |  |  |                                         'repo_id': data[i].id, | 
					
						
							|  |  |  |                                         'path': '/' | 
					
						
							|  |  |  |                                     }, | 
					
						
							|  |  |  |                                     'children': true | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  |                                     }); | 
					
						
							|  |  |  |                                 } | 
					
						
							|  |  |  |                             } | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                             _this.renderDirTree($container, $form, other_repos); | 
					
						
							|  |  |  |                             $container.removeClass('hide'); | 
					
						
							|  |  |  |                         }, | 
					
						
							|  |  |  |                         complete: function() { | 
					
						
							|  |  |  |                             $loading_tip.hide(); | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  |                         } | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2016-08-31 16:10:46 +08:00
										 |  |  |                     $span.attr('class','icon-caret-right'); | 
					
						
							|  |  |  |                     $container.addClass('hide'); | 
					
						
							| 
									
										
										
										
											2015-01-29 11:28:53 +08:00
										 |  |  |                 } | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-01-26 20:54:39 +08:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return FileTree; | 
					
						
							|  |  |  | }); |