Source code for page

"""Fullscreen page"""
# Author(s): Davide.De-Marchi@ec.europa.eu
# Copyright © European Union 2022-2023
# 
# Licensed under the EUPL, Version 1.2 or as soon they will be approved by 
# the European Commission subsequent versions of the EUPL (the "Licence");
# 
# You may not use this work except in compliance with the Licence.
# 
# You may obtain a copy of the Licence at:
# https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12

# Unless required by applicable law or agreed to in writing, software
# distributed under the Licence is distributed on an "AS IS"
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
# express or implied.
# 
# See the Licence for the specific language governing permissions and
# limitations under the Licence.

# Imports
from IPython.display import display
from ipywidgets import widgets, Layout
import ipyvuetify as v

try:
    from . import settings
    from . import dialogGeneric
    from . import tooltip
except:
    import settings
    import dialogGeneric
    import tooltip


#####################################################################################################################################################
# Open a page in fullscreen mode
#####################################################################################################################################################
[docs]class page(): """ Fullsceen page with title and footer bar. Parameters ---------- appname : str Name of the application. It will be displayed on the left side of the title bar title : str Title of the page output : instance of widgets.Output() class Output widget to be used for the opening of the fullscreen dialog that implements the page onclose : function, optional Python function to call when the user closes the page. The function will receive no parameters (default is None) titlecolor : str, optional Color to use for the title bar background (default is settings.color_first) titledark : bool, optional If True the text on the title bar will be displayed in white, otherwise in black color (defaul is True) titleheight : int, optional Height of the title bar in pixels (default is 54) footercolor : str, optional Color to use fir the footer bar background (default is settings.color_second) footerdark : bool, optional If True the text on the footer bar will be displayed in white, otherwise in black color (defaul is False) footerheight : int, optional Height of the footer bar in pixels (default is 30) logoappurl : str, optional String containing the url of the application logo, to be displayed on the left side of the title bar (default is '') logowidth : int, optional Width in pixels of the logo button (default is 40) on_logoapp : function, optional Python function to call when the user clicks on the pplication logo. The function will receive no parameters (default is None) copyrighttext : str, optional Text to display as copyright message on the footer bar (default is '') show_back : bool, optional If True a "back" button is displayed on the right side of the title bar (default is True) show_help : bool, optional If True a "help" button is displayed on the right side of the title bar (default is True) on_help : function, optional Python function to call when the user clicks the help button. The function will receive no parameters (default is None) logocreditsurl : str, optional String containing the url of the credits logo, to be displayed on the right side of the title bar (default is ''). If no url is passed, the logo of the European Commission is displayed show_credits : bool, optional If True a "credits" button is displayed on the right side of the title bar (default is True) on_credits : function, optional Python function to call when the user clicks the credits button. The function will receive no parameters (default is None) transition : str, optional Transition to be used for display and hide of the page (default is 'dialog-bottom-transition'). See: https://vuetifyjs.com/en/styles/transitions/ for a list of available transitions (substitute 'v-' with 'dialog-') persistent : bool, optional If True the page will be persistent and not close at the hitting of the "ESC" key (default is False) Examples -------- Creation of an example page:: from vois.vuetify import page from ipywidgets import widgets from IPython.display import display output = widgets.Output() display(output) def onclose(): pass def on_click(): pass p = page.page('Application XYZ', 'Map page', output, onclose=onclose, titlecolor='#008800', titledark=True, footercolor='#cccccc', footerdark=False, logoappurl='https://jeodpp.jrc.ec.europa.eu/services/shared/pngs/BDAP_Logo1024transparent.png', on_logoapp=on_click, copyrighttext='European Commission - Joint Research Centre', show_back=True, show_help=True, on_help=on_click, show_credits=True, on_credits=on_click) card = p.create() card.children = [] p.open() .. figure:: figures/page.png :scale: 100 % :alt: page widget Example of a page """ # Click on the APP logo def click_on_logoapp(self, *args): if not self.on_logoapp is None: self.on_logoapp() # Click on the back button def click_on_back(self, *args): self.close() # Click on the help button def click_on_help(self, *args): if not self.on_help is None: self.on_help() # Click on the credits button def click_on_credits(self, *args): if not self.on_credits is None: self.on_credits() # Create the page and returns the card widget where the content of the page must be displayed def create(self): textcolor = 'black' if self.titledark: textcolor = 'white' children = [] if not self.logoapp is None: btn_logo = v.Btn(text=True, rounded=False, ripple=False, style_='width: %dpx; height: 40px;'%self.logowidth, class_='pa-0 ma-0 ml-1', children=[self.logoapp]) btn_logo.on_event('click', self.click_on_logoapp) if len(self.appname) > 0: children.append(tooltip.tooltip("Info on %s"%self.appname, btn_logo)) else: children.append(btn_logo) if len(self.appname) > 0: title = v.ToolbarTitle(children=['%s:'%self.appname], class_='pa-0 ma-0 mt-1 ml-1', style_='height: 30px; color: %s; font-size: 26;'%textcolor) children.append(title) if len(self.title) > 0: subtitle = v.ToolbarTitle(children=[self.title], class_='pa-0 ma-0 mt-1 ml-2', style_='height: 30px; color: %s; font-size: 26;'%textcolor) children.append(subtitle) children.append(v.Spacer()) for cb in self.custom_buttons: iconname,tooltiptext,callback = cb btn = v.Btn(icon=True, class_="pa-0 ma-0 mt-1", dark=self.titledark, children=[v.Icon(children=[iconname])]) btn.on_event('click', callback) children.append(tooltip.tooltip(tooltiptext, btn)) if self.show_back: btn_back = v.Btn(icon=True, class_="pa-0 ma-0 mt-1", dark=self.titledark, children=[v.Icon(children=['mdi-arrow-left'])]) btn_back.on_event('click', self.click_on_back) children.append(tooltip.tooltip("Close current page", btn_back)) if self.show_help: btn_help = v.Btn(icon=True, class_="pa-0 ma-0 mt-1 mr-3", dark=self.titledark, children=[v.Icon(children=['mdi-help'])]) btn_help.on_event('click', self.click_on_help) children.append(tooltip.tooltip("Display application help", btn_help)) if self.show_credits: btn_credits = v.Btn(text=True, rounded=False, ripple=False, style_='width: 170px; height: %dpx;'%(self.titleheight-4), class_='pa-0 ma-0 mr-1', children=[self.logoCredits]) btn_credits.on_event('click', self.click_on_credits) children.append(tooltip.tooltip("Open credits info", btn_credits)) self.appbar = v.AppBar(height=self.titleheight, min_height=self.titleheight, max_height=self.titleheight, color=self.titlecolor, children=children) # Content of the footer bar textcolor = 'black' if self.footerdark: textcolor = 'white' copyicon = v.Icon(class_="pa-0 ma-0 mr-2", small=True, color=textcolor, children=['mdi-copyright']) ctext = v.Card(flat=True, color=self.footercolor, style_='color: %s;'%textcolor, children=[self.copyrighttext]) frow = v.Row(class_='pa-0 ma-0 mt-n2 mb-n3', justify="center", no_gutters=True, children=[copyicon,ctext]) self.footer = v.Footer(color=self.footercolor, padless=True, children=[frow], class_='pa-0 ma-0', rounded=False, height=self.footerheight, max_height=self.footerheight, min_height=self.footerheight, style_='height: %dpx; overflow: hidden; border-bottom-left-radius: 0; border-bottom-right-radius: 0;'%self.footerheight) # Main content of the page: a card to be filled with custom content self.height = 'calc(100vh - %dpx)'%(self.titleheight+self.footerheight) self.card = v.Card(children=[], elevation=5,class_="pa-0 ma-0", style_='width: 100vw; max-width: 100vw; height: %s; max-height: %s;'%(self.height,self.height)) return self.card # Open the dialog def open(self): self.dlg = dialogGeneric.dialogGeneric(title='', titleheight='0px', text='', show=True, no_click_animation=True, addclosebuttons=False, persistent=self.persistent, transition=self.transition, fullscreen=True, content=[self.appbar,self.card,self.footer], output=self.output) # Close the dialog def close(self): if not self.dlg is None: self.dlg.close() if not self.onclose is None: self.onclose() # Add a custom buttom to the page (before the call to create!) def customButtonAdd(self, iconname, tooltiptext, callback): self.custom_buttons.append((iconname,tooltiptext,callback)) # Each item has an icon name, a tooltip string and a callback function # Remove all custom buttons def customButtonClear(self): self.custom_buttons = [] # Initialization def __init__(self, appname, title, output, onclose=None, titlecolor=settings.color_first, titledark=True, titleheight=54, footercolor=settings.color_second, footerdark=False, footerheight=30, logoappurl='', logowidth=40, on_logoapp=None, copyrighttext='', show_back=True, show_help=True, on_help=None, logocreditsurl='', show_credits=True, on_credits=None, transition='dialog-bottom-transition', persistent=False): self.dlg = None self.appname = appname self.title = title self.output = output self.onclose = onclose self.titlecolor = titlecolor self.titledark = titledark self.titleheight = titleheight self.footercolor = footercolor self.footerdark = footerdark self.footerheight = footerheight self.logowidth = logowidth self.copyrighttext = copyrighttext self.show_back = show_back self.show_help = show_help self.on_help = on_help self.show_credits = show_credits self.on_credits = on_credits self.on_logoapp = on_logoapp self.transition = transition self.persistent = persistent self.custom_buttons = [] # Each item has an icon name, a tooltip string and a callback function if len(logoappurl) > 0: self.logoapp = v.Img(class_='pa-0 ma-0 mr-2', max_width=self.logowidth, src=logoappurl) else: self.logoapp = None if len(logocreditsurl) > 0: self.logoCredits = v.Img(class_='pa-0 ma-0 mr-2', max_width=120, src=logocreditsurl) else: self.logoCredits = v.Img(class_='pa-0 ma-0 mr-2', max_width=120, src='')