From a16110c76f3d6dfd148714201d6667b95f7210e2 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Sat, 5 Sep 2020 10:48:29 -0700 Subject: Implement announcement feature --- web/app/controller/Root.js | 20 +++++++++++++++++++- web/app/view/dialog/Server.js | 4 ++++ 2 files changed, 23 insertions(+), 1 deletion(-) (limited to 'web/app') diff --git a/web/app/controller/Root.js b/web/app/controller/Root.js index 935b1f15..bbfa0845 100644 --- a/web/app/controller/Root.js +++ b/web/app/controller/Root.js @@ -66,10 +66,28 @@ Ext.define('Traccar.controller.Root', { }); }, + showAnnouncement: function (announcement) { + var maxWidth = Ext.getBody().getViewSize().width - 2 * Traccar.Style.normalPadding; + if (maxWidth > Traccar.Style.windowWidth) { + maxWidth = Traccar.Style.windowWidth; + } + Ext.Msg.show({ + msg: announcement, + buttons: Ext.Msg.OK, + closable: false, + modal: false, + maxWidth: maxWidth + }).alignTo(Ext.getBody(), "t-t", [0, Traccar.Style.normalPadding]); + }, + onServerReturn: function (options, success, response) { - var token, parameters = {}; + var announcement, token, parameters = {}; if (success) { Traccar.app.setServer(Ext.decode(response.responseText)); + announcement = Traccar.app.getServer().get('announcement'); + if (announcement) { + this.showAnnouncement(announcement); + } token = Ext.Object.fromQueryString(window.location.search).token; if (token) { parameters.token = token; diff --git a/web/app/view/dialog/Server.js b/web/app/view/dialog/Server.js index b72dbb0c..d9e225ec 100644 --- a/web/app/view/dialog/Server.js +++ b/web/app/view/dialog/Server.js @@ -88,6 +88,10 @@ Ext.define('Traccar.view.dialog.Server', { xtype: 'unescapedTextField', name: 'poiLayer', fieldLabel: Strings.mapPoiLayer + }, { + xtype: 'unescapedTextField', + name: 'announcement', + fieldLabel: Strings.serverAnnouncement }] }, { xtype: 'fieldset', -- cgit v1.2.3