{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "The `FastGridTemplate` is a simple extension of the basic template that uses the [Fast design library](https://www.fast.design/) and applies the `panel.theme.Fast` design system by default. It is a list-like variant where the `main` area acts like a list-like container, unlike the grid-like templates such as `ReactTemplate` and `FastGridTemplate`.\n", "\n", "## Basic Templates\n", "\n", "For a large variety of use cases we do not need complete control over the exact layout of each individual component on the page, as could be achieved with a [custom template](../../user_guide/Templates.ipynb), we just want to achieve a more polished look and feel. For these cases Panel ships with a number of default templates, which are defined by declaring four main content areas on the page, which can be populated as desired:\n", "\n", "* **`header`**: The header area of the HTML page\n", "* **`sidebar`**: A collapsible sidebar\n", "* **`main`**: The main area of the application\n", "* **`modal`**: A modal area which can be opened and closed from Python\n", "\n", "These four areas behave very similarly to other Panel layout components and have list-like semantics. This means we can easily append new components into these areas. Unlike other layout components however, the contents of the areas is fixed once rendered. If you need a dynamic layout you should therefore insert a regular Panel layout component (e.g. a `Column` or `Row`) and modify it in place once added to one of the content areas. \n", "\n", "Templates can allow for us to quickly and easily create web apps for displaying our data. Panel comes with a default Template, and includes multiple Templates that extend the default which add some customization for a better display.\n", "\n", "#### Parameters:\n", "\n", "In addition to the four different areas we can populate, the `FastListTemplate` also provides the parameters below:\n", "\n", "* **`site`** (str): Name of the site. Will be shown in the header. Default is '', i.e. not shown.\n", "* **`site_url`** (str): Url of the site and logo. Default is \"/\".\n", "* **`logo`** (str): URI of logo to add to the header (if local file, logo is base64 encoded as URI).\n", "* **`title`** (str): A title to show in the header. Also added to the document head meta settings and as the browser tab title.\n", "* **`favicon`** (str): URI of favicon to add to the document head (if local file, favicon is base64 encoded as URI).\n", "* **`sidebar_footer`** (str): Can be used to insert additional HTML. For example a menu, some additional info, links etc.\n", "* **`config`** (TemplateConfig): Contains configuration options similar to `pn.config` but applied to the current Template only. (Currently only `css_files` is supported)\n", "* **`busy_indicator`** (BooleanIndicator): Visual indicator of application busy state.\n", "\n", "For **styling** you can use\n", "\n", "* **`theme`** (Theme): A Theme class (available in `panel.template`. One of `DefaultTheme` or `DarkTheme`). \n", " - For convenience you can provide \"default\" or \"dark\" string to the constructor.\n", " - If you add `?theme=default` or `?theme=dark` in the url this will set the theme unless explicitly declared\n", "* **`theme_toggle`** (boolean): If `True` a switch to toggle the Theme is shown. Default is `True`.\n", "* **`background_color`** (str): Optional body background color override.\n", "* **`neutral_color`** (str): Optional body neutral color override.\n", "* **`accent_base_color`** (str): Optional body accent base color override. The default is #0072B5 (French Blue).\n", "* **`header_background`** (str): Optional header background color override.\n", "* **`header_color`** (str): Optional header text color override.\n", "* **`header_neutral_color`** (str): Optional header neutral color override.\n", "* **`header_accent_base_color`** (str): Optional header accent base color override.\n", "* **`corner_radius`** (str): The corner radius applied to controls.\n", "* **`font`** (str): A font url to import.\n", "* **`font_url`** (str): A font url to import.\n", "* **`shadow`** (str): Optional shadow override. Whether or not to apply shadow.\n", "* **`main_layout`** (str): What to wrap the main components into. Options are '' (i.e. none) and 'card' (Default). Could be extended to Accordion, Tab etc. in the future.\n", "\n", "The **`accent`** argument is a short cut to set both the `accent_base_color` and the `header_background`. Some accent colors that work well are #A01346 (Fast), #00A170 (Mint), #DAA520 (Golden Rod), #2F4F4F (Dark Slate Grey), #F08080 (Light Coral) and #4099da (Summer Sky).\n", "\n", "For **layout** you can use\n", "\n", "* **`collapsed_sidebar`** (str, `default=False`): Whether the sidebar (if present) is initially collapsed.\n", "* **`sidebar_width`** (int): The width of the sidebar in pixels. Default is 330.\n", "* **`main_max_width`** (str): The maximum width of the main area. For example '800px' or '80%'. If the string is '' (default) no max width is set.\n", "\n", "For **meta** and **base** values you can use\n", "\n", "* **`meta_description`** (str): A meta description to add to the document head for search engine optimization. For example 'P.A. Nelson'.\n", "* **`meta_keywords`** (str): Meta keywords to add to the document head for search engine optimization.\n", "* **`meta_author`** (str): A meta author to add to the the document head for search engine optimization. For example 'P.A. Nelson'.\n", "* **`meta_refresh`** (str): A meta refresh rate to add to the document head. For example '30' will instruct the browser to refresh every 30 seconds. Default is '', i.e. no automatic refresh.\n", "* **`meta_viewport`** (str): A meta viewport to add to the header.\n", "* **`base_url`** (str): Specifies the base URL for all relative URLs in a page. Default is '', i.e. not the domain.\n", "* **`base_target`** (str): Specifies the base Target for all relative URLs in a page. Default is _self.\n", "\n", "________" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "In this case we are using the `FastListTemplate`, built using the [Fast.design](https://www.fast.design/) framework. Here is an example of how you can set up a display using this template:" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "tags": [] }, "outputs": [], "source": [ "import hvplot.pandas\n", "import numpy as np\n", "import panel as pn\n", "import pandas as pd\n", "\n", "xs = np.linspace(0, np.pi)\n", "\n", "freq = pn.widgets.FloatSlider(name=\"Frequency\", start=0, end=10, value=2)\n", "phase = pn.widgets.FloatSlider(name=\"Phase\", start=0, end=np.pi)\n", "\n", "def sine(freq, phase):\n", " return pd.DataFrame(dict(y=np.sin(xs*freq+phase)), index=xs)\n", "\n", "def cosine(freq, phase):\n", " return pd.DataFrame(dict(y=np.cos(xs*freq+phase)), index=xs)\n", "\n", "dfi_sine = hvplot.bind(sine, freq, phase).interactive()\n", "dfi_cosine = hvplot.bind(cosine, freq, phase).interactive()\n", "\n", "plot_opts = dict(\n", " responsive=True, min_height=400,\n", " # Align the curves' color with the template's color\n", " color=pn.template.FastListTemplate.accent_base_color\n", ")\n", "\n", "# Instantiate the template with widgets displayed in the sidebar\n", "template = pn.template.FastListTemplate(\n", " title=\"FastListTemplate\",\n", " sidebar=[freq, phase],\n", ")\n", "# Append a layout to the main area, to demonstrate the list-like API\n", "template.main.append(\n", " pn.Row(\n", " dfi_sine.hvplot(title='Sine', **plot_opts).output(),\n", " dfi_cosine.hvplot(title='Cosine', **plot_opts).output(),\n", " )\n", ")\n", "template.servable();" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Each built-in template comes with a *light* (default) and *dark* theme. The theme can be set when instantiating the template with the `theme` parameter, or [globally](../../how_to/styling/themes.md).\n", "\n", "

FastListTemplate with DefaultTheme

\n", "\n", "
\n", "

FastListTemplate with DarkTheme

\n", "" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ ":::{tip}\n", "Built-in templates don't render necessarily well in a notebook as their styling can badly interact with the notebook built-in styling. You can disable rendering the output of a cell using `;`, as done above. For development purposes, the app can be quickly rendered in another tab by replacing `.servable()` with `.show()`. Alternatively, the [JupyterLab Preview](../../how_to/notebook/jupyterlabpreview.md) can be used to display objects marked with `.servable()` in a new JupyterLab tab, circumventing any potential styling issue.\n", ":::" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Tips & Tricks\n", "\n", "### Restrict the height of cards in the main area and keep full screen mode working\n", "\n", "The FastListTemplate is organized horizontally into *cards*. Each card provides a *full screen* button in the top, right corner. Below we will describe how to configure for *full screen mode*.\n", "\n", "In order for a Panel component to maximize in full screen mode its\n", "\n", "- `sizing_mode` should be set to `\"stretch_both\"`\n", "- `height`, `width`, `max_height` and `max_width` should not be set.\n", "\n", "This will force the *card* to also *stretch_both* in non full screen mode. To set a specific max-height in non full screen mode, you can use `raw_css` on the template.\n", "\n", "**Example**\n", "\n", "```python\n", "import panel as pn\n", "\n", "pn.extension(sizing_mode=\"stretch_width\")\n", "\n", "CSS = \"\"\"\n", "div.card-margin:nth-child(1) {\n", " max-height: 300px;\n", "}\n", "div.card-margin:nth-child(2) {\n", " max-height: 400px;\n", "}\n", "\"\"\"\n", "\n", "layout1 = pn.Column(styles={\"background\": \"green\"}, sizing_mode=\"stretch_both\")\n", "layout2 = pn.Column(styles={\"background\": \"red\"}, sizing_mode=\"stretch_both\")\n", "\n", "pn.template.FastListTemplate(site=\"Panel\", title=\"App\", main=[layout1, layout2], raw_css=[CSS]).servable()\n", "```\n", "\n", "" ] } ], "metadata": { "language_info": { "name": "python", "pygments_lexer": "ipython3" } }, "nbformat": 4, "nbformat_minor": 4 }