summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2015-03-25 15:46:59 +0100
committerMorris Jobke <hey@morrisjobke.de>2015-03-25 15:46:59 +0100
commitd83741396a771ebb5912c1556c01bc8be5e68fae (patch)
treeb1b99169f645df48f4a25092c27ae6c6e5c97d93
parent13904a7f8979a87492ac765e05017eb1e4b69588 (diff)
parentc68fd6d5e3739ebc318a27838dbce13ba8df2b02 (diff)
downloadnextcloud-server-d83741396a771ebb5912c1556c01bc8be5e68fae.tar.gz
nextcloud-server-d83741396a771ebb5912c1556c01bc8be5e68fae.zip
Merge pull request #15180 from owncloud/ext-tabbing
Use individual timers for separate config rows
-rw-r--r--apps/files_external/js/settings.js51
1 files changed, 21 insertions, 30 deletions
diff --git a/apps/files_external/js/settings.js b/apps/files_external/js/settings.js
index 9e4d026980f..254bab30c56 100644
--- a/apps/files_external/js/settings.js
+++ b/apps/files_external/js/settings.js
@@ -412,7 +412,7 @@ MountConfigListView.prototype = {
/**
* Flag whether the list is about user storage configs (true)
* or global storage configs (false)
- *
+ *
* @type bool
*/
_isPersonal: false,
@@ -488,35 +488,12 @@ MountConfigListView.prototype = {
_initEvents: function() {
var self = this;
- this.$el.on('paste', 'td input', function() {
- var $me = $(this);
- var $tr = $me.closest('tr');
- setTimeout(function() {
- highlightInput($me);
- self.saveStorageConfig($tr);
- }, 20);
- });
-
- var timer;
-
- this.$el.on('keyup', 'td input', function() {
- clearTimeout(timer);
- var $tr = $(this).closest('tr');
- highlightInput($(this));
- if ($(this).val) {
- timer = setTimeout(function() {
- self.saveStorageConfig($tr);
- }, 2000);
- }
- });
-
- this.$el.on('change', 'td input:checkbox', function() {
- self.saveStorageConfig($(this).closest('tr'));
- });
-
- this.$el.on('change', '.applicable', function() {
- self.saveStorageConfig($(this).closest('tr'));
- });
+ var onChangeHandler = _.bind(this._onChange, this);
+ //this.$el.on('input', 'td input', onChangeHandler);
+ this.$el.on('keyup', 'td input', onChangeHandler);
+ this.$el.on('paste', 'td input', onChangeHandler);
+ this.$el.on('change', 'td input:checkbox', onChangeHandler);
+ this.$el.on('change', '.applicable', onChangeHandler);
this.$el.on('click', '.status>span', function() {
self.recheckStorageConfig($(this).closest('tr'));
@@ -529,6 +506,20 @@ MountConfigListView.prototype = {
this.$el.on('change', '.selectBackend', _.bind(this._onSelectBackend, this));
},
+ _onChange: function(event) {
+ var self = this;
+ var $target = $(event.target);
+ highlightInput($target);
+ var $tr = $target.closest('tr');
+
+ var timer = $tr.data('save-timer');
+ clearTimeout(timer);
+ timer = setTimeout(function() {
+ self.saveStorageConfig($tr);
+ }, 2000);
+ $tr.data('save-timer', timer);
+ },
+
_onSelectBackend: function(event) {
var $target = $(event.target);
var $el = this.$el;