aboutsummaryrefslogtreecommitdiff
path: root/web/app/view/BaseEditDialogController.js
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2015-09-23 12:03:00 +1200
committerAnton Tananaev <anton.tananaev@gmail.com>2015-09-23 12:03:00 +1200
commit45249d656002ac258f18fbc4713408dcefc08ee2 (patch)
tree478fa035a5dfdf8dc2b8b4fedef35316781c1678 /web/app/view/BaseEditDialogController.js
parent7de3f92aed50668bca4187a3b9fb784923be1b34 (diff)
parent9c46d4cffe47dab99e87111a5e33aa5246c771ab (diff)
downloadtrackermap-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.js22
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();
}
});