]> source.dussan.org Git - redmine.git/commitdiff
Added a bit of AJAX on the SCM browser (tree view).
authorJean-Philippe Lang <jp_lang@yahoo.fr>
Mon, 22 Oct 2007 17:45:41 +0000 (17:45 +0000)
committerJean-Philippe Lang <jp_lang@yahoo.fr>
Mon, 22 Oct 2007 17:45:41 +0000 (17:45 +0000)
git-svn-id: http://redmine.rubyforge.org/svn/trunk@862 e93f8b46-1217-0410-a6f0-8f06a7374b81

app/controllers/repositories_controller.rb
app/views/repositories/_dir_list.rhtml
app/views/repositories/_dir_list_content.rhtml [new file with mode: 0644]
public/images/folder.png
public/images/folder_open.png [new file with mode: 0644]
public/javascripts/prototype.js
public/stylesheets/application.css

index 9439481e22101b2d2f4ec67e6e6af0915a978045..945cb26231e049dcf39104b92a6a906cfebb8e60 100644 (file)
@@ -56,7 +56,11 @@ class RepositoriesController < ApplicationController
   
   def browse
     @entries = @repository.entries(@path, @rev)
-    show_error and return unless @entries    
+    if request.xhr?
+      @entries ? render(:partial => 'dir_list_content') : render(:nothing => true)
+    else
+      show_error unless @entries
+    end
   end
   
   def changes
index 5555ee87e0469e48e4837bc79b5731d56f35ee1d..b9c3fd54c6ec60eb4cb159bee4a8c334b7d05d57 100644 (file)
@@ -1,26 +1,15 @@
 <table class="list">
-<thead><tr>
+<thead>
+<tr id="root">
 <th><%= l(:field_name) %></th>
 <th><%= l(:field_filesize) %></th>
 <th><%= l(:label_revision) %></th>
 <th><%= l(:label_date) %></th>
 <th><%= l(:field_author) %></th>
 <th><%= l(:field_comments) %></th>
-</tr></thead>
-<tbody>
-<% total_size = 0
-@entries.each do |entry| %>
-<tr class="<%= cycle 'odd', 'even' %>">
-<td><%= link_to h(entry.name), { :action => (entry.is_dir? ? 'browse' : 'changes'), :id => @project, :path => entry.path, :rev => @rev }, :class => ("icon " + (entry.is_dir? ? 'icon-folder' : 'icon-file')) %></td>
-<td align="right"><%= (entry.size ? number_to_human_size(entry.size) : "?") unless entry.is_dir? %></td>
-<td align="right"><%= link_to(entry.lastrev.name, :action => 'revision', :id => @project, :rev => entry.lastrev.identifier) if entry.lastrev && entry.lastrev.identifier %></td>
-<td align="center"><%= format_time(entry.lastrev.time) if entry.lastrev %></td>
-<td align="center"><em><%=h(entry.lastrev.author) if entry.lastrev %></em></td>
-<% changeset = @project.repository.changesets.find_by_revision(entry.lastrev.identifier) if entry.lastrev %>
-<td><%=h truncate(changeset.comments, 100) unless changeset.nil? %></td>
 </tr>
-<% total_size += entry.size if entry.size
-end %>
+</thead>
+<tbody>
+<%= render :partial => 'dir_list_content' %>
 </tbody>
 </table>
-<p class="textright"><em><%= l(:label_total) %>: <%= number_to_human_size(total_size) %></em></p>
\ No newline at end of file
diff --git a/app/views/repositories/_dir_list_content.rhtml b/app/views/repositories/_dir_list_content.rhtml
new file mode 100644 (file)
index 0000000..742da49
--- /dev/null
@@ -0,0 +1,32 @@
+<% @entries.each do |entry| %>
+<% tr_id = Digest::MD5.hexdigest(entry.path)
+   depth = params[:depth].to_i %>
+<tr id="<%= tr_id %>">
+<td>
+<%= if entry.is_dir?
+  link_to_remote h(entry.name),
+                 {:url => {:action => 'browse', :id => @project, :path => entry.path, :rev => @rev, :depth => (depth + 1)},
+                  :update => tr_id,
+                  :position => :after,
+                  :success => "Element.addClassName('#{tr_id}', 'open');",
+                  :condition => "!Element.hasClassName('#{tr_id}', 'open')"
+                 },
+                 {:href => url_for({:action => 'browse', :id => @project, :path => entry.path, :rev => @rev}),
+                  :class => ('icon icon-folder'),
+                  :style => "margin-left: #{18 * depth}px;"
+                 }
+else
+  link_to h(entry.name),
+          {:action => (entry.is_dir? ? 'browse' : 'changes'), :id => @project, :path => entry.path, :rev => @rev},
+          :class => 'icon icon-file',
+          :style => "margin-left: #{18 * depth}px;"
+end %>
+</td>
+<td align="right"><%= (entry.size ? number_to_human_size(entry.size) : "?") unless entry.is_dir? %></td>
+<td align="right"><%= link_to(entry.lastrev.name, :action => 'revision', :id => @project, :rev => entry.lastrev.identifier) if entry.lastrev && entry.lastrev.identifier %></td>
+<td align="center"><%= format_time(entry.lastrev.time) if entry.lastrev %></td>
+<td align="center"><em><%=h(entry.lastrev.author) if entry.lastrev %></em></td>
+<% changeset = @project.repository.changesets.find_by_revision(entry.lastrev.identifier) if entry.lastrev %>
+<td><%=h truncate(changeset.comments, 50) unless changeset.nil? %></td>
+</tr>
+<% end %>
index d2ab69ad5473f2135155de1d9891d554906e8783..03e56110ca3b08f40cb5c57306a0b48cd6c48b93 100644 (file)
Binary files a/public/images/folder.png and b/public/images/folder.png differ
diff --git a/public/images/folder_open.png b/public/images/folder_open.png
new file mode 100644 (file)
index 0000000..2b49d31
Binary files /dev/null and b/public/images/folder_open.png differ
index 505822177b81910ba7426835e5014c1f3de374de..2735d10dcb78bb6d146ade11b1ba122448b02ff7 100644 (file)
@@ -1629,7 +1629,7 @@ Abstract.Insertion.prototype = {
       } catch (e) {
         var tagName = this.element.tagName.toUpperCase();
         if (['TBODY', 'TR'].include(tagName)) {
-          this.insertContent(this.contentFromAnonymousTable());
+          this.insertContent(this.contentFromAnonymousTable()._reverse());
         } else {
           throw e;
         }
index 298e5748b89cca54a32edbdcad53245cbf1cb5cd..cf0c3baf5715cf9ab7b0daa1862b579151185604 100644 (file)
@@ -432,6 +432,7 @@ vertical-align: middle;
 .icon-txt { background-image: url(../images/txt.png); }
 .icon-file { background-image: url(../images/file.png); }
 .icon-folder { background-image: url(../images/folder.png); }
+.open .icon-folder { background-image: url(../images/folder_open.png); }
 .icon-package { background-image: url(../images/package.png); }
 .icon-home { background-image: url(../images/home.png); }
 .icon-user { background-image: url(../images/user.png); }