1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-08-02 07:47:32 +00:00

Merge pull request #1075 from haiwen/clean_share

[file view] clean 'share'
This commit is contained in:
Daniel Pan 2016-03-19 13:09:31 +08:00
commit 6f2014593f
2 changed files with 6 additions and 337 deletions

View File

@ -1,15 +1,9 @@
{% load i18n %} {# for file/dir share #}
{% load i18n %}
<div id="file-share" class="hide">
<h3 class="hd">{% trans 'Share %(name)s' %}</h3>
<div id="file-share-tabs" class="left-right-tabs ovhd">
<ul class="left-right-tabs-nav fleft">
<li class="tab"><a href="#link-share" class="a">{% trans "Download Link" %}</a></li>
{% if user_perm == 'rw' %}
<li class="tab" id="upload-link-share-tab"><a href="#upload-link-share" class="a">{% trans "Upload Link" %}</a></li>{# for dir #}
{% endif %}
{% if ENABLE_SUB_LIBRARY and not repo.is_virtual and is_repo_owner %}
<li class="tab" id="syncable-share-tab"><a href="#syncable-share" class="a">{% trans "Private Share" %}</a></li> {# for dir #}
{% endif %}
</ul>
<div class="fright">
@ -58,51 +52,6 @@
</div>
</div>
{% if user_perm == 'rw' %}
<div id="upload-link-share" class="tabs-panel">
<p class="tip">{% trans "You can share the generated link to others and then they can upload files to this directory via the link." %}</p>
<div id="upload-link-options">
<label class="checkbox-label">
<span class="checkbox"><input type="checkbox" name="use-passwd" id="upload-link-passwd-switch" class="checkbox-orig" /></span>
<span class="checkbox-option">{% trans "Add password protection"%}</span>
</label>
<div id="upload-link-passwd" class="hide">
<label>{% trans "Password"%}</label><span class="tip">{% blocktrans %}(at least {{share_link_password_min_length}} characters){% endblocktrans %}</span><br />
<input type="password" name="passwd" disabled="disabled" class="input input-disabled" /><br />
<label>{% trans "Password again"%}</label><br />
<input type="password" name="passwd_again" disabled="disabled" class="input input-disabled" />
</div>
<p class="error hide"></p>
</div>
<button id="gen-upload-link-btn" class="hide">{% trans "Generate"%}</button>
<div id="share-upload-link-body" class="hide">
<p><span class="vam">{% trans 'Upload Link: ' %}</span><input type="text" readonly="readonly" id="shared-upload-link-text" class="vam" /></p>
<button id="send-upload-link">{% trans 'Send' %}</button>
<button id="rm-shared-upload-link">{% trans 'Delete' %}</button>
<form id="upload-link-send-form" action="" method="post" class="hide">{% csrf_token %}
<label>{% trans "Send to:"%}</label><br />
<input type="text" class="input" id="upload-link-send-input" name="email" placeholder="{% trans "Emails, Seperated by ','"%}" /><br />
<input type="hidden" name="shared_upload_link" value="{{ dir_shared_upload_link }}" />
<label>{% trans "Message (optional):"%}</label><br />
<textarea class="textarea" name="extra_msg" id="upload-extra-msg-text"></textarea><br />
<p class="error hide"></p>
<input type="submit" value="{% trans "Submit"%}" class="submit" />
<input type="button" value="{% trans "Cancel"%}" class="cancel" />
<p id="upload-sending" class="hide">{% trans "Sending..."%}</p>
</form>
</div>
</div>
{% endif %}
{% if ENABLE_SUB_LIBRARY and not repo.is_virtual and is_repo_owner %}
<div id="syncable-share" class="tabs-panel">
{% url 'share_repo' as repo_share_url %}
{% with post_url=repo_share_url %}
{% include "snippets/repo_share_form.html" %} {# for sub-lib share #}
{% endwith %}
</div>
{% endif %}
</div>
</div>

View File

@ -1,7 +1,8 @@
{% load i18n %}
{% load url from future %}
var share_list = [], contacts = [];
/*
var share_list = [];
$(function () {
$.ajax({
url:'{% url 'get_contacts' %}',
@ -12,66 +13,21 @@ $(function () {
for (var i = 0, len = contact_list.length; i < len; i++) {
contact_email = contact_list[i].email;
share_list.push({value: contact_email, label: contact_email});
contacts.push({value:contact_email, avatar:contact_list[i].avatar});
}
}
});
});
*/
function showSharePopup(op, name, aj_data, type, cur_path) {
var path;
if (op.attr('id') == 'share-cur-dir') {
path = cur_path.substr(0, cur_path.length - 1); // rm the last '/' as seafile_api treats '/xx' and '/xx/' as different
} else {
path = cur_path + name;
}
var path = cur_path + name;
var form = $('#file-share');
{% if ENABLE_SUB_LIBRARY and not repo.is_virtual and is_repo_owner %}
var grp_options_ct = $('#share-grp-options');
if (!$.trim(grp_options_ct.html())) {
var grp_options = '<ul class="option-list">';
{% for group in request.user.joined_groups %}
grp_options += '<li> <label class="checkbox-label"> <span class="checkbox"><input type="checkbox" name="grp" value="{{ group.group_name }}" class="checkbox-orig"/></span> {{group.avatar|safe}} <span class="checkbox-option">' + "{{ group.group_name }}" + '</span> </label> </li>';
{% endfor %}
grp_options += '</ul>';
grp_options_ct.html(grp_options);
}
var contact_options_ct = $('#share-contact-options');
if (!$.trim(contact_options_ct.html())) {
var contact_options = '<ul class="option-list">';
for (var i = 0, len = contacts.length; i < len; i++) {
contact_email = contacts[i].value;
contact_options += ' <li> <label class="checkbox-label"> <span class="checkbox"><input type="checkbox" name="contact" value="' + contact_email + '" class="checkbox-orig" /></span>' + contacts[i].avatar + ' <span class="checkbox-option">' + contact_email + '</span> </label> </li>';
}
contact_options += '</ul>';
contact_options_ct.html(contact_options);
}
$('.checkbox-orig', $('#share-grp-options, #share-contact-options')).click(function() {
$(this).parent().toggleClass('checkbox-checked');
});
$(".checkbox-label", $('#share-grp-options, #share-contact-options')).hover(
function() {
$(this).addClass('hl');
},
function() {
$(this).removeClass('hl');
}
);
{% endif %}
form.modal({appendTo: "#main",'focus':false, containerCss:{"padding":0}});
var hd = $('#file-share .hd');
hd.html(hd.html().replace('%(name)s', '<span class="op-target">' + HTMLescape(trimFilename(name, 30)) + '</span>'));
if (type == 'd') {
$('#private-share-tab, #private-share').remove();
} else {
$('#syncable-share-tab, #syncable-share, #upload-link-share-tab, #upload-link-share').remove();
}
$("#file-share-tabs").tabs();
// share link
@ -92,61 +48,6 @@ function showSharePopup(op, name, aj_data, type, cur_path) {
$('input[name="file_shared_name"]').val(name);
$('input[name="file_shared_type"]').val(type);
{% if user_perm == 'rw' %}
// share upload link
$('#upload-link-share-tab .a').click(function() {
if (op.attr('data-upload-link')) {
$('#gen-upload-link-btn, #upload-link-options').addClass('hide');
$('#share-upload-link-body').removeClass('hide');
var link = op.attr('data-upload-link');
$('#shared-upload-link-text, #upload-link-send-form input[name="shared_upload_link"]').val(link);
$('#main').append('<p id="linkwidth" class="hide">' + link + '</p>');
$('#shared-upload-link-text').css({'width':$('#linkwidth').width() + 25});
$('#linkwidth').remove();
} else {
$('#gen-upload-link-btn, #upload-link-options').removeClass('hide');
$('#share-upload-link-body').addClass('hide');
}
$('#gen-upload-link-btn').data('aj_data', aj_data).data('obj', op);
$('#rm-shared-upload-link').data('obj', op);
});
{% endif %}
// 'private share' for file
$('#private-share-tab a').click(function() {
var form = $('#private-share-form');
$("input[name=s_type]", form).val(type);
$("input[name=path]", form).val(path);
var opts = '', email, avatar;
for (var i = 0, len = contacts.length; i < len; i++) {
email = contacts[i].value;
opts += '<option value="' + email + '" data-index="' + i + '">' + email + '</option>';
}
var format = function(item) {
return contacts[$(item.element).data('index')].avatar + '<span class="vam">' + item.text + '</span>';
}
$('[name="emails"]', form).html(opts).select2({
placeholder: "{% trans "Select contacts" %}",
formatResult: format,
formatSelection: format,
escapeMarkup: function(m) { return m; }
});
});
{% if ENABLE_SUB_LIBRARY and not repo.is_virtual and is_repo_owner %}
// syncable share for dir
$('#syncable-share-tab a').click(function() {
var form = $("#repo-share-form");
form.removeClass('hide').css({'width':'auto', 'padding-top':0});
$("h3", form).remove();
$('.checkbox-label', form).css({'margin-right':'3px'}); // make it not show on top of the scrollbar when hover
form.data('dir-path', path);
$("#repo-share-tabs").tabs();
$('#repo-share-tabs .ui-tabs-nav').css({'padding-left': '1.4em'});
});
{% endif %}
$('#simplemodal-container').css({'height':'auto', 'width':'auto'});
}
@ -158,7 +59,7 @@ $('#send-link').click(function() {
var text = $('#download-extra-msg-text');
text.css({'width': $('#link-share').width() - parseInt(text.css('padding-left')) - parseInt(text.css('padding-right')) - parseInt(text.css('border-left-width')) - parseInt(text.css('border-right-width'))});
$('#link-send-form').removeClass('hide');
addAutocomplete('#link-send-input', '#link-send-form', share_list);
//addAutocomplete('#link-send-input', '#link-send-form', share_list);
});
$("#link-send-form .cancel").click(function() {
@ -329,187 +230,6 @@ $('#rm-shared-link').click(function() {
});
});
{% if user_perm == 'rw' %}
$('#shared-upload-link-text').click(function() {
$(this).select();
});
$('#send-upload-link').click(function() {
$(this).addClass('hide');
$('#rm-shared-upload-link').addClass('hide');
var input = $('#upload-link-send-input');
input.css({'width': $('#upload-link-share').width() - parseInt(input.css('padding-left')) - parseInt(input.css('padding-right')) - parseInt(input.css('border-left-width')) - parseInt(input.css('border-right-width'))});
var text = $('#upload-extra-msg-text');
text.css({'width': $('#upload-link-share').width() - parseInt(text.css('padding-left')) - parseInt(text.css('padding-right')) - parseInt(text.css('border-left-width')) - parseInt(text.css('border-right-width'))});
$('#upload-link-send-form').removeClass('hide');
addAutocomplete('#upload-link-send-input', '#upload-link-send-form', share_list);
});
$("#upload-link-send-form .cancel").click(function() {
$('#upload-link-send-form, #send-upload-link, #rm-shared-upload-link').toggleClass('hide');
});
$("#upload-link-send-form").submit(function(event) {
var form = $(this),
shared_upload_link = form.children('input[name="shared_upload_link"]').val(),
email = $.trim(form.children('input[name="email"]').val()),
submit_btn = form.children('input[type="submit"]'),
extra_msg = form.children('textarea[name="extra_msg"]').val();
if (!email) {
apply_form_error('upload-link-send-form', "{% trans "Please input at least an email." %}");
return false;
}
disable(submit_btn);
$('#upload-link-send-form .error').addClass('hide');
$('#upload-sending').removeClass('hide');
$.ajax({
type: "POST",
url: "{% url 'send_shared_upload_link' %}",
dataType: 'json',
cache: false,
beforeSend: prepareCSRFToken,
data: {
shared_upload_link: shared_upload_link,
email: email,
extra_msg: extra_msg
},
success: function(data) {
$.modal.close();
var msg = "{% trans "Successfully sent to {placeholder}" %}"
.replace('{placeholder}', data['send_success'].join(', '));
feedback(msg, "success");
if (data['send_failed'].length > 0) {
msg += '<br />' + "{% trans "Failed to send to {placeholder}" %}"
.replace('{placeholder}', data['send_failed'].join(', '));
feedback(msg, 'info');
}
},
error: function(xhr, textStatus, errorThrown) {
$('#upload-sending').addClass('hide');
enable(submit_btn);
var err_str = '';
if (xhr.responseText) {
var err = jQuery.parseJSON(xhr.responseText);
if (err.error) {
err_str = err.error;
} else {
for (var i in err) {
err_str += err[i];
}
}
} else {
err_str = "{% trans "Failed. Please check the network." %}";
}
apply_form_error('upload-link-send-form', err_str);
}
});
return false;
});
$('#gen-upload-link-btn').click(function() {
var gen_upload_link_btn = $(this),
obj = gen_upload_link_btn.data('obj'),
form = $('#upload-link-options'),
form_id = form.attr('id'),
passwd_switch = $('#upload-link-passwd-switch'),
use_passwd = passwd_switch.attr('checked'),
passwd, passwd_again, post_data;
if (use_passwd) {
passwd = $('input[name="passwd"]', form).val();
passwd_again = $('input[name="passwd_again"]', form).val();
if (!$.trim(passwd)) {
apply_form_error(form_id, "{% trans "Please enter password" %}");
return false;
}
if ($.trim(passwd).length < {{share_link_password_min_length}}) {
apply_form_error(form_id, "{% trans "Password is too short" %}");
return false;
}
if (!$.trim(passwd_again)) {
apply_form_error(form_id, "{% trans "Please enter the password again" %}");
return false;
}
if ($.trim(passwd) != $.trim(passwd_again)) {
apply_form_error(form_id, "{% trans "Passwords don't match" %}");
return false;
}
post_data = {'use_passwd': 1, 'passwd': passwd};
} else {
post_data = {'use_passwd': 0};
}
$.ajax({
url: '{% url 'ajax_get_upload_link' %}',
type: 'POST',
dataType: 'json',
beforeSend: prepareCSRFToken,
data: $.extend(post_data, {
'repo_id': $(this).data('aj_data').repo_id,
'p': $(this).data('aj_data').p
}),
success: function(data) {
var upload_link = data['upload_link'];
gen_upload_link_btn.addClass('hide');
$('#upload-link-options, #upload-link-options .error').addClass('hide');
$('#upload-link-passwd').hide();
$('#upload-link-passwd-switch').attr('checked', false).parent().removeClass('checkbox-checked');
$('[type="password"]', form).val('').attr('disabled', false).removeClass('input-disabled');
$('#shared-upload-link-text, #upload-link-send-form input[name="shared_upload_link"]').val(upload_link);
$('#main').append('<p id="linkwidth" class="hide">' + upload_link + '</p>');
$('#shared-upload-link-text').css({'width':$('#linkwidth').width() + 25});
$('#linkwidth').remove();
$('#share-upload-link-body').removeClass('hide');
obj.attr({'data-upload-link': upload_link, 'data-upload-token': data['token']});
},
error: function(xhr, textStatus, errorThrown) {
location.reload(true);
}
});
return false;
});
$('#rm-shared-upload-link').click(function() {
var obj = $(this).data('obj'),
token = obj.attr('data-upload-token');
$.ajax({
url: '{% url 'ajax_remove_shared_upload_link' %}',
type: 'POST',
data: {'t': token},
dataType: 'json',
cache: false,
beforeSend: prepareCSRFToken,
success: function(data) {
$('#share-upload-link-body').addClass('hide');
$('#upload-link-options, #gen-upload-link-btn').removeClass('hide');
obj.attr({'data-upload-link': '', 'data-upload-token':''});
},
error:ajaxErrorHandler
});
});
$('#upload-link-passwd-switch').click(function () {
var form = $('#upload-link-options'),
pwd_input = $('input[type="password"]', form);
var link_passwd = $('#upload-link-passwd');
if ($(this).attr('checked')) {
pwd_input.attr('disabled', false).removeClass('input-disabled');
link_passwd.slideDown(100);
} else {
link_passwd.slideUp(100);
pwd_input.attr('disabled', true).addClass('input-disabled');
}
});
{% endif %}
$('#link-passwd-switch').click(function () {
var form = $('#link-options'),
pwd_input = $('input[type="password"]', form);