summaryrefslogtreecommitdiffstats
path: root/apps/files_external/js/dropbox.js
diff options
context:
space:
mode:
authorMichael Gapczynski <mtgap@owncloud.com>2012-08-13 17:10:36 -0400
committerMichael Gapczynski <mtgap@owncloud.com>2012-08-13 17:10:58 -0400
commit830676b475ad072aa7d6e69a5facae319befa52c (patch)
tree4f4c5c12d5f048be6f3bc5454ce8ba0c28234f6a /apps/files_external/js/dropbox.js
parentd3bdab286b77c58bf8c1accfdb3946402ed9535a (diff)
downloadnextcloud-server-830676b475ad072aa7d6e69a5facae319befa52c.tar.gz
nextcloud-server-830676b475ad072aa7d6e69a5facae319befa52c.zip
Improve usability for configuring Dropbox and Google Drive external storage
Diffstat (limited to 'apps/files_external/js/dropbox.js')
-rw-r--r--apps/files_external/js/dropbox.js46
1 files changed, 34 insertions, 12 deletions
diff --git a/apps/files_external/js/dropbox.js b/apps/files_external/js/dropbox.js
index 08ce88b1026..92194792f42 100644
--- a/apps/files_external/js/dropbox.js
+++ b/apps/files_external/js/dropbox.js
@@ -1,15 +1,17 @@
$(document).ready(function() {
- $('#externalStorage tbody tr').each(function() {
- if ($(this).find('.backend').data('class') == 'OC_Filestorage_Dropbox') {
+ $('#externalStorage tbody tr.OC_Filestorage_Dropbox').each(function() {
+ var configured = $(this).find('[data-parameter="configured"]');
+ if ($(configured).val() == 'true') {
+ $(this).find('.configuration input').attr('disabled', 'disabled');
+ $(this).find('.configuration').append('<span id="access" style="padding-left:0.5em;">Access granted</span>');
+ } else {
var app_key = $(this).find('.configuration [data-parameter="app_key"]').val();
var app_secret = $(this).find('.configuration [data-parameter="app_secret"]').val();
- if (app_key == '' && app_secret == '') {
- $(this).find('.configuration').append('<a class="button dropbox">Grant access</a>');
- } else {
+ var config = $(this).find('.configuration');
+ if (app_key != '' && app_secret != '') {
var pos = window.location.search.indexOf('oauth_token') + 12
var token = $(this).find('.configuration [data-parameter="token"]');
- var access = true;
if (pos != -1 && window.location.search.substr(pos, $(token).val().length) == $(token).val()) {
var token_secret = $(this).find('.configuration [data-parameter="token_secret"]');
var tr = $(this);
@@ -18,16 +20,31 @@ $(document).ready(function() {
$(token).val(result.access_token);
$(token_secret).val(result.access_token_secret);
OC.MountConfig.saveStorage(tr);
+ $(tr).find('.configuration input').attr('disabled', 'disabled');
+ $(tr).find('.configuration').append('<span id="access" style="padding-left:0.5em;">Access granted</span>');
} else {
- access = false;
OC.dialogs.alert(result.data.message, 'Error configuring Dropbox storage');
}
});
}
- if (access && $(this).find('.configuration #granted').length == 0) {
- $(this).find('.configuration input').attr('disabled', 'disabled');
- $(this).find('.configuration').append('<span id="granted">Access granted</span>');
+ } else if ($(this).find('.mountPoint input').val() != '' && $(config).find('[data-parameter="app_key"]').val() != '' && $(config).find('[data-parameter="app_secret"]').val() != '' && $(this).find('.dropbox').length == 0) {
+ $(this).find('.configuration').append('<a class="button dropbox">Grant access</a>');
+ }
+ }
+ });
+
+ $('#externalStorage tbody tr input').live('keyup', function() {
+ var tr = $(this).parent().parent();
+ if ($(tr).hasClass('OC_Filestorage_Dropbox') && $(tr).find('[data-parameter="configured"]').val() != 'true') {
+ var config = $(tr).find('.configuration');
+ if ($(tr).find('.mountPoint input').val() != '' && $(config).find('[data-parameter="app_key"]').val() != '' && $(config).find('[data-parameter="app_secret"]').val() != '') {
+ if ($(tr).find('.dropbox').length == 0) {
+ $(config).append('<a class="button dropbox">Grant access</a>');
+ } else {
+ $(tr).find('.dropbox').show();
}
+ } else if ($(tr).find('.dropbox').length > 0) {
+ $(tr).find('.dropbox').hide();
}
}
});
@@ -38,14 +55,19 @@ $(document).ready(function() {
var app_secret = $(this).parent().find('[data-parameter="app_secret"]').val();
if (app_key != '' && app_secret != '') {
var tr = $(this).parent().parent();
+ var configured = $(this).parent().find('[data-parameter="configured"]');
var token = $(this).parent().find('[data-parameter="token"]');
var token_secret = $(this).parent().find('[data-parameter="token_secret"]');
$.post(OC.filePath('files_external', 'ajax', 'dropbox.php'), { step: 1, app_key: app_key, app_secret: app_secret, callback: window.location.href }, function(result) {
if (result && result.status == 'success') {
+ $(configured).val('false');
$(token).val(result.data.request_token);
$(token_secret).val(result.data.request_token_secret);
- OC.MountConfig.saveStorage(tr);
- window.location = result.data.url;
+ if (OC.MountConfig.saveStorage(tr)) {
+ window.location = result.data.url;
+ } else {
+ OC.dialogs.alert('Fill out all required fields', 'Error configuring Dropbox storage');
+ }
} else {
OC.dialogs.alert(result.data.message, 'Error configuring Dropbox storage');
}