From 5a1e77c174273781040954fbd2235f8e58ee9f7c Mon Sep 17 00:00:00 2001 From: Fabio Manganiello Date: Wed, 13 Jun 2018 20:40:45 +0200 Subject: [PATCH] Added iframe modal on dashboard with support for dynamic events to temporarily/permanently display a custom web page on the connected browsers --- platypush/backend/http/static/js/application.js | 13 +++++++++++-- platypush/backend/http/static/js/dashboard.js | 15 +++++++++++++++ platypush/backend/http/templates/dashboard.html | 8 ++++++++ platypush/message/event/web/__init__.py | 16 ++++++++++++++++ 4 files changed, 50 insertions(+), 2 deletions(-) diff --git a/platypush/backend/http/static/js/application.js b/platypush/backend/http/static/js/application.js index 83768316c4..8534fe3a44 100644 --- a/platypush/backend/http/static/js/application.js +++ b/platypush/backend/http/static/js/application.js @@ -145,7 +145,7 @@ $(document).ready(function() { }; var initModalOpenBindings = function() { - $('body').on('click touch', '[data-modal]', function(event) { + $('body').on('mouseup touchend', '[data-modal]', function(event) { var $source = $(event.target); var $modal = $($source.data('modal')); $modal.fadeIn(); @@ -153,11 +153,20 @@ $(document).ready(function() { }; var initModalCloseBindings = function() { - $('body').on('click touch', '[data-dismiss-modal]', function(event) { + $('body').on('mouseup touchend', '[data-dismiss-modal]', function(event) { var $source = $(event.target); var $modal = $($source.data('dismiss-modal')); $modal.fadeOut(); }); + + $('body').on('mouseup touchend', function(event) { + var $source = $(event.target); + if (!$source.parents('.modal').length + && !$source.data('modal') + && !$source.data('dismiss-modal')) { + $('.modal').filter(':visible').fadeOut(); + } + }); }; var initModals = function() { diff --git a/platypush/backend/http/static/js/dashboard.js b/platypush/backend/http/static/js/dashboard.js index 2270a4c5bc..274cfa8398 100644 --- a/platypush/backend/http/static/js/dashboard.js +++ b/platypush/backend/http/static/js/dashboard.js @@ -7,6 +7,21 @@ $(document).ready(function() { for (var key of Object.keys(event.args)) { $widget.find('[data-bind=' + key + ']').text(event.args[key]); } + } else if (event.args.type == 'platypush.message.event.web.DashboardIframeUpdateEvent') { + var url = event.args.url; + var $modal = $('#iframe-modal'); + var $iframe = $modal.find('iframe'); + $iframe.attr('src', url); + $iframe.prop('width', event.args.width || '100%'); + $iframe.prop('height', event.args.height || '600'); + + if ('timeout' in event.args) { + setTimeout(function() { + $modal.fadeOut(); + }, parseFloat(event.args.timeout) * 1000); + } + + $modal.fadeIn(); } }; diff --git a/platypush/backend/http/templates/dashboard.html b/platypush/backend/http/templates/dashboard.html index ff77e030a0..5a5d77596b 100644 --- a/platypush/backend/http/templates/dashboard.html +++ b/platypush/backend/http/templates/dashboard.html @@ -33,6 +33,14 @@
+ + +
{% set used_columns = [0] %} {% for widget_name, widget in config['widgets'].items() %} diff --git a/platypush/message/event/web/__init__.py b/platypush/message/event/web/__init__.py index e69de29bb2..14ed1eb8f7 100644 --- a/platypush/message/event/web/__init__.py +++ b/platypush/message/event/web/__init__.py @@ -0,0 +1,16 @@ +from platypush.message.event import Event + + +class DashboardIframeUpdateEvent(Event): + """ + Deliver a DashboardIframeUpdateEvent if you are using the web dashboard + and you want the connected web clients to show a certain URL in the iframe + modal window for (optionally) a certain time. + """ + + def __init__(self, url, width=None, height=None, timeout=None, *args, **kwargs): + super().__init__(url=url, width=width, height=height, timeout=timeout, *args, **kwargs) + + +# vim:sw=4:ts=4:et: +