From 0e766c9024e2457320f64353e29bb5e2d8294b28 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Tue, 19 Feb 2013 22:09:27 +1300 Subject: Add application settings --- src/org/traccar/web/client/Traccar.java | 10 ++- .../web/client/controller/SettingsController.java | 38 +++++++++- .../model/ApplicationSettingsProperties.java | 30 ++++++++ src/org/traccar/web/client/model/DataService.java | 3 + .../traccar/web/client/model/DataServiceAsync.java | 3 + .../web/client/view/ApplicationSettingsDialog.java | 81 ++++++++++++++++++++++ .../client/view/ApplicationSettingsDialog.ui.xml | 33 +++++++++ src/org/traccar/web/client/view/DeviceView.java | 4 +- src/org/traccar/web/client/view/LoginDialog.java | 10 +++ src/org/traccar/web/client/view/LoginDialog.ui.xml | 2 +- 10 files changed, 207 insertions(+), 7 deletions(-) create mode 100644 src/org/traccar/web/client/model/ApplicationSettingsProperties.java create mode 100644 src/org/traccar/web/client/view/ApplicationSettingsDialog.java create mode 100644 src/org/traccar/web/client/view/ApplicationSettingsDialog.ui.xml (limited to 'src/org/traccar/web/client') diff --git a/src/org/traccar/web/client/Traccar.java b/src/org/traccar/web/client/Traccar.java index 8fa67ecd..d775bb4a 100644 --- a/src/org/traccar/web/client/Traccar.java +++ b/src/org/traccar/web/client/Traccar.java @@ -16,6 +16,8 @@ package org.traccar.web.client; import org.traccar.web.client.controller.LoginController; +import org.traccar.web.client.model.BaseAsyncCallback; +import org.traccar.web.shared.model.ApplicationSettings; import com.google.gwt.core.client.EntryPoint; @@ -23,7 +25,13 @@ public class Traccar implements EntryPoint, LoginController.LoginHandler { @Override public void onModuleLoad() { - new LoginController().login(this); + Application.getDataService().updateApplicationSettings(null, new BaseAsyncCallback() { + @Override + public void onSuccess(ApplicationSettings result) { + ApplicationContext.getInstance().setApplicationSettings(result); + new LoginController().login(Traccar.this); + } + }); } @Override diff --git a/src/org/traccar/web/client/controller/SettingsController.java b/src/org/traccar/web/client/controller/SettingsController.java index b98d1bc8..75130f2b 100644 --- a/src/org/traccar/web/client/controller/SettingsController.java +++ b/src/org/traccar/web/client/controller/SettingsController.java @@ -1,6 +1,26 @@ +/* + * Copyright 2013 Anton Tananaev (anton.tananaev@gmail.com) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package org.traccar.web.client.controller; +import org.traccar.web.client.Application; +import org.traccar.web.client.ApplicationContext; +import org.traccar.web.client.model.BaseAsyncCallback; +import org.traccar.web.client.view.ApplicationSettingsDialog; import org.traccar.web.client.view.DeviceView; +import org.traccar.web.shared.model.ApplicationSettings; public class SettingsController implements DeviceView.SettingsHandler { @@ -23,9 +43,21 @@ public class SettingsController implements DeviceView.SettingsHandler { } @Override - public void onGlobalSelected() { - // TODO Auto-generated method stub - + public void onApplicationSelected() { + new ApplicationSettingsDialog( + ApplicationContext.getInstance().getApplicationSettings(), + new ApplicationSettingsDialog.ApplicationSettingsHandler() { + @Override + public void onSave(ApplicationSettings applicationSettings) { + Application.getDataService().updateApplicationSettings(applicationSettings, new BaseAsyncCallback() { + @Override + public void onSuccess(ApplicationSettings result) { + ApplicationContext.getInstance().setApplicationSettings(result); + } + }); + + } + }).show(); } } diff --git a/src/org/traccar/web/client/model/ApplicationSettingsProperties.java b/src/org/traccar/web/client/model/ApplicationSettingsProperties.java new file mode 100644 index 00000000..b30572e5 --- /dev/null +++ b/src/org/traccar/web/client/model/ApplicationSettingsProperties.java @@ -0,0 +1,30 @@ +/* + * Copyright 2013 Anton Tananaev (anton.tananaev@gmail.com) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.traccar.web.client.model; + +import org.traccar.web.shared.model.ApplicationSettings; + +import com.sencha.gxt.core.client.ValueProvider; +import com.sencha.gxt.data.shared.ModelKeyProvider; +import com.sencha.gxt.data.shared.PropertyAccess; + +public interface ApplicationSettingsProperties extends PropertyAccess { + + ModelKeyProvider id(); + + ValueProvider registrationEnabled(); + +} diff --git a/src/org/traccar/web/client/model/DataService.java b/src/org/traccar/web/client/model/DataService.java index cdf993d4..a16ae51d 100644 --- a/src/org/traccar/web/client/model/DataService.java +++ b/src/org/traccar/web/client/model/DataService.java @@ -18,6 +18,7 @@ package org.traccar.web.client.model; import java.util.Date; import java.util.List; +import org.traccar.web.shared.model.ApplicationSettings; import org.traccar.web.shared.model.Device; import org.traccar.web.shared.model.Position; @@ -47,4 +48,6 @@ public interface DataService extends RemoteService { List getLatestPositions(); + ApplicationSettings updateApplicationSettings(ApplicationSettings applicationSettings); + } diff --git a/src/org/traccar/web/client/model/DataServiceAsync.java b/src/org/traccar/web/client/model/DataServiceAsync.java index f8fdbcda..c0478fb8 100644 --- a/src/org/traccar/web/client/model/DataServiceAsync.java +++ b/src/org/traccar/web/client/model/DataServiceAsync.java @@ -18,6 +18,7 @@ package org.traccar.web.client.model; import java.util.Date; import java.util.List; +import org.traccar.web.shared.model.ApplicationSettings; import org.traccar.web.shared.model.Device; import org.traccar.web.shared.model.Position; @@ -45,4 +46,6 @@ public interface DataServiceAsync { void getPositions(Device device, Date from, Date to, AsyncCallback> callback); + void updateApplicationSettings(ApplicationSettings applicationSettings, AsyncCallback callback); + } diff --git a/src/org/traccar/web/client/view/ApplicationSettingsDialog.java b/src/org/traccar/web/client/view/ApplicationSettingsDialog.java new file mode 100644 index 00000000..24b9f96d --- /dev/null +++ b/src/org/traccar/web/client/view/ApplicationSettingsDialog.java @@ -0,0 +1,81 @@ +/* + * Copyright 2013 Anton Tananaev (anton.tananaev@gmail.com) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.traccar.web.client.view; + +import org.traccar.web.shared.model.ApplicationSettings; + +import com.google.gwt.core.client.GWT; +import com.google.gwt.editor.client.Editor; +import com.google.gwt.editor.client.SimpleBeanEditorDriver; +import com.google.gwt.uibinder.client.UiBinder; +import com.google.gwt.uibinder.client.UiField; +import com.google.gwt.uibinder.client.UiHandler; +import com.google.gwt.user.client.ui.Widget; +import com.sencha.gxt.widget.core.client.Window; +import com.sencha.gxt.widget.core.client.event.SelectEvent; +import com.sencha.gxt.widget.core.client.form.CheckBox; + +public class ApplicationSettingsDialog implements Editor { + + private static ApplicationSettingsDialogUiBinder uiBinder = GWT.create(ApplicationSettingsDialogUiBinder.class); + + interface ApplicationSettingsDialogUiBinder extends UiBinder { + } + + private ApplicationSettingsDriver driver = GWT.create(ApplicationSettingsDriver.class); + + interface ApplicationSettingsDriver extends SimpleBeanEditorDriver { + } + + public interface ApplicationSettingsHandler { + public void onSave(ApplicationSettings applicationSettings); + } + + private ApplicationSettingsHandler applicationSettingsHandler; + + @UiField + Window window; + + @UiField + CheckBox registrationEnabled; + + public ApplicationSettingsDialog(ApplicationSettings applicationSettings, ApplicationSettingsHandler applicationSettingsHandler) { + this.applicationSettingsHandler = applicationSettingsHandler; + uiBinder.createAndBindUi(this); + driver.initialize(this); + driver.edit(applicationSettings); + } + + public void show() { + window.show(); + } + + public void hide() { + window.hide(); + } + + @UiHandler("saveButton") + public void onLoginClicked(SelectEvent event) { + window.hide(); + applicationSettingsHandler.onSave(driver.flush()); + } + + @UiHandler("cancelButton") + public void onRegisterClicked(SelectEvent event) { + window.hide(); + } + +} diff --git a/src/org/traccar/web/client/view/ApplicationSettingsDialog.ui.xml b/src/org/traccar/web/client/view/ApplicationSettingsDialog.ui.xml new file mode 100644 index 00000000..effdc4ad --- /dev/null +++ b/src/org/traccar/web/client/view/ApplicationSettingsDialog.ui.xml @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/org/traccar/web/client/view/DeviceView.java b/src/org/traccar/web/client/view/DeviceView.java index 8a0b6243..341b5083 100644 --- a/src/org/traccar/web/client/view/DeviceView.java +++ b/src/org/traccar/web/client/view/DeviceView.java @@ -145,7 +145,7 @@ public class DeviceView implements SelectionChangedEvent.SelectionChangedHandler public void onAccountSelected(); public void onPreferencesSelected(); public void onUsersSelected(); - public void onGlobalSelected(); + public void onApplicationSelected(); } private SettingsHandler settingsHandler; @@ -167,7 +167,7 @@ public class DeviceView implements SelectionChangedEvent.SelectionChangedHandler @UiHandler("globalAccount") public void onSettingsGlobalSelected(SelectionEvent event) { - settingsHandler.onGlobalSelected(); + settingsHandler.onApplicationSelected(); } } diff --git a/src/org/traccar/web/client/view/LoginDialog.java b/src/org/traccar/web/client/view/LoginDialog.java index e09da48d..59b46239 100644 --- a/src/org/traccar/web/client/view/LoginDialog.java +++ b/src/org/traccar/web/client/view/LoginDialog.java @@ -15,12 +15,15 @@ */ package org.traccar.web.client.view; +import org.traccar.web.client.ApplicationContext; + import com.google.gwt.core.client.GWT; import com.google.gwt.uibinder.client.UiBinder; import com.google.gwt.uibinder.client.UiField; import com.google.gwt.uibinder.client.UiHandler; import com.google.gwt.user.client.ui.Widget; import com.sencha.gxt.widget.core.client.Window; +import com.sencha.gxt.widget.core.client.button.TextButton; import com.sencha.gxt.widget.core.client.event.SelectEvent; import com.sencha.gxt.widget.core.client.form.PasswordField; import com.sencha.gxt.widget.core.client.form.TextField; @@ -48,9 +51,16 @@ public class LoginDialog { @UiField PasswordField password; + @UiField + TextButton registerButton; + public LoginDialog(LoginHandler loginHandler) { this.loginHandler = loginHandler; uiBinder.createAndBindUi(this); + + if (ApplicationContext.getInstance().getApplicationSettings().getRegistrationEnabled()) { + registerButton.enable(); + } } public void show() { diff --git a/src/org/traccar/web/client/view/LoginDialog.ui.xml b/src/org/traccar/web/client/view/LoginDialog.ui.xml index 8c31b308..c9314430 100644 --- a/src/org/traccar/web/client/view/LoginDialog.ui.xml +++ b/src/org/traccar/web/client/view/LoginDialog.ui.xml @@ -33,7 +33,7 @@ - + -- cgit v1.2.3