diff options
author | Morris Jobke <hey@morrisjobke.de> | 2015-03-25 15:46:59 +0100 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2015-03-25 15:46:59 +0100 |
commit | d83741396a771ebb5912c1556c01bc8be5e68fae (patch) | |
tree | b1b99169f645df48f4a25092c27ae6c6e5c97d93 | |
parent | 13904a7f8979a87492ac765e05017eb1e4b69588 (diff) | |
parent | c68fd6d5e3739ebc318a27838dbce13ba8df2b02 (diff) | |
download | nextcloud-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.js | 51 |
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; |