diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2015-09-23 12:03:00 +1200 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2015-09-23 12:03:00 +1200 |
commit | 45249d656002ac258f18fbc4713408dcefc08ee2 (patch) | |
tree | 478fa035a5dfdf8dc2b8b4fedef35316781c1678 /web/app/view/BaseEditDialogController.js | |
parent | 7de3f92aed50668bca4187a3b9fb784923be1b34 (diff) | |
parent | 9c46d4cffe47dab99e87111a5e33aa5246c771ab (diff) | |
download | trackermap-server-45249d656002ac258f18fbc4713408dcefc08ee2.tar.gz trackermap-server-45249d656002ac258f18fbc4713408dcefc08ee2.tar.bz2 trackermap-server-45249d656002ac258f18fbc4713408dcefc08ee2.zip |
Merge changes from master branch
Diffstat (limited to 'web/app/view/BaseEditDialogController.js')
-rw-r--r-- | web/app/view/BaseEditDialogController.js | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/web/app/view/BaseEditDialogController.js b/web/app/view/BaseEditDialogController.js index df4db0e50..863a75dcb 100644 --- a/web/app/view/BaseEditDialogController.js +++ b/web/app/view/BaseEditDialogController.js @@ -19,9 +19,27 @@ Ext.define('Traccar.view.BaseEditDialogController', { alias: 'controller.baseEditDialog', onSaveClick: function(button) { - var dialog = button.up('window').down('form'); + var dialog, store, record; + dialog = button.up('window').down('form'); dialog.updateRecord(); - dialog.getRecord().save(); + record = dialog.getRecord(); + store = record.store; + if (store) { + if (record.phantom) { + store.add(record); + } + store.sync({ + success: function() { + store.reload(); // workaround for selection problem + }, + failure: function(batch) { + store.rejectChanges(); + Traccar.ErrorManager.check(true, batch.exceptions[0].getResponse()); + } + }); + } else { + record.save(); + } button.up('window').close(); } }); |