-<% content_for :tab_line_buttons do %>
-<div class="row">
- <div class="col-md-6"></div>
- <div class="col-md-6">
- <div class="pull-right">
- <span style="padding-left: 1em">Collection storage status:</span>
- <%= render partial: 'toggle_persist', locals: { uuid: @object.uuid, current_state: (@is_persistent ? 'persistent' : 'cache') } %>
+<script>
+// The "each" loop in select_all_files() and unselect_all_files()
+// is needed because .trigger("change") does not play well with clippy.
+// Once clippy has been retired, we should be able to compress this
+// into .filter(":visible").prop("checked", true).trigger("change").
+//
+function select_all_files() {
+ $("#collection_files :checkbox").filter(":visible").each(
+ function() {
+ $(this).prop("checked", true).trigger("change");
+ });
+}
+
+function unselect_all_files() {
+ $("#collection_files :checkbox").filter(":visible").each(
+ function() {
+ $(this).prop("checked", false).trigger("change");
+ });
+}
+</script>
+<div class="selection-action-container" style="padding-left: 1em">
+ <% if !defined? no_checkboxes or !no_checkboxes %>
+ <div class="row">
+ <div class="pull-left">
+ <div class="btn-group btn-group-sm">
+ <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown">Selection... <span class="caret"></span></button>
+ <ul class="dropdown-menu" role="menu">
+ <li><%= link_to "Create new collection with selected files", '#',
+ 'data-href' => combine_selected_path(
+ action_data: {current_project_uuid: @object.owner_uuid}.to_json
+ ),
+ 'data-selection-param-name' => 'selection[]',
+ 'data-selection-action' => 'combine-collections',
+ 'method' => 'post',
+ 'data-toggle' => 'dropdown'
+ %></li>
+ </ul>
+ </div>
+ <div class="btn-group btn-group-sm">
+ <button id="select-all" type="button" class="btn btn-default" onClick="select_all_files()">Select all</button>
+ <button id="unselect-all" type="button" class="btn btn-default" onClick="unselect_all_files()">Unselect all</button>
+ </div>
+ </div>
+ <div class="pull-right">
+ <input class="form-control filterable-control" data-filterable-target="ul#collection_files" id="file_regex" name="file_regex" placeholder="filename regex" type="text"/>
</div>
</div>
-</div>
-<% end %>
+ <p/>
+ <% end %>
<% file_tree = @object.andand.files_tree %>
<% if file_tree.nil? or file_tree.empty? %>
<% else %>
<ul id="collection_files" class="collection_files">
<% dirstack = [file_tree.first.first] %>
- <% file_tree.each_with_index do |(dirname, filename, size), index| %>
+ <% file_tree.take(10000).each_with_index do |(dirname, filename, size), index| %>
<% file_path = CollectionsHelper::file_path([dirname, filename]) %>
<% while dirstack.any? and (dirstack.last != dirname) %>
<% dirstack.pop %></ul></li>
<ul class="collection_files">
<% else %>
<% link_params = {controller: 'collections', action: 'show_file',
- uuid: @object.uuid, file: file_path, size: size} %>
- <div class="collection_files_row">
+ uuid: @object.portable_data_hash, file: file_path, size: size} %>
+ <div class="collection_files_row filterable">
<div class="collection_files_buttons pull-right">
<%= raw(human_readable_bytes_html(size)) %>
+ <% disable_search = (Rails.configuration.filename_suffixes_with_view_icon.include? file_path.split('.')[-1]) ? false : true %>
+ <%= link_to(raw('<i class="fa fa-search"></i>'),
+ link_params.merge(disposition: 'inline'),
+ {title: "View #{file_path}", class: "btn btn-info btn-sm", disabled: disable_search}) %>
+ <%= link_to(raw('<i class="fa fa-download"></i>'),
+ link_params.merge(disposition: 'attachment'),
+ {title: "Download #{file_path}", class: "btn btn-info btn-sm"}) %>
+ </div>
+
+ <div class="collection_files_name">
+ <% if !defined? no_checkboxes or !no_checkboxes %>
<%= check_box_tag 'uuids[]', "#{@object.uuid}/#{file_path}", false, {
:class => 'persistent-selection',
:friendly_type => "File",
:friendly_name => "#{@object.uuid}/#{file_path}",
:href => url_for(controller: 'collections', action: 'show_file',
- uuid: @object.uuid, file: file_path),
+ uuid: @object.portable_data_hash, file: file_path),
:title => "Include #{file_path} in your selections",
} %>
- <%= link_to(raw('<i class="fa fa-search"></i>'),
- link_params.merge(disposition: 'inline'),
- {title: "View #{file_path}", class: "btn btn-info btn-sm"}) %>
- <%= link_to(raw('<i class="fa fa-download"></i>'),
- link_params.merge(disposition: 'attachment'),
- {title: "Download #{file_path}", class: "btn btn-info btn-sm"}) %>
- </div>
+ <span> </span>
+ <% end %>
<% if CollectionsHelper::is_image(filename) %>
- <div class="collection_files_name"><i class="fa fa-fw fa-bar-chart-o"></i> <%= filename %></div>
+ <i class="fa fa-fw fa-bar-chart-o"></i> <%= filename %></div>
</div>
<div class="collection_files_inline">
<%= link_to(image_tag("#{url_for @object}/#{file_path}"),
{title: file_path}) %>
</div>
<% else %>
- <div class="collection_files_name"><i class="fa fa-fw fa-file"></i> <%= filename %></div>
+ <i class="fa fa-fw fa-file"></i> <%= filename %></div>
</div>
<% end %>
</li>
<% content_for :footer_html do %>
<div id="collection-sharing-modal-window" class="modal fade" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true"></div>
<% end %>
+
+</div>