X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/579300424ef50990ff9414f2eabf8f371f278d99..ebb166d65eb37f89edeccfc5be97014f3f2a73e2:/apps/workbench/app/assets/javascripts/application.js?ds=sidebyside
diff --git a/apps/workbench/app/assets/javascripts/application.js b/apps/workbench/app/assets/javascripts/application.js
index 3d2914b18c..d66cb9224f 100644
--- a/apps/workbench/app/assets/javascripts/application.js
+++ b/apps/workbench/app/assets/javascripts/application.js
@@ -18,6 +18,8 @@
//= require bootstrap/tooltip
//= require bootstrap/popover
//= require bootstrap/collapse
+//= require bootstrap/modal
+//= require bootstrap/button
//= require bootstrap3-editable/bootstrap-editable
//= require_tree .
@@ -27,7 +29,6 @@ jQuery(function($){
'X-CSRF-Token': $('meta[name="csrf-token"]').attr('content')
}
});
- $('.editable').editable();
$('[data-toggle=tooltip]').tooltip();
$('.expand-collapse-row').on('click', function(event) {
@@ -41,27 +42,108 @@ jQuery(function($){
}
targets.fadeToggle(200);
});
+
$(document).
on('ajax:send', function(e, xhr) {
- $('.loading').show();
+ $('.loading').fadeTo('fast', 1);
}).
on('ajax:complete', function(e, status) {
- $('.loading').hide();
+ $('.loading').fadeOut('fast', 0);
}).
on('click', '.removable-tag a', function(e) {
- $(this).parents('[data-tag-link-uuid]').eq(0).next().andSelf().remove();
+ var tag_span = $(this).parents('[data-tag-link-uuid]').eq(0)
+ tag_span.fadeTo('fast', 0.2);
+ $.ajax('/links/' + tag_span.attr('data-tag-link-uuid'),
+ {dataType: 'json',
+ type: 'POST',
+ data: { '_method': 'DELETE' },
+ context: tag_span}).
+ done(function(data, status, jqxhr) {
+ this.remove();
+ }).
+ fail(function(jqxhr, status, error) {
+ this.addClass('label-danger').fadeTo('fast', '1');
+ });
+ return false;
}).
on('click', 'a.add-tag-button', function(e) {
- new_tag = window.prompt("Add tag for collection "+
- $(this).parents('tr').attr('data-object-uuid'),
+ var jqxhr;
+ var new_tag_uuid = 'new-tag-' + Math.random();
+ var tag_head_uuid = $(this).parents('tr').attr('data-object-uuid');
+ var new_tag = window.prompt("Add tag for collection "+
+ tag_head_uuid,
"");
- if (new_tag != null) {
- $(this).
- parent().
- find('>span').
- append($('').text(new_tag).append(' ×')).
- append('
');
- }
+ if (new_tag == null)
+ return false;
+ var new_tag_span =
+ $('').
+ attr('data-tag-link-uuid', new_tag_uuid).
+ text(new_tag).
+ css('opacity', '0.2').
+ append(' ');
+ $(this).
+ parent().
+ find('>span').
+ append(new_tag_span).
+ append(' ');
+ $.ajax($(this).attr('data-remote-href'),
+ {dataType: 'json',
+ type: $(this).attr('data-remote-method'),
+ data: {
+ 'link[head_uuid]': tag_head_uuid,
+ 'link[link_class]': 'tag',
+ 'link[name]': new_tag
+ },
+ context: new_tag_span}).
+ done(function(data, status, jqxhr) {
+ this.attr('data-tag-link-uuid', data.uuid).
+ fadeTo('fast', '1');
+ }).
+ fail(function(jqxhr, status, error) {
+ this.addClass('label-danger').fadeTo('fast', '1');
+ });
return false;
});
-})(jQuery);
+
+ $(document).
+ on('ajax:complete ready', function() {
+ // See http://getbootstrap.com/javascript/#buttons
+ $('.btn').button();
+ });
+
+ HeaderRowFixer = function(selector) {
+ this.duplicateTheadTr = function() {
+ $(selector).each(function() {
+ var the_table = this;
+ if ($('>tbody>tr:first>th', the_table).length > 0)
+ return;
+ $('>tbody', the_table).
+ prepend($('>thead>tr', the_table).
+ clone().
+ css('opacity', 0));
+ });
+ }
+ this.fixThead = function() {
+ $(selector).each(function() {
+ var widths = [];
+ $('> tbody > tr:eq(1) > td', this).each( function(i,v){
+ widths.push($(v).width());
+ });
+ for(i=0;i