diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml
index c64590045f..68a50b5fc8 100644
--- a/.pre-commit-config.yaml
+++ b/.pre-commit-config.yaml
@@ -3,41 +3,46 @@
default_stages: [commit]
repos:
-- repo: https://github.com/pre-commit/pre-commit-hooks
+ - repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.4.0
hooks:
- - id: check-builtin-literals
- - id: check-case-conflict
- - id: check-docstring-first
- - id: check-executables-have-shebangs
- - id: check-toml
- - id: check-json
- - id: detect-private-key
- - id: end-of-file-fixer
+ - id: check-builtin-literals
+ - id: check-case-conflict
+ - id: check-docstring-first
+ - id: check-executables-have-shebangs
+ - id: check-toml
+ - id: check-json
+ - id: detect-private-key
+ - id: end-of-file-fixer
exclude: \.min\.js$
- - id: trailing-whitespace
-- repo: https://github.com/charliermarsh/ruff-pre-commit
+ - id: trailing-whitespace
+ - repo: https://github.com/charliermarsh/ruff-pre-commit
rev: 'v0.0.261'
hooks:
- - id: ruff # See 'setup.cfg' for args
+ - id: ruff # See 'setup.cfg' for args
args: [panel]
files: panel/
-- repo: https://github.com/pycqa/isort
+ - repo: https://github.com/pycqa/isort
rev: 5.12.0
hooks:
- id: isort
name: isort (python)
-- repo: https://github.com/hoxbro/clean_notebook
+ - repo: https://github.com/hoxbro/clean_notebook
rev: v0.1.9
hooks:
- id: clean-notebook
args: [-i, tags]
-- repo: https://github.com/codespell-project/codespell
- rev: v2.2.4
- hooks:
- - id: codespell
- additional_dependencies:
- - tomli
+ - repo: https://github.com/codespell-project/codespell
+ rev: v2.2.4
+ hooks:
+ - id: codespell
+ additional_dependencies:
+ - tomli
+ - repo: https://github.com/pre-commit/mirrors-prettier
+ rev: v2.7.1
+ hooks:
+ - id: prettier
+ types_or: [css]
ci:
autofix_prs: false
autoupdate_schedule: quarterly
diff --git a/.prettierrc b/.prettierrc
new file mode 100644
index 0000000000..f8dec5b189
--- /dev/null
+++ b/.prettierrc
@@ -0,0 +1,5 @@
+{
+ "tabWidth": 2,
+ "semi": false,
+ "singleQuote": true
+}
diff --git a/doc/_static/css/custom.css b/doc/_static/css/custom.css
index 1bac662283..c73c3a6a00 100644
--- a/doc/_static/css/custom.css
+++ b/doc/_static/css/custom.css
@@ -1,178 +1,179 @@
-:root[data-theme="light"], :root[data-theme="dark"] {
- --pst-color-primary: #0072B5;
- --pst-color-link: #0072B5;
- --pst-color-inline-code: #0072B5;
- --sd-color-card-border-hover: #0072B5;
+:root[data-theme='light'],
+:root[data-theme='dark'] {
+ --pst-color-primary: #0072b5;
+ --pst-color-link: #0072b5;
+ --pst-color-inline-code: #0072b5;
+ --sd-color-card-border-hover: #0072b5;
}
-html[data-theme=dark] .bd-content div.cell_output .text_html {
- background-color: var(--pst-color-background);
- color: var(--pst-color-text-base);
+html[data-theme='dark'] .bd-content div.cell_output .text_html {
+ background-color: var(--pst-color-background);
+ color: var(--pst-color-text-base);
}
/* Align navbar item in center */
.navbar-header-items__center {
- margin-left: auto;
- margin-right: auto;
+ margin-left: auto;
+ margin-right: auto;
}
/* Ensure content fills full space */
.bd-main .bd-content .bd-article-container {
- max-width: unset;
+ max-width: unset;
}
/* Hide primary sidenav bottom section to avoid extra scroll */
.sidebar-primary-items__end.sidebar-primary__section {
- display: none;
+ display: none;
}
.nav-link {
- white-space: nowrap;
+ white-space: nowrap;
}
.showcase-table {
- border-spacing: 15px
+ border-spacing: 15px;
}
.showcase-table td {
- border: 0px;
- vertical-align: top;
+ border: 0px;
+ vertical-align: top;
}
.cell_output {
- padding-left: 0;
+ padding-left: 0;
}
-html[data-theme=dark] .bd-content div.cell_output .text_html,
-html[data-theme=light] .bd-content div.cell_output .text_html {
- padding: 0;
+html[data-theme='dark'] .bd-content div.cell_output .text_html,
+html[data-theme='light'] .bd-content div.cell_output .text_html {
+ padding: 0;
}
@media (max-width: 960px) {
- .homepage-logo {
- display: none;
- }
+ .homepage-logo {
+ display: none;
+ }
}
@media (min-width: 1400px) {
- .bd-sidebar {
- max-width: 300px;
- }
+ .bd-sidebar {
+ max-width: 300px;
+ }
- .bd-main .bd-content .bd-article-container .bd-article {
- padding-left: 0.5rem;
- padding-top: 0.5rem;
- }
+ .bd-main .bd-content .bd-article-container .bd-article {
+ padding-left: 0.5rem;
+ padding-top: 0.5rem;
+ }
- .bd-page-width {
- max-width: 100%;
- }
+ .bd-page-width {
+ max-width: 100%;
+ }
}
@media (min-width: 1600px) {
- .bd-page-width {
- max-width: 85%;
- }
+ .bd-page-width {
+ max-width: 85%;
+ }
}
@media (min-width: 1800px) {
- .bd-page-width {
- max-width: 80%;
- }
+ .bd-page-width {
+ max-width: 80%;
+ }
}
#scroller-right {
- max-width: 14%;
+ max-width: 14%;
}
@media (max-width: 1400px) {
- #scroller-right {
- position: relative;
- right: unset;
- top: unset;
- max-width: 100%;
- transform: unset;
- }
+ #scroller-right {
+ position: relative;
+ right: unset;
+ top: unset;
+ max-width: 100%;
+ transform: unset;
+ }
}
.theme-switch-button {
- font-size: unset;
+ font-size: unset;
}
.sd-card-body.sponsor-logo {
- flex-grow: unset;
- margin: auto;
+ flex-grow: unset;
+ margin: auto;
}
.sponsor-logo img {
- min-height: 80px;
- object-fit: contain;
+ min-height: 80px;
+ object-fit: contain;
}
button.toggle-button {
- display: none;
+ display: none;
}
.toggle-hidden:not(.admonition) {
- height: 0;
+ height: 0;
}
.tag_hide-input {
- margin-bottom: 0 !important;
+ margin-bottom: 0 !important;
}
details.hide.above-input {
- display: none;
+ display: none;
}
.toggle-hidden + .cell_output {
- margin-top: 0 !important;
+ margin-top: 0 !important;
}
dl.field-list {
- display: none
+ display: none;
}
/* Improve styling */
div.cell div.cell_input {
- border: none;
+ border: none;
}
.highlight {
- border-radius: 4px;
+ border-radius: 4px;
}
-html[data-theme="light"] .highlight {
- background-color: #263238;
- color: #f8f8f2;
+html[data-theme='light'] .highlight {
+ background-color: #263238;
+ color: #f8f8f2;
}
pre[id^='codecell'] {
- background-color: unset;
- border: none;
- border-radius: 0.5em;
- color: #f8f8f2;
- box-shadow: none;
- padding: 1.5em;
+ background-color: unset;
+ border: none;
+ border-radius: 0.5em;
+ color: #f8f8f2;
+ box-shadow: none;
+ padding: 1.5em;
}
button.copybtn {
- background-color: #263238;
+ background-color: #263238;
}
button.copybtn:hover {
- background-color: #263238;
- color: #f8f8f2;
+ background-color: #263238;
+ color: #f8f8f2;
}
.highlight button.copybtn:hover {
- background: none
+ background: none;
}
.o-tooltip--left:after {
- background: none;
+ background: none;
}
ul.current.nav.bd-sidenav {
- padding: 0;
+ padding: 0;
}
diff --git a/doc/_static/css/dataframe.css b/doc/_static/css/dataframe.css
index d1bb173498..8076a48d48 100644
--- a/doc/_static/css/dataframe.css
+++ b/doc/_static/css/dataframe.css
@@ -1,47 +1,49 @@
table.dataframe {
- margin-left: auto;
- margin-right: auto;
- border: none;
- border-collapse: collapse;
- border-spacing: 0;
- font-size: 12px;
- table-layout: auto;
- width: 100%;
+ margin-left: auto;
+ margin-right: auto;
+ border: none;
+ border-collapse: collapse;
+ border-spacing: 0;
+ font-size: 12px;
+ table-layout: auto;
+ width: 100%;
}
-.dataframe tr, .dataframe th, .dataframe td {
- text-align: right;
- vertical-align: middle;
- padding: 0.5em 0.5em;
- line-height: normal;
- white-space: normal;
- max-width: none;
- border: none;
+.dataframe tr,
+.dataframe th,
+.dataframe td {
+ text-align: right;
+ vertical-align: middle;
+ padding: 0.5em 0.5em;
+ line-height: normal;
+ white-space: normal;
+ max-width: none;
+ border: none;
}
.dataframe tbody {
- display: table-row-group;
- vertical-align: middle;
- border-color: inherit;
+ display: table-row-group;
+ vertical-align: middle;
+ border-color: inherit;
}
.dataframe tbody tr:nth-child(odd) {
- background-color: var(--pst-color-surface, #f5f5f5);
- color: var(--pst-color-text-base);
+ background-color: var(--pst-color-surface, #f5f5f5);
+ color: var(--pst-color-text-base);
}
.dataframe thead {
- border-bottom: 1px solid var(--pst-color-border);
- vertical-align: bottom;
+ border-bottom: 1px solid var(--pst-color-border);
+ vertical-align: bottom;
}
.dataframe tbody tr:hover {
- background-color: #e1f5fe;
- color: #000000;
- cursor: pointer;
+ background-color: #e1f5fe;
+ color: #000000;
+ cursor: pointer;
}
:host {
- overflow: auto;
- padding-right: 1px;
+ overflow: auto;
+ padding-right: 1px;
}
diff --git a/doc/conf.py b/doc/conf.py
index 4b575de536..3bab9a3d11 100644
--- a/doc/conf.py
+++ b/doc/conf.py
@@ -61,7 +61,7 @@
},
{
"name": "Discord",
- "url": "https://discord.gg/muhupDZM",
+ "url": "https://discord.gg/AXRHnJU6sP",
"icon": "fa-brands fa-discord",
},
],
diff --git a/doc/how_to/styling/design.md b/doc/how_to/styling/design.md
index b74c6ec36d..8377908297 100644
--- a/doc/how_to/styling/design.md
+++ b/doc/how_to/styling/design.md
@@ -46,4 +46,5 @@ pn.Tabs(
## Related Resources
+- Discover [how to customize a design](design_variables.md) next.
- Discover [how to toggle between themes](themes.md) next.
diff --git a/doc/how_to/styling/design_variables.md b/doc/how_to/styling/design_variables.md
new file mode 100644
index 0000000000..8cfe4380ad
--- /dev/null
+++ b/doc/how_to/styling/design_variables.md
@@ -0,0 +1,69 @@
+# Customize a Design
+
+This guide addresses how to customize a design system with CSS variables.
+
+:::{versionadded} 1.0.0
+The design feature was added in 1.0.0 and is actively being developed and improved. Currently there are a limited number of design variables but in future the goal is to expose a large variety of styling options via CSS variables.
+:::
+
+```{admonition} Prerequisites
+1. The [How-to > Apply a Design](./design.md) guides describe how to select a design system to apply to the components to achieve a consistent design language.
+2. The [How-to > Apply CSS](./apply_css.md) guide describes how to apply CSS definitions in Panel.
+```
+
+---
+
+The Design systems in Panel are set up to be overridden by CSS variables. The usual order of fallbacks for CSS variables is the following:
+
+1. User defined design variables (e.g. `--design-primary-color`)
+2. Editor/notebook dependent variables (e.g. `--jp-brand-color0`, for JupyterLab)
+3. The theme CSS variable definitions (e.g. `--panel-primary-color`)
+
+To override a particular style we therefore simply have to override one of the user defined design variables:
+
+| Variable | Description |
+|----------------------------------|--------------------------------------------------------|
+| `--design-primary-color` | Primary color of the design. |
+| `--design-primary-text-color` | Color of text rendered on top of primary color. |
+| `--design-secondary-color` | Secondary color of the design. |
+| `--design-secondary-text-color` | Color of text rendered on top of secondary color. |
+| `--design-background-color` | Color of the background layer. |
+| `--design-background-text-color` | Color of text rendered on top of the background layer. |
+| `--design-surface-color` | Color of the surface layer. |
+| `--design-surface-text-color` | Color of text rendered on top of the surface layer. |
+
+```{note}
+Background and surface colors generally are only set at the template level.
+```
+
+When and how to set these variables depends on the precise use case, e.g. if you consistently want to override the colors in a template, use the `Template.config.raw_css` or `Template.config.css_files` parameters to define an inline or imported stylesheet that will apply across the entire template.
+
+For global overrides that apply in all scenarios you can use the `pn.config.global_css` parameter, e.g. here we initialize it via the `pn.extension`:
+
+```{pyodide}
+import panel as pn
+
+pn.extension(design='material', global_css=[':root { --design-primary-color: purple; }'])
+```
+
+When defining design variable overrides globally use the `:root` CSS selector, which applies the variable from the root on down.
+
+```{pyodide}
+pn.Tabs(
+ ('Slider', pn.widgets.FloatSlider(start=0, end=7, value=3)),
+ ('Button', pn.widgets.Button(name='Click me!', button_type='primary'))
+)
+```
+
+Alternatively you can also define it directly on a component by adding it to the `stylesheets` and prefixing it with the `:host` selector:
+
+```{pyodide}
+pn.Tabs(
+ ('Slider', pn.widgets.FloatSlider(
+ start=0, end=7, value=3, stylesheets=[':host { --design-primary-color: red; }']
+ )),
+ ('Button', pn.widgets.Button(name='Click me!', button_type='primary'))
+)
+```
+
+## Related Resources
diff --git a/doc/how_to/styling/index.md b/doc/how_to/styling/index.md
index 1f17d7746f..f0c698660b 100644
--- a/doc/how_to/styling/index.md
+++ b/doc/how_to/styling/index.md
@@ -12,7 +12,7 @@ Panel provides a comprehensive system for applying designs, themes and custom st
How to switch between different design systems.
:::
-:::{grid-item-card} {octicon}`paintbrush;2.5em;sd-mr-1 sd-animate-grow50` Toggle themes
+:::{grid-item-card} {octicon}`sun;2.5em;sd-mr-1 sd-animate-grow50` Toggle themes
:link: themes
:link-type: doc
@@ -26,6 +26,13 @@ How to toggle between themes (e.g. 'light' and 'dark').
How to apply custom CSS styling.
:::
+:::{grid-item-card} {octicon}`paintbrush;2.5em;sd-mr-1 sd-animate-grow50` Customize a Design
+:link: design_variables
+:link-type: doc
+
+How to customize designs and themes with CSS variables.
+:::
+
:::{grid-item-card} {octicon}`hourglass;2.5em;sd-mr-1 sd-animate-grow50` Customize Loading Icon
:link: load_icon
:link-type: doc
diff --git a/doc/index.md b/doc/index.md
index 70277f5eb5..120b1cbdbf 100644
--- a/doc/index.md
+++ b/doc/index.md
@@ -16,7 +16,7 @@ sd_hide_title: true
The powerful data exploration & web app framework for Python
-::::{card-carousel} 3
+::::{card-carousel} 4
:::{card} Portfolio Optimizer
:img-top: https://assets.holoviz.org/panel/gallery/portfolio_optimizer.png
@@ -58,9 +58,8 @@ sd_hide_title: true
Panel is an [open-source](https://github.com/holoviz/panel/blob/main/LICENSE.txt) Python library that lets you **easily build powerful tools, dashboards and complex applications entirely in Python**. It has a batteries-included philosophy, putting the PyData ecosystem, powerful data tables and much more at your fingertips. High-level reactive APIs and lower-level callback based APIs ensure you can quickly build exploratory applications, but you aren't limited if you build complex, multi-page apps with rich interactivity. Panel is a member of the [HoloViz](https://holoviz.org/) ecosystem, your gateway into a connected ecosystem of data exploration tools.
-```{eval-rst}
-.. notebook:: panel ../examples/homepage.ipynb
- :disable_interactivity_warning: True
+```{eval-rst} panel ../examples/homepage.ipynb
+:disable_interactivity_warning: True
```
Panel makes it simple to:
diff --git a/panel/_templates/jupyter.css b/panel/_templates/jupyter.css
index c2d5ad2765..f73620e75c 100644
--- a/panel/_templates/jupyter.css
+++ b/panel/_templates/jupyter.css
@@ -1,6 +1,7 @@
-*[data-root-id], *[data-root-id] > * {
- box-sizing: border-box;
- font-family: var(--jp-ui-font-family);
- font-size: var(--jp-ui-font-size1);
- color: var(--jp-ui-font-color1);
+*[data-root-id],
+*[data-root-id] > * {
+ box-sizing: border-box;
+ font-family: var(--jp-ui-font-family);
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color1);
}
diff --git a/panel/config.py b/panel/config.py
index bf1bdf38b8..70ed8340b9 100644
--- a/panel/config.py
+++ b/panel/config.py
@@ -133,6 +133,9 @@ class _config(_base_config):
exception_handler = param.Callable(default=None, doc="""
General exception handler for events.""")
+ global_css = param.List(default=[], doc="""
+ List of raw CSS to be added to the header.""")
+
global_loading_spinner = param.Boolean(default=False, doc="""
Whether to add a global loading spinner for the whole application.""")
@@ -394,7 +397,7 @@ def __getattribute__(self, attr):
curdoc = state.curdoc
if curdoc and curdoc not in session_config:
session_config[curdoc] = {}
- if (attr in ('raw_css', 'css_files', 'js_files', 'js_modules') and
+ if (attr in ('raw_css', 'global_css', 'css_files', 'js_files', 'js_modules') and
curdoc and attr not in session_config[curdoc]):
new_obj = copy.copy(super().__getattribute__(attr))
setattr(self, attr, new_obj)
@@ -670,7 +673,7 @@ def __call__(self, *args, **params):
f'systems include: {list(designs)}.'
)
setattr(config, k, designs[v])
- elif k in ('css_files', 'raw_css'):
+ elif k in ('css_files', 'raw_css', 'global_css'):
if not isinstance(v, list):
raise ValueError('%s should be supplied as a list, '
'not as a %s type.' %
diff --git a/panel/dist/bundled/datatabulator/tabulator-tables@5.4.4/dist/css/tabulator_fast.min.css b/panel/dist/bundled/datatabulator/tabulator-tables@5.4.4/dist/css/tabulator_fast.min.css
index edd895bbc0..73872606ae 100644
--- a/panel/dist/bundled/datatabulator/tabulator-tables@5.4.4/dist/css/tabulator_fast.min.css
+++ b/panel/dist/bundled/datatabulator/tabulator-tables@5.4.4/dist/css/tabulator_fast.min.css
@@ -9,555 +9,846 @@
-moz-transform: translateZ(0);
-ms-transform: translateZ(0);
-o-transform: translateZ(0);
- transform: translateZ(0); }
- .tabulator[tabulator-layout="fitDataFill"] .tabulator-tableholder .tabulator-table {
- min-width: 100%; }
- .tabulator[tabulator-layout="fitDataTable"] {
- display: inline-block; }
- .tabulator.tabulator-block-select {
- user-select: none; }
- .tabulator .tabulator-header {
- position: relative;
- box-sizing: border-box;
- width: 100%;
- border-bottom: 2px solid var(--accent-fill-rest);
- background-color: var(--fill-color);
- color: var(--neutral-foreground-rest);
- font-weight: bold;
- white-space: nowrap;
- overflow: hidden;
- -moz-user-select: none;
- -khtml-user-select: none;
- -webkit-user-select: none;
- -o-user-select: none; }
- .tabulator .tabulator-header.tabulator-header-hidden {
- display: none; }
- .tabulator .tabulator-header .tabulator-header-contents {
- position: relative;
- overflow: hidden; }
- .tabulator .tabulator-header .tabulator-header-contents .tabulator-headers {
- display: inline-block; }
- .tabulator .tabulator-header .tabulator-col {
- display: inline-flex;
- position: relative;
- box-sizing: border-box;
- flex-direction: column;
- justify-content: flex-start;
- border-right: 1px solid var(--neutral-stroke-divider-rest);
- background: var(--fill-color);
- text-align: left;
- vertical-align: bottom;
- overflow: hidden; }
- .tabulator .tabulator-header .tabulator-col.tabulator-moving {
- position: absolute;
- border: 1px solid var(--neutral-divider-rest);
- background: var(--fill-color);
- pointer-events: none; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content {
- box-sizing: border-box;
- position: relative;
- padding: 4px; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-header-popup-button {
- padding: 0 8px; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-header-popup-button:hover {
- cursor: pointer;
- opacity: .6; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title-holder {
- position: relative; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title {
- box-sizing: border-box;
- width: 100%;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- vertical-align: bottom; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title.tabulator-col-title-wrap {
- white-space: normal;
- text-overflow: initial; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title .tabulator-title-editor {
- box-sizing: border-box;
- width: 100%;
- border: 1px solid #999;
- padding: 1px;
- background: #fff; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title .tabulator-header-popup-button + .tabulator-title-editor {
- width: calc(100% - 22px); }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-sorter {
- display: flex;
- align-items: center;
- position: absolute;
- top: 0;
- bottom: 0;
- right: 4px; }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-sorter .tabulator-arrow {
- width: 0;
- height: 0;
- border-left: 6px solid transparent;
- border-right: 6px solid transparent;
- border-bottom: 6px solid #bbb; }
- .tabulator .tabulator-header .tabulator-col.tabulator-col-group .tabulator-col-group-cols {
- position: relative;
- display: flex;
- border-top: 1px solid var(--accent-fill-rest);
- overflow: hidden;
- margin-right: -1px; }
- .tabulator .tabulator-header .tabulator-col .tabulator-header-filter {
- position: relative;
- box-sizing: border-box;
- margin-top: 2px;
- width: 100%;
- text-align: center; }
- .tabulator .tabulator-header .tabulator-col .tabulator-header-filter textarea {
- height: auto !important; }
- .tabulator .tabulator-header .tabulator-col .tabulator-header-filter svg {
- margin-top: 3px; }
- .tabulator .tabulator-header .tabulator-col .tabulator-header-filter input::-ms-clear {
- width: 0;
- height: 0; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable .tabulator-col-title {
- padding-right: 25px; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable.tabulator-col-sorter-element:hover {
- cursor: pointer;
- background-color: var(--fill-color); }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="none"] .tabulator-col-content .tabulator-col-sorter {
- color: #bbb; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="none"] .tabulator-col-content .tabulator-col-sorter.tabulator-col-sorter-element .tabulator-arrow:hover {
- cursor: pointer;
- border-bottom: 6px solid #555; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="none"] .tabulator-col-content .tabulator-col-sorter .tabulator-arrow {
- border-top: none;
- border-bottom: 6px solid #bbb; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="ascending"] .tabulator-col-content .tabulator-col-sorter {
- color: #666; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="ascending"] .tabulator-col-content .tabulator-col-sorter.tabulator-col-sorter-element .tabulator-arrow:hover {
- cursor: pointer;
- border-bottom: 6px solid #555; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="ascending"] .tabulator-col-content .tabulator-col-sorter .tabulator-arrow {
- border-top: none;
- border-bottom: 6px solid #666; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="descending"] .tabulator-col-content .tabulator-col-sorter {
- color: #666; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="descending"] .tabulator-col-content .tabulator-col-sorter.tabulator-col-sorter-element .tabulator-arrow:hover {
- cursor: pointer;
- border-top: 6px solid #555; }
- .tabulator .tabulator-header .tabulator-col.tabulator-sortable[aria-sort="descending"] .tabulator-col-content .tabulator-col-sorter .tabulator-arrow {
- border-bottom: none;
- border-top: 6px solid #666;
- color: #666; }
- .tabulator .tabulator-header .tabulator-col.tabulator-col-vertical .tabulator-col-content .tabulator-col-title {
- writing-mode: vertical-rl;
- text-orientation: mixed;
- display: flex;
- align-items: center;
- justify-content: center; }
- .tabulator .tabulator-header .tabulator-col.tabulator-col-vertical.tabulator-col-vertical-flip .tabulator-col-title {
- transform: rotate(180deg); }
- .tabulator .tabulator-header .tabulator-col.tabulator-col-vertical.tabulator-sortable .tabulator-col-title {
- padding-right: 0;
- padding-top: 20px; }
- .tabulator .tabulator-header .tabulator-col.tabulator-col-vertical.tabulator-sortable.tabulator-col-vertical-flip .tabulator-col-title {
- padding-right: 0;
- padding-bottom: 20px; }
- .tabulator .tabulator-header .tabulator-col.tabulator-col-vertical.tabulator-sortable .tabulator-col-sorter {
- justify-content: center;
- left: 0;
- right: 0;
- top: 4px;
- bottom: auto; }
- .tabulator .tabulator-header .tabulator-frozen {
- position: sticky;
- left: 0;
- z-index: 10; }
- .tabulator .tabulator-header .tabulator-frozen.tabulator-frozen-left {
- border-right: 2px solid var(--neutral-divider-rest); }
- .tabulator .tabulator-header .tabulator-frozen.tabulator-frozen-right {
- border-left: 2px solid var(--neutral-divider-rest); }
- .tabulator .tabulator-header .tabulator-calcs-holder {
- box-sizing: border-box;
- background: var(--fill-color) !important;
- border-top: 1px solid var(--neutral-divider-rest);
- border-bottom: 1px solid var(--accent-fill-rest); }
- .tabulator .tabulator-header .tabulator-calcs-holder .tabulator-row {
- background: var(--fill-color) !important; }
- .tabulator .tabulator-header .tabulator-calcs-holder .tabulator-row .tabulator-col-resize-handle {
- display: none; }
- .tabulator .tabulator-header .tabulator-frozen-rows-holder:empty {
- display: none; }
- .tabulator .tabulator-tableholder {
- position: relative;
- width: 100%;
- white-space: nowrap;
- overflow: auto;
- -webkit-overflow-scrolling: touch; }
- .tabulator .tabulator-tableholder:focus {
- outline: none; }
- .tabulator .tabulator-tableholder .tabulator-placeholder {
- box-sizing: border-box;
- display: flex;
- align-items: center;
- justify-content: center;
- width: 100%; }
- .tabulator .tabulator-tableholder .tabulator-placeholder[tabulator-render-mode="virtual"] {
- min-height: 100%;
- min-width: 100%; }
- .tabulator .tabulator-tableholder .tabulator-placeholder .tabulator-placeholder-contents {
- display: inline-block;
- text-align: center;
- padding: 10px;
- color: #ccc;
- font-weight: bold;
- font-size: 20px;
- white-space: normal; }
- .tabulator .tabulator-tableholder .tabulator-table {
- position: relative;
- display: inline-block;
- background-color: var(--fill-color);
- white-space: nowrap;
- overflow: visible;
- color: var(--neutral-foreground-rest); }
- .tabulator .tabulator-tableholder .tabulator-table .tabulator-row.tabulator-calcs {
- font-weight: bold;
- background: var(--neutral-fill-rest) !important; }
- .tabulator .tabulator-tableholder .tabulator-table .tabulator-row.tabulator-calcs.tabulator-calcs-top {
- border-bottom: 2px solid var(--neutral-divider-rest); }
- .tabulator .tabulator-tableholder .tabulator-table .tabulator-row.tabulator-calcs.tabulator-calcs-bottom {
- border-top: 2px solid var(--neutral-divider-rest); }
- .tabulator .tabulator-footer {
- border-top: 1px solid var(--neutral-divider-rest);
- background-color: var(--fill-color);
- color: var(--neutral-foreground-rest);
- font-weight: bold;
- white-space: nowrap;
- user-select: none;
- -moz-user-select: none;
- -khtml-user-select: none;
- -webkit-user-select: none;
- -o-user-select: none; }
- .tabulator .tabulator-footer .tabulator-footer-contents {
- display: flex;
- flex-direction: row;
- align-items: center;
- justify-content: space-between;
- padding: 5px 10px; }
- .tabulator .tabulator-footer .tabulator-footer-contents:empty {
- display: none; }
- .tabulator .tabulator-footer .tabulator-calcs-holder {
- box-sizing: border-box;
- width: 100%;
- text-align: left;
- background: var(--fill-color) !important;
- border-bottom: 1px solid var(--neutral-divider-rest);
- border-top: 1px solid var(--neutral-divider-rest);
- overflow: hidden; }
- .tabulator .tabulator-footer .tabulator-calcs-holder .tabulator-row {
- display: inline-block;
- background: var(--fill-color) !important; }
- .tabulator .tabulator-footer .tabulator-calcs-holder .tabulator-row .tabulator-col-resize-handle {
- display: none; }
- .tabulator .tabulator-footer .tabulator-calcs-holder:only-child {
- margin-bottom: -5px;
- border-bottom: none; }
- .tabulator .tabulator-footer > * + .tabulator-page-counter {
- margin-left: 10px; }
- .tabulator .tabulator-footer .tabulator-page-counter {
- font-weight: normal; }
- .tabulator .tabulator-footer .tabulator-paginator {
- flex: 1;
- text-align: right;
- color: var(--neutral-foreground-rest);
- font-family: inherit;
- font-weight: inherit;
- font-size: inherit; }
- .tabulator .tabulator-footer .tabulator-page-size {
- display: inline-block;
- margin: 0 5px;
- padding: 2px 5px;
- border: 1px solid var(--accent-fill-rest);
- border-radius: 3px; }
- .tabulator .tabulator-footer .tabulator-pages {
- margin: 0 7px; }
- .tabulator .tabulator-footer .tabulator-page {
- display: inline-block;
- margin: 0 2px;
- padding: 2px 5px;
- border: 1px solid var(--accent-fill-rest);
- border-radius: 3px;
- background: rgba(255, 255, 255, 0.2); }
- .tabulator .tabulator-footer .tabulator-page.active {
- color: var(--neutral-foreground-active); }
- .tabulator .tabulator-footer .tabulator-page:disabled {
- opacity: .5; }
- .tabulator .tabulator-footer .tabulator-page:not(.disabled):hover {
- cursor: pointer;
- background: rgba(0, 0, 0, 0.2);
- color: #fff; }
- .tabulator .tabulator-col-resize-handle {
- position: relative;
- display: inline-block;
- width: 6px;
- margin-left: -3px;
- margin-right: -3px;
- z-index: 10;
- vertical-align: middle; }
- .tabulator .tabulator-col-resize-handle:hover {
- cursor: ew-resize; }
- .tabulator .tabulator-col-resize-handle:last-of-type {
- width: 3px;
- margin-right: 0; }
- .tabulator .tabulator-alert {
- position: absolute;
- display: flex;
- align-items: center;
- top: 0;
- left: 0;
- z-index: 100;
- height: 100%;
- width: 100%;
- background: rgba(0, 0, 0, 0.4);
- text-align: center; }
- .tabulator .tabulator-alert .tabulator-alert-msg {
- display: inline-block;
- margin: 0 auto;
- padding: 10px 20px;
- border-radius: 10px;
- background: #fff;
- font-weight: bold;
- font-size: 16px; }
- .tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-msg {
- border: 4px solid #333;
- color: #000; }
- .tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-error {
- border: 4px solid #D00;
- color: #590000; }
+ transform: translateZ(0);
+}
+.tabulator[tabulator-layout='fitDataFill']
+ .tabulator-tableholder
+ .tabulator-table {
+ min-width: 100%;
+}
+.tabulator[tabulator-layout='fitDataTable'] {
+ display: inline-block;
+}
+.tabulator.tabulator-block-select {
+ user-select: none;
+}
+.tabulator .tabulator-header {
+ position: relative;
+ box-sizing: border-box;
+ width: 100%;
+ border-bottom: 2px solid var(--accent-fill-rest);
+ background-color: var(--fill-color);
+ color: var(--neutral-foreground-rest);
+ font-weight: bold;
+ white-space: nowrap;
+ overflow: hidden;
+ -moz-user-select: none;
+ -khtml-user-select: none;
+ -webkit-user-select: none;
+ -o-user-select: none;
+}
+.tabulator .tabulator-header.tabulator-header-hidden {
+ display: none;
+}
+.tabulator .tabulator-header .tabulator-header-contents {
+ position: relative;
+ overflow: hidden;
+}
+.tabulator .tabulator-header .tabulator-header-contents .tabulator-headers {
+ display: inline-block;
+}
+.tabulator .tabulator-header .tabulator-col {
+ display: inline-flex;
+ position: relative;
+ box-sizing: border-box;
+ flex-direction: column;
+ justify-content: flex-start;
+ border-right: 1px solid var(--neutral-stroke-divider-rest);
+ background: var(--fill-color);
+ text-align: left;
+ vertical-align: bottom;
+ overflow: hidden;
+}
+.tabulator .tabulator-header .tabulator-col.tabulator-moving {
+ position: absolute;
+ border: 1px solid var(--neutral-divider-rest);
+ background: var(--fill-color);
+ pointer-events: none;
+}
+.tabulator .tabulator-header .tabulator-col .tabulator-col-content {
+ box-sizing: border-box;
+ position: relative;
+ padding: 4px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-header-popup-button {
+ padding: 0 8px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-header-popup-button:hover {
+ cursor: pointer;
+ opacity: 0.6;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-title-holder {
+ position: relative;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-title {
+ box-sizing: border-box;
+ width: 100%;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ vertical-align: bottom;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-title.tabulator-col-title-wrap {
+ white-space: normal;
+ text-overflow: initial;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-title
+ .tabulator-title-editor {
+ box-sizing: border-box;
+ width: 100%;
+ border: 1px solid #999;
+ padding: 1px;
+ background: #fff;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-title
+ .tabulator-header-popup-button
+ + .tabulator-title-editor {
+ width: calc(100% - 22px);
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-sorter {
+ display: flex;
+ align-items: center;
+ position: absolute;
+ top: 0;
+ bottom: 0;
+ right: 4px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-sorter
+ .tabulator-arrow {
+ width: 0;
+ height: 0;
+ border-left: 6px solid transparent;
+ border-right: 6px solid transparent;
+ border-bottom: 6px solid #bbb;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-col-group
+ .tabulator-col-group-cols {
+ position: relative;
+ display: flex;
+ border-top: 1px solid var(--accent-fill-rest);
+ overflow: hidden;
+ margin-right: -1px;
+}
+.tabulator .tabulator-header .tabulator-col .tabulator-header-filter {
+ position: relative;
+ box-sizing: border-box;
+ margin-top: 2px;
+ width: 100%;
+ text-align: center;
+}
+.tabulator .tabulator-header .tabulator-col .tabulator-header-filter textarea {
+ height: auto !important;
+}
+.tabulator .tabulator-header .tabulator-col .tabulator-header-filter svg {
+ margin-top: 3px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-header-filter
+ input::-ms-clear {
+ width: 0;
+ height: 0;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable
+ .tabulator-col-title {
+ padding-right: 25px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable.tabulator-col-sorter-element:hover {
+ cursor: pointer;
+ background-color: var(--fill-color);
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='none']
+ .tabulator-col-content
+ .tabulator-col-sorter {
+ color: #bbb;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='none']
+ .tabulator-col-content
+ .tabulator-col-sorter.tabulator-col-sorter-element
+ .tabulator-arrow:hover {
+ cursor: pointer;
+ border-bottom: 6px solid #555;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='none']
+ .tabulator-col-content
+ .tabulator-col-sorter
+ .tabulator-arrow {
+ border-top: none;
+ border-bottom: 6px solid #bbb;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='ascending']
+ .tabulator-col-content
+ .tabulator-col-sorter {
+ color: #666;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='ascending']
+ .tabulator-col-content
+ .tabulator-col-sorter.tabulator-col-sorter-element
+ .tabulator-arrow:hover {
+ cursor: pointer;
+ border-bottom: 6px solid #555;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='ascending']
+ .tabulator-col-content
+ .tabulator-col-sorter
+ .tabulator-arrow {
+ border-top: none;
+ border-bottom: 6px solid #666;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='descending']
+ .tabulator-col-content
+ .tabulator-col-sorter {
+ color: #666;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='descending']
+ .tabulator-col-content
+ .tabulator-col-sorter.tabulator-col-sorter-element
+ .tabulator-arrow:hover {
+ cursor: pointer;
+ border-top: 6px solid #555;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-sortable[aria-sort='descending']
+ .tabulator-col-content
+ .tabulator-col-sorter
+ .tabulator-arrow {
+ border-bottom: none;
+ border-top: 6px solid #666;
+ color: #666;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-col-vertical
+ .tabulator-col-content
+ .tabulator-col-title {
+ writing-mode: vertical-rl;
+ text-orientation: mixed;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-col-vertical.tabulator-col-vertical-flip
+ .tabulator-col-title {
+ transform: rotate(180deg);
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-col-vertical.tabulator-sortable
+ .tabulator-col-title {
+ padding-right: 0;
+ padding-top: 20px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-col-vertical.tabulator-sortable.tabulator-col-vertical-flip
+ .tabulator-col-title {
+ padding-right: 0;
+ padding-bottom: 20px;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col.tabulator-col-vertical.tabulator-sortable
+ .tabulator-col-sorter {
+ justify-content: center;
+ left: 0;
+ right: 0;
+ top: 4px;
+ bottom: auto;
+}
+.tabulator .tabulator-header .tabulator-frozen {
+ position: sticky;
+ left: 0;
+ z-index: 10;
+}
+.tabulator .tabulator-header .tabulator-frozen.tabulator-frozen-left {
+ border-right: 2px solid var(--neutral-divider-rest);
+}
+.tabulator .tabulator-header .tabulator-frozen.tabulator-frozen-right {
+ border-left: 2px solid var(--neutral-divider-rest);
+}
+.tabulator .tabulator-header .tabulator-calcs-holder {
+ box-sizing: border-box;
+ background: var(--fill-color) !important;
+ border-top: 1px solid var(--neutral-divider-rest);
+ border-bottom: 1px solid var(--accent-fill-rest);
+}
+.tabulator .tabulator-header .tabulator-calcs-holder .tabulator-row {
+ background: var(--fill-color) !important;
+}
+.tabulator
+ .tabulator-header
+ .tabulator-calcs-holder
+ .tabulator-row
+ .tabulator-col-resize-handle {
+ display: none;
+}
+.tabulator .tabulator-header .tabulator-frozen-rows-holder:empty {
+ display: none;
+}
+.tabulator .tabulator-tableholder {
+ position: relative;
+ width: 100%;
+ white-space: nowrap;
+ overflow: auto;
+ -webkit-overflow-scrolling: touch;
+}
+.tabulator .tabulator-tableholder:focus {
+ outline: none;
+}
+.tabulator .tabulator-tableholder .tabulator-placeholder {
+ box-sizing: border-box;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ width: 100%;
+}
+.tabulator
+ .tabulator-tableholder
+ .tabulator-placeholder[tabulator-render-mode='virtual'] {
+ min-height: 100%;
+ min-width: 100%;
+}
+.tabulator
+ .tabulator-tableholder
+ .tabulator-placeholder
+ .tabulator-placeholder-contents {
+ display: inline-block;
+ text-align: center;
+ padding: 10px;
+ color: #ccc;
+ font-weight: bold;
+ font-size: 20px;
+ white-space: normal;
+}
+.tabulator .tabulator-tableholder .tabulator-table {
+ position: relative;
+ display: inline-block;
+ background-color: var(--fill-color);
+ white-space: nowrap;
+ overflow: visible;
+ color: var(--neutral-foreground-rest);
+}
+.tabulator
+ .tabulator-tableholder
+ .tabulator-table
+ .tabulator-row.tabulator-calcs {
+ font-weight: bold;
+ background: var(--neutral-fill-rest) !important;
+}
+.tabulator
+ .tabulator-tableholder
+ .tabulator-table
+ .tabulator-row.tabulator-calcs.tabulator-calcs-top {
+ border-bottom: 2px solid var(--neutral-divider-rest);
+}
+.tabulator
+ .tabulator-tableholder
+ .tabulator-table
+ .tabulator-row.tabulator-calcs.tabulator-calcs-bottom {
+ border-top: 2px solid var(--neutral-divider-rest);
+}
+.tabulator .tabulator-footer {
+ border-top: 1px solid var(--neutral-divider-rest);
+ background-color: var(--fill-color);
+ color: var(--neutral-foreground-rest);
+ font-weight: bold;
+ white-space: nowrap;
+ user-select: none;
+ -moz-user-select: none;
+ -khtml-user-select: none;
+ -webkit-user-select: none;
+ -o-user-select: none;
+}
+.tabulator .tabulator-footer .tabulator-footer-contents {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-between;
+ padding: 5px 10px;
+}
+.tabulator .tabulator-footer .tabulator-footer-contents:empty {
+ display: none;
+}
+.tabulator .tabulator-footer .tabulator-calcs-holder {
+ box-sizing: border-box;
+ width: 100%;
+ text-align: left;
+ background: var(--fill-color) !important;
+ border-bottom: 1px solid var(--neutral-divider-rest);
+ border-top: 1px solid var(--neutral-divider-rest);
+ overflow: hidden;
+}
+.tabulator .tabulator-footer .tabulator-calcs-holder .tabulator-row {
+ display: inline-block;
+ background: var(--fill-color) !important;
+}
+.tabulator
+ .tabulator-footer
+ .tabulator-calcs-holder
+ .tabulator-row
+ .tabulator-col-resize-handle {
+ display: none;
+}
+.tabulator .tabulator-footer .tabulator-calcs-holder:only-child {
+ margin-bottom: -5px;
+ border-bottom: none;
+}
+.tabulator .tabulator-footer > * + .tabulator-page-counter {
+ margin-left: 10px;
+}
+.tabulator .tabulator-footer .tabulator-page-counter {
+ font-weight: normal;
+}
+.tabulator .tabulator-footer .tabulator-paginator {
+ flex: 1;
+ text-align: right;
+ color: var(--neutral-foreground-rest);
+ font-family: inherit;
+ font-weight: inherit;
+ font-size: inherit;
+}
+.tabulator .tabulator-footer .tabulator-page-size {
+ display: inline-block;
+ margin: 0 5px;
+ padding: 2px 5px;
+ border: 1px solid var(--accent-fill-rest);
+ border-radius: 3px;
+}
+.tabulator .tabulator-footer .tabulator-pages {
+ margin: 0 7px;
+}
+.tabulator .tabulator-footer .tabulator-page {
+ display: inline-block;
+ margin: 0 2px;
+ padding: 2px 5px;
+ border: 1px solid var(--accent-fill-rest);
+ border-radius: 3px;
+ background: rgba(255, 255, 255, 0.2);
+}
+.tabulator .tabulator-footer .tabulator-page.active {
+ color: var(--neutral-foreground-active);
+}
+.tabulator .tabulator-footer .tabulator-page:disabled {
+ opacity: 0.5;
+}
+.tabulator .tabulator-footer .tabulator-page:not(.disabled):hover {
+ cursor: pointer;
+ background: rgba(0, 0, 0, 0.2);
+ color: #fff;
+}
+.tabulator .tabulator-col-resize-handle {
+ position: relative;
+ display: inline-block;
+ width: 6px;
+ margin-left: -3px;
+ margin-right: -3px;
+ z-index: 10;
+ vertical-align: middle;
+}
+.tabulator .tabulator-col-resize-handle:hover {
+ cursor: ew-resize;
+}
+.tabulator .tabulator-col-resize-handle:last-of-type {
+ width: 3px;
+ margin-right: 0;
+}
+.tabulator .tabulator-alert {
+ position: absolute;
+ display: flex;
+ align-items: center;
+ top: 0;
+ left: 0;
+ z-index: 100;
+ height: 100%;
+ width: 100%;
+ background: rgba(0, 0, 0, 0.4);
+ text-align: center;
+}
+.tabulator .tabulator-alert .tabulator-alert-msg {
+ display: inline-block;
+ margin: 0 auto;
+ padding: 10px 20px;
+ border-radius: 10px;
+ background: #fff;
+ font-weight: bold;
+ font-size: 16px;
+}
+.tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-msg {
+ border: 4px solid #333;
+ color: #000;
+}
+.tabulator .tabulator-alert .tabulator-alert-msg.tabulator-alert-state-error {
+ border: 4px solid #d00;
+ color: #590000;
+}
.tabulator-row {
position: relative;
box-sizing: border-box;
min-height: 22px;
- background-color: var(--fill-color); }
- .tabulator-row.tabulator-row-even {
- background-color: var(--neutral-fill-rest); }
- .tabulator-row.tabulator-selectable:hover {
- background-color: var(--accent-fill-hover);
- color: var(--foreground-on-accent-hover);
- cursor: pointer; }
- .tabulator-row.tabulator-selected {
- background-color: var(--accent-fill-active);
- color: var(--foreground-on-accent-rest); }
- .tabulator-row.tabulator-selected:hover {
- background-color: var(--accent-fill-hover);
- cursor: pointer; }
- .tabulator-row.tabulator-row-moving {
- border: 1px solid #000;
- background: #fff; }
- .tabulator-row.tabulator-moving {
- position: absolute;
- border-top: 1px solid var(--neutral-divider-rest);
- border-bottom: 1px solid var(--neutral-divider-rest);
- pointer-events: none;
- z-index: 15; }
- .tabulator-row .tabulator-row-resize-handle {
- position: absolute;
- right: 0;
- bottom: 0;
- left: 0;
- height: 5px; }
- .tabulator-row .tabulator-row-resize-handle.prev {
- top: 0;
- bottom: auto; }
- .tabulator-row .tabulator-row-resize-handle:hover {
- cursor: ns-resize; }
- .tabulator-row .tabulator-responsive-collapse {
- box-sizing: border-box;
- padding: 5px;
- border-top: 1px solid var(--neutral-divider-rest);
- border-bottom: 1px solid var(--neutral-divider-rest); }
- .tabulator-row .tabulator-responsive-collapse:empty {
- display: none; }
- .tabulator-row .tabulator-responsive-collapse table {
- font-size: 14px; }
- .tabulator-row .tabulator-responsive-collapse table tr td {
- position: relative; }
- .tabulator-row .tabulator-responsive-collapse table tr td:first-of-type {
- padding-right: 10px; }
- .tabulator-row .tabulator-cell {
- display: inline-block;
- position: relative;
- box-sizing: border-box;
- padding: 4px;
- border-right: 1px solid var(--neutral-divider-rest);
- vertical-align: middle;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis; }
- .tabulator-row .tabulator-cell.tabulator-frozen {
- display: inline-block;
- position: sticky;
- left: 0;
- background-color: inherit;
- z-index: 10; }
- .tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-left {
- border-right: 2px solid var(--neutral-divider-rest); }
- .tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-right {
- border-left: 2px solid var(--neutral-divider-rest); }
- .tabulator-row .tabulator-cell.tabulator-editing {
- border: 1px solid #999;
- outline: none;
- padding: 0; }
- .tabulator-row .tabulator-cell.tabulator-editing input, .tabulator-row .tabulator-cell.tabulator-editing select {
- border: 1px;
- background: transparent;
- color: var(--neutral-foreground-rest);
- outline: none; }
- .tabulator-row .tabulator-cell.tabulator-validation-fail {
- border: 1px solid #dd0000; }
- .tabulator-row .tabulator-cell.tabulator-validation-fail input, .tabulator-row .tabulator-cell.tabulator-validation-fail select {
- border: 1px;
- background: transparent;
- color: #dd0000; }
- .tabulator-row .tabulator-cell.tabulator-row-handle {
- display: inline-flex;
- align-items: center;
- justify-content: center;
- -moz-user-select: none;
- -khtml-user-select: none;
- -webkit-user-select: none;
- -o-user-select: none; }
- .tabulator-row .tabulator-cell.tabulator-row-handle .tabulator-row-handle-box {
- width: 80%; }
- .tabulator-row .tabulator-cell.tabulator-row-handle .tabulator-row-handle-box .tabulator-row-handle-bar {
- width: 100%;
- height: 3px;
- margin-top: 2px;
- background: #666; }
- .tabulator-row .tabulator-cell .tabulator-data-tree-branch {
- display: inline-block;
- vertical-align: middle;
- height: 9px;
- width: 7px;
- margin-top: -9px;
- margin-right: 5px;
- border-bottom-left-radius: 1px;
- border-left: 2px solid var(--neutral-divider-rest);
- border-bottom: 2px solid var(--neutral-divider-rest); }
- .tabulator-row .tabulator-cell .tabulator-data-tree-control {
- display: inline-flex;
- justify-content: center;
- align-items: center;
- vertical-align: middle;
- height: 11px;
- width: 11px;
- margin-right: 5px;
- border: 1px solid var(--neutral-foreground-rest);
- border-radius: 2px;
- background: rgba(0, 0, 0, 0.1);
- overflow: hidden; }
- .tabulator-row .tabulator-cell .tabulator-data-tree-control:hover {
- cursor: pointer;
- background: rgba(0, 0, 0, 0.2); }
- .tabulator-row .tabulator-cell .tabulator-data-tree-control .tabulator-data-tree-control-collapse {
- display: inline-block;
- position: relative;
- height: 7px;
- width: 1px;
- background: transparent; }
- .tabulator-row .tabulator-cell .tabulator-data-tree-control .tabulator-data-tree-control-collapse:after {
- position: absolute;
- content: "";
- left: -3px;
- top: 3px;
- height: 1px;
- width: 7px;
- background: var(--neutral-foreground-rest); }
- .tabulator-row .tabulator-cell .tabulator-data-tree-control .tabulator-data-tree-control-expand {
- display: inline-block;
- position: relative;
- height: 7px;
- width: 1px;
- background: var(--neutral-foreground-rest); }
- .tabulator-row .tabulator-cell .tabulator-data-tree-control .tabulator-data-tree-control-expand:after {
- position: absolute;
- content: "";
- left: -3px;
- top: 3px;
- height: 1px;
- width: 7px;
- background: var(--neutral-foreground-rest); }
- .tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle {
- display: inline-flex;
- align-items: center;
- justify-content: center;
- -moz-user-select: none;
- -khtml-user-select: none;
- -webkit-user-select: none;
- -o-user-select: none;
- height: 15px;
- width: 15px;
- border-radius: 20px;
- background: #666;
- color: var(--fill-color);
- font-weight: bold;
- font-size: 1.1em; }
- .tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle:hover {
- opacity: .7;
- cursor: pointer; }
- .tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle.open .tabulator-responsive-collapse-toggle-close {
- display: initial; }
- .tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle.open .tabulator-responsive-collapse-toggle-open {
- display: none; }
- .tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle svg {
- stroke: var(--fill-color); }
- .tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle .tabulator-responsive-collapse-toggle-close {
- display: none; }
- .tabulator-row .tabulator-cell .tabulator-traffic-light {
- display: inline-block;
- height: 14px;
- width: 14px;
- border-radius: 14px; }
- .tabulator-row.tabulator-group {
- box-sizing: border-box;
- border-bottom: 1px solid #999;
- border-right: 1px solid var(--neutral-divider-rest);
- border-top: 1px solid #999;
- padding: 5px;
- padding-left: 10px;
- background: #ccc;
- font-weight: bold;
- min-width: 100%; }
- .tabulator-row.tabulator-group:hover {
- cursor: pointer;
- background-color: rgba(0, 0, 0, 0.1); }
- .tabulator-row.tabulator-group.tabulator-group-visible .tabulator-arrow {
- margin-right: 10px;
- border-left: 6px solid transparent;
- border-right: 6px solid transparent;
- border-top: 6px solid #666;
- border-bottom: 0; }
- .tabulator-row.tabulator-group.tabulator-group-level-1 {
- padding-left: 30px; }
- .tabulator-row.tabulator-group.tabulator-group-level-2 {
- padding-left: 50px; }
- .tabulator-row.tabulator-group.tabulator-group-level-3 {
- padding-left: 70px; }
- .tabulator-row.tabulator-group.tabulator-group-level-4 {
- padding-left: 90px; }
- .tabulator-row.tabulator-group.tabulator-group-level-5 {
- padding-left: 110px; }
- .tabulator-row.tabulator-group .tabulator-group-toggle {
- display: inline-block; }
- .tabulator-row.tabulator-group .tabulator-arrow {
- display: inline-block;
- width: 0;
- height: 0;
- margin-right: 16px;
- border-top: 6px solid transparent;
- border-bottom: 6px solid transparent;
- border-right: 0;
- border-left: 6px solid #666;
- vertical-align: middle; }
- .tabulator-row.tabulator-group span {
- margin-left: 10px;
- color: #d00; }
+ background-color: var(--fill-color);
+}
+.tabulator-row.tabulator-row-even {
+ background-color: var(--neutral-fill-rest);
+}
+.tabulator-row.tabulator-selectable:hover {
+ background-color: var(--accent-fill-hover);
+ color: var(--foreground-on-accent-hover);
+ cursor: pointer;
+}
+.tabulator-row.tabulator-selected {
+ background-color: var(--accent-fill-active);
+ color: var(--foreground-on-accent-rest);
+}
+.tabulator-row.tabulator-selected:hover {
+ background-color: var(--accent-fill-hover);
+ cursor: pointer;
+}
+.tabulator-row.tabulator-row-moving {
+ border: 1px solid #000;
+ background: #fff;
+}
+.tabulator-row.tabulator-moving {
+ position: absolute;
+ border-top: 1px solid var(--neutral-divider-rest);
+ border-bottom: 1px solid var(--neutral-divider-rest);
+ pointer-events: none;
+ z-index: 15;
+}
+.tabulator-row .tabulator-row-resize-handle {
+ position: absolute;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ height: 5px;
+}
+.tabulator-row .tabulator-row-resize-handle.prev {
+ top: 0;
+ bottom: auto;
+}
+.tabulator-row .tabulator-row-resize-handle:hover {
+ cursor: ns-resize;
+}
+.tabulator-row .tabulator-responsive-collapse {
+ box-sizing: border-box;
+ padding: 5px;
+ border-top: 1px solid var(--neutral-divider-rest);
+ border-bottom: 1px solid var(--neutral-divider-rest);
+}
+.tabulator-row .tabulator-responsive-collapse:empty {
+ display: none;
+}
+.tabulator-row .tabulator-responsive-collapse table {
+ font-size: 14px;
+}
+.tabulator-row .tabulator-responsive-collapse table tr td {
+ position: relative;
+}
+.tabulator-row .tabulator-responsive-collapse table tr td:first-of-type {
+ padding-right: 10px;
+}
+.tabulator-row .tabulator-cell {
+ display: inline-block;
+ position: relative;
+ box-sizing: border-box;
+ padding: 4px;
+ border-right: 1px solid var(--neutral-divider-rest);
+ vertical-align: middle;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+}
+.tabulator-row .tabulator-cell.tabulator-frozen {
+ display: inline-block;
+ position: sticky;
+ left: 0;
+ background-color: inherit;
+ z-index: 10;
+}
+.tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-left {
+ border-right: 2px solid var(--neutral-divider-rest);
+}
+.tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-right {
+ border-left: 2px solid var(--neutral-divider-rest);
+}
+.tabulator-row .tabulator-cell.tabulator-editing {
+ border: 1px solid #999;
+ outline: none;
+ padding: 0;
+}
+.tabulator-row .tabulator-cell.tabulator-editing input,
+.tabulator-row .tabulator-cell.tabulator-editing select {
+ border: 1px;
+ background: transparent;
+ color: var(--neutral-foreground-rest);
+ outline: none;
+}
+.tabulator-row .tabulator-cell.tabulator-validation-fail {
+ border: 1px solid #dd0000;
+}
+.tabulator-row .tabulator-cell.tabulator-validation-fail input,
+.tabulator-row .tabulator-cell.tabulator-validation-fail select {
+ border: 1px;
+ background: transparent;
+ color: #dd0000;
+}
+.tabulator-row .tabulator-cell.tabulator-row-handle {
+ display: inline-flex;
+ align-items: center;
+ justify-content: center;
+ -moz-user-select: none;
+ -khtml-user-select: none;
+ -webkit-user-select: none;
+ -o-user-select: none;
+}
+.tabulator-row .tabulator-cell.tabulator-row-handle .tabulator-row-handle-box {
+ width: 80%;
+}
+.tabulator-row
+ .tabulator-cell.tabulator-row-handle
+ .tabulator-row-handle-box
+ .tabulator-row-handle-bar {
+ width: 100%;
+ height: 3px;
+ margin-top: 2px;
+ background: #666;
+}
+.tabulator-row .tabulator-cell .tabulator-data-tree-branch {
+ display: inline-block;
+ vertical-align: middle;
+ height: 9px;
+ width: 7px;
+ margin-top: -9px;
+ margin-right: 5px;
+ border-bottom-left-radius: 1px;
+ border-left: 2px solid var(--neutral-divider-rest);
+ border-bottom: 2px solid var(--neutral-divider-rest);
+}
+.tabulator-row .tabulator-cell .tabulator-data-tree-control {
+ display: inline-flex;
+ justify-content: center;
+ align-items: center;
+ vertical-align: middle;
+ height: 11px;
+ width: 11px;
+ margin-right: 5px;
+ border: 1px solid var(--neutral-foreground-rest);
+ border-radius: 2px;
+ background: rgba(0, 0, 0, 0.1);
+ overflow: hidden;
+}
+.tabulator-row .tabulator-cell .tabulator-data-tree-control:hover {
+ cursor: pointer;
+ background: rgba(0, 0, 0, 0.2);
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-collapse {
+ display: inline-block;
+ position: relative;
+ height: 7px;
+ width: 1px;
+ background: transparent;
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-collapse:after {
+ position: absolute;
+ content: '';
+ left: -3px;
+ top: 3px;
+ height: 1px;
+ width: 7px;
+ background: var(--neutral-foreground-rest);
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-expand {
+ display: inline-block;
+ position: relative;
+ height: 7px;
+ width: 1px;
+ background: var(--neutral-foreground-rest);
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-expand:after {
+ position: absolute;
+ content: '';
+ left: -3px;
+ top: 3px;
+ height: 1px;
+ width: 7px;
+ background: var(--neutral-foreground-rest);
+}
+.tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle {
+ display: inline-flex;
+ align-items: center;
+ justify-content: center;
+ -moz-user-select: none;
+ -khtml-user-select: none;
+ -webkit-user-select: none;
+ -o-user-select: none;
+ height: 15px;
+ width: 15px;
+ border-radius: 20px;
+ background: #666;
+ color: var(--fill-color);
+ font-weight: bold;
+ font-size: 1.1em;
+}
+.tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle:hover {
+ opacity: 0.7;
+ cursor: pointer;
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-responsive-collapse-toggle.open
+ .tabulator-responsive-collapse-toggle-close {
+ display: initial;
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-responsive-collapse-toggle.open
+ .tabulator-responsive-collapse-toggle-open {
+ display: none;
+}
+.tabulator-row .tabulator-cell .tabulator-responsive-collapse-toggle svg {
+ stroke: var(--fill-color);
+}
+.tabulator-row
+ .tabulator-cell
+ .tabulator-responsive-collapse-toggle
+ .tabulator-responsive-collapse-toggle-close {
+ display: none;
+}
+.tabulator-row .tabulator-cell .tabulator-traffic-light {
+ display: inline-block;
+ height: 14px;
+ width: 14px;
+ border-radius: 14px;
+}
+.tabulator-row.tabulator-group {
+ box-sizing: border-box;
+ border-bottom: 1px solid #999;
+ border-right: 1px solid var(--neutral-divider-rest);
+ border-top: 1px solid #999;
+ padding: 5px;
+ padding-left: 10px;
+ background: #ccc;
+ font-weight: bold;
+ min-width: 100%;
+}
+.tabulator-row.tabulator-group:hover {
+ cursor: pointer;
+ background-color: rgba(0, 0, 0, 0.1);
+}
+.tabulator-row.tabulator-group.tabulator-group-visible .tabulator-arrow {
+ margin-right: 10px;
+ border-left: 6px solid transparent;
+ border-right: 6px solid transparent;
+ border-top: 6px solid #666;
+ border-bottom: 0;
+}
+.tabulator-row.tabulator-group.tabulator-group-level-1 {
+ padding-left: 30px;
+}
+.tabulator-row.tabulator-group.tabulator-group-level-2 {
+ padding-left: 50px;
+}
+.tabulator-row.tabulator-group.tabulator-group-level-3 {
+ padding-left: 70px;
+}
+.tabulator-row.tabulator-group.tabulator-group-level-4 {
+ padding-left: 90px;
+}
+.tabulator-row.tabulator-group.tabulator-group-level-5 {
+ padding-left: 110px;
+}
+.tabulator-row.tabulator-group .tabulator-group-toggle {
+ display: inline-block;
+}
+.tabulator-row.tabulator-group .tabulator-arrow {
+ display: inline-block;
+ width: 0;
+ height: 0;
+ margin-right: 16px;
+ border-top: 6px solid transparent;
+ border-bottom: 6px solid transparent;
+ border-right: 0;
+ border-left: 6px solid #666;
+ vertical-align: middle;
+}
+.tabulator-row.tabulator-group span {
+ margin-left: 10px;
+ color: #d00;
+}
.tabulator-popup-container {
position: absolute;
@@ -569,11 +860,13 @@
font-size: 14px;
overflow-y: auto;
-webkit-overflow-scrolling: touch;
- z-index: 10000; }
+ z-index: 10000;
+}
.tabulator-popup {
padding: 5px;
- border-radius: 3px; }
+ border-radius: 3px;
+}
.tabulator-tooltip {
max-width: Min(500px, 100%);
@@ -581,121 +874,191 @@
border-radius: 2px;
box-shadow: none;
font-size: 12px;
- pointer-events: none; }
+ pointer-events: none;
+}
.tabulator-menu .tabulator-menu-item {
position: relative;
box-sizing: border-box;
padding: 5px 10px;
- user-select: none; }
- .tabulator-menu .tabulator-menu-item.tabulator-menu-item-disabled {
- opacity: .5; }
- .tabulator-menu .tabulator-menu-item:not(.tabulator-menu-item-disabled):hover {
- cursor: pointer;
- background: var(--neutral-fill-rest); }
- .tabulator-menu .tabulator-menu-item.tabulator-menu-item-submenu {
- padding-right: 25px; }
- .tabulator-menu .tabulator-menu-item.tabulator-menu-item-submenu::after {
- display: inline-block;
- position: absolute;
- top: calc(5px + .4em);
- right: 10px;
- height: 7px;
- width: 7px;
- content: '';
- border-width: 1px 1px 0 0;
- border-style: solid;
- border-color: var(--neutral-divider-rest);
- vertical-align: top;
- transform: rotate(45deg); }
+ user-select: none;
+}
+.tabulator-menu .tabulator-menu-item.tabulator-menu-item-disabled {
+ opacity: 0.5;
+}
+.tabulator-menu .tabulator-menu-item:not(.tabulator-menu-item-disabled):hover {
+ cursor: pointer;
+ background: var(--neutral-fill-rest);
+}
+.tabulator-menu .tabulator-menu-item.tabulator-menu-item-submenu {
+ padding-right: 25px;
+}
+.tabulator-menu .tabulator-menu-item.tabulator-menu-item-submenu::after {
+ display: inline-block;
+ position: absolute;
+ top: calc(5px + 0.4em);
+ right: 10px;
+ height: 7px;
+ width: 7px;
+ content: '';
+ border-width: 1px 1px 0 0;
+ border-style: solid;
+ border-color: var(--neutral-divider-rest);
+ vertical-align: top;
+ transform: rotate(45deg);
+}
.tabulator-menu .tabulator-menu-separator {
- border-top: 1px solid var(--neutral-divider-rest); }
+ border-top: 1px solid var(--neutral-divider-rest);
+}
.tabulator-edit-list {
max-height: 200px;
font-size: 14px;
overflow-y: auto;
- -webkit-overflow-scrolling: touch; }
- .tabulator-edit-list .tabulator-edit-list-item {
- padding: 4px;
- color: var(--neutral-foreground-rest);
- outline: none; }
- .tabulator-edit-list .tabulator-edit-list-item.active {
- color: var(--fill-color);
- background: #999; }
- .tabulator-edit-list .tabulator-edit-list-item.active.focused {
- outline: 1px solid rgba(var(--fill-color), 0.5); }
- .tabulator-edit-list .tabulator-edit-list-item.focused {
- outline: 1px solid #999; }
- .tabulator-edit-list .tabulator-edit-list-item:hover {
- cursor: pointer;
- color: var(--fill-color);
- background: #999; }
- .tabulator-edit-list .tabulator-edit-list-placeholder {
- padding: 4px;
- color: var(--neutral-foreground-rest);
- text-align: center; }
- .tabulator-edit-list .tabulator-edit-list-group {
- border-bottom: 1px solid var(--neutral-divider-rest);
- padding: 4px;
- padding-top: 6px;
- color: var(--neutral-foreground-rest);
- font-weight: bold; }
- .tabulator-edit-list .tabulator-edit-list-item.tabulator-edit-list-group-level-2, .tabulator-edit-list .tabulator-edit-list-group.tabulator-edit-list-group-level-2 {
- padding-left: 12px; }
- .tabulator-edit-list .tabulator-edit-list-item.tabulator-edit-list-group-level-3, .tabulator-edit-list .tabulator-edit-list-group.tabulator-edit-list-group-level-3 {
- padding-left: 20px; }
- .tabulator-edit-list .tabulator-edit-list-item.tabulator-edit-list-group-level-4, .tabulator-edit-list .tabulator-edit-list-group.tabulator-edit-list-group-level-4 {
- padding-left: 28px; }
- .tabulator-edit-list .tabulator-edit-list-item.tabulator-edit-list-group-level-5, .tabulator-edit-list .tabulator-edit-list-group.tabulator-edit-list-group-level-5 {
- padding-left: 36px; }
+ -webkit-overflow-scrolling: touch;
+}
+.tabulator-edit-list .tabulator-edit-list-item {
+ padding: 4px;
+ color: var(--neutral-foreground-rest);
+ outline: none;
+}
+.tabulator-edit-list .tabulator-edit-list-item.active {
+ color: var(--fill-color);
+ background: #999;
+}
+.tabulator-edit-list .tabulator-edit-list-item.active.focused {
+ outline: 1px solid rgba(var(--fill-color), 0.5);
+}
+.tabulator-edit-list .tabulator-edit-list-item.focused {
+ outline: 1px solid #999;
+}
+.tabulator-edit-list .tabulator-edit-list-item:hover {
+ cursor: pointer;
+ color: var(--fill-color);
+ background: #999;
+}
+.tabulator-edit-list .tabulator-edit-list-placeholder {
+ padding: 4px;
+ color: var(--neutral-foreground-rest);
+ text-align: center;
+}
+.tabulator-edit-list .tabulator-edit-list-group {
+ border-bottom: 1px solid var(--neutral-divider-rest);
+ padding: 4px;
+ padding-top: 6px;
+ color: var(--neutral-foreground-rest);
+ font-weight: bold;
+}
+.tabulator-edit-list
+ .tabulator-edit-list-item.tabulator-edit-list-group-level-2,
+.tabulator-edit-list
+ .tabulator-edit-list-group.tabulator-edit-list-group-level-2 {
+ padding-left: 12px;
+}
+.tabulator-edit-list
+ .tabulator-edit-list-item.tabulator-edit-list-group-level-3,
+.tabulator-edit-list
+ .tabulator-edit-list-group.tabulator-edit-list-group-level-3 {
+ padding-left: 20px;
+}
+.tabulator-edit-list
+ .tabulator-edit-list-item.tabulator-edit-list-group-level-4,
+.tabulator-edit-list
+ .tabulator-edit-list-group.tabulator-edit-list-group-level-4 {
+ padding-left: 28px;
+}
+.tabulator-edit-list
+ .tabulator-edit-list-item.tabulator-edit-list-group-level-5,
+.tabulator-edit-list
+ .tabulator-edit-list-group.tabulator-edit-list-group-level-5 {
+ padding-left: 36px;
+}
.tabulator.tabulator-ltr {
- direction: ltr; }
+ direction: ltr;
+}
.tabulator.tabulator-rtl {
text-align: initial;
- direction: rtl; }
- .tabulator.tabulator-rtl .tabulator-header .tabulator-col {
- text-align: initial;
- border-left: 1px solid var(--accent-fill-rest);
- border-right: initial; }
- .tabulator.tabulator-rtl .tabulator-header .tabulator-col.tabulator-col-group .tabulator-col-group-cols {
- margin-right: initial;
- margin-left: -1px; }
- .tabulator.tabulator-rtl .tabulator-header .tabulator-col.tabulator-sortable .tabulator-col-title {
- padding-right: 0;
- padding-left: 25px; }
- .tabulator.tabulator-rtl .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-sorter {
- left: 8px;
- right: initial; }
- .tabulator.tabulator-rtl .tabulator-row .tabulator-cell {
- border-right: initial;
- border-left: 1px solid var(--neutral-divider-rest); }
- .tabulator.tabulator-rtl .tabulator-row .tabulator-cell .tabulator-data-tree-branch {
- margin-right: initial;
- margin-left: 5px;
- border-bottom-left-radius: initial;
- border-bottom-right-radius: 1px;
- border-left: initial;
- border-right: 2px solid var(--neutral-divider-rest); }
- .tabulator.tabulator-rtl .tabulator-row .tabulator-cell .tabulator-data-tree-control {
- margin-right: initial;
- margin-left: 5px; }
- .tabulator.tabulator-rtl .tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-left {
- border-left: 2px solid var(--neutral-divider-rest); }
- .tabulator.tabulator-rtl .tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-right {
- border-right: 2px solid var(--neutral-divider-rest); }
- .tabulator.tabulator-rtl .tabulator-row .tabulator-col-resize-handle:last-of-type {
- width: 3px;
- margin-left: 0;
- margin-right: -3px; }
- .tabulator.tabulator-rtl .tabulator-footer .tabulator-calcs-holder {
- text-align: initial; }
+ direction: rtl;
+}
+.tabulator.tabulator-rtl .tabulator-header .tabulator-col {
+ text-align: initial;
+ border-left: 1px solid var(--accent-fill-rest);
+ border-right: initial;
+}
+.tabulator.tabulator-rtl
+ .tabulator-header
+ .tabulator-col.tabulator-col-group
+ .tabulator-col-group-cols {
+ margin-right: initial;
+ margin-left: -1px;
+}
+.tabulator.tabulator-rtl
+ .tabulator-header
+ .tabulator-col.tabulator-sortable
+ .tabulator-col-title {
+ padding-right: 0;
+ padding-left: 25px;
+}
+.tabulator.tabulator-rtl
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-sorter {
+ left: 8px;
+ right: initial;
+}
+.tabulator.tabulator-rtl .tabulator-row .tabulator-cell {
+ border-right: initial;
+ border-left: 1px solid var(--neutral-divider-rest);
+}
+.tabulator.tabulator-rtl
+ .tabulator-row
+ .tabulator-cell
+ .tabulator-data-tree-branch {
+ margin-right: initial;
+ margin-left: 5px;
+ border-bottom-left-radius: initial;
+ border-bottom-right-radius: 1px;
+ border-left: initial;
+ border-right: 2px solid var(--neutral-divider-rest);
+}
+.tabulator.tabulator-rtl
+ .tabulator-row
+ .tabulator-cell
+ .tabulator-data-tree-control {
+ margin-right: initial;
+ margin-left: 5px;
+}
+.tabulator.tabulator-rtl
+ .tabulator-row
+ .tabulator-cell.tabulator-frozen.tabulator-frozen-left {
+ border-left: 2px solid var(--neutral-divider-rest);
+}
+.tabulator.tabulator-rtl
+ .tabulator-row
+ .tabulator-cell.tabulator-frozen.tabulator-frozen-right {
+ border-right: 2px solid var(--neutral-divider-rest);
+}
+.tabulator.tabulator-rtl
+ .tabulator-row
+ .tabulator-col-resize-handle:last-of-type {
+ width: 3px;
+ margin-left: 0;
+ margin-right: -3px;
+}
+.tabulator.tabulator-rtl .tabulator-footer .tabulator-calcs-holder {
+ text-align: initial;
+}
-.tabulator-cell a {color: var(--accent-fill-rest);}
-.tabulator-cell a:hover {color: var(--neutral-foreground-rest); }
+.tabulator-cell a {
+ color: var(--accent-fill-rest);
+}
+.tabulator-cell a:hover {
+ color: var(--neutral-foreground-rest);
+}
.tabulator-print-fullscreen {
position: absolute;
@@ -703,162 +1066,220 @@
bottom: 0;
left: 0;
right: 0;
- z-index: 10000; }
+ z-index: 10000;
+}
body.tabulator-print-fullscreen-hide > *:not(.tabulator-print-fullscreen) {
- display: none !important; }
+ display: none !important;
+}
.tabulator-print-table {
- border-collapse: collapse; }
- .tabulator-print-table .tabulator-data-tree-branch {
- display: inline-block;
- vertical-align: middle;
- height: 9px;
- width: 7px;
- margin-top: -9px;
- margin-right: 5px;
- border-bottom-left-radius: 1px;
- border-left: 2px solid var(--neutral-divider-rest);
- border-bottom: 2px solid var(--neutral-divider-rest); }
- .tabulator-print-table .tabulator-print-table-group {
- box-sizing: border-box;
- border-bottom: 1px solid #999;
- border-right: 1px solid var(--neutral-divider-rest);
- border-top: 1px solid #999;
- padding: 5px;
- padding-left: 10px;
- background: #ccc;
- font-weight: bold;
- min-width: 100%; }
- .tabulator-print-table .tabulator-print-table-group:hover {
- cursor: pointer;
- background-color: rgba(0, 0, 0, 0.1); }
- .tabulator-print-table .tabulator-print-table-group.tabulator-group-visible .tabulator-arrow {
- margin-right: 10px;
- border-left: 6px solid transparent;
- border-right: 6px solid transparent;
- border-top: 6px solid #666;
- border-bottom: 0; }
- .tabulator-print-table .tabulator-print-table-group.tabulator-group-level-1 td {
- padding-left: 30px !important; }
- .tabulator-print-table .tabulator-print-table-group.tabulator-group-level-2 td {
- padding-left: 50px !important; }
- .tabulator-print-table .tabulator-print-table-group.tabulator-group-level-3 td {
- padding-left: 70px !important; }
- .tabulator-print-table .tabulator-print-table-group.tabulator-group-level-4 td {
- padding-left: 90px !important; }
- .tabulator-print-table .tabulator-print-table-group.tabulator-group-level-5 td {
- padding-left: 110px !important; }
- .tabulator-print-table .tabulator-print-table-group .tabulator-group-toggle {
- display: inline-block; }
- .tabulator-print-table .tabulator-print-table-group .tabulator-arrow {
- display: inline-block;
- width: 0;
- height: 0;
- margin-right: 16px;
- border-top: 6px solid transparent;
- border-bottom: 6px solid transparent;
- border-right: 0;
- border-left: 6px solid #666;
- vertical-align: middle; }
- .tabulator-print-table .tabulator-print-table-group span {
- margin-left: 10px;
- color: #d00; }
- .tabulator-print-table .tabulator-data-tree-control {
- display: inline-flex;
- justify-content: center;
- align-items: center;
- vertical-align: middle;
- height: 11px;
- width: 11px;
- margin-right: 5px;
- border: 1px solid var(--neutral-foreground-rest);
- border-radius: 2px;
- background: rgba(0, 0, 0, 0.1);
- overflow: hidden; }
- .tabulator-print-table .tabulator-data-tree-control:hover {
- cursor: pointer;
- background: rgba(0, 0, 0, 0.2); }
- .tabulator-print-table .tabulator-data-tree-control .tabulator-data-tree-control-collapse {
- display: inline-block;
- position: relative;
- height: 7px;
- width: 1px;
- background: transparent; }
- .tabulator-print-table .tabulator-data-tree-control .tabulator-data-tree-control-collapse:after {
- position: absolute;
- content: "";
- left: -3px;
- top: 3px;
- height: 1px;
- width: 7px;
- background: var(--neutral-foreground-rest); }
- .tabulator-print-table .tabulator-data-tree-control .tabulator-data-tree-control-expand {
- display: inline-block;
- position: relative;
- height: 7px;
- width: 1px;
- background: var(--neutral-foreground-rest); }
- .tabulator-print-table .tabulator-data-tree-control .tabulator-data-tree-control-expand:after {
- position: absolute;
- content: "";
- left: -3px;
- top: 3px;
- height: 1px;
- width: 7px;
- background: var(--neutral-foreground-rest); }
+ border-collapse: collapse;
+}
+.tabulator-print-table .tabulator-data-tree-branch {
+ display: inline-block;
+ vertical-align: middle;
+ height: 9px;
+ width: 7px;
+ margin-top: -9px;
+ margin-right: 5px;
+ border-bottom-left-radius: 1px;
+ border-left: 2px solid var(--neutral-divider-rest);
+ border-bottom: 2px solid var(--neutral-divider-rest);
+}
+.tabulator-print-table .tabulator-print-table-group {
+ box-sizing: border-box;
+ border-bottom: 1px solid #999;
+ border-right: 1px solid var(--neutral-divider-rest);
+ border-top: 1px solid #999;
+ padding: 5px;
+ padding-left: 10px;
+ background: #ccc;
+ font-weight: bold;
+ min-width: 100%;
+}
+.tabulator-print-table .tabulator-print-table-group:hover {
+ cursor: pointer;
+ background-color: rgba(0, 0, 0, 0.1);
+}
+.tabulator-print-table
+ .tabulator-print-table-group.tabulator-group-visible
+ .tabulator-arrow {
+ margin-right: 10px;
+ border-left: 6px solid transparent;
+ border-right: 6px solid transparent;
+ border-top: 6px solid #666;
+ border-bottom: 0;
+}
+.tabulator-print-table .tabulator-print-table-group.tabulator-group-level-1 td {
+ padding-left: 30px !important;
+}
+.tabulator-print-table .tabulator-print-table-group.tabulator-group-level-2 td {
+ padding-left: 50px !important;
+}
+.tabulator-print-table .tabulator-print-table-group.tabulator-group-level-3 td {
+ padding-left: 70px !important;
+}
+.tabulator-print-table .tabulator-print-table-group.tabulator-group-level-4 td {
+ padding-left: 90px !important;
+}
+.tabulator-print-table .tabulator-print-table-group.tabulator-group-level-5 td {
+ padding-left: 110px !important;
+}
+.tabulator-print-table .tabulator-print-table-group .tabulator-group-toggle {
+ display: inline-block;
+}
+.tabulator-print-table .tabulator-print-table-group .tabulator-arrow {
+ display: inline-block;
+ width: 0;
+ height: 0;
+ margin-right: 16px;
+ border-top: 6px solid transparent;
+ border-bottom: 6px solid transparent;
+ border-right: 0;
+ border-left: 6px solid #666;
+ vertical-align: middle;
+}
+.tabulator-print-table .tabulator-print-table-group span {
+ margin-left: 10px;
+ color: #d00;
+}
+.tabulator-print-table .tabulator-data-tree-control {
+ display: inline-flex;
+ justify-content: center;
+ align-items: center;
+ vertical-align: middle;
+ height: 11px;
+ width: 11px;
+ margin-right: 5px;
+ border: 1px solid var(--neutral-foreground-rest);
+ border-radius: 2px;
+ background: rgba(0, 0, 0, 0.1);
+ overflow: hidden;
+}
+.tabulator-print-table .tabulator-data-tree-control:hover {
+ cursor: pointer;
+ background: rgba(0, 0, 0, 0.2);
+}
+.tabulator-print-table
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-collapse {
+ display: inline-block;
+ position: relative;
+ height: 7px;
+ width: 1px;
+ background: transparent;
+}
+.tabulator-print-table
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-collapse:after {
+ position: absolute;
+ content: '';
+ left: -3px;
+ top: 3px;
+ height: 1px;
+ width: 7px;
+ background: var(--neutral-foreground-rest);
+}
+.tabulator-print-table
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-expand {
+ display: inline-block;
+ position: relative;
+ height: 7px;
+ width: 1px;
+ background: var(--neutral-foreground-rest);
+}
+.tabulator-print-table
+ .tabulator-data-tree-control
+ .tabulator-data-tree-control-expand:after {
+ position: absolute;
+ content: '';
+ left: -3px;
+ top: 3px;
+ height: 1px;
+ width: 7px;
+ background: var(--neutral-foreground-rest);
+}
.tabulator {
- background-color: var(--fill-color); }
- .tabulator .tabulator-header .tabulator-col {
- background-color: var(--fill-color); }
- .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title .tabulator-title-editor {
- color: #fff; }
- .tabulator .tabulator-header .tabulator-col .tabulator-header-filter input, .tabulator .tabulator-header .tabulator-col .tabulator-header-filter select {
- border: 1px solid #999;
- background: #444;
- color: #fff; }
- .tabulator .tabulator-header .tabulator-calcs-holder {
- background: var(--fill-color) !important; }
- .tabulator .tabulator-header .tabulator-calcs-holder .tabulator-row {
- background: var(--fill-color) !important; }
- .tabulator .tabulator-footer .tabulator-calcs-holder {
- background: var(--fill-color) !important; }
- .tabulator .tabulator-footer .tabulator-calcs-holder .tabulator-row {
- background: var(--fill-color) !important; }
- .tabulator .tabulator-footer .tabulator-paginator label {
- color: #fff; }
- .tabulator .tabulator-footer .tabulator-page-counter {
- color: #fff; }
- .tabulator .tabulator-footer .tabulator-page {
- color: var(--neutral-foreground-rest);
- font-family: inherit;
- font-weight: inherit;
- font-size: inherit; }
+ background-color: var(--fill-color);
+}
+.tabulator .tabulator-header .tabulator-col {
+ background-color: var(--fill-color);
+}
+.tabulator
+ .tabulator-header
+ .tabulator-col
+ .tabulator-col-content
+ .tabulator-col-title
+ .tabulator-title-editor {
+ color: #fff;
+}
+.tabulator .tabulator-header .tabulator-col .tabulator-header-filter input,
+.tabulator .tabulator-header .tabulator-col .tabulator-header-filter select {
+ border: 1px solid #999;
+ background: #444;
+ color: #fff;
+}
+.tabulator .tabulator-header .tabulator-calcs-holder {
+ background: var(--fill-color) !important;
+}
+.tabulator .tabulator-header .tabulator-calcs-holder .tabulator-row {
+ background: var(--fill-color) !important;
+}
+.tabulator .tabulator-footer .tabulator-calcs-holder {
+ background: var(--fill-color) !important;
+}
+.tabulator .tabulator-footer .tabulator-calcs-holder .tabulator-row {
+ background: var(--fill-color) !important;
+}
+.tabulator .tabulator-footer .tabulator-paginator label {
+ color: #fff;
+}
+.tabulator .tabulator-footer .tabulator-page-counter {
+ color: #fff;
+}
+.tabulator .tabulator-footer .tabulator-page {
+ color: var(--neutral-foreground-rest);
+ font-family: inherit;
+ font-weight: inherit;
+ font-size: inherit;
+}
.tabulator-row.tabulator-group {
min-width: 100%;
- color: #333; }
- .tabulator-row.tabulator-group:hover {
- cursor: pointer;
- background-color: rgba(0, 0, 0, 0.1); }
- .tabulator-row.tabulator-group span {
- color: #666; }
+ color: #333;
+}
+.tabulator-row.tabulator-group:hover {
+ cursor: pointer;
+ background-color: rgba(0, 0, 0, 0.1);
+}
+.tabulator-row.tabulator-group span {
+ color: #666;
+}
.tabulator-edit-select-list {
- background: var(--neutral-foreground-rest); }
- .tabulator-edit-select-list .tabulator-edit-select-list-item {
- color: var(--fill-color); }
- .tabulator-edit-select-list .tabulator-edit-select-list-item.active {
- color: #999;
- background: var(--neutral-fill-rest); }
- .tabulator-edit-select-list .tabulator-edit-select-list-item.active.focused {
- outline: 1px solid rgba(153, 153, 153, 0.5); }
- .tabulator-edit-select-list .tabulator-edit-select-list-item.focused {
- outline: 1px solid var(--neutral-fill-rest); }
- .tabulator-edit-select-list .tabulator-edit-select-list-item:hover {
- color: #999;
- background: var(--fill-color); }
+ background: var(--neutral-foreground-rest);
+}
+.tabulator-edit-select-list .tabulator-edit-select-list-item {
+ color: var(--fill-color);
+}
+.tabulator-edit-select-list .tabulator-edit-select-list-item.active {
+ color: #999;
+ background: var(--neutral-fill-rest);
+}
+.tabulator-edit-select-list .tabulator-edit-select-list-item.active.focused {
+ outline: 1px solid rgba(153, 153, 153, 0.5);
+}
+.tabulator-edit-select-list .tabulator-edit-select-list-item.focused {
+ outline: 1px solid var(--neutral-fill-rest);
+}
+.tabulator-edit-select-list .tabulator-edit-select-list-item:hover {
+ color: #999;
+ background: var(--fill-color);
+}
.tabulator-print-table .tabulator-print-table-group {
- color: #333; }
+ color: #333;
+}
diff --git a/panel/dist/css/alerts.css b/panel/dist/css/alerts.css
index df0646d93d..05ff035161 100644
--- a/panel/dist/css/alerts.css
+++ b/panel/dist/css/alerts.css
@@ -1,132 +1,137 @@
:host(.alert) {
- padding: 0.75rem 1.25rem;
- border: 1px solid transparent;
- border-radius: 0.25rem;
+ padding: 0.75rem 1.25rem;
+ border: 1px solid transparent;
+ border-radius: 0.25rem;
}
:host(.alert) a {
- color: rgb(11, 46, 19); /* #002752; */
- font-weight: 700;
- text-decoration: rgb(11, 46, 19);
- text-decoration-color: rgb(11, 46, 19);
- text-decoration-line: none;
- text-decoration-style: solid;
- text-decoration-thickness: auto;
+ color: rgb(11, 46, 19); /* #002752; */
+ font-weight: 700;
+ text-decoration: rgb(11, 46, 19);
+ text-decoration-color: rgb(11, 46, 19);
+ text-decoration-line: none;
+ text-decoration-style: solid;
+ text-decoration-thickness: auto;
}
:host(.alert) a:hover {
- color: rgb(11, 46, 19);
- font-weight: 700;
- text-decoration: underline;
+ color: rgb(11, 46, 19);
+ font-weight: 700;
+ text-decoration: underline;
}
:host(.alert-primary) {
- color: var(--primary-text-color);
- background-color: var(--primary-bg-subtle);
- border-color: var(--primary-border-subtle);
+ color: var(--primary-text-color);
+ background-color: var(--primary-bg-subtle);
+ border-color: var(--primary-border-subtle);
}
:host(.alert-primary) hr {
- border-top-color: #9fcdff;
+ border-top-color: #9fcdff;
}
:host(.alert-secondary) {
- color: var(--secondary-text-color);
- background-color: var(--secondary-bg-subtle);
- border-color: var(--secondary-border-subtle);
+ color: var(--secondary-text-color);
+ background-color: var(--secondary-bg-subtle);
+ border-color: var(--secondary-border-subtle);
}
:host(.alert-secondary) hr {
- border-top-color: #c8cbcf;
+ border-top-color: #c8cbcf;
}
:host(.alert-success) {
- color: var(--success-text-color);
- background-color: var(--success-bg-subtle);
- border-color: var(--success-border-subtle);
+ color: var(--success-text-color);
+ background-color: var(--success-bg-subtle);
+ border-color: var(--success-border-subtle);
}
:host(.alert-success) hr {
- border-top-color: #b1dfbb;
+ border-top-color: #b1dfbb;
}
:host(.alert-info) {
- color: var(--info-text-color);
- background-color: var(--info-bg-subtle);
- border-color: var(--info-border-subtle);
+ color: var(--info-text-color);
+ background-color: var(--info-bg-subtle);
+ border-color: var(--info-border-subtle);
}
:host(.alert-info) hr {
- border-top-color: #abdde5;
+ border-top-color: #abdde5;
}
:host(.alert-warning) {
- color: var(--warning-text-color);
- background-color: var(--warning-bg-subtle);
- border-color: var(--warning-border-subtle);
+ color: var(--warning-text-color);
+ background-color: var(--warning-bg-subtle);
+ border-color: var(--warning-border-subtle);
}
:host(.alert-warning) hr {
- border-top-color: #ffe8a1;
+ border-top-color: #ffe8a1;
}
:host(.alert-danger) {
- color: var(--danger-text-color);
- background-color: var(--danger-bg-subtle);
- border-color: var(--danger-border-subtle);
+ color: var(--danger-text-color);
+ background-color: var(--danger-bg-subtle);
+ border-color: var(--danger-border-subtle);
}
:host(.alert-danger) hr {
- border-top-color: #f1b0b7;
+ border-top-color: #f1b0b7;
}
:host(.alert-light) {
- color: var(--light-text-color);
- background-color: var(--light-bg-subtle);
- border-color: var(--light-border-subtle);
+ color: var(--light-text-color);
+ background-color: var(--light-bg-subtle);
+ border-color: var(--light-border-subtle);
}
:host(.alert-light) hr {
- border-top-color: #ececf6;
+ border-top-color: #ececf6;
}
:host(.alert-dark) {
- color: var(--dark-text-color);
- background-color: var(--dark-bg-subtle);
- border-color: var(--dark-border-subtle);
+ color: var(--dark-text-color);
+ background-color: var(--dark-bg-subtle);
+ border-color: var(--dark-border-subtle);
}
:host(.alert-dark) hr {
- border-top-color: #b9bbbe;
+ border-top-color: #b9bbbe;
}
/* adjfæl */
:host(.alert-primary) a {
- color: var(--primary-text-color);
+ color: var(--primary-text-color);
}
:host(.alert-secondary) a {
- color: var(--secondary-text-color);
+ color: var(--secondary-text-color);
}
:host(.alert-success) a {
- color: var(--success-text-color);
+ color: var(--success-text-color);
}
:host(.alert-info) a {
- color: var(--info-text-color);
+ color: var(--info-text-color);
}
:host(.alert-warning) a {
- color: var(--warning-text-color);
+ color: var(--warning-text-color);
}
:host(.alert-danger) a {
- color: var(--danger-text-color);
+ color: var(--danger-text-color);
}
:host(.alert-light) a {
- color: var(--light-text-color);
+ color: var(--light-text-color);
}
:host(.alert-dark) a {
- color: var(--dark-text-color);
+ color: var(--dark-text-color);
}
-h1, h2, h3, h4, h5, h6 {
- margin-block-start: 0;
- margin-block-end: 0.2em;
+h1,
+h2,
+h3,
+h4,
+h5,
+h6 {
+ margin-block-start: 0;
+ margin-block-end: 0.2em;
}
diff --git a/panel/dist/css/button.css b/panel/dist/css/button.css
index 4769f03d71..99ded4130a 100644
--- a/panel/dist/css/button.css
+++ b/panel/dist/css/button.css
@@ -1,106 +1,125 @@
+:host {
+ --primary-color: var(--design-primary-color, var(--panel-primary-color));
+ --primary-text-color: var(
+ --design-primary-text-color,
+ var(--panel-on-primary-color)
+ );
+ --background-text-color: var(
+ --design-background-text-color,
+ var(--panel-on-background-color)
+ );
+ --surface-color: var(--design-surface-color, var(--panel-surface-color));
+ --surface-text-color: var(--design-surface-color, var(--panel-surface-color));
+}
+
.bk-btn:active {
- transform: scale(0.98);
+ transform: scale(0.98);
}
:host(.outline) .bk-btn {
- background-color: transparent;
+ background-color: transparent;
}
:host(.solid) .bk-btn {
- border: unset;
+ border: unset;
}
:host(.solid) .bk-btn.bk-btn-default {
- background-color: var(--panel-surface-color);
- color: var(--panel-on-surface-color);
+ background-color: var(--surface-color);
+ color: var(--on-surface-color);
}
:host(.outline) .bk-btn.bk-btn-default {
- color: var(--panel-on-background-color);
+ color: var(--background-text-color);
}
:host(.outline) .bk-btn.bk-btn-default.bk-active {
- color: var(--panel-on-background-color);
- box-shadow: inset 0px 3px 5px rgb(0 0 0 / 25%);
+ color: var(--background-text-color);
+ box-shadow: inset 0px 3px 5px rgb(0 0 0 / 25%);
}
:host(.outline) .bk-btn-group .bk-btn-default.bk-active {
- background-color: var(--panel-surface-color);
- color: var(--panel-on-surface-color);
+ background-color: var(--surface-color);
+ color: var(--surface-text-color);
}
:host(.solid) .bk-btn.bk-btn-primary {
- background-color: var(--panel-primary-color);
+ background-color: var(--primary-color);
}
:host(.solid) .bk-btn.bk-btn-primary.bk-active {
- background-color: var(--panel-primary-color);
- box-shadow: inset 0px 3px 5px rgb(0 0 0 / 25%);
+ background-color: var(--primary-color);
+ box-shadow: inset 0px 3px 5px rgb(0 0 0 / 25%);
}
:host(.outline) .bk-btn-primary {
- background-color: transparent;
- color: var(--panel-on-background-color);
+ background-color: transparent;
+ color: var(--background-text-color);
}
-:host(.outline) .bk-btn-primary.bk-active,:host(.outline) .bk-btn-primary:hover {
- color: var(--neutral-foreground-rest);
+:host(.outline) .bk-btn-primary.bk-active,
+:host(.outline) .bk-btn-primary:hover {
+ color: var(--background-text-color);
}
:host(.outline) .bk-btn-group .bk-btn-primary.bk-active {
- background-color: var(--panel-primary-color);
- color: var(--panel-on-primary-color);
+ background-color: var(--primary-color);
+ color: var(--primary-text-color);
}
:host(.outline) .bk-btn-success {
- color: var(--success-bg-color);
+ color: var(--success-bg-color);
}
-:host(.outline) .bk-btn-success.bk-active, :host(.outline) .bk-btn-success:hover {
- color: var(--panel-on-background-color);
+:host(.outline) .bk-btn-success.bk-active,
+:host(.outline) .bk-btn-success:hover {
+ color: var(--background-text-color);
}
:host(.outline) .bk-btn-group .bk-btn-success.bk-active {
- background-color: var(--success-bg-color);
- color: var(--success-text-color);
+ background-color: var(--success-bg-color);
+ color: var(--success-text-color);
}
:host(.outline) .bk-btn-warning {
- color: var(--warning-bg-color);
+ color: var(--warning-bg-color);
}
-:host(.outline) .bk-btn-warning.bk-active, :host(.outline) .bk-btn-warning:hover {
- color: var(--panel-on-background-color);
+:host(.outline) .bk-btn-warning.bk-active,
+:host(.outline) .bk-btn-warning:hover {
+ color: var(--background-text-color);
}
:host(.outline) .bk-btn-group .bk-btn-warning.bk-active {
- background-color: var(--warning-bg-color);
- color: var(--warning-text-color);
+ background-color: var(--warning-bg-color);
+ color: var(--warning-text-color);
}
:host(.outline) .bk-btn-danger {
- color: var(--danger-bg-color);
+ color: var(--danger-bg-color);
}
-:host(.outline) .bk-btn-danger.bk-active, :host(.outline) .bk-btn-danger:hover {
- color: var(--panel-on-background-color);
+:host(.outline) .bk-btn-danger.bk-active,
+:host(.outline) .bk-btn-danger:hover {
+ color: var(--background-text-color);
}
:host(.outline) .bk-btn-group .bk-btn-danger.bk-active {
- background-color: var(--danger-bg-color);
- color: var(--danger-text-color);
+ background-color: var(--danger-bg-color);
+ color: var(--danger-text-color);
}
:host(.outline) .bk-btn-light {
- border-color: var(--light-bg-color);
- color: var(--panel-on-background-color);
+ border-color: var(--light-bg-color);
+ color: var(--background-text-color);
}
-:host(.outline) .bk-btn-light.bk-active, :host(.outline) .bk-btn-light:hover {
- color: var(--panel-on-background-color);
+:host(.outline) .bk-btn-light.bk-active,
+:host(.outline) .bk-btn-light:hover {
+ color: var(--background-text-color);
}
:host(.outline) .bk-btn-group .bk-btn-light.bk-active {
- background-color: var(--light-bg-color);
- color: var(--light-text-color);
+ background-color: var(--light-bg-color);
+ color: var(--light-text-color);
}
diff --git a/panel/dist/css/card.css b/panel/dist/css/card.css
index 2626109eaf..c17cdde19b 100644
--- a/panel/dist/css/card.css
+++ b/panel/dist/css/card.css
@@ -1,57 +1,57 @@
:host(.card) {
- border: 1px solid rgba(0,0,0,.125);
- border-radius: 0.25rem;
+ border: 1px solid rgba(0, 0, 0, 0.125);
+ border-radius: 0.25rem;
}
:host(.accordion) {
- border: 1px solid rgba(0,0,0,.125);
+ border: 1px solid rgba(0, 0, 0, 0.125);
}
.card-header {
- align-items: center;
- background-color: rgba(0, 0, 0, 0.03);
- border: unset;
- border-radius: 0.25rem;
- display: inline-flex;
- justify-content: start;
- position: sticky;
- left: 0;
- width: 100%;
+ align-items: center;
+ background-color: rgba(0, 0, 0, 0.03);
+ border: unset;
+ border-radius: 0.25rem;
+ display: inline-flex;
+ justify-content: start;
+ position: sticky;
+ left: 0;
+ width: 100%;
}
.accordion-header {
- align-items: center;
- background-color: rgba(0, 0, 0, 0.03);
- border: 1px solid;
- border-radius: 0;
- display: flex;
- justify-content: start;
- position: sticky;
- left: 0;
- width: 100%;
+ align-items: center;
+ background-color: rgba(0, 0, 0, 0.03);
+ border: 1px solid;
+ border-radius: 0;
+ display: flex;
+ justify-content: start;
+ position: sticky;
+ left: 0;
+ width: 100%;
}
.card-button {
- background-color: transparent;
- margin-left: 0.5em;
- margin-right: 0.5em;
+ background-color: transparent;
+ margin-left: 0.5em;
+ margin-right: 0.5em;
}
.card-header-row {
- margin-bottom: auto;
- margin-top: auto;
- position: relative !important;
- max-width: calc(100% - 2em);
+ margin-bottom: auto;
+ margin-top: auto;
+ position: relative !important;
+ max-width: calc(100% - 2em);
}
.card-title {
- align-items: center;
- font-size: 1.4em;
- font-weight: bold;
- overflow-wrap: break-word;
+ align-items: center;
+ font-size: 1.4em;
+ font-weight: bold;
+ overflow-wrap: break-word;
}
.card-header-row > .bk {
- overflow-wrap: break-word;
- text-align: center;
+ overflow-wrap: break-word;
+ text-align: center;
}
diff --git a/panel/dist/css/dataframe.css b/panel/dist/css/dataframe.css
index daaa90dd78..d3e09bfd7b 100644
--- a/panel/dist/css/dataframe.css
+++ b/panel/dist/css/dataframe.css
@@ -1,47 +1,50 @@
table.panel-df {
- margin-left: auto;
- margin-right: auto;
- border: none;
- border-collapse: collapse;
- border-spacing: 0;
- font-size: 12px;
- table-layout: auto;
- width: 100%;
+ margin-left: auto;
+ margin-right: auto;
+ border: none;
+ border-collapse: collapse;
+ border-spacing: 0;
+ font-size: 12px;
+ table-layout: auto;
+ width: 100%;
}
-.panel-df tr, .panel-df th, .panel-df td {
- text-align: right;
- vertical-align: middle;
- padding: 0.5em 0.5em;
- line-height: normal;
- white-space: normal;
- max-width: none;
- border: none;
+.panel-df tr,
+.panel-df th,
+.panel-df td {
+ text-align: right;
+ vertical-align: middle;
+ padding: 0.5em 0.5em;
+ line-height: normal;
+ white-space: normal;
+ max-width: none;
+ border: none;
}
.panel-df tbody {
- display: table-row-group;
- vertical-align: middle;
- border-color: inherit;
+ display: table-row-group;
+ vertical-align: middle;
+ border-color: inherit;
}
.panel-df tbody tr:nth-child(odd) {
- background: var(--panel-surface-color);
- color: var(--panel-on-surface-color);
+ background: var(--design-surface-color, var(--panel-surface-color));
+ color: var(--design-surface-text-color, var(--panel-on-surface-color));
}
.panel-df thead {
- border-bottom: 1px solid var(--panel-on-background-color);
- vertical-align: bottom;
+ border-bottom: 1px solid
+ var(--design-background-text-color, var(--panel-on-background-color));
+ vertical-align: bottom;
}
.panel-df tbody tr:hover {
- background-color: #e1f5fe;
- color: #000000;
- cursor: pointer;
+ background-color: #e1f5fe;
+ color: #000000;
+ cursor: pointer;
}
:host {
- overflow: auto;
- padding-right: 1px;
+ overflow: auto;
+ padding-right: 1px;
}
diff --git a/panel/dist/css/debugger.css b/panel/dist/css/debugger.css
index 763f514b1a..7361cd87ca 100644
--- a/panel/dist/css/debugger.css
+++ b/panel/dist/css/debugger.css
@@ -1,14 +1,14 @@
.debugger-card {
- border: 1px solid rgba(0,0,0,1);
- color: rgba(255,255,255,1);
- background-color: rgba(0,0,0,1);
+ border: 1px solid rgba(0, 0, 0, 1);
+ color: rgba(255, 255, 255, 1);
+ background-color: rgba(0, 0, 0, 1);
border-radius: 0rem;
}
.debugger-card-header {
align-items: center;
text-align: left;
- background-color: rgba(0, 0, 0, 1)!important;
+ background-color: rgba(0, 0, 0, 1) !important;
color: rgba(255, 255, 255, 1);
border-radius: 0rem;
display: inline-flex;
@@ -32,11 +32,11 @@
/* Special debugger buttons for clearing and saving */
button.special_btn {
- width: 25px;
- height: 25px;
- background-color: black;
- color: white;
- display: inline-block;
+ width: 25px;
+ height: 25px;
+ background-color: black;
+ color: white;
+ display: inline-block;
}
button.special_btn .tooltiptext {
@@ -62,9 +62,9 @@ button.special_btn:hover .tooltiptext {
}
button.clear_btn:hover .shown {
- display: none;
+ display: none;
}
button.clear_btn:hover:before {
- content: "☑";
+ content: '☑';
}
diff --git a/panel/dist/css/divider.css b/panel/dist/css/divider.css
index 1e6c600429..c2f696060e 100644
--- a/panel/dist/css/divider.css
+++ b/panel/dist/css/divider.css
@@ -1,10 +1,10 @@
-:host{
- width: 100%;
+:host {
+ width: 100%;
}
-div.bk-clearfix{
- width:100%;
+div.bk-clearfix {
+ width: 100%;
}
-hr{
- margin:0px;
- margin-bottom:3px;
+hr {
+ margin: 0px;
+ margin-bottom: 3px;
}
diff --git a/panel/dist/css/gridbox.css b/panel/dist/css/gridbox.css
index 41614b0edc..c1a05145df 100644
--- a/panel/dist/css/gridbox.css
+++ b/panel/dist/css/gridbox.css
@@ -1,10 +1,10 @@
:host(.equal-width) {
- grid-auto-columns: minmax(0, 1fr);
- grid-auto-flow: column;
- grid-template-columns: unset;
+ grid-auto-columns: minmax(0, 1fr);
+ grid-auto-flow: column;
+ grid-template-columns: unset;
}
:host(.equal-height) {
- grid-auto-rows: minmax(0, 1fr);
- grid-template-rows: unset;
+ grid-auto-rows: minmax(0, 1fr);
+ grid-template-rows: unset;
}
diff --git a/panel/dist/css/gridspec.css b/panel/dist/css/gridspec.css
index 8a5050bc23..fd0173a503 100644
--- a/panel/dist/css/gridspec.css
+++ b/panel/dist/css/gridspec.css
@@ -1,7 +1,7 @@
:host {
- grid-auto-columns: minmax(0, 1fr);
- grid-auto-rows: minmax(0, 1fr);
- grid-auto-flow: column;
- grid-template-columns: unset;
- grid-template-rows: unset;
+ grid-auto-columns: minmax(0, 1fr);
+ grid-auto-rows: minmax(0, 1fr);
+ grid-auto-flow: column;
+ grid-template-columns: unset;
+ grid-template-rows: unset;
}
diff --git a/panel/dist/css/gridstack.css b/panel/dist/css/gridstack.css
index e2517d325c..ee88d540d9 100644
--- a/panel/dist/css/gridstack.css
+++ b/panel/dist/css/gridstack.css
@@ -1,4 +1,4 @@
.grid-stack > .grid-stack-item > .ui-resizable-se {
- right: 5px !important;
- bottom: 5px !important;
+ right: 5px !important;
+ bottom: 5px !important;
}
diff --git a/panel/dist/css/json.css b/panel/dist/css/json.css
index ea0d5d2cee..ebc916b0ef 100644
--- a/panel/dist/css/json.css
+++ b/panel/dist/css/json.css
@@ -17,11 +17,13 @@
.json-formatter-row .json-formatter-children.json-formatter-empty:after {
display: none;
}
-.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-object:after {
- content: "No properties";
+.json-formatter-row
+ .json-formatter-children.json-formatter-empty.json-formatter-object:after {
+ content: 'No properties';
}
-.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-array:after {
- content: "[]";
+.json-formatter-row
+ .json-formatter-children.json-formatter-empty.json-formatter-array:after {
+ content: '[]';
}
.json-formatter-row .json-formatter-string,
.json-formatter-row .json-formatter-stringifiable {
@@ -36,13 +38,13 @@
color: red;
}
.json-formatter-row .json-formatter-null {
- color: #855A00;
+ color: #855a00;
}
.json-formatter-row .json-formatter-undefined {
color: #ca0b69;
}
.json-formatter-row .json-formatter-function {
- color: #FF20ED;
+ color: #ff20ed;
}
.json-formatter-row .json-formatter-date {
background-color: rgba(0, 0, 0, 0.05);
@@ -56,7 +58,7 @@
color: blue;
}
.json-formatter-row .json-formatter-key {
- color: #00008B;
+ color: #00008b;
padding-right: 0.2rem;
}
.json-formatter-row .json-formatter-toggler-link {
@@ -73,7 +75,7 @@
.json-formatter-row .json-formatter-toggler:after {
display: inline-block;
transition: transform 100ms ease-in;
- content: "\25BA";
+ content: '\25BA';
}
.json-formatter-row > a > .json-formatter-preview-text {
opacity: 0;
@@ -83,7 +85,9 @@
.json-formatter-row:hover > a > .json-formatter-preview-text {
opacity: 0.6;
}
-.json-formatter-row.json-formatter-open > .json-formatter-toggler-link .json-formatter-toggler:after {
+.json-formatter-row.json-formatter-open
+ > .json-formatter-toggler-link
+ .json-formatter-toggler:after {
transform: rotate(90deg);
}
.json-formatter-row.json-formatter-open > .json-formatter-children:after {
@@ -107,53 +111,57 @@
.json-formatter-dark.json-formatter-row .json-formatter-row {
margin-left: 1rem;
}
-.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty {
+.json-formatter-dark.json-formatter-row
+ .json-formatter-children.json-formatter-empty {
opacity: 0.5;
margin-left: 1rem;
}
-.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty:after {
+.json-formatter-dark.json-formatter-row
+ .json-formatter-children.json-formatter-empty:after {
display: none;
}
-.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-object:after {
- content: "No properties";
+.json-formatter-dark.json-formatter-row
+ .json-formatter-children.json-formatter-empty.json-formatter-object:after {
+ content: 'No properties';
}
-.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-array:after {
- content: "[]";
+.json-formatter-dark.json-formatter-row
+ .json-formatter-children.json-formatter-empty.json-formatter-array:after {
+ content: '[]';
}
.json-formatter-dark.json-formatter-row .json-formatter-string,
.json-formatter-dark.json-formatter-row .json-formatter-stringifiable {
- color: #31F031;
+ color: #31f031;
white-space: pre;
word-wrap: break-word;
}
.json-formatter-dark.json-formatter-row .json-formatter-number {
- color: #66C2FF;
+ color: #66c2ff;
}
.json-formatter-dark.json-formatter-row .json-formatter-boolean {
- color: #EC4242;
+ color: #ec4242;
}
.json-formatter-dark.json-formatter-row .json-formatter-null {
- color: #EEC97D;
+ color: #eec97d;
}
.json-formatter-dark.json-formatter-row .json-formatter-undefined {
color: #ef8fbe;
}
.json-formatter-dark.json-formatter-row .json-formatter-function {
- color: #FD48CB;
+ color: #fd48cb;
}
.json-formatter-dark.json-formatter-row .json-formatter-date {
background-color: rgba(255, 255, 255, 0.05);
}
.json-formatter-dark.json-formatter-row .json-formatter-url {
text-decoration: underline;
- color: #027BFF;
+ color: #027bff;
cursor: pointer;
}
.json-formatter-dark.json-formatter-row .json-formatter-bracket {
- color: #9494FF;
+ color: #9494ff;
}
.json-formatter-dark.json-formatter-row .json-formatter-key {
- color: #23A0DB;
+ color: #23a0db;
padding-right: 0.2rem;
}
.json-formatter-dark.json-formatter-row .json-formatter-toggler-link {
@@ -170,23 +178,30 @@
.json-formatter-dark.json-formatter-row .json-formatter-toggler:after {
display: inline-block;
transition: transform 100ms ease-in;
- content: "\25BA";
+ content: '\25BA';
}
.json-formatter-dark.json-formatter-row > a > .json-formatter-preview-text {
opacity: 0;
transition: opacity 0.15s ease-in;
font-style: italic;
}
-.json-formatter-dark.json-formatter-row:hover > a > .json-formatter-preview-text {
+.json-formatter-dark.json-formatter-row:hover
+ > a
+ > .json-formatter-preview-text {
opacity: 0.6;
}
-.json-formatter-dark.json-formatter-row.json-formatter-open > .json-formatter-toggler-link .json-formatter-toggler:after {
+.json-formatter-dark.json-formatter-row.json-formatter-open
+ > .json-formatter-toggler-link
+ .json-formatter-toggler:after {
transform: rotate(90deg);
}
-.json-formatter-dark.json-formatter-row.json-formatter-open > .json-formatter-children:after {
+.json-formatter-dark.json-formatter-row.json-formatter-open
+ > .json-formatter-children:after {
display: inline-block;
}
-.json-formatter-dark.json-formatter-row.json-formatter-open > a > .json-formatter-preview-text {
+.json-formatter-dark.json-formatter-row.json-formatter-open
+ > a
+ > .json-formatter-preview-text {
display: none;
}
.json-formatter-dark.json-formatter-row.json-formatter-open.json-formatter-empty:after {
diff --git a/panel/dist/css/katex.css b/panel/dist/css/katex.css
index 54ed5a60df..b7a40bf8be 100644
--- a/panel/dist/css/katex.css
+++ b/panel/dist/css/katex.css
@@ -1,3 +1,3 @@
span.katex-html {
- display: none;
+ display: none;
}
diff --git a/panel/dist/css/layout.css b/panel/dist/css/layout.css
new file mode 100644
index 0000000000..4f6c6eacc7
--- /dev/null
+++ b/panel/dist/css/layout.css
@@ -0,0 +1,2 @@
+.scrollable {
+}
diff --git a/panel/dist/css/loading.css b/panel/dist/css/loading.css
index 8424596821..80294a3bf7 100644
--- a/panel/dist/css/loading.css
+++ b/panel/dist/css/loading.css
@@ -1,14 +1,16 @@
-:host(.pn-loading), .pn-loading {
+:host(.pn-loading),
+.pn-loading {
overflow: hidden;
}
-:host(.pn-loading):before, .pn-loading:before {
+:host(.pn-loading):before,
+.pn-loading:before {
position: absolute;
height: 100%;
width: 100%;
content: '';
z-index: 1000;
- background-color: rgb(255,255,255,0.50);
+ background-color: rgb(255, 255, 255, 0.5);
border-color: lightgray;
background-repeat: no-repeat;
background-position: center;
@@ -17,7 +19,8 @@
cursor: progress;
}
-:host(.pn-loading) .pn-loading-msg, .pn-loading .pn-loading-msg {
+:host(.pn-loading) .pn-loading-msg,
+.pn-loading .pn-loading-msg {
position: absolute;
top: 72%;
font-size: 2em;
diff --git a/panel/dist/css/loadingspinner.css b/panel/dist/css/loadingspinner.css
index 4d02b93193..e4a74c6a69 100644
--- a/panel/dist/css/loadingspinner.css
+++ b/panel/dist/css/loadingspinner.css
@@ -1,18 +1,18 @@
:host(.loader) {
- overflow: hidden;
- display: flex;
+ overflow: hidden;
+ display: flex;
}
:host(.loader) div::after {
- content: "";
- display: block;
- border-radius: 50%;
- -webkit-mask-image: radial-gradient(transparent 50%, rgba(0, 0, 0, 1) 54%);
- width: 100%;
- height: 100%;
- left: 0;
- top: 0;
- animation: spin 2s linear infinite;
+ content: '';
+ display: block;
+ border-radius: 50%;
+ -webkit-mask-image: radial-gradient(transparent 50%, rgba(0, 0, 0, 1) 54%);
+ width: 100%;
+ height: 100%;
+ left: 0;
+ top: 0;
+ animation: spin 2s linear infinite;
}
:host(.loader.dark) div::after {
@@ -67,7 +67,7 @@
linear-gradient(45deg, #f0f0f0 50%, #343a40 50%);
}
-:host(.loader.spin.primary-dark) div::after {
+:host(.loader.spin.primary-dark) div::after {
background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%),
linear-gradient(45deg, #0f0f0f 50%, var(--primary-bg-color) 50%);
}
@@ -109,11 +109,19 @@
/* Safari */
@-webkit-keyframes spin {
- 0% { -webkit-transform: rotate(0deg); }
- 100% { -webkit-transform: rotate(360deg); }
+ 0% {
+ -webkit-transform: rotate(0deg);
+ }
+ 100% {
+ -webkit-transform: rotate(360deg);
+ }
}
@keyframes spin {
- 0% { transform: rotate(0deg); }
- 100% { transform: rotate(360deg); }
+ 0% {
+ transform: rotate(0deg);
+ }
+ 100% {
+ transform: rotate(360deg);
+ }
}
diff --git a/panel/dist/css/markdown.css b/panel/dist/css/markdown.css
index e38c35eefe..3332c1ff1f 100644
--- a/panel/dist/css/markdown.css
+++ b/panel/dist/css/markdown.css
@@ -1,121 +1,337 @@
-.codehilite .hll { background-color: #2C3B41 }
-.codehilite { background: var(--code-bg-color); }
-.codehilite .c { color: #546E7A; font-style: italic } /* Comment */
-.codehilite .err { border: 1px solid #FF5370 } /* Error */
-.codehilite .esc { color: #89DDFF; } /* Escape */
-.codehilite .g { color: #EFFFFF; } /* Generic */
-.codehilite .k { color: #BB80B3; font-weight: bold } /* Keyword */
-.codehilite .l { color: #C3E88D; font-weight: bold } /* Literal */
-.codehilite .n { color: #EEFFFF; } /* Name */
-.codehilite .o { color: #89DDFF; } /* Operator */
-.codehilite .p { color: #89DDFF; } /* Punctuation */
-.codehilite .ch { color: #546E7A; font-style: italic } /* Comment.Hashbang */
-.codehilite .cm { color: #546E7A; font-style: italic } /* Comment.Multiline */
-.codehilite .cp { color: #546E7A } /* Comment.Preproc */
-.codehilite .cpf { color: #546E7A; font-style: italic } /* Comment.PreprocFile */
-.codehilite .c1 { color: #546E7A; font-style: italic } /* Comment.Single */
-.codehilite .cs { color: #546E7A; font-style: italic } /* Comment.Special */
-.codehilite .gd { color: #FF5370; } /* Generic.Deleted */
-.codehilite .ge { color: #89DDFF; font-style: italic } /* Generic.Emph */
-.codehilite .gr { color: #FF5370; } /* Generic.Error */
-.codehilite .gh { color: #C3E88D; font-weight: bold } /* Generic.Heading */
-.codehilite .gi { color: #C3E88D; } /* Generic.Inserted */
-.codehilite .go { color: #546E7A; } /* Generic.Output */
-.codehilite .gp { color: #FFCB6B; font-weight: bold } /* Generic.Prompt */
-.codehilite .gs { color: #FF5370; font-weight: bold } /* Generic.Strong */
-.codehilite .gu { color: #89DDFF; font-weight: bold } /* Generic.Subheading */
-.codehilite .gt { color: #FF5370 } /* Generic.Traceback */
-.codehilite .kc { color: #89DDFF; font-weight: bold } /* Keyword.Constant */
-.codehilite .kd { color: #BB80B3; font-weight: bold } /* Keyword.Declaration */
-.codehilite .kn { color: #89DDFF; font-weight: bold } /* Keyword.Namespace */
-.codehilite .kp { color: #89DDFF } /* Keyword.Pseudo */
-.codehilite .kr { color: #BB80B3; font-weight: bold } /* Keyword.Reserved */
-.codehilite .kt { color: #BB80B3 } /* Keyword.Type */
-.codehilite .ld { color: #C3E88D } /* Literal.Date */
-.codehilite .m { color: #F78C6C } /* Literal.Number */
-.codehilite .s { color: #C3E88D } /* Literal.String */
-.codehilite .na { color: #BB80B3 } /* Name.Attribute */
-.codehilite .nb { color: #82AAFF } /* Name.Builtin */
-.codehilite .nc { color: #FFCB6B; font-weight: bold } /* Name.Class */
-.codehilite .no { color: #EEFFFF } /* Name.Constant */
-.codehilite .nd { color: #82AAFF } /* Name.Decorator */
-.codehilite .ni { color: #89DDFF; font-weight: bold } /* Name.Entity */
-.codehilite .ne { color: #FFCB6B; font-weight: bold } /* Name.Exception */
-.codehilite .nf { color: #82AAFF } /* Name.Function */
-.codehilite .nl { color: #82AAFF } /* Name.Label */
-.codehilite .nn { color: #FFCB6B; font-weight: bold } /* Name.Namespace */
-.codehilite .nt { color: #FF5370; font-weight: bold } /* Name.Tag */
-.codehilite .np { color: #FFCB6B; } /* Name.Property */
-.codehilite .nx { color: #EFFFFF; } /* Name.Other */
-.codehilite .nv { color: #89DDFF; } /* Name.Variable */
-.codehilite .ow { color: #89DDFF; font-weight: bold } /* Operator.Word */
-.codehilite .pm { color: #89DDFF; } /* Punctuation.Marker */
-.codehilite .py { color: #FFCB6B; } /* Name.Property */
-.codehilite .w { color: #EEFFFF } /* Text.Whitespace */
-.codehilite .mb { color: #F78C6C } /* Literal.Number.Bin */
-.codehilite .mf { color: #F78C6C } /* Literal.Number.Float */
-.codehilite .mh { color: #F78C6C } /* Literal.Number.Hex */
-.codehilite .mi { color: #F78C6C } /* Literal.Number.Integer */
-.codehilite .mo { color: #F78C6C } /* Literal.Number.Oct */
-.codehilite .sa { color: #BB80B3 } /* Literal.String.Affix */
-.codehilite .sb { color: #C3E88D } /* Literal.String.Backtick */
-.codehilite .sc { color: #C3E88D } /* Literal.String.Char */
-.codehilite .dl { color: #EEFFFF } /* Literal.String.Delimiter */
-.codehilite .sd { color: #546E7A; font-style: italic } /* Literal.String.Doc */
-.codehilite .s2 { color: #C3E88D } /* Literal.String.Double */
-.codehilite .se { color: #EEFFFF; font-weight: bold } /* Literal.String.Escape */
-.codehilite .sh { color: #C3E88D } /* Literal.String.Heredoc */
-.codehilite .si { color: #89DDFF; font-weight: bold } /* Literal.String.Interpol */
-.codehilite .sx { color: #C3E88D } /* Literal.String.Other */
-.codehilite .sr { color: #89DDFF } /* Literal.String.Regex */
-.codehilite .s1 { color: #C3E88D } /* Literal.String.Single */
-.codehilite .ss { color: #89DDFF } /* Literal.String.Symbol */
-.codehilite .bp { color: #89DDFF } /* Name.Builtin.Pseudo */
-.codehilite .fm { color: #82AAFF } /* Name.Function.Magic */
-.codehilite .vc { color: #89DDFF } /* Name.Variable.Class */
-.codehilite .vg { color: #89DDFF } /* Name.Variable.Global */
-.codehilite .vi { color: #89DDFF } /* Name.Variable.Instance */
-.codehilite .vm { color: #82AAFF } /* Name.Variable.Magic */
-.codehilite .il { color: #F78C6C } /* Literal.Number.Integer.Long */
+.codehilite .hll {
+ background-color: #2c3b41;
+}
+.codehilite {
+ background: var(--code-bg-color);
+}
+.codehilite .c {
+ color: #546e7a;
+ font-style: italic;
+} /* Comment */
+.codehilite .err {
+ border: 1px solid #ff5370;
+} /* Error */
+.codehilite .esc {
+ color: #89ddff;
+} /* Escape */
+.codehilite .g {
+ color: #efffff;
+} /* Generic */
+.codehilite .k {
+ color: #bb80b3;
+ font-weight: bold;
+} /* Keyword */
+.codehilite .l {
+ color: #c3e88d;
+ font-weight: bold;
+} /* Literal */
+.codehilite .n {
+ color: #eeffff;
+} /* Name */
+.codehilite .o {
+ color: #89ddff;
+} /* Operator */
+.codehilite .p {
+ color: #89ddff;
+} /* Punctuation */
+.codehilite .ch {
+ color: #546e7a;
+ font-style: italic;
+} /* Comment.Hashbang */
+.codehilite .cm {
+ color: #546e7a;
+ font-style: italic;
+} /* Comment.Multiline */
+.codehilite .cp {
+ color: #546e7a;
+} /* Comment.Preproc */
+.codehilite .cpf {
+ color: #546e7a;
+ font-style: italic;
+} /* Comment.PreprocFile */
+.codehilite .c1 {
+ color: #546e7a;
+ font-style: italic;
+} /* Comment.Single */
+.codehilite .cs {
+ color: #546e7a;
+ font-style: italic;
+} /* Comment.Special */
+.codehilite .gd {
+ color: #ff5370;
+} /* Generic.Deleted */
+.codehilite .ge {
+ color: #89ddff;
+ font-style: italic;
+} /* Generic.Emph */
+.codehilite .gr {
+ color: #ff5370;
+} /* Generic.Error */
+.codehilite .gh {
+ color: #c3e88d;
+ font-weight: bold;
+} /* Generic.Heading */
+.codehilite .gi {
+ color: #c3e88d;
+} /* Generic.Inserted */
+.codehilite .go {
+ color: #546e7a;
+} /* Generic.Output */
+.codehilite .gp {
+ color: #ffcb6b;
+ font-weight: bold;
+} /* Generic.Prompt */
+.codehilite .gs {
+ color: #ff5370;
+ font-weight: bold;
+} /* Generic.Strong */
+.codehilite .gu {
+ color: #89ddff;
+ font-weight: bold;
+} /* Generic.Subheading */
+.codehilite .gt {
+ color: #ff5370;
+} /* Generic.Traceback */
+.codehilite .kc {
+ color: #89ddff;
+ font-weight: bold;
+} /* Keyword.Constant */
+.codehilite .kd {
+ color: #bb80b3;
+ font-weight: bold;
+} /* Keyword.Declaration */
+.codehilite .kn {
+ color: #89ddff;
+ font-weight: bold;
+} /* Keyword.Namespace */
+.codehilite .kp {
+ color: #89ddff;
+} /* Keyword.Pseudo */
+.codehilite .kr {
+ color: #bb80b3;
+ font-weight: bold;
+} /* Keyword.Reserved */
+.codehilite .kt {
+ color: #bb80b3;
+} /* Keyword.Type */
+.codehilite .ld {
+ color: #c3e88d;
+} /* Literal.Date */
+.codehilite .m {
+ color: #f78c6c;
+} /* Literal.Number */
+.codehilite .s {
+ color: #c3e88d;
+} /* Literal.String */
+.codehilite .na {
+ color: #bb80b3;
+} /* Name.Attribute */
+.codehilite .nb {
+ color: #82aaff;
+} /* Name.Builtin */
+.codehilite .nc {
+ color: #ffcb6b;
+ font-weight: bold;
+} /* Name.Class */
+.codehilite .no {
+ color: #eeffff;
+} /* Name.Constant */
+.codehilite .nd {
+ color: #82aaff;
+} /* Name.Decorator */
+.codehilite .ni {
+ color: #89ddff;
+ font-weight: bold;
+} /* Name.Entity */
+.codehilite .ne {
+ color: #ffcb6b;
+ font-weight: bold;
+} /* Name.Exception */
+.codehilite .nf {
+ color: #82aaff;
+} /* Name.Function */
+.codehilite .nl {
+ color: #82aaff;
+} /* Name.Label */
+.codehilite .nn {
+ color: #ffcb6b;
+ font-weight: bold;
+} /* Name.Namespace */
+.codehilite .nt {
+ color: #ff5370;
+ font-weight: bold;
+} /* Name.Tag */
+.codehilite .np {
+ color: #ffcb6b;
+} /* Name.Property */
+.codehilite .nx {
+ color: #efffff;
+} /* Name.Other */
+.codehilite .nv {
+ color: #89ddff;
+} /* Name.Variable */
+.codehilite .ow {
+ color: #89ddff;
+ font-weight: bold;
+} /* Operator.Word */
+.codehilite .pm {
+ color: #89ddff;
+} /* Punctuation.Marker */
+.codehilite .py {
+ color: #ffcb6b;
+} /* Name.Property */
+.codehilite .w {
+ color: #eeffff;
+} /* Text.Whitespace */
+.codehilite .mb {
+ color: #f78c6c;
+} /* Literal.Number.Bin */
+.codehilite .mf {
+ color: #f78c6c;
+} /* Literal.Number.Float */
+.codehilite .mh {
+ color: #f78c6c;
+} /* Literal.Number.Hex */
+.codehilite .mi {
+ color: #f78c6c;
+} /* Literal.Number.Integer */
+.codehilite .mo {
+ color: #f78c6c;
+} /* Literal.Number.Oct */
+.codehilite .sa {
+ color: #bb80b3;
+} /* Literal.String.Affix */
+.codehilite .sb {
+ color: #c3e88d;
+} /* Literal.String.Backtick */
+.codehilite .sc {
+ color: #c3e88d;
+} /* Literal.String.Char */
+.codehilite .dl {
+ color: #eeffff;
+} /* Literal.String.Delimiter */
+.codehilite .sd {
+ color: #546e7a;
+ font-style: italic;
+} /* Literal.String.Doc */
+.codehilite .s2 {
+ color: #c3e88d;
+} /* Literal.String.Double */
+.codehilite .se {
+ color: #eeffff;
+ font-weight: bold;
+} /* Literal.String.Escape */
+.codehilite .sh {
+ color: #c3e88d;
+} /* Literal.String.Heredoc */
+.codehilite .si {
+ color: #89ddff;
+ font-weight: bold;
+} /* Literal.String.Interpol */
+.codehilite .sx {
+ color: #c3e88d;
+} /* Literal.String.Other */
+.codehilite .sr {
+ color: #89ddff;
+} /* Literal.String.Regex */
+.codehilite .s1 {
+ color: #c3e88d;
+} /* Literal.String.Single */
+.codehilite .ss {
+ color: #89ddff;
+} /* Literal.String.Symbol */
+.codehilite .bp {
+ color: #89ddff;
+} /* Name.Builtin.Pseudo */
+.codehilite .fm {
+ color: #82aaff;
+} /* Name.Function.Magic */
+.codehilite .vc {
+ color: #89ddff;
+} /* Name.Variable.Class */
+.codehilite .vg {
+ color: #89ddff;
+} /* Name.Variable.Global */
+.codehilite .vi {
+ color: #89ddff;
+} /* Name.Variable.Instance */
+.codehilite .vm {
+ color: #82aaff;
+} /* Name.Variable.Magic */
+.codehilite .il {
+ color: #f78c6c;
+} /* Literal.Number.Integer.Long */
-h1 { margin-block-start: 0.34em; margin-block-end: 0.34em; }
-h2 { margin-block-start: 0.42em; margin-block-end: 0.42em; }
-h3 { margin-block-start: 0.5em; margin-block-end: 0.5em; }
-h4 { margin-block-start: 0.67em; margin-block-end: 0.67em; }
-h5 { margin-block-start: 0.84em; margin-block-end: 0.84em; }
-h6 { margin-block-start: 1.17em; margin-block-end: 1.17em; }
-ul { padding-inline-start: 2em }
-ol { padding-inline-start: 2em }
-strong { font-weight: 600 }
-a { color: var(--panel-primary-color); }
-code { color: var(--code-text-color); }
-a.header-anchor { visibility: hidden; }
+h1 {
+ margin-block-start: 0.34em;
+ margin-block-end: 0.34em;
+}
+h2 {
+ margin-block-start: 0.42em;
+ margin-block-end: 0.42em;
+}
+h3 {
+ margin-block-start: 0.5em;
+ margin-block-end: 0.5em;
+}
+h4 {
+ margin-block-start: 0.67em;
+ margin-block-end: 0.67em;
+}
+h5 {
+ margin-block-start: 0.84em;
+ margin-block-end: 0.84em;
+}
+h6 {
+ margin-block-start: 1.17em;
+ margin-block-end: 1.17em;
+}
+ul {
+ padding-inline-start: 2em;
+}
+ol {
+ padding-inline-start: 2em;
+}
+strong {
+ font-weight: 600;
+}
+a {
+ color: var(--design-primary-color, var(--panel-primary-color));
+}
+code {
+ color: var(--code-text-color);
+}
+a.header-anchor {
+ visibility: hidden;
+}
h1:hover a.header-anchor::before,
h2:hover a.header-anchor::before {
- content: "";
- background-image: url('');
- background-size: 0.7em 0.7em;
- background-repeat: no-repeat;
- display: inline-block;
- width: 0.7em;
- height: 0.7em;
- visibility: visible;
+ content: '';
+ background-image: url('');
+ background-size: 0.7em 0.7em;
+ background-repeat: no-repeat;
+ display: inline-block;
+ width: 0.7em;
+ height: 0.7em;
+ visibility: visible;
}
.codehilite {
- padding: 1rem 1.25rem;
- margin-top: 1rem;
- margin-bottom: 1rem;
- border-radius: 0.25rem;
+ padding: 1rem 1.25rem;
+ margin-top: 1rem;
+ margin-bottom: 1rem;
+ border-radius: 0.25rem;
}
-table, th, td {
- border: 1px solid;
- border-collapse: collapse;
- padding: 5px;
+table,
+th,
+td {
+ border: 1px solid;
+ border-collapse: collapse;
+ padding: 5px;
}
p {
- overflow-wrap: break-word;
+ overflow-wrap: break-word;
}
diff --git a/panel/dist/css/perspective-datatable.css b/panel/dist/css/perspective-datatable.css
index 54ebf52104..ac72d59681 100644
--- a/panel/dist/css/perspective-datatable.css
+++ b/panel/dist/css/perspective-datatable.css
@@ -33,17 +33,37 @@ regular-table:hover {
}
.sub-cell-scroll-enabled regular-table table tbody tr:first-child td,
.sub-cell-scroll-enabled regular-table table tbody tr:first-child th {
- clip-path: polygon(0 var(--regular-table--clip-y, 0), 0 200%, 200% 200%, 200% var(--regular-table--clip-y, 0));
+ clip-path: polygon(
+ 0 var(--regular-table--clip-y, 0),
+ 0 200%,
+ 200% 200%,
+ 200% var(--regular-table--clip-y, 0)
+ );
}
.sub-cell-scroll-enabled regular-table table thead th.rt-group-corner {
background: var(--plugin--background, white);
z-index: 1;
}
.sub-cell-scroll-enabled regular-table table tbody tr td:first-of-type {
- clip-path: polygon(var(--regular-table--clip-x, 0) 0, var(--regular-table--clip-x, 0) 200%, 200% 200%, 200% 0);
-}
-.sub-cell-scroll-enabled regular-table table tbody tr:first-child td:first-of-type {
- clip-path: polygon(var(--regular-table--clip-x, 0) var(--regular-table--clip-y, 0), var(--regular-table--clip-x, 0) 200%, 200% 200%, 200% var(--regular-table--clip-y, 0));
+ clip-path: polygon(
+ var(--regular-table--clip-x, 0) 0,
+ var(--regular-table--clip-x, 0) 200%,
+ 200% 200%,
+ 200% 0
+ );
+}
+.sub-cell-scroll-enabled
+ regular-table
+ table
+ tbody
+ tr:first-child
+ td:first-of-type {
+ clip-path: polygon(
+ var(--regular-table--clip-x, 0) var(--regular-table--clip-y, 0),
+ var(--regular-table--clip-x, 0) 200%,
+ 200% 200%,
+ 200% var(--regular-table--clip-y, 0)
+ );
}
regular-table {
font-family: inherit;
@@ -135,14 +155,14 @@ regular-table table {
regular-table span.rt-row-header-icon {
color: #aaa;
padding-right: 4px;
- font-family: var(--button--font-family, "Material Icons");
+ font-family: var(--button--font-family, 'Material Icons');
}
regular-table span.rt-column-header-icon {
font-size: 10px;
padding-left: 3px;
display: inline-block;
width: 10px;
- font-family: var(--button--font-family, "Material Icons");
+ font-family: var(--button--font-family, 'Material Icons');
}
regular-table span.rt-row-header-icon:hover {
color: #1a7da1;
@@ -228,10 +248,12 @@ regular-table::-webkit-scrollbar-thumb:hover {
box-shadow: 5px 4px 0px -4px var(--inactive--color, #eaedef);
}
.psp-is-top.psp-header-group:not(.psp-header-group-corner) {
- box-shadow: 5px 4px 0px -4px var(--inactive--color, #eaedef), 0px 10px 0 -9px var(--inactive--color, #eaedef);
+ box-shadow: 5px 4px 0px -4px var(--inactive--color, #eaedef),
+ 0px 10px 0 -9px var(--inactive--color, #eaedef);
}
.psp-header-border.psp-header-group:not(.psp-is-top):not(.psp-header-group-corner) {
- box-shadow: 1px 0px var(--inactive--color, #eaedef), 0px 10px 0 -9px var(--inactive--color, #eaedef);
+ box-shadow: 1px 0px var(--inactive--color, #eaedef),
+ 0px 10px 0 -9px var(--inactive--color, #eaedef);
}
.psp-header-leaf.psp-header-border {
box-shadow: 5px -4px 0px -4px var(--inactive--color, #eaedef);
@@ -247,16 +269,38 @@ tr:only-child th {
* the Apache License 2.0. The full license can be found in the LICENSE file.
*
*/
-regular-table tbody tr:hover th.psp-tree-leaf:not(.psp-row-selected):not(.psp-row-subselected),
-regular-table tbody tr:hover th.psp-tree-label:not(.psp-row-selected):not(.psp-row-subselected),
-regular-table tbody tr:hover td:not(.psp-row-selected):not(.psp-row-subselected) {
+regular-table
+ tbody
+ tr:hover
+ th.psp-tree-leaf:not(.psp-row-selected):not(.psp-row-subselected),
+regular-table
+ tbody
+ tr:hover
+ th.psp-tree-label:not(.psp-row-selected):not(.psp-row-subselected),
+regular-table
+ tbody
+ tr:hover
+ td:not(.psp-row-selected):not(.psp-row-subselected) {
border-color: var(--rt-hover--border-color, #c5c9d080) !important;
background-color: transparent;
- box-shadow: 0px 1px 0px var(--rt-hover--border-color, #c5c9d080), 0px 3px 0px rgba(0, 0, 0, 0.05), 0px 5px 0px rgba(0, 0, 0, 0.01);
-}
-regular-table tbody tr:hover + tr th.psp-tree-leaf:not(.psp-row-selected):not(.psp-row-subselected),
-regular-table tbody tr:hover + tr th.psp-tree-label:not(.psp-row-selected):not(.psp-row-subselected),
-regular-table tbody tr:hover + tr td:not(.psp-row-selected):not(.psp-row-subselected) {
+ box-shadow: 0px 1px 0px var(--rt-hover--border-color, #c5c9d080),
+ 0px 3px 0px rgba(0, 0, 0, 0.05), 0px 5px 0px rgba(0, 0, 0, 0.01);
+}
+regular-table
+ tbody
+ tr:hover
+ + tr
+ th.psp-tree-leaf:not(.psp-row-selected):not(.psp-row-subselected),
+regular-table
+ tbody
+ tr:hover
+ + tr
+ th.psp-tree-label:not(.psp-row-selected):not(.psp-row-subselected),
+regular-table
+ tbody
+ tr:hover
+ + tr
+ td:not(.psp-row-selected):not(.psp-row-subselected) {
border-top-color: transparent;
}
regular-table tbody tr th:first-child:not(:empty),
@@ -297,26 +341,39 @@ perspective-viewer[settings] regular-table .psp-header-leaf {
vertical-align: top;
padding-top: 2px;
}
-perspective-viewer[settings] regular-table .psp-header-leaf:not(.psp-header-corner):before {
+perspective-viewer[settings]
+ regular-table
+ .psp-header-leaf:not(.psp-header-corner):before {
font-family: var(--button--font-family, inherit);
- content: var(--column-style-open-button--content, var(--config-button-icon--content, "\1f527"));
+ content: var(
+ --column-style-open-button--content,
+ var(--config-button-icon--content, '\1f527')
+ );
position: absolute;
width: calc(100% - 8px);
left: 5px;
bottom: 0px;
color: var(--inactive--color, #b4b7be);
}
-perspective-viewer[settings] regular-table .psp-header-leaf.psp-menu-enabled:not(.psp-header-corner):before {
+perspective-viewer[settings]
+ regular-table
+ .psp-header-leaf.psp-menu-enabled:not(.psp-header-corner):before {
color: inherit;
cursor: pointer;
}
-perspective-viewer[settings] regular-table .psp-header-leaf.psp-menu-open:not(.psp-header-corner) {
+perspective-viewer[settings]
+ regular-table
+ .psp-header-leaf.psp-menu-open:not(.psp-header-corner) {
pointer-events: none;
}
-perspective-viewer[settings] regular-table .psp-header-leaf.psp-menu-open:not(.psp-header-corner):before {
- content: var(--column-style-close-button--content, "X");
+perspective-viewer[settings]
+ regular-table
+ .psp-header-leaf.psp-menu-open:not(.psp-header-corner):before {
+ content: var(--column-style-close-button--content, 'X');
}
-perspective-viewer[settings] regular-table .psp-header-leaf.psp-menu-enabled:hover:before {
+perspective-viewer[settings]
+ regular-table
+ .psp-header-leaf.psp-menu-enabled:hover:before {
color: #338dcd;
}
perspective-viewer[settings] regular-table .psp-header-leaf .rt-column-resize {
@@ -356,22 +413,22 @@ perspective-viewer.dragging regular-table {
.psp-header-sort-desc:after {
font-family: var(--button--font-family, inherit);
font-size: 10px;
- content: var(--sort-order-desc--content, "\2193");
+ content: var(--sort-order-desc--content, '\2193');
}
.psp-header-sort-asc:after {
font-family: var(--button--font-family, inherit);
font-size: 10px;
- content: var(--sort-order-asc--content, "\2191");
+ content: var(--sort-order-asc--content, '\2191');
}
.psp-header-sort-col-desc:after {
font-family: var(--button--font-family, inherit);
font-size: 10px;
- content: var(--sort-order-col-desc--content, "\2190");
+ content: var(--sort-order-col-desc--content, '\2190');
}
.psp-header-sort-col-asc:after {
font-family: var(--button--font-family, inherit);
font-size: 10px;
- content: var(--sort-order-col-asc--content, "\2192");
+ content: var(--sort-order-col-asc--content, '\2192');
}
tbody th:last-of-type {
border-right: 1px solid #eaedef;
@@ -379,7 +436,12 @@ tbody th:last-of-type {
text-overflow: ellipsis;
}
tbody th:empty {
- background-image: linear-gradient(to right, transparent 9px, #eee 10px, transparent 11px);
+ background-image: linear-gradient(
+ to right,
+ transparent 9px,
+ #eee 10px,
+ transparent 11px
+ );
background-repeat: no-repeat;
min-width: 20px;
max-width: 20px;
@@ -396,10 +458,10 @@ tbody th:empty {
vertical-align: -1px;
}
.psp-tree-label-expand:before {
- content: var(--tree-label-expand--content, "+");
+ content: var(--tree-label-expand--content, '+');
}
.psp-tree-label-collapse:before {
- content: var(--tree-label-collapse--content, "-");
+ content: var(--tree-label-collapse--content, '-');
}
.psp-tree-label:hover:before {
color: #338dcd;
@@ -434,7 +496,7 @@ regular-table table tbody td {
border-left-width: 0px;
}
.psp-bool-type {
- font-family: var(--button--font-family, "Material Icons");
+ font-family: var(--button--font-family, 'Material Icons');
}
.boolean-editable {
cursor: pointer;
@@ -472,7 +534,10 @@ regular-table table tbody th:empty {
}
@keyframes pulse_pos {
0% {
- background-color: var(--pulse--background-color-start, rgba(0, 128, 255, 0.5));
+ background-color: var(
+ --pulse--background-color-start,
+ rgba(0, 128, 255, 0.5)
+ );
}
100% {
background-color: var(--pulse--background-color-end, rgba(0, 128, 255, 0));
@@ -480,7 +545,10 @@ regular-table table tbody th:empty {
}
@keyframes pulse_pos2 {
0% {
- background-color: var(--pulse--background-color-start, rgba(0, 128, 255, 0.5));
+ background-color: var(
+ --pulse--background-color-start,
+ rgba(0, 128, 255, 0.5)
+ );
}
100% {
background-color: var(--pulse--background-color-end, rgba(0, 128, 255, 0));
@@ -488,7 +556,10 @@ regular-table table tbody th:empty {
}
@keyframes pulse_neg {
0% {
- background-color: var(--pulse--background-color-start, rgba(255, 25, 0, 0.5));
+ background-color: var(
+ --pulse--background-color-start,
+ rgba(255, 25, 0, 0.5)
+ );
}
100% {
background-color: var(--pulse--background-color-end, rgba(255, 25, 0, 0));
@@ -496,7 +567,10 @@ regular-table table tbody th:empty {
}
@keyframes pulse_neg2 {
0% {
- background-color: var(--pulse--background-color-start, rgba(255, 25, 0, 0.5));
+ background-color: var(
+ --pulse--background-color-start,
+ rgba(255, 25, 0, 0.5)
+ );
}
100% {
background-color: var(--pulse--background-color-end, rgba(255, 25, 0, 0));
diff --git a/panel/dist/css/plotly.css b/panel/dist/css/plotly.css
index 7392ec5931..867f47787a 100644
--- a/panel/dist/css/plotly.css
+++ b/panel/dist/css/plotly.css
@@ -1,109 +1,143 @@
-.js-plotly-plot .plotly, .js-plotly-plot .plotly div {
+.js-plotly-plot .plotly,
+.js-plotly-plot .plotly div {
direction: ltr;
font-family: 'Open Sans', verdana, arial, sans-serif;
margin: 0;
- padding: 0; }
+ padding: 0;
+}
-.js-plotly-plot .plotly input, .js-plotly-plot .plotly button {
- font-family: 'Open Sans', verdana, arial, sans-serif; }
- .js-plotly-plot .plotly input:focus, .js-plotly-plot .plotly button:focus {
- outline: none; }
+.js-plotly-plot .plotly input,
+.js-plotly-plot .plotly button {
+ font-family: 'Open Sans', verdana, arial, sans-serif;
+}
+.js-plotly-plot .plotly input:focus,
+.js-plotly-plot .plotly button:focus {
+ outline: none;
+}
.js-plotly-plot .plotly a {
- text-decoration: none; }
- .js-plotly-plot .plotly a:hover {
- text-decoration: none; }
+ text-decoration: none;
+}
+.js-plotly-plot .plotly a:hover {
+ text-decoration: none;
+}
.js-plotly-plot .plotly .crisp {
- shape-rendering: crispEdges; }
+ shape-rendering: crispEdges;
+}
.js-plotly-plot .plotly .user-select-none {
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-o-user-select: none;
- user-select: none; }
+ user-select: none;
+}
.js-plotly-plot .plotly svg {
- overflow: hidden; }
+ overflow: hidden;
+}
.js-plotly-plot .plotly svg a {
- fill: #447adb; }
+ fill: #447adb;
+}
.js-plotly-plot .plotly svg a:hover {
- fill: #3c6dc5; }
+ fill: #3c6dc5;
+}
.js-plotly-plot .plotly .main-svg {
position: absolute;
top: 0;
left: 0;
- pointer-events: none; }
- .js-plotly-plot .plotly .main-svg .draglayer {
- pointer-events: all; }
+ pointer-events: none;
+}
+.js-plotly-plot .plotly .main-svg .draglayer {
+ pointer-events: all;
+}
.js-plotly-plot .plotly .cursor-default {
- cursor: default; }
+ cursor: default;
+}
.js-plotly-plot .plotly .cursor-pointer {
- cursor: pointer; }
+ cursor: pointer;
+}
.js-plotly-plot .plotly .cursor-crosshair {
- cursor: crosshair; }
+ cursor: crosshair;
+}
.js-plotly-plot .plotly .cursor-move {
- cursor: move; }
+ cursor: move;
+}
.js-plotly-plot .plotly .cursor-col-resize {
- cursor: col-resize; }
+ cursor: col-resize;
+}
.js-plotly-plot .plotly .cursor-row-resize {
- cursor: row-resize; }
+ cursor: row-resize;
+}
.js-plotly-plot .plotly .cursor-ns-resize {
- cursor: ns-resize; }
+ cursor: ns-resize;
+}
.js-plotly-plot .plotly .cursor-ew-resize {
- cursor: ew-resize; }
+ cursor: ew-resize;
+}
.js-plotly-plot .plotly .cursor-sw-resize {
- cursor: sw-resize; }
+ cursor: sw-resize;
+}
.js-plotly-plot .plotly .cursor-s-resize {
- cursor: s-resize; }
+ cursor: s-resize;
+}
.js-plotly-plot .plotly .cursor-se-resize {
- cursor: se-resize; }
+ cursor: se-resize;
+}
.js-plotly-plot .plotly .cursor-w-resize {
- cursor: w-resize; }
+ cursor: w-resize;
+}
.js-plotly-plot .plotly .cursor-e-resize {
- cursor: e-resize; }
+ cursor: e-resize;
+}
.js-plotly-plot .plotly .cursor-nw-resize {
- cursor: nw-resize; }
+ cursor: nw-resize;
+}
.js-plotly-plot .plotly .cursor-n-resize {
- cursor: n-resize; }
+ cursor: n-resize;
+}
.js-plotly-plot .plotly .cursor-ne-resize {
- cursor: ne-resize; }
+ cursor: ne-resize;
+}
.js-plotly-plot .plotly .cursor-grab {
cursor: -webkit-grab;
- cursor: grab; }
+ cursor: grab;
+}
.js-plotly-plot .plotly .modebar {
position: absolute;
top: 2px;
- right: 2px; }
+ right: 2px;
+}
.js-plotly-plot .plotly .ease-bg {
-webkit-transition: background-color 0.3s ease 0s;
-moz-transition: background-color 0.3s ease 0s;
-ms-transition: background-color 0.3s ease 0s;
-o-transition: background-color 0.3s ease 0s;
- transition: background-color 0.3s ease 0s; }
+ transition: background-color 0.3s ease 0s;
+}
.js-plotly-plot .plotly .modebar--hover > :not(.watermark) {
opacity: 0;
@@ -111,10 +145,12 @@
-moz-transition: opacity 0.3s ease 0s;
-ms-transition: opacity 0.3s ease 0s;
-o-transition: opacity 0.3s ease 0s;
- transition: opacity 0.3s ease 0s; }
+ transition: opacity 0.3s ease 0s;
+}
.js-plotly-plot .plotly:hover .modebar--hover .modebar-group {
- opacity: 1; }
+ opacity: 1;
+}
.js-plotly-plot .plotly .modebar-group {
float: left;
@@ -123,7 +159,8 @@
padding-left: 8px;
position: relative;
vertical-align: middle;
- white-space: nowrap; }
+ white-space: nowrap;
+}
.js-plotly-plot .plotly .modebar-btn {
position: relative;
@@ -133,77 +170,93 @@
/* display: inline-block; including this breaks 3d interaction in .embed mode. Chrome bug? */
cursor: pointer;
line-height: normal;
- box-sizing: border-box; }
- .js-plotly-plot .plotly .modebar-btn svg {
- position: relative;
- top: 2px; }
+ box-sizing: border-box;
+}
+.js-plotly-plot .plotly .modebar-btn svg {
+ position: relative;
+ top: 2px;
+}
.js-plotly-plot .plotly .modebar.vertical {
display: flex;
flex-direction: column;
flex-wrap: wrap;
align-content: flex-end;
- max-height: 100%; }
- .js-plotly-plot .plotly .modebar.vertical svg {
- top: -1px; }
- .js-plotly-plot .plotly .modebar.vertical .modebar-group {
- display: block;
- float: none;
- padding-left: 0px;
- padding-bottom: 8px; }
- .js-plotly-plot .plotly .modebar.vertical .modebar-group .modebar-btn {
- display: block;
- text-align: center; }
+ max-height: 100%;
+}
+.js-plotly-plot .plotly .modebar.vertical svg {
+ top: -1px;
+}
+.js-plotly-plot .plotly .modebar.vertical .modebar-group {
+ display: block;
+ float: none;
+ padding-left: 0px;
+ padding-bottom: 8px;
+}
+.js-plotly-plot .plotly .modebar.vertical .modebar-group .modebar-btn {
+ display: block;
+ text-align: center;
+}
.js-plotly-plot .plotly [data-title] {
/**
* tooltip body
- */ }
- .js-plotly-plot .plotly [data-title]:before, .js-plotly-plot .plotly [data-title]:after {
- position: absolute;
- -webkit-transform: translate3d(0, 0, 0);
- -moz-transform: translate3d(0, 0, 0);
- -ms-transform: translate3d(0, 0, 0);
- -o-transform: translate3d(0, 0, 0);
- transform: translate3d(0, 0, 0);
- display: none;
- opacity: 0;
- z-index: 1001;
- pointer-events: none;
- top: 110%;
- right: 50%; }
- .js-plotly-plot .plotly [data-title]:hover:before, .js-plotly-plot .plotly [data-title]:hover:after {
- display: block;
- opacity: 1; }
- .js-plotly-plot .plotly [data-title]:before {
- content: '';
- position: absolute;
- background: transparent;
- border: 6px solid transparent;
- z-index: 1002;
- margin-top: -12px;
- border-bottom-color: #69738a;
- margin-right: -6px; }
- .js-plotly-plot .plotly [data-title]:after {
- content: attr(data-title);
- background: #69738a;
- color: white;
- padding: 8px 10px;
- font-size: 12px;
- line-height: 12px;
- white-space: nowrap;
- margin-right: -18px;
- border-radius: 2px; }
-
-.js-plotly-plot .plotly .vertical [data-title]:before, .js-plotly-plot .plotly .vertical [data-title]:after {
+ */
+}
+.js-plotly-plot .plotly [data-title]:before,
+.js-plotly-plot .plotly [data-title]:after {
+ position: absolute;
+ -webkit-transform: translate3d(0, 0, 0);
+ -moz-transform: translate3d(0, 0, 0);
+ -ms-transform: translate3d(0, 0, 0);
+ -o-transform: translate3d(0, 0, 0);
+ transform: translate3d(0, 0, 0);
+ display: none;
+ opacity: 0;
+ z-index: 1001;
+ pointer-events: none;
+ top: 110%;
+ right: 50%;
+}
+.js-plotly-plot .plotly [data-title]:hover:before,
+.js-plotly-plot .plotly [data-title]:hover:after {
+ display: block;
+ opacity: 1;
+}
+.js-plotly-plot .plotly [data-title]:before {
+ content: '';
+ position: absolute;
+ background: transparent;
+ border: 6px solid transparent;
+ z-index: 1002;
+ margin-top: -12px;
+ border-bottom-color: #69738a;
+ margin-right: -6px;
+}
+.js-plotly-plot .plotly [data-title]:after {
+ content: attr(data-title);
+ background: #69738a;
+ color: white;
+ padding: 8px 10px;
+ font-size: 12px;
+ line-height: 12px;
+ white-space: nowrap;
+ margin-right: -18px;
+ border-radius: 2px;
+}
+
+.js-plotly-plot .plotly .vertical [data-title]:before,
+.js-plotly-plot .plotly .vertical [data-title]:after {
top: 0%;
- right: 200%; }
+ right: 200%;
+}
.js-plotly-plot .plotly .vertical [data-title]:before {
border: 6px solid transparent;
border-left-color: #69738a;
margin-top: 8px;
- margin-right: -30px; }
+ margin-right: -30px;
+}
.plotly-notifier {
font-family: 'Open Sans', verdana, arial, sans-serif;
@@ -212,35 +265,40 @@
right: 20px;
z-index: 10000;
font-size: 10pt;
- max-width: 180px; }
- .plotly-notifier p {
- margin: 0; }
- .plotly-notifier .notifier-note {
- min-width: 180px;
- max-width: 250px;
- border: 1px solid #fff;
- z-index: 3000;
- margin: 0;
- background-color: #8c97af;
- background-color: rgba(140, 151, 175, 0.9);
- color: #fff;
- padding: 10px;
- overflow-wrap: break-word;
- word-wrap: break-word;
- -ms-hyphens: auto;
- -webkit-hyphens: auto;
- hyphens: auto; }
- .plotly-notifier .notifier-close {
- color: #fff;
- opacity: 0.8;
- float: right;
- padding: 0 5px;
- background: none;
- border: none;
- font-size: 20px;
- font-weight: bold;
- line-height: 20px; }
- .plotly-notifier .notifier-close:hover {
- color: #444;
- text-decoration: none;
- cursor: pointer; }
+ max-width: 180px;
+}
+.plotly-notifier p {
+ margin: 0;
+}
+.plotly-notifier .notifier-note {
+ min-width: 180px;
+ max-width: 250px;
+ border: 1px solid #fff;
+ z-index: 3000;
+ margin: 0;
+ background-color: #8c97af;
+ background-color: rgba(140, 151, 175, 0.9);
+ color: #fff;
+ padding: 10px;
+ overflow-wrap: break-word;
+ word-wrap: break-word;
+ -ms-hyphens: auto;
+ -webkit-hyphens: auto;
+ hyphens: auto;
+}
+.plotly-notifier .notifier-close {
+ color: #fff;
+ opacity: 0.8;
+ float: right;
+ padding: 0 5px;
+ background: none;
+ border: none;
+ font-size: 20px;
+ font-weight: bold;
+ line-height: 20px;
+}
+.plotly-notifier .notifier-close:hover {
+ color: #444;
+ text-decoration: none;
+ cursor: pointer;
+}
diff --git a/panel/dist/css/progress.css b/panel/dist/css/progress.css
index 629a14410a..966c9f63ca 100644
--- a/panel/dist/css/progress.css
+++ b/panel/dist/css/progress.css
@@ -1,15 +1,15 @@
progress {
- appearance: none;
- -moz-appearance: none;
- -webkit-appearance: none;
- border: none;
- height: 20px;
- border-radius: 3px;
- box-shadow: 0 2px 3px rgba(0, 0, 0, 0.5) inset;
- color: royalblue;
- position: relative;
- margin: 0 0 1.5em;
- width: 100%;
+ appearance: none;
+ -moz-appearance: none;
+ -webkit-appearance: none;
+ border: none;
+ height: 20px;
+ border-radius: 3px;
+ box-shadow: 0 2px 3px rgba(0, 0, 0, 0.5) inset;
+ color: royalblue;
+ position: relative;
+ margin: 0 0 1.5em;
+ width: 100%;
}
progress[value]::-webkit-progress-bar {
@@ -181,7 +181,7 @@ progress:not([value])::-webkit-progress-bar {
left/2.5em 1.5em;
}
progress:not([value])::before {
- content: " ";
+ content: ' ';
position: absolute;
height: 20px;
top: 0;
diff --git a/panel/dist/css/regular_table.css b/panel/dist/css/regular_table.css
new file mode 100644
index 0000000000..e69de29bb2
diff --git a/panel/dist/css/select.css b/panel/dist/css/select.css
index f9decac26d..da29b60694 100644
--- a/panel/dist/css/select.css
+++ b/panel/dist/css/select.css
@@ -1,4 +1,4 @@
.bk-input {
- box-sizing: border-box;
- margin: 10px 0;
+ box-sizing: border-box;
+ margin: 10px 0;
}
diff --git a/panel/dist/css/swipe.css b/panel/dist/css/swipe.css
index 31f07187d5..9d242baa50 100644
--- a/panel/dist/css/swipe.css
+++ b/panel/dist/css/swipe.css
@@ -1,12 +1,12 @@
.swipe-container {
- display: grid;
- grid-template-columns: 1fr;
- grid-template-rows: 1fr;
+ display: grid;
+ grid-template-columns: 1fr;
+ grid-template-rows: 1fr;
}
.swipe-container .outer {
- grid-column: 1;
- grid-row: 1;
+ grid-column: 1;
+ grid-row: 1;
}
.swipe-container .slider {
diff --git a/panel/dist/css/widgetbox.css b/panel/dist/css/widgetbox.css
index e644e827e0..56ec2f00fe 100644
--- a/panel/dist/css/widgetbox.css
+++ b/panel/dist/css/widgetbox.css
@@ -1,9 +1,9 @@
:host(.panel-widget-box) {
- min-height: 20px;
- border: 1px solid #e3e3e3;
- border-radius: 4px;
- -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.05);
- box-shadow: inset 0 1px 1px rgba(0,0,0,.05);
- overflow-x: hidden;
- overflow-y: hidden;
+ min-height: 20px;
+ border: 1px solid #e3e3e3;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
+ overflow-x: hidden;
+ overflow-y: hidden;
}
diff --git a/panel/dist/css/widgets.css b/panel/dist/css/widgets.css
index d2b0c13570..d8145a0bed 100644
--- a/panel/dist/css/widgets.css
+++ b/panel/dist/css/widgets.css
@@ -1,5 +1,6 @@
/* JSON Pane */
-.bk-root .json-formatter-row .json-formatter-string, .bk-root .json-formatter-row .json-formatter-stringifiable {
+.bk-root .json-formatter-row .json-formatter-string,
+.bk-root .json-formatter-row .json-formatter-stringifiable {
white-space: pre-wrap;
}
diff --git a/panel/io/resources.py b/panel/io/resources.py
index 7a04de3938..af91a67592 100644
--- a/panel/io/resources.py
+++ b/panel/io/resources.py
@@ -671,7 +671,7 @@ def css_raw(self):
if config.global_loading_spinner:
loading_base = (DIST_DIR / "css" / "loading.css").read_text(encoding='utf-8')
raw.extend([loading_base, loading_css()])
- return raw + process_raw_css(config.raw_css)
+ return raw + process_raw_css(config.raw_css) + process_raw_css(config.global_css)
@property
def js_files(self):
diff --git a/panel/template/bootstrap/bootstrap.css b/panel/template/bootstrap/bootstrap.css
index ab47c3cc38..e0789a8049 100644
--- a/panel/template/bootstrap/bootstrap.css
+++ b/panel/template/bootstrap/bootstrap.css
@@ -1,175 +1,193 @@
-:root, :host {
- --bs-primary-color: var(--panel-on-primary-color);
- --bs-primary-bg: var(--panel-primary-color);
- --bs-secondary-color: var(--panel-on-secondary-color);
- --bs-secondary-bg: var(--panel-secondary-color);
- --bs-form-control-bg: var(--panel-background-color);
- --bs-body-bg: var(--panel-background-color);
- --bs-body-color: var(--panel-on-background-color);
- --bs-surface-bg: var(--panel-surface-color);
- --bs-surface-color: var(--panel-on-surface-color);
- --bokeh-base-font: system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue","Noto Sans","Liberation Sans",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
+:root,
+:host {
+ --bs-primary-color: var(
+ --design-primary-text-color,
+ var(--panel-on-primary-color)
+ );
+ --bs-primary-bg: var(--design-primary-color, var(--panel-primary-color));
+ --bs-secondary-color: var(
+ --design-secondary-text-color,
+ var(--panel-on-secondary-color)
+ );
+ --bs-secondary-bg: var(--design-primary-color, var(--panel-secondary-color));
+ --bs-form-control-bg: var(
+ --design-background-color,
+ var(--panel-background-color)
+ );
+ --bs-body-bg: var(--design-background-color, var(--panel-background-color));
+ --bs-body-color: var(
+ --design-background-text-color,
+ var(--panel-on-background-color)
+ );
+ --bs-surface-bg: var(--design-surface-color, var(--panel-surface-color));
+ --bs-surface-color: var(
+ --design-surface-text-color,
+ var(--panel-on-surface-color)
+ );
+ --bokeh-base-font: system-ui, -apple-system, 'Segoe UI', Roboto,
+ 'Helvetica Neue', 'Noto Sans', 'Liberation Sans', Arial, sans-serif,
+ 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
}
html {
- scrollbar-face-color: var(--bs-surface-bg);
- scrollbar-base-color: var(--bs-surface-bg);
- scrollbar-3dlight-color: var(--bs-surface-bg);
- scrollbar-highlight-color: var(--bs-surface-bg);
- scrollbar-track-color: var(--bs-body-bg);
- scrollbar-arrow-color: var(--bs-body-bg);
- scrollbar-shadow-color: var(--bs-surface-bg);
+ scrollbar-face-color: var(--bs-surface-bg);
+ scrollbar-base-color: var(--bs-surface-bg);
+ scrollbar-3dlight-color: var(--bs-surface-bg);
+ scrollbar-highlight-color: var(--bs-surface-bg);
+ scrollbar-track-color: var(--bs-body-bg);
+ scrollbar-arrow-color: var(--bs-body-bg);
+ scrollbar-shadow-color: var(--bs-surface-bg);
}
::-webkit-scrollbar {
- width: 12px;
+ width: 12px;
}
::-webkit-scrollbar-track {
- background-color: var(--bs-body-bg);
- border-radius: 10px;
+ background-color: var(--bs-body-bg);
+ border-radius: 10px;
}
::-webkit-scrollbar-thumb {
- background-color: var(--bs-surface-bg);
+ background-color: var(--bs-surface-bg);
}
::-webkit-scrollbar-corner {
- background-color: var(--bs-surface-bg);
+ background-color: var(--bs-surface-bg);
}
body {
- color: var(--bs-body-color);
- background-color: var(--bs-body-bg);
- height: 100vh;
+ color: var(--bs-body-color);
+ background-color: var(--bs-body-bg);
+ height: 100vh;
}
#container {
- padding: 0px;
+ padding: 0px;
}
/* Header */
#header {
- background-color: var(--bs-primary-bg);
- color: var(--bs-primary-color);
+ background-color: var(--bs-primary-bg);
+ color: var(--bs-primary-color);
}
.navbar-toggle {
- background: none;
- border: none;
- padding-left: 10px;
+ background: none;
+ border: none;
+ padding-left: 10px;
}
a.navbar-brand {
- padding-left: 10px;
- display: flex;
- align-items: center;
- font-size: 1.5em;
+ padding-left: 10px;
+ display: flex;
+ align-items: center;
+ font-size: 1.5em;
}
#header .title {
- color: var(--bs-primary-color);
- text-decoration: none;
- text-decoration-line: none;
- text-decoration-style: initial;
- text-decoration-color: initial;
- font-weight: 400;
- font-size: 1.5em;
- padding-left: 0.5em;
- line-height: 2em;
- white-space: nowrap;
+ color: var(--bs-primary-color);
+ text-decoration: none;
+ text-decoration-line: none;
+ text-decoration-style: initial;
+ text-decoration-color: initial;
+ font-weight: 400;
+ font-size: 1.5em;
+ padding-left: 0.5em;
+ line-height: 2em;
+ white-space: nowrap;
}
#header-items {
- align-items: center;
- display: flex;
- flex-grow: 1;
- margin-left: 15px;
- white-space: nowrap;
+ align-items: center;
+ display: flex;
+ flex-grow: 1;
+ margin-left: 15px;
+ white-space: nowrap;
}
.app-header {
- display: contents;
- padding-left: 10px;
+ display: contents;
+ padding-left: 10px;
}
.app-header a.title:hover {
- color: var(--bs-primary-color);
- text-decoration: none;
+ color: var(--bs-primary-color);
+ text-decoration: none;
}
img.app-logo {
- padding-right: 10px;
- font-size: 28px;
- height: 30px;
- max-width: inherit;
+ padding-right: 10px;
+ font-size: 28px;
+ height: 30px;
+ max-width: inherit;
}
/* Sidebar */
#sidebar {
- border-right: 1px solid var(--bs-border-color);
- height: 100%;
- overflow: hidden auto;
- padding: 15px 10px 15px 5px;
+ border-right: 1px solid var(--bs-border-color);
+ height: 100%;
+ overflow: hidden auto;
+ padding: 15px 10px 15px 5px;
}
#sidebar.collapsing {
- display: block;
- width: 0;
+ display: block;
+ width: 0;
}
/* Main Area */
#content {
- height: 100%;
- margin: 0px;
+ height: 100%;
+ margin: 0px;
}
#main {
- background-color: var(--bs-body-bg);
- color: var(--bs-body-color);
- overflow-y: auto;
- padding: 10px 20px 20px 10px;
+ background-color: var(--bs-body-bg);
+ color: var(--bs-body-color);
+ overflow-y: auto;
+ padding: 10px 20px 20px 10px;
}
/* Modal */
.pn-modal {
- overflow-y: auto;
+ overflow-y: auto;
}
.pn-modal-content {
- display: block;
- min-height: 42px;
+ display: block;
+ min-height: 42px;
}
.pn-modal-close {
- height: 40px;
- float: right;
- padding: 0px;
- position: relative;
- width: 40px;
- z-index: 100;
+ height: 40px;
+ float: right;
+ padding: 0px;
+ position: relative;
+ width: 40px;
+ z-index: 100;
}
.pn-modal-close:hover,
.pn-modal-close:focus {
- cursor: pointer;
- font-weight: 800;
- text-decoration: none;
+ cursor: pointer;
+ font-weight: 800;
+ text-decoration: none;
}
.pn-busy-container {
- align-items: center;
- justify-content: center;
- display: flex;
- margin-left: auto;
+ align-items: center;
+ justify-content: center;
+ display: flex;
+ margin-left: auto;
}
@media (min-width: 576px) {
- .modal-dialog {
- max-width: 80%;
- }
+ .modal-dialog {
+ max-width: 80%;
+ }
}
diff --git a/panel/template/bootstrap/bootstrap.html b/panel/template/bootstrap/bootstrap.html
index 4a0d5af0c1..4bacb46570 100644
--- a/panel/template/bootstrap/bootstrap.html
+++ b/panel/template/bootstrap/bootstrap.html
@@ -48,13 +48,13 @@
diff --git a/panel/template/fast/js/fast_template.js b/panel/template/fast/js/fast_template.js
index 50f443fabe..edfc7a2e1f 100644
--- a/panel/template/fast/js/fast_template.js
+++ b/panel/template/fast/js/fast_template.js
@@ -1,113 +1,117 @@
function updateURLParameter(url, param, paramVal) {
- var TheAnchor = null;
- var newAdditionalURL = "";
- var tempArray = url.split("?");
- var baseURL = tempArray[0];
- var additionalURL = tempArray[1];
- var temp = "";
+ var TheAnchor = null
+ var newAdditionalURL = ''
+ var tempArray = url.split('?')
+ var baseURL = tempArray[0]
+ var additionalURL = tempArray[1]
+ var temp = ''
if (additionalURL) {
- var tmpAnchor = additionalURL.split("#");
- var TheParams = tmpAnchor[0];
- var TheAnchor = tmpAnchor[1];
+ var tmpAnchor = additionalURL.split('#')
+ var TheParams = tmpAnchor[0]
+ var TheAnchor = tmpAnchor[1]
if (TheAnchor) {
- additionalURL = TheParams;
+ additionalURL = TheParams
}
- tempArray = additionalURL.split("&");
+ tempArray = additionalURL.split('&')
- for (var i=0; i'
} else {
- button.innerHTML = ''
+ button.innerHTML =
+ ''
}
-});
+})
diff --git a/panel/template/fast/list/fast_list_template.css b/panel/template/fast/list/fast_list_template.css
index 1883a66257..00755f9674 100644
--- a/panel/template/fast/list/fast_list_template.css
+++ b/panel/template/fast/list/fast_list_template.css
@@ -1,3 +1,3 @@
.card-margin {
- margin: 1em 0;
+ margin: 1em 0;
}
diff --git a/panel/template/fast/list/fast_list_template.html b/panel/template/fast/list/fast_list_template.html
index 3431154f08..fb5d39ad84 100644
--- a/panel/template/fast/list/fast_list_template.html
+++ b/panel/template/fast/list/fast_list_template.html
@@ -28,31 +28,31 @@
diff --git a/panel/template/golden/golden.css b/panel/template/golden/golden.css
index 554a4062a4..38f49e9967 100644
--- a/panel/template/golden/golden.css
+++ b/panel/template/golden/golden.css
@@ -1,11 +1,14 @@
body {
display: flex;
height: 100vh;
- font-family: "Lato", sans-serif;
+ font-family: 'Lato', sans-serif;
margin: 0px;
}
-body, .main-area, .main-content, .lm_goldenlayout {
+body,
+.main-area,
+.main-content,
+.lm_goldenlayout {
overflow: hidden;
}
@@ -59,8 +62,8 @@ img.app-logo {
padding-right: 10px;
font-size: 28px;
height: 30px;
- padding-top:9px;
- padding-bottom:9px;
+ padding-top: 9px;
+ padding-bottom: 9px;
max-width: inherit;
}
@@ -90,7 +93,10 @@ p.bk.golden-card-button {
}
.lm_content {
- background-color: var(--panel-background-color);
+ background-color: var(
+ --design-background-color,
+ var(--panel-background-color)
+ );
overflow-y: auto !important;
}
@@ -113,7 +119,7 @@ p.bk.golden-card-button {
}
.pn-modal-content {
- background-color: #fefefe;
+ background-color: var(--design-surface-color, var(--panel-surface-color));
margin: auto;
margin-top: 25px;
margin-bottom: 25px;
diff --git a/panel/template/golden/golden.html b/panel/template/golden/golden.html
index 9aa9a06df1..2802613084 100644
--- a/panel/template/golden/golden.html
+++ b/panel/template/golden/golden.html
@@ -34,13 +34,13 @@
diff --git a/panel/template/material/default.css b/panel/template/material/default.css
index 1787bb61be..9a6e45603e 100644
--- a/panel/template/material/default.css
+++ b/panel/template/material/default.css
@@ -1,4 +1,4 @@
:root {
- --mdc-theme-error: #b00020;
- --mdc-theme-on-error: #ffffff;
+ --mdc-theme-error: #b00020;
+ --mdc-theme-on-error: #ffffff;
}
diff --git a/panel/template/material/material.css b/panel/template/material/material.css
index d8c96a3b31..0c0d01ff94 100644
--- a/panel/template/material/material.css
+++ b/panel/template/material/material.css
@@ -1,189 +1,219 @@
:root {
- --bokeh-base-font: inherit;
- --mdc-theme-primary: var(--panel-primary-color);
- --mdc-theme-primary-lightened: rgba(var(--panel-primary-rgb), 0.35);
- --mdc-theme-on-primary: var(--panel-on-primary-color);
- --mdc-theme-secondary: var(--panel-secondary-color);
- --mdc-theme-secondary-lightened: rgba(var(--panel-secondary-rgb), 0.8);
- --mdc-theme-on-secondary: var(--panel-on-secondary-color);
- --mdc-theme-background: var(--panel-background-color);
- --mdc-theme-on-background: var(--panel-on-background-color);
- --mdc-theme-surface: var(--panel-surface-color);
- --mdc-theme-on-surface: var(--panel-on-surface-color);
- --mdc-theme-text-primary-on-background: rgba(var(--panel-on-background-rgb), 0.87);
- --mdc-typography--font-family: var(--bokeh-base-font);
- --mdc-shape-small: 4px;
- --mdc-shape-medium: 4px;
- --mdc-shape-large: 0px;
+ --bokeh-base-font: inherit;
+ --mdc-theme-surface: var(--design-surface-color, var(--panel-surface-color));
+ --mdc-theme-primary: var(--design-primary-color, var(--panel-primary-color));
+ --mdc-theme-primary-lightened: color-mix(
+ in srgb,
+ var(--mdc-theme-primary) 30%,
+ var(--mdc-theme-surface)
+ );
+ --mdc-theme-on-primary: var(
+ --design-primary-text-color,
+ var(--panel-on-primary-color)
+ );
+ --mdc-theme-secondary: var(
+ --design-secondary-color,
+ var(--panel-secondary-color)
+ );
+ --mdc-theme-secondary-lightened: color-mix(
+ in srgb,
+ var(--mdc-theme-secondary) 80%,
+ var(--mdc-theme-surface)
+ );
+ --mdc-theme-on-secondary: var(
+ --design-secondary-text-color,
+ var(--panel-on-secondary-color)
+ );
+ --mdc-theme-background: var(
+ --design-background-color,
+ var(--panel-background-color)
+ );
+ --mdc-theme-on-background: var(
+ --design-background-text-color,
+ var(--panel-on-background-color)
+ );
+ --mdc-theme-on-surface: var(
+ --design-surface-text-color,
+ var(--panel-on-surface-color)
+ );
+ --mdc-theme-text-primary-on-background: color-mix(
+ in srgb,
+ var(--mdc-theme-on-background) 87%,
+ var(--mdc-theme-surface)
+ );
+ --mdc-typography--font-family: var(--bokeh-base-font);
+ --mdc-shape-small: 4px;
+ --mdc-shape-medium: 4px;
+ --mdc-shape-large: 0px;
}
html {
- scrollbar-face-color: var(--mdc-theme-surface);
- scrollbar-base-color: var(--mdc-theme-surface);
- scrollbar-3dlight-color: var(--mdc-theme-surface);
- scrollbar-highlight-color: var(--mdc-theme-surface);
- scrollbar-track-color: var(--mdc-theme-background);
- scrollbar-arrow-color: var(--mdc-theme-background);
- scrollbar-shadow-color: var(--mdc-theme-surface);
+ scrollbar-face-color: var(--mdc-theme-surface);
+ scrollbar-base-color: var(--mdc-theme-surface);
+ scrollbar-3dlight-color: var(--mdc-theme-surface);
+ scrollbar-highlight-color: var(--mdc-theme-surface);
+ scrollbar-track-color: var(--mdc-theme-background);
+ scrollbar-arrow-color: var(--mdc-theme-background);
+ scrollbar-shadow-color: var(--mdc-theme-surface);
}
::-webkit-scrollbar {
- width: 12px;
+ width: 12px;
}
::-webkit-scrollbar-track {
- background-color: var(--mdc-theme-background);
- border-radius: 10px;
+ background-color: var(--mdc-theme-background);
+ border-radius: 10px;
}
::-webkit-scrollbar-thumb {
- background-color: var(--mdc-theme-surface);
+ background-color: var(--mdc-theme-surface);
}
::-webkit-scrollbar-corner {
- background-color: var(--mdc-theme-surface);
+ background-color: var(--mdc-theme-surface);
}
body {
- background-color: var(--mdc-theme-background);
- color: var(--mdc-theme-on-background);
- display: flex;
- height: 100vh;
- margin: 0px;
- overflow-x: hidden;
- overflow-y: hidden;
+ background-color: var(--mdc-theme-background);
+ color: var(--mdc-theme-on-background);
+ display: flex;
+ height: 100vh;
+ margin: 0px;
+ overflow-x: hidden;
+ overflow-y: hidden;
}
img {
- max-width: 100%;
+ max-width: 100%;
}
#container {
- padding: 0px;
- height: 100vh;
- width: 100vw;
- max-width: 100vw;
+ padding: 0px;
+ height: 100vh;
+ width: 100vw;
+ max-width: 100vw;
}
#sidebar .mdc-list {
- padding-left: 5px;
- padding-right: 5px;
+ padding-left: 5px;
+ padding-right: 5px;
}
.mdc-drawer-app-content {
- flex: auto;
- position: relative;
- overflow: hidden;
+ flex: auto;
+ position: relative;
+ overflow: hidden;
}
.mdc-drawer {
- background: var(--mdc-theme-background);
- color: var(--mdc-theme-on-background);
+ background: var(--mdc-theme-background);
+ color: var(--mdc-theme-on-background);
}
.mdc-drawer-app-content {
- margin-left: 0 !important;
+ margin-left: 0 !important;
}
.title-bar {
- display: contents;
- justify-content: center;
- align-content: center;
- width: 100%;
+ display: contents;
+ justify-content: center;
+ align-content: center;
+ width: 100%;
}
.app-header {
- display: contents;
- padding-left: 10px;
- font-size: 1.25em;
+ display: contents;
+ padding-left: 10px;
+ font-size: 1.25em;
}
img.app-logo {
- padding-right: 10px;
- font-size: 28px;
- height: 30px;
- max-width: inherit;
- padding-top: 12px;
- padding-bottom: 6px;
+ padding-right: 10px;
+ font-size: 28px;
+ height: 30px;
+ max-width: inherit;
+ padding-top: 12px;
+ padding-bottom: 6px;
}
#app-title {
- padding-right: 12px;
- padding-left: 12px;
+ padding-right: 12px;
+ padding-left: 12px;
}
.title {
- color: #fff;
- text-decoration: none;
- text-decoration-line: none;
- text-decoration-style: initial;
- text-decoration-color: initial;
- font-weight: 400;
- font-size: 1.25em;
- line-height: 2em;
- white-space: nowrap;
+ color: #fff;
+ text-decoration: none;
+ text-decoration-line: none;
+ text-decoration-style: initial;
+ text-decoration-color: initial;
+ font-weight: 400;
+ font-size: 1.25em;
+ line-height: 2em;
+ white-space: nowrap;
}
.main-content {
- height: calc(100vh - 64px);
- overflow: auto;
- padding: 5px 15px 0px 15px;
+ height: calc(100vh - 64px);
+ overflow: auto;
+ padding: 5px 15px 0px 15px;
}
#header {
- position: absolute;
- z-index: 7;
+ position: absolute;
+ z-index: 7;
}
#header-items {
- align-items: center;
- display: flex;
- width: 100%;
- margin-left: 25px;
+ align-items: center;
+ display: flex;
+ width: 100%;
+ margin-left: 25px;
}
.pn-busy-container {
- align-items: center;
- justify-content: center;
- display: flex;
+ align-items: center;
+ justify-content: center;
+ display: flex;
}
.mdc-drawer__content {
- overflow-x: hidden;
+ overflow-x: hidden;
}
.pn-modal {
- overflow-y: scroll;
- width: 100%;
- display: none;
- position: absolute;
- top: 0;
- left: 0;
+ overflow-y: scroll;
+ width: 100%;
+ display: none;
+ position: absolute;
+ top: 0;
+ left: 0;
}
.mdc-dialog .mdc-dialog__content {
- color: var(--mdc-theme-on-surface);
+ color: var(--mdc-theme-on-surface);
}
.pn-modal-content {
- background-color: var(--mdc-theme-surface);
- margin: auto;
- margin-top: 25px;
- margin-bottom: 25px;
- padding: 15px 20px 20px 20px;
- border: 1px solid #888;
- width: 80% !important;
+ background-color: var(--mdc-theme-surface);
+ margin: auto;
+ margin-top: 25px;
+ margin-bottom: 25px;
+ padding: 15px 20px 20px 20px;
+ border: 1px solid #888;
+ width: 80% !important;
}
.pn-modal-close {
- position: absolute;
- right: 25px;
- z-index: 100;
+ position: absolute;
+ right: 25px;
+ z-index: 100;
}
.pn-modal-close:hover,
.pn-modal-close:focus {
- color: #000;
- text-decoration: none;
- cursor: pointer;
+ color: #000;
+ text-decoration: none;
+ cursor: pointer;
}
diff --git a/panel/template/material/material.html b/panel/template/material/material.html
index 151f4d9cc5..fa9c28d4c1 100644
--- a/panel/template/material/material.html
+++ b/panel/template/material/material.html
@@ -48,8 +48,8 @@
{% endblock %}
@@ -53,10 +53,10 @@