diff --git a/projects/CoFFE-sponge-proteins/README.md b/projects/CoFFE-sponge-proteins/README.md index 910fa379beb05bb010fa316292d07f41923f2c8f..1a9a99cbe6f68ba77a25a7cbef98291a877ad57d 100644 --- a/projects/CoFFE-sponge-proteins/README.md +++ b/projects/CoFFE-sponge-proteins/README.md @@ -1,8 +1,6 @@ # Modelling of Spongilla lacustris proteome with functional annotations -Main links: -- [Link Project in MA](https://modelarchive.org/doi/10.5452/ma-coffe-slac) (incl. background on project itself) -- [Jira-story](https://jira.biozentrum.unibas.ch/browse/SCHWED-5596) +[Link to project in ModelArchive](https://modelarchive.org/doi/10.5452/ma-coffe-slac) (incl. background on project itself) Setup: - Using ColabFold for monomer predictions with AlphaFold without links to sequence databases @@ -16,11 +14,6 @@ Special features here: - Description is long multiline text which includes output from functional annotation - Expected to be the first set of models converted by us to ModelCIF and fully imported into ModelArchive - Includes generic code for handling of ColabFold setup based on config.json -- Includes test code for conversion of ModelCIF to content displayed in ModelArchive Content: - translate2modelcif.py : script to do conversion; compatible with Docker setup from [ma-wilkins-import](https://git.scicore.unibas.ch/schwede/ma-wilkins-import/-/tree/6bbd6fa7ec53e1a0971fba40c96fa971d1022f74) (and script based on code there) -- tests folder with - - custom Docker setup used locally (Mac; with extra libraries for testing) and on work machine (managed CentOS with old docker version) - - test_modelCIF_MA.py to convert ModelCIF to content displayed in ModelArchive (needs gemmi library) - - test.ipynb and .html for tests performed during development diff --git a/projects/CoFFE-sponge-proteins/tests/Docker/Dockerfile_GT b/projects/CoFFE-sponge-proteins/tests/Docker/Dockerfile_GT deleted file mode 100644 index e87a2e5dcec22cc52069d0a1320bd9b2a2172913..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/Docker/Dockerfile_GT +++ /dev/null @@ -1,49 +0,0 @@ -ARG VERSION_OST="2.3.0" -FROM registry.scicore.unibas.ch/schwede/openstructure:${VERSION_OST} -# We need to declare ARGs again which were declared before the build stage -# (FROM directive), otherwise they won't be available in this stage. -ARG VERSION_OST - -## Set up environment -ENV SRC_DIR="/tmp" \ - VERSION_OST=${VERSION_OST} \ - PYTHONUNBUFFERED=1 \ - PYTHONDONTWRITEBYTECODE=1 - -## Install python-modelcif and python-ihm -COPY requirements.txt ${SRC_DIR} -COPY pdbx.tar.gz ${SRC_DIR} -WORKDIR ${SRC_DIR} -RUN set -e pipefail; \ - apt-get update -y; \ - # for development, install venv - apt-get install -y git pip python3.8-venv; \ - pip install -r requirements.txt; \ - # for development, install extra stuff - pip install black pylint ipython jupyter markdown gemmi; \ - tar zxf pdbx.tar.gz -C /usr/local/lib64/python3.8/site-packages; \ - # python-ihm and -modelcif - git clone https://github.com/ihmwg/python-ihm.git ihm.git; \ - cd ihm.git; \ - python3 setup.py build; \ - python3 setup.py install; \ - rm -rf ${SRC_DIR}/ihm.git; \ - cd ${SRC_DIR}; \ - git clone https://github.com/ihmwg/python-modelcif.git modelcif.git; \ - cd modelcif.git; \ - python3 setup.py build; \ - python3 setup.py install; \ - rm -rf ${SRC_DIR}/modelcif.git; \ - apt-get remove -y git pip; \ - rm ${SRC_DIR}/requirements.txt ${SRC_DIR}/pdbx.tar.gz - -# had issues with older docker version on managed centos box... - -# NOTEBOOK ENV -ENV DNG_ROOT=$OST_ROOT -ENV DNG_INITDIR=${DNG_ROOT}/lib64/python3.8/site-packages/ost - -# standard entry point ipython -RUN echo 'alias ost_ipython="ipython -i $DNG_INITDIR/ost_startup.py"' >> ~/.bashrc - -ENTRYPOINT bash diff --git a/projects/CoFFE-sponge-proteins/tests/Docker/Dockerfile_work b/projects/CoFFE-sponge-proteins/tests/Docker/Dockerfile_work deleted file mode 100644 index e84268271b382408c29a517b441c80bfc5f0cdb3..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/Docker/Dockerfile_work +++ /dev/null @@ -1,47 +0,0 @@ -ARG VERSION_OST="2.3.0" -FROM registry.scicore.unibas.ch/schwede/openstructure:${VERSION_OST} -# We need to declare ARGs again which were declared before the build stage -# (FROM directive), otherwise they won't be available in this stage. -ARG VERSION_OST - -## Set up environment -ENV SRC_DIR="/tmp" \ - VERSION_OST=${VERSION_OST} \ - PYTHONUNBUFFERED=1 \ - PYTHONDONTWRITEBYTECODE=1 - - -LABEL org.openstructure.base-image="${VERSION_OST}" -LABEL org.openstructure.translate2modelcif="2022-04-08.1" -LABEL maintainer="Stefan Bienert <stefan.bienert@unibas.ch>" -LABEL vendor1="Schwede Group (schwedelab.org)" -LABEL vendor2="SIB - Swiss Institute of Bioinformatics (sib.swiss)" -LABEL vendor3="Biozentrum - University of Basel (biozentrum.unibas.ch)" - - -## Install python-modelcif and python-ihm -COPY requirements.txt ${SRC_DIR} -WORKDIR ${SRC_DIR} -RUN set -e pipefail; \ - apt-get update -y; \ - # for development, install venv - apt-get install -y git pip python3.8-venv; \ - pip install -r requirements.txt; \ - # for development, install black & PyLint - pip install black pylint; \ - git clone https://github.com/ihmwg/python-ihm.git ihm.git; \ - cd ihm.git; \ - python3 setup.py build; \ - python3 setup.py install; \ - rm -rf ${SRC_DIR}/ihm.git; \ - cd ${SRC_DIR}; \ - git clone https://github.com/ihmwg/python-modelcif.git modelcif.git; \ - cd modelcif.git; \ - python3 setup.py build; \ - python3 setup.py install; \ - rm -rf ${SRC_DIR}/modelcif.git; \ - apt-get remove -y git pip - -# had issues with older docker version on managed centos box... - -ENTRYPOINT bash diff --git a/projects/CoFFE-sponge-proteins/tests/Docker/NOTES.txt b/projects/CoFFE-sponge-proteins/tests/Docker/NOTES.txt deleted file mode 100644 index edc2292f130adfdf6be01c3d4651236c65c481e3..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/Docker/NOTES.txt +++ /dev/null @@ -1,24 +0,0 @@ -Based on https://git.scicore.unibas.ch/schwede/ma-wilkins-import/-/tree/develop/ - ------------------------------------- -GT versions of Docker: -- Dockerfile_work: simplified stuff to make it work on old docker version on CentOS box --> use Ctrl-P + Ctrl-Q to detach without closing bash and run in background... --> "docker ps -a" and "docker attach <NAME>" to get back in and "docker logs [--tail N] <NAME>" to see output -- Dockerfile_GT: added extra libraries and ost_ipython alias for convenience --> pdbx.tar.gz is PDBx Python Parser as in MA (original adapted for py3) --> NOTE: pdbx.tar.gz outdated by now, but ok (not used in the end anyway) ------------------------------------- -docker build -f Dockerfile_GT -t modelcif_test . -(change Dockerfile_GT to Dockerfile_work on CentOS box) -docker run --rm -ti -v "$(pwd)":/tmp modelcif_test --> can use "ost_ipython" in there -docker run --rm -ti -v "$(pwd)":/tmp -p 8888:8888 --entrypoint jupyter modelcif_test notebook --ip 0.0.0.0 --no-browser --allow-root - ------------------------------------- -Original instructions from Bienchen: ------------------------------------- -docker build -t matranslator:2022-07-18.1 . -docker run --rm -i -v /Users/stefan/.bash_profile:/home/mmcif/.bash_profile -v /Users/stefan/.bash_aliases:/home/mmcif/.bash_aliases -v /Users/stefan/.bashrc:/home/mmcif/.bashrc -v /Users/stefan/Projects/ma-wilkins-import.git:/data -v /Users/stefan/Projects/ma-wilkins-import.git/.docker-bash-history:/home/mmcif/.bash_history -t matranslator:2022-07-18.1 bash -ost translate2modelcif.py A0A1B0GTU1-O75152/ ------------------------------------- diff --git a/projects/CoFFE-sponge-proteins/tests/Docker/pdbx.tar.gz b/projects/CoFFE-sponge-proteins/tests/Docker/pdbx.tar.gz deleted file mode 100644 index 7f5eeb918722efc3321527fb9ed7decea13d7ec4..0000000000000000000000000000000000000000 Binary files a/projects/CoFFE-sponge-proteins/tests/Docker/pdbx.tar.gz and /dev/null differ diff --git a/projects/CoFFE-sponge-proteins/tests/Docker/requirements.txt b/projects/CoFFE-sponge-proteins/tests/Docker/requirements.txt deleted file mode 100644 index 2abd7d3a956e774cb5b3d3765de5e9b9d66f2d96..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/Docker/requirements.txt +++ /dev/null @@ -1,2 +0,0 @@ -requests -ujson diff --git a/projects/CoFFE-sponge-proteins/tests/test.html b/projects/CoFFE-sponge-proteins/tests/test.html deleted file mode 100644 index 853fd59e16a07ad8ccedfe5382a7820492710bbc..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/test.html +++ /dev/null @@ -1,17126 +0,0 @@ -<!DOCTYPE html> -<html> -<head><meta charset="utf-8" /> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>test</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script> - - - - -<style type="text/css"> - pre { line-height: 125%; } -td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } -span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } -td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } -span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } -.highlight .hll { background-color: var(--jp-cell-editor-active-background) } -.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) } -.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */ -.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */ -.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */ -.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */ -.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */ -.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */ -.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */ -.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */ -.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */ -.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */ -.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */ -.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */ -.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */ -.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */ -.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */ -.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */ -.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */ -.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */ -.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */ -.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */ -.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */ -.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */ -.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */ -.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */ -.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */ -.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */ -.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */ -.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */ -.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */ -.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */ -.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */ -.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */ -.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */ -.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */ -.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */ -.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */ -.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */ -.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */ -.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */ -.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */ - </style> - - - -<style type="text/css"> -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* - * Mozilla scrollbar styling - */ - -/* use standard opaque scrollbars for most nodes */ -[data-jp-theme-scrollbars='true'] { - scrollbar-color: rgb(var(--jp-scrollbar-thumb-color)) - var(--jp-scrollbar-background-color); -} - -/* for code nodes, use a transparent style of scrollbar. These selectors - * will match lower in the tree, and so will override the above */ -[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar, -[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar { - scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; -} - -/* tiny scrollbar */ - -.jp-scrollbar-tiny { - scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; - scrollbar-width: thin; -} - -/* - * Webkit scrollbar styling - */ - -/* use standard opaque scrollbars for most nodes */ - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-corner { - background: var(--jp-scrollbar-background-color); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-thumb { - background: rgb(var(--jp-scrollbar-thumb-color)); - border: var(--jp-scrollbar-thumb-margin) solid transparent; - background-clip: content-box; - border-radius: var(--jp-scrollbar-thumb-radius); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:horizontal { - border-left: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); - border-right: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:vertical { - border-top: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); - border-bottom: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); -} - -/* for code nodes, use a transparent style of scrollbar */ - -[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-corner, -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-corner { - background-color: transparent; -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-thumb, -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-thumb { - background: rgba(var(--jp-scrollbar-thumb-color), 0.5); - border: var(--jp-scrollbar-thumb-margin) solid transparent; - background-clip: content-box; - border-radius: var(--jp-scrollbar-thumb-radius); -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-track:horizontal { - border-left: var(--jp-scrollbar-endpad) solid transparent; - border-right: var(--jp-scrollbar-endpad) solid transparent; -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-track:vertical { - border-top: var(--jp-scrollbar-endpad) solid transparent; - border-bottom: var(--jp-scrollbar-endpad) solid transparent; -} - -/* tiny scrollbar */ - -.jp-scrollbar-tiny::-webkit-scrollbar, -.jp-scrollbar-tiny::-webkit-scrollbar-corner { - background-color: transparent; - height: 4px; - width: 4px; -} - -.jp-scrollbar-tiny::-webkit-scrollbar-thumb { - background: rgba(var(--jp-scrollbar-thumb-color), 0.5); -} - -.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal { - border-left: 0px solid transparent; - border-right: 0px solid transparent; -} - -.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical { - border-top: 0px solid transparent; - border-bottom: 0px solid transparent; -} - -/* - * Phosphor - */ - -.lm-ScrollBar[data-orientation='horizontal'] { - min-height: 16px; - max-height: 16px; - min-width: 45px; - border-top: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='vertical'] { - min-width: 16px; - max-width: 16px; - min-height: 45px; - border-left: 1px solid #a0a0a0; -} - -.lm-ScrollBar-button { - background-color: #f0f0f0; - background-position: center center; - min-height: 15px; - max-height: 15px; - min-width: 15px; - max-width: 15px; -} - -.lm-ScrollBar-button:hover { - background-color: #dadada; -} - -.lm-ScrollBar-button.lm-mod-active { - background-color: #cdcdcd; -} - -.lm-ScrollBar-track { - background: #f0f0f0; -} - -.lm-ScrollBar-thumb { - background: #cdcdcd; -} - -.lm-ScrollBar-thumb:hover { - background: #bababa; -} - -.lm-ScrollBar-thumb.lm-mod-active { - background: #a0a0a0; -} - -.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb { - height: 100%; - min-width: 15px; - border-left: 1px solid #a0a0a0; - border-right: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb { - width: 100%; - min-height: 15px; - border-top: 1px solid #a0a0a0; - border-bottom: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='horizontal'] - .lm-ScrollBar-button[data-action='decrement'] { - background-image: var(--jp-icon-caret-left); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='horizontal'] - .lm-ScrollBar-button[data-action='increment'] { - background-image: var(--jp-icon-caret-right); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='vertical'] - .lm-ScrollBar-button[data-action='decrement'] { - background-image: var(--jp-icon-caret-up); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='vertical'] - .lm-ScrollBar-button[data-action='increment'] { - background-image: var(--jp-icon-caret-down); - background-size: 17px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-Widget, /* </DEPRECATED> */ -.lm-Widget { - box-sizing: border-box; - position: relative; - overflow: hidden; - cursor: default; -} - - -/* <DEPRECATED> */ .p-Widget.p-mod-hidden, /* </DEPRECATED> */ -.lm-Widget.lm-mod-hidden { - display: none !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-CommandPalette, /* </DEPRECATED> */ -.lm-CommandPalette { - display: flex; - flex-direction: column; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-CommandPalette-search, /* </DEPRECATED> */ -.lm-CommandPalette-search { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-content, /* </DEPRECATED> */ -.lm-CommandPalette-content { - flex: 1 1 auto; - margin: 0; - padding: 0; - min-height: 0; - overflow: auto; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p-CommandPalette-header, /* </DEPRECATED> */ -.lm-CommandPalette-header { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - - -/* <DEPRECATED> */ .p-CommandPalette-item, /* </DEPRECATED> */ -.lm-CommandPalette-item { - display: flex; - flex-direction: row; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemIcon, /* </DEPRECATED> */ -.lm-CommandPalette-itemIcon { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemContent, /* </DEPRECATED> */ -.lm-CommandPalette-itemContent { - flex: 1 1 auto; - overflow: hidden; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemShortcut, /* </DEPRECATED> */ -.lm-CommandPalette-itemShortcut { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemLabel, /* </DEPRECATED> */ -.lm-CommandPalette-itemLabel { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.lm-close-icon { - border:1px solid transparent; - background-color: transparent; - position: absolute; - z-index:1; - right:3%; - top: 0; - bottom: 0; - margin: auto; - padding: 7px 0; - display: none; - vertical-align: middle; - outline: 0; - cursor: pointer; -} -.lm-close-icon:after { - content: "X"; - display: block; - width: 15px; - height: 15px; - text-align: center; - color:#000; - font-weight: normal; - font-size: 12px; - cursor: pointer; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-DockPanel, /* </DEPRECATED> */ -.lm-DockPanel { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-DockPanel-widget, /* </DEPRECATED> */ -.lm-DockPanel-widget { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-DockPanel-tabBar, /* </DEPRECATED> */ -.lm-DockPanel-tabBar { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle, /* </DEPRECATED> */ -.lm-DockPanel-handle { - z-index: 2; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle.p-mod-hidden, /* </DEPRECATED> */ -.lm-DockPanel-handle.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle:after, /* </DEPRECATED> */ -.lm-DockPanel-handle:after { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='horizontal'], -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='horizontal'] { - cursor: ew-resize; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='vertical'], -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='vertical'] { - cursor: ns-resize; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='horizontal']:after, -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='horizontal']:after { - left: 50%; - min-width: 8px; - transform: translateX(-50%); -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='vertical']:after, -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='vertical']:after { - top: 50%; - min-height: 8px; - transform: translateY(-50%); -} - - -/* <DEPRECATED> */ .p-DockPanel-overlay, /* </DEPRECATED> */ -.lm-DockPanel-overlay { - z-index: 3; - box-sizing: border-box; - pointer-events: none; -} - - -/* <DEPRECATED> */ .p-DockPanel-overlay.p-mod-hidden, /* </DEPRECATED> */ -.lm-DockPanel-overlay.lm-mod-hidden { - display: none !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-Menu, /* </DEPRECATED> */ -.lm-Menu { - z-index: 10000; - position: absolute; - white-space: nowrap; - overflow-x: hidden; - overflow-y: auto; - outline: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-Menu-content, /* </DEPRECATED> */ -.lm-Menu-content { - margin: 0; - padding: 0; - display: table; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p-Menu-item, /* </DEPRECATED> */ -.lm-Menu-item { - display: table-row; -} - - -/* <DEPRECATED> */ -.p-Menu-item.p-mod-hidden, -.p-Menu-item.p-mod-collapsed, -/* </DEPRECATED> */ -.lm-Menu-item.lm-mod-hidden, -.lm-Menu-item.lm-mod-collapsed { - display: none !important; -} - - -/* <DEPRECATED> */ -.p-Menu-itemIcon, -.p-Menu-itemSubmenuIcon, -/* </DEPRECATED> */ -.lm-Menu-itemIcon, -.lm-Menu-itemSubmenuIcon { - display: table-cell; - text-align: center; -} - - -/* <DEPRECATED> */ .p-Menu-itemLabel, /* </DEPRECATED> */ -.lm-Menu-itemLabel { - display: table-cell; - text-align: left; -} - - -/* <DEPRECATED> */ .p-Menu-itemShortcut, /* </DEPRECATED> */ -.lm-Menu-itemShortcut { - display: table-cell; - text-align: right; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-MenuBar, /* </DEPRECATED> */ -.lm-MenuBar { - outline: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-MenuBar-content, /* </DEPRECATED> */ -.lm-MenuBar-content { - margin: 0; - padding: 0; - display: flex; - flex-direction: row; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p--MenuBar-item, /* </DEPRECATED> */ -.lm-MenuBar-item { - box-sizing: border-box; -} - - -/* <DEPRECATED> */ -.p-MenuBar-itemIcon, -.p-MenuBar-itemLabel, -/* </DEPRECATED> */ -.lm-MenuBar-itemIcon, -.lm-MenuBar-itemLabel { - display: inline-block; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-ScrollBar, /* </DEPRECATED> */ -.lm-ScrollBar { - display: flex; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ -.p-ScrollBar[data-orientation='horizontal'], -/* </DEPRECATED> */ -.lm-ScrollBar[data-orientation='horizontal'] { - flex-direction: row; -} - - -/* <DEPRECATED> */ -.p-ScrollBar[data-orientation='vertical'], -/* </DEPRECATED> */ -.lm-ScrollBar[data-orientation='vertical'] { - flex-direction: column; -} - - -/* <DEPRECATED> */ .p-ScrollBar-button, /* </DEPRECATED> */ -.lm-ScrollBar-button { - box-sizing: border-box; - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-ScrollBar-track, /* </DEPRECATED> */ -.lm-ScrollBar-track { - box-sizing: border-box; - position: relative; - overflow: hidden; - flex: 1 1 auto; -} - - -/* <DEPRECATED> */ .p-ScrollBar-thumb, /* </DEPRECATED> */ -.lm-ScrollBar-thumb { - box-sizing: border-box; - position: absolute; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-SplitPanel-child, /* </DEPRECATED> */ -.lm-SplitPanel-child { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle, /* </DEPRECATED> */ -.lm-SplitPanel-handle { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle.p-mod-hidden, /* </DEPRECATED> */ -.lm-SplitPanel-handle.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle:after, /* </DEPRECATED> */ -.lm-SplitPanel-handle:after { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle { - cursor: ew-resize; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle { - cursor: ns-resize; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle:after, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after { - left: 50%; - min-width: 8px; - transform: translateX(-50%); -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle:after, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after { - top: 50%; - min-height: 8px; - transform: translateY(-50%); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-TabBar, /* </DEPRECATED> */ -.lm-TabBar { - display: flex; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-TabBar[data-orientation='horizontal'], /* </DEPRECATED> */ -.lm-TabBar[data-orientation='horizontal'] { - flex-direction: row; - align-items: flex-end; -} - - -/* <DEPRECATED> */ .p-TabBar[data-orientation='vertical'], /* </DEPRECATED> */ -.lm-TabBar[data-orientation='vertical'] { - flex-direction: column; - align-items: flex-end; -} - - -/* <DEPRECATED> */ .p-TabBar-content, /* </DEPRECATED> */ -.lm-TabBar-content { - margin: 0; - padding: 0; - display: flex; - flex: 1 1 auto; - list-style-type: none; -} - - -/* <DEPRECATED> */ -.p-TabBar[data-orientation='horizontal'] > .p-TabBar-content, -/* </DEPRECATED> */ -.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content { - flex-direction: row; -} - - -/* <DEPRECATED> */ -.p-TabBar[data-orientation='vertical'] > .p-TabBar-content, -/* </DEPRECATED> */ -.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content { - flex-direction: column; -} - - -/* <DEPRECATED> */ .p-TabBar-tab, /* </DEPRECATED> */ -.lm-TabBar-tab { - display: flex; - flex-direction: row; - box-sizing: border-box; - overflow: hidden; -} - - -/* <DEPRECATED> */ -.p-TabBar-tabIcon, -.p-TabBar-tabCloseIcon, -/* </DEPRECATED> */ -.lm-TabBar-tabIcon, -.lm-TabBar-tabCloseIcon { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-TabBar-tabLabel, /* </DEPRECATED> */ -.lm-TabBar-tabLabel { - flex: 1 1 auto; - overflow: hidden; - white-space: nowrap; -} - - -.lm-TabBar-tabInput { - user-select: all; - width: 100%; - box-sizing : border-box; -} - - -/* <DEPRECATED> */ .p-TabBar-tab.p-mod-hidden, /* </DEPRECATED> */ -.lm-TabBar-tab.lm-mod-hidden { - display: none !important; -} - - -.lm-TabBar-addButton.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-TabBar.p-mod-dragging .p-TabBar-tab, /* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging .lm-TabBar-tab { - position: relative; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab { - left: 0; - transition: left 150ms ease; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab { - top: 0; - transition: top 150ms ease; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging { - transition: none; -} - -.lm-TabBar-tabLabel .lm-TabBar-tabInput { - user-select: all; - width: 100%; - box-sizing : border-box; - background: inherit; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-TabPanel-tabBar, /* </DEPRECATED> */ -.lm-TabPanel-tabBar { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-TabPanel-stackedPanel, /* </DEPRECATED> */ -.lm-TabPanel-stackedPanel { - z-index: 0; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - -@charset "UTF-8"; -html{ - -webkit-box-sizing:border-box; - box-sizing:border-box; } - -*, -*::before, -*::after{ - -webkit-box-sizing:inherit; - box-sizing:inherit; } - -body{ - font-size:14px; - font-weight:400; - letter-spacing:0; - line-height:1.28581; - text-transform:none; - color:#182026; - font-family:-apple-system, "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", "Icons16", sans-serif; } - -p{ - margin-bottom:10px; - margin-top:0; } - -small{ - font-size:12px; } - -strong{ - font-weight:600; } - -::-moz-selection{ - background:rgba(125, 188, 255, 0.6); } - -::selection{ - background:rgba(125, 188, 255, 0.6); } -.bp3-heading{ - color:#182026; - font-weight:600; - margin:0 0 10px; - padding:0; } - .bp3-dark .bp3-heading{ - color:#f5f8fa; } - -h1.bp3-heading, .bp3-running-text h1{ - font-size:36px; - line-height:40px; } - -h2.bp3-heading, .bp3-running-text h2{ - font-size:28px; - line-height:32px; } - -h3.bp3-heading, .bp3-running-text h3{ - font-size:22px; - line-height:25px; } - -h4.bp3-heading, .bp3-running-text h4{ - font-size:18px; - line-height:21px; } - -h5.bp3-heading, .bp3-running-text h5{ - font-size:16px; - line-height:19px; } - -h6.bp3-heading, .bp3-running-text h6{ - font-size:14px; - line-height:16px; } -.bp3-ui-text{ - font-size:14px; - font-weight:400; - letter-spacing:0; - line-height:1.28581; - text-transform:none; } - -.bp3-monospace-text{ - font-family:monospace; - text-transform:none; } - -.bp3-text-muted{ - color:#5c7080; } - .bp3-dark .bp3-text-muted{ - color:#a7b6c2; } - -.bp3-text-disabled{ - color:rgba(92, 112, 128, 0.6); } - .bp3-dark .bp3-text-disabled{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-text-overflow-ellipsis{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; } -.bp3-running-text{ - font-size:14px; - line-height:1.5; } - .bp3-running-text h1{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h1{ - color:#f5f8fa; } - .bp3-running-text h2{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h2{ - color:#f5f8fa; } - .bp3-running-text h3{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h3{ - color:#f5f8fa; } - .bp3-running-text h4{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h4{ - color:#f5f8fa; } - .bp3-running-text h5{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h5{ - color:#f5f8fa; } - .bp3-running-text h6{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h6{ - color:#f5f8fa; } - .bp3-running-text hr{ - border:none; - border-bottom:1px solid rgba(16, 22, 26, 0.15); - margin:20px 0; } - .bp3-dark .bp3-running-text hr{ - border-color:rgba(255, 255, 255, 0.15); } - .bp3-running-text p{ - margin:0 0 10px; - padding:0; } - -.bp3-text-large{ - font-size:16px; } - -.bp3-text-small{ - font-size:12px; } -a{ - color:#106ba3; - text-decoration:none; } - a:hover{ - color:#106ba3; - cursor:pointer; - text-decoration:underline; } - a .bp3-icon, a .bp3-icon-standard, a .bp3-icon-large{ - color:inherit; } - a code, - .bp3-dark a code{ - color:inherit; } - .bp3-dark a, - .bp3-dark a:hover{ - color:#48aff0; } - .bp3-dark a .bp3-icon, .bp3-dark a .bp3-icon-standard, .bp3-dark a .bp3-icon-large, - .bp3-dark a:hover .bp3-icon, - .bp3-dark a:hover .bp3-icon-standard, - .bp3-dark a:hover .bp3-icon-large{ - color:inherit; } -.bp3-running-text code, .bp3-code{ - font-family:monospace; - text-transform:none; - background:rgba(255, 255, 255, 0.7); - border-radius:3px; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2); - color:#5c7080; - font-size:smaller; - padding:2px 5px; } - .bp3-dark .bp3-running-text code, .bp3-running-text .bp3-dark code, .bp3-dark .bp3-code{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - color:#a7b6c2; } - .bp3-running-text a > code, a > .bp3-code{ - color:#137cbd; } - .bp3-dark .bp3-running-text a > code, .bp3-running-text .bp3-dark a > code, .bp3-dark a > .bp3-code{ - color:inherit; } - -.bp3-running-text pre, .bp3-code-block{ - font-family:monospace; - text-transform:none; - background:rgba(255, 255, 255, 0.7); - border-radius:3px; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - color:#182026; - display:block; - font-size:13px; - line-height:1.4; - margin:10px 0; - padding:13px 15px 12px; - word-break:break-all; - word-wrap:break-word; } - .bp3-dark .bp3-running-text pre, .bp3-running-text .bp3-dark pre, .bp3-dark .bp3-code-block{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-running-text pre > code, .bp3-code-block > code{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; - font-size:inherit; - padding:0; } - -.bp3-running-text kbd, .bp3-key{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - color:#5c7080; - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - font-family:inherit; - font-size:12px; - height:24px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - line-height:24px; - min-width:24px; - padding:3px 6px; - vertical-align:middle; } - .bp3-running-text kbd .bp3-icon, .bp3-key .bp3-icon, .bp3-running-text kbd .bp3-icon-standard, .bp3-key .bp3-icon-standard, .bp3-running-text kbd .bp3-icon-large, .bp3-key .bp3-icon-large{ - margin-right:5px; } - .bp3-dark .bp3-running-text kbd, .bp3-running-text .bp3-dark kbd, .bp3-dark .bp3-key{ - background:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - color:#a7b6c2; } -.bp3-running-text blockquote, .bp3-blockquote{ - border-left:solid 4px rgba(167, 182, 194, 0.5); - margin:0 0 10px; - padding:0 20px; } - .bp3-dark .bp3-running-text blockquote, .bp3-running-text .bp3-dark blockquote, .bp3-dark .bp3-blockquote{ - border-color:rgba(115, 134, 148, 0.5); } -.bp3-running-text ul, -.bp3-running-text ol, .bp3-list{ - margin:10px 0; - padding-left:30px; } - .bp3-running-text ul li:not(:last-child), .bp3-running-text ol li:not(:last-child), .bp3-list li:not(:last-child){ - margin-bottom:5px; } - .bp3-running-text ul ol, .bp3-running-text ol ol, .bp3-list ol, - .bp3-running-text ul ul, - .bp3-running-text ol ul, - .bp3-list ul{ - margin-top:5px; } - -.bp3-list-unstyled{ - list-style:none; - margin:0; - padding:0; } - .bp3-list-unstyled li{ - padding:0; } -.bp3-rtl{ - text-align:right; } - -.bp3-dark{ - color:#f5f8fa; } - -:focus{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:2px; - -moz-outline-radius:6px; } - -.bp3-focus-disabled :focus{ - outline:none !important; } - .bp3-focus-disabled :focus ~ .bp3-control-indicator{ - outline:none !important; } - -.bp3-alert{ - max-width:400px; - padding:20px; } - -.bp3-alert-body{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-alert-body .bp3-icon{ - font-size:40px; - margin-right:20px; - margin-top:0; } - -.bp3-alert-contents{ - word-break:break-word; } - -.bp3-alert-footer{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:reverse; - -ms-flex-direction:row-reverse; - flex-direction:row-reverse; - margin-top:10px; } - .bp3-alert-footer .bp3-button{ - margin-left:10px; } -.bp3-breadcrumbs{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - cursor:default; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-wrap:wrap; - flex-wrap:wrap; - height:30px; - list-style:none; - margin:0; - padding:0; } - .bp3-breadcrumbs > li{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-breadcrumbs > li::after{ - background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.71 7.29l-4-4a1.003 1.003 0 00-1.42 1.42L8.59 8 5.3 11.29c-.19.18-.3.43-.3.71a1.003 1.003 0 001.71.71l4-4c.18-.18.29-.43.29-.71 0-.28-.11-.53-.29-.71z' fill='%235C7080'/%3e%3c/svg%3e"); - content:""; - display:block; - height:16px; - margin:0 5px; - width:16px; } - .bp3-breadcrumbs > li:last-of-type::after{ - display:none; } - -.bp3-breadcrumb, -.bp3-breadcrumb-current, -.bp3-breadcrumbs-collapsed{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - font-size:16px; } - -.bp3-breadcrumb, -.bp3-breadcrumbs-collapsed{ - color:#5c7080; } - -.bp3-breadcrumb:hover{ - text-decoration:none; } - -.bp3-breadcrumb.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-breadcrumb .bp3-icon{ - margin-right:5px; } - -.bp3-breadcrumb-current{ - color:inherit; - font-weight:600; } - .bp3-breadcrumb-current .bp3-input{ - font-size:inherit; - font-weight:inherit; - vertical-align:baseline; } - -.bp3-breadcrumbs-collapsed{ - background:#ced9e0; - border:none; - border-radius:3px; - cursor:pointer; - margin-right:2px; - padding:1px 5px; - vertical-align:text-bottom; } - .bp3-breadcrumbs-collapsed::before{ - background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cg fill='%235C7080'%3e%3ccircle cx='2' cy='8.03' r='2'/%3e%3ccircle cx='14' cy='8.03' r='2'/%3e%3ccircle cx='8' cy='8.03' r='2'/%3e%3c/g%3e%3c/svg%3e") center no-repeat; - content:""; - display:block; - height:16px; - width:16px; } - .bp3-breadcrumbs-collapsed:hover{ - background:#bfccd6; - color:#182026; - text-decoration:none; } - -.bp3-dark .bp3-breadcrumb, -.bp3-dark .bp3-breadcrumbs-collapsed{ - color:#a7b6c2; } - -.bp3-dark .bp3-breadcrumbs > li::after{ - color:#a7b6c2; } - -.bp3-dark .bp3-breadcrumb.bp3-disabled{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-dark .bp3-breadcrumb-current{ - color:#f5f8fa; } - -.bp3-dark .bp3-breadcrumbs-collapsed{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-breadcrumbs-collapsed:hover{ - background:rgba(16, 22, 26, 0.6); - color:#f5f8fa; } -.bp3-button{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border:none; - border-radius:3px; - cursor:pointer; - font-size:14px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - padding:5px 10px; - text-align:left; - vertical-align:middle; - min-height:30px; - min-width:30px; } - .bp3-button > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-button > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-button::before, - .bp3-button > *{ - margin-right:7px; } - .bp3-button:empty::before, - .bp3-button > :last-child{ - margin-right:0; } - .bp3-button:empty{ - padding:0 !important; } - .bp3-button:disabled, .bp3-button.bp3-disabled{ - cursor:not-allowed; } - .bp3-button.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-button.bp3-align-right, - .bp3-align-right .bp3-button{ - text-align:right; } - .bp3-button.bp3-align-left, - .bp3-align-left .bp3-button{ - text-align:left; } - .bp3-button:not([class*="bp3-intent-"]){ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; } - .bp3-button:not([class*="bp3-intent-"]):hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-button:not([class*="bp3-intent-"]):active, .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active:hover, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-button.bp3-intent-primary{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-primary:hover, .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-primary:hover{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{ - background-color:#0e5a8a; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-primary:disabled, .bp3-button.bp3-intent-primary.bp3-disabled{ - background-color:rgba(19, 124, 189, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-success{ - background-color:#0f9960; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-success:hover, .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-success:hover{ - background-color:#0d8050; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{ - background-color:#0a6640; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-success:disabled, .bp3-button.bp3-intent-success.bp3-disabled{ - background-color:rgba(15, 153, 96, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-warning{ - background-color:#d9822b; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-warning:hover, .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-warning:hover{ - background-color:#bf7326; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{ - background-color:#a66321; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-warning:disabled, .bp3-button.bp3-intent-warning.bp3-disabled{ - background-color:rgba(217, 130, 43, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-danger{ - background-color:#db3737; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-danger:hover, .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-danger:hover{ - background-color:#c23030; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{ - background-color:#a82a2a; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-danger:disabled, .bp3-button.bp3-intent-danger.bp3-disabled{ - background-color:rgba(219, 55, 55, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{ - stroke:#ffffff; } - .bp3-button.bp3-large, - .bp3-large .bp3-button{ - min-height:40px; - min-width:40px; - font-size:16px; - padding:5px 15px; } - .bp3-button.bp3-large::before, - .bp3-button.bp3-large > *, - .bp3-large .bp3-button::before, - .bp3-large .bp3-button > *{ - margin-right:10px; } - .bp3-button.bp3-large:empty::before, - .bp3-button.bp3-large > :last-child, - .bp3-large .bp3-button:empty::before, - .bp3-large .bp3-button > :last-child{ - margin-right:0; } - .bp3-button.bp3-small, - .bp3-small .bp3-button{ - min-height:24px; - min-width:24px; - padding:0 7px; } - .bp3-button.bp3-loading{ - position:relative; } - .bp3-button.bp3-loading[class*="bp3-icon-"]::before{ - visibility:hidden; } - .bp3-button.bp3-loading .bp3-button-spinner{ - margin:0; - position:absolute; } - .bp3-button.bp3-loading > :not(.bp3-button-spinner){ - visibility:hidden; } - .bp3-button[class*="bp3-icon-"]::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - color:#5c7080; } - .bp3-button .bp3-icon, .bp3-button .bp3-icon-standard, .bp3-button .bp3-icon-large{ - color:#5c7080; } - .bp3-button .bp3-icon.bp3-align-right, .bp3-button .bp3-icon-standard.bp3-align-right, .bp3-button .bp3-icon-large.bp3-align-right{ - margin-left:7px; } - .bp3-button .bp3-icon:first-child:last-child, - .bp3-button .bp3-spinner + .bp3-icon:last-child{ - margin:0 -7px; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]){ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover, .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"])[class*="bp3-icon-"]::before{ - color:#a7b6c2; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-large{ - color:#a7b6c2; } - .bp3-dark .bp3-button[class*="bp3-intent-"]{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:active, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:disabled, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-disabled{ - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.3); } - .bp3-dark .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{ - stroke:#8a9ba8; } - .bp3-button:disabled::before, - .bp3-button:disabled .bp3-icon, .bp3-button:disabled .bp3-icon-standard, .bp3-button:disabled .bp3-icon-large, .bp3-button.bp3-disabled::before, - .bp3-button.bp3-disabled .bp3-icon, .bp3-button.bp3-disabled .bp3-icon-standard, .bp3-button.bp3-disabled .bp3-icon-large, .bp3-button[class*="bp3-intent-"]::before, - .bp3-button[class*="bp3-intent-"] .bp3-icon, .bp3-button[class*="bp3-intent-"] .bp3-icon-standard, .bp3-button[class*="bp3-intent-"] .bp3-icon-large{ - color:inherit !important; } - .bp3-button.bp3-minimal{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-button.bp3-minimal:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button.bp3-minimal:active, .bp3-button.bp3-minimal.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button.bp3-minimal:disabled, .bp3-button.bp3-minimal:disabled:hover, .bp3-button.bp3-minimal.bp3-disabled, .bp3-button.bp3-minimal.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button.bp3-minimal{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button.bp3-minimal:hover, .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button.bp3-minimal:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button.bp3-minimal:disabled, .bp3-dark .bp3-button.bp3-minimal:disabled:hover, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-primary{ - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:hover, .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-success{ - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:hover, .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-warning{ - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:hover, .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-danger{ - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:hover, .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - border:1px solid rgba(24, 32, 38, 0.2); - -webkit-box-sizing:border-box; - box-sizing:border-box; } - .bp3-button.bp3-outlined:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button.bp3-outlined:active, .bp3-button.bp3-outlined.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button.bp3-outlined{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button.bp3-outlined:hover, .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button.bp3-outlined:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-primary{ - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:hover, .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-success{ - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:hover, .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-warning{ - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:hover, .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-danger{ - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:hover, .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled:hover{ - border-color:rgba(92, 112, 128, 0.1); } - .bp3-dark .bp3-button.bp3-outlined{ - border-color:rgba(255, 255, 255, 0.4); } - .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{ - border-color:rgba(255, 255, 255, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-primary{ - border-color:rgba(16, 107, 163, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - border-color:rgba(16, 107, 163, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{ - border-color:rgba(72, 175, 240, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - border-color:rgba(72, 175, 240, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-success{ - border-color:rgba(13, 128, 80, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - border-color:rgba(13, 128, 80, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{ - border-color:rgba(61, 204, 145, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - border-color:rgba(61, 204, 145, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-warning{ - border-color:rgba(191, 115, 38, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - border-color:rgba(191, 115, 38, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{ - border-color:rgba(255, 179, 102, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - border-color:rgba(255, 179, 102, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-danger{ - border-color:rgba(194, 48, 48, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - border-color:rgba(194, 48, 48, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{ - border-color:rgba(255, 115, 115, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - border-color:rgba(255, 115, 115, 0.2); } - -a.bp3-button{ - text-align:center; - text-decoration:none; - -webkit-transition:none; - transition:none; } - a.bp3-button, a.bp3-button:hover, a.bp3-button:active{ - color:#182026; } - a.bp3-button.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); } - -.bp3-button-text{ - -webkit-box-flex:0; - -ms-flex:0 1 auto; - flex:0 1 auto; } - -.bp3-button.bp3-align-left .bp3-button-text, .bp3-button.bp3-align-right .bp3-button-text, -.bp3-button-group.bp3-align-left .bp3-button-text, -.bp3-button-group.bp3-align-right .bp3-button-text{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } -.bp3-button-group{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; } - .bp3-button-group .bp3-button{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - position:relative; - z-index:4; } - .bp3-button-group .bp3-button:focus{ - z-index:5; } - .bp3-button-group .bp3-button:hover{ - z-index:6; } - .bp3-button-group .bp3-button:active, .bp3-button-group .bp3-button.bp3-active{ - z-index:7; } - .bp3-button-group .bp3-button:disabled, .bp3-button-group .bp3-button.bp3-disabled{ - z-index:3; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]{ - z-index:9; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:focus{ - z-index:10; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:hover{ - z-index:11; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:active, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-active{ - z-index:12; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:disabled, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-disabled{ - z-index:8; } - .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:first-child) .bp3-button, - .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:first-child){ - border-bottom-left-radius:0; - border-top-left-radius:0; } - .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){ - border-bottom-right-radius:0; - border-top-right-radius:0; - margin-right:-1px; } - .bp3-button-group.bp3-minimal .bp3-button{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-button-group.bp3-minimal .bp3-button:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{ - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{ - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{ - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{ - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button-group .bp3-popover-wrapper, - .bp3-button-group .bp3-popover-target{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-button-group.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-button-group .bp3-button.bp3-fill, - .bp3-button-group.bp3-fill .bp3-button:not(.bp3-fixed){ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-button-group.bp3-vertical{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - vertical-align:top; } - .bp3-button-group.bp3-vertical.bp3-fill{ - height:100%; - width:unset; } - .bp3-button-group.bp3-vertical .bp3-button{ - margin-right:0 !important; - width:100%; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:first-child .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:first-child{ - border-radius:3px 3px 0 0; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:last-child .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:last-child{ - border-radius:0 0 3px 3px; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:not(:last-child){ - margin-bottom:-1px; } - .bp3-button-group.bp3-align-left .bp3-button{ - text-align:left; } - .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){ - margin-right:1px; } - .bp3-dark .bp3-button-group.bp3-vertical > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-dark .bp3-button-group.bp3-vertical > .bp3-button:not(:last-child){ - margin-bottom:1px; } -.bp3-callout{ - font-size:14px; - line-height:1.5; - background-color:rgba(138, 155, 168, 0.15); - border-radius:3px; - padding:10px 12px 9px; - position:relative; - width:100%; } - .bp3-callout[class*="bp3-icon-"]{ - padding-left:40px; } - .bp3-callout[class*="bp3-icon-"]::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - color:#5c7080; - left:10px; - position:absolute; - top:10px; } - .bp3-callout.bp3-callout-icon{ - padding-left:40px; } - .bp3-callout.bp3-callout-icon > .bp3-icon:first-child{ - color:#5c7080; - left:10px; - position:absolute; - top:10px; } - .bp3-callout .bp3-heading{ - line-height:20px; - margin-bottom:5px; - margin-top:0; } - .bp3-callout .bp3-heading:last-child{ - margin-bottom:0; } - .bp3-dark .bp3-callout{ - background-color:rgba(138, 155, 168, 0.2); } - .bp3-dark .bp3-callout[class*="bp3-icon-"]::before{ - color:#a7b6c2; } - .bp3-callout.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.15); } - .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-primary > .bp3-icon:first-child, - .bp3-callout.bp3-intent-primary .bp3-heading{ - color:#106ba3; } - .bp3-dark .bp3-callout.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-primary > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-primary .bp3-heading{ - color:#48aff0; } - .bp3-callout.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.15); } - .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-success > .bp3-icon:first-child, - .bp3-callout.bp3-intent-success .bp3-heading{ - color:#0d8050; } - .bp3-dark .bp3-callout.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-success > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-success .bp3-heading{ - color:#3dcc91; } - .bp3-callout.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.15); } - .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-warning > .bp3-icon:first-child, - .bp3-callout.bp3-intent-warning .bp3-heading{ - color:#bf7326; } - .bp3-dark .bp3-callout.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-warning > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-warning .bp3-heading{ - color:#ffb366; } - .bp3-callout.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.15); } - .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-danger > .bp3-icon:first-child, - .bp3-callout.bp3-intent-danger .bp3-heading{ - color:#c23030; } - .bp3-dark .bp3-callout.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-danger > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-danger .bp3-heading{ - color:#ff7373; } - .bp3-running-text .bp3-callout{ - margin:20px 0; } -.bp3-card{ - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - padding:20px; - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-card.bp3-dark, - .bp3-dark .bp3-card{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - -.bp3-elevation-0{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - .bp3-elevation-0.bp3-dark, - .bp3-dark .bp3-elevation-0{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - -.bp3-elevation-1{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-elevation-1.bp3-dark, - .bp3-dark .bp3-elevation-1{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-2{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); } - .bp3-elevation-2.bp3-dark, - .bp3-dark .bp3-elevation-2{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-3{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); } - .bp3-elevation-3.bp3-dark, - .bp3-dark .bp3-elevation-3{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-4{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); } - .bp3-elevation-4.bp3-dark, - .bp3-dark .bp3-elevation-4{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); } - -.bp3-card.bp3-interactive:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - cursor:pointer; } - .bp3-card.bp3-interactive:hover.bp3-dark, - .bp3-dark .bp3-card.bp3-interactive:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - -.bp3-card.bp3-interactive:active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - opacity:0.9; - -webkit-transition-duration:0; - transition-duration:0; } - .bp3-card.bp3-interactive:active.bp3-dark, - .bp3-dark .bp3-card.bp3-interactive:active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-collapse{ - height:0; - overflow-y:hidden; - -webkit-transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-collapse .bp3-collapse-body{ - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-collapse .bp3-collapse-body[aria-hidden="true"]{ - display:none; } - -.bp3-context-menu .bp3-popover-target{ - display:block; } - -.bp3-context-menu-popover-target{ - position:fixed; } - -.bp3-divider{ - border-bottom:1px solid rgba(16, 22, 26, 0.15); - border-right:1px solid rgba(16, 22, 26, 0.15); - margin:5px; } - .bp3-dark .bp3-divider{ - border-color:rgba(16, 22, 26, 0.4); } -.bp3-dialog-container{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - min-height:100%; - pointer-events:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - width:100%; } - .bp3-dialog-container.bp3-overlay-enter > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear > .bp3-dialog{ - opacity:0; - -webkit-transform:scale(0.5); - transform:scale(0.5); } - .bp3-dialog-container.bp3-overlay-enter-active > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear-active > .bp3-dialog{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:opacity, transform; - transition-property:opacity, transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-dialog-container.bp3-overlay-exit > .bp3-dialog{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-dialog-container.bp3-overlay-exit-active > .bp3-dialog{ - opacity:0; - -webkit-transform:scale(0.5); - transform:scale(0.5); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:opacity, transform; - transition-property:opacity, transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - -.bp3-dialog{ - background:#ebf1f5; - border-radius:6px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:30px 0; - padding-bottom:20px; - pointer-events:all; - -webkit-user-select:text; - -moz-user-select:text; - -ms-user-select:text; - user-select:text; - width:500px; } - .bp3-dialog:focus{ - outline:0; } - .bp3-dialog.bp3-dark, - .bp3-dark .bp3-dialog{ - background:#293742; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - -.bp3-dialog-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background:#ffffff; - border-radius:6px 6px 0 0; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - min-height:40px; - padding-left:20px; - padding-right:5px; - z-index:30; } - .bp3-dialog-header .bp3-icon-large, - .bp3-dialog-header .bp3-icon{ - color:#5c7080; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin-right:10px; } - .bp3-dialog-header .bp3-heading{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:inherit; - margin:0; } - .bp3-dialog-header .bp3-heading:last-child{ - margin-right:20px; } - .bp3-dark .bp3-dialog-header{ - background:#30404d; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-dialog-header .bp3-icon-large, - .bp3-dark .bp3-dialog-header .bp3-icon{ - color:#a7b6c2; } - -.bp3-dialog-body{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:18px; - margin:20px; } - -.bp3-dialog-footer{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin:0 20px; } - -.bp3-dialog-footer-actions{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:end; - -ms-flex-pack:end; - justify-content:flex-end; } - .bp3-dialog-footer-actions .bp3-button{ - margin-left:10px; } -.bp3-multistep-dialog-panels{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - -.bp3-multistep-dialog-left-panel{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-dark .bp3-multistep-dialog-left-panel{ - background:#202b33; } - -.bp3-multistep-dialog-right-panel{ - background-color:#f5f8fa; - border-left:1px solid rgba(16, 22, 26, 0.15); - border-radius:0 0 6px 0; - -webkit-box-flex:3; - -ms-flex:3; - flex:3; - min-width:0; } - .bp3-dark .bp3-multistep-dialog-right-panel{ - background-color:#293742; - border-left:1px solid rgba(16, 22, 26, 0.4); } - -.bp3-multistep-dialog-footer{ - background-color:#ffffff; - border-radius:0 0 6px 0; - border-top:1px solid rgba(16, 22, 26, 0.15); - padding:10px; } - .bp3-dark .bp3-multistep-dialog-footer{ - background:#30404d; - border-top:1px solid rgba(16, 22, 26, 0.4); } - -.bp3-dialog-step-container{ - background-color:#f5f8fa; - border-bottom:1px solid rgba(16, 22, 26, 0.15); } - .bp3-dark .bp3-dialog-step-container{ - background:#293742; - border-bottom:1px solid rgba(16, 22, 26, 0.4); } - .bp3-dialog-step-container.bp3-dialog-step-viewed{ - background-color:#ffffff; } - .bp3-dark .bp3-dialog-step-container.bp3-dialog-step-viewed{ - background:#30404d; } - -.bp3-dialog-step{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:#f5f8fa; - border-radius:6px; - cursor:not-allowed; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin:4px; - padding:6px 14px; } - .bp3-dark .bp3-dialog-step{ - background:#293742; } - .bp3-dialog-step-viewed .bp3-dialog-step{ - background-color:#ffffff; - cursor:pointer; } - .bp3-dark .bp3-dialog-step-viewed .bp3-dialog-step{ - background:#30404d; } - .bp3-dialog-step:hover{ - background-color:#f5f8fa; } - .bp3-dark .bp3-dialog-step:hover{ - background:#293742; } - -.bp3-dialog-step-icon{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:rgba(92, 112, 128, 0.6); - border-radius:50%; - color:#ffffff; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:25px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - width:25px; } - .bp3-dark .bp3-dialog-step-icon{ - background-color:rgba(167, 182, 194, 0.6); } - .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-icon{ - background-color:#2b95d6; } - .bp3-dialog-step-viewed .bp3-dialog-step-icon{ - background-color:#8a9ba8; } - -.bp3-dialog-step-title{ - color:rgba(92, 112, 128, 0.6); - -webkit-box-flex:1; - -ms-flex:1; - flex:1; - padding-left:10px; } - .bp3-dark .bp3-dialog-step-title{ - color:rgba(167, 182, 194, 0.6); } - .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-title{ - color:#2b95d6; } - .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{ - color:#182026; } - .bp3-dark .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{ - color:#f5f8fa; } -.bp3-drawer{ - background:#ffffff; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:0; - padding:0; } - .bp3-drawer:focus{ - outline:0; } - .bp3-drawer.bp3-position-top{ - height:50%; - left:0; - right:0; - top:0; } - .bp3-drawer.bp3-position-top.bp3-overlay-enter, .bp3-drawer.bp3-position-top.bp3-overlay-appear{ - -webkit-transform:translateY(-100%); - transform:translateY(-100%); } - .bp3-drawer.bp3-position-top.bp3-overlay-enter-active, .bp3-drawer.bp3-position-top.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-top.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer.bp3-position-top.bp3-overlay-exit-active{ - -webkit-transform:translateY(-100%); - transform:translateY(-100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-bottom{ - bottom:0; - height:50%; - left:0; - right:0; } - .bp3-drawer.bp3-position-bottom.bp3-overlay-enter, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear{ - -webkit-transform:translateY(100%); - transform:translateY(100%); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-enter-active, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-exit-active{ - -webkit-transform:translateY(100%); - transform:translateY(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-left{ - bottom:0; - left:0; - top:0; - width:50%; } - .bp3-drawer.bp3-position-left.bp3-overlay-enter, .bp3-drawer.bp3-position-left.bp3-overlay-appear{ - -webkit-transform:translateX(-100%); - transform:translateX(-100%); } - .bp3-drawer.bp3-position-left.bp3-overlay-enter-active, .bp3-drawer.bp3-position-left.bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-left.bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer.bp3-position-left.bp3-overlay-exit-active{ - -webkit-transform:translateX(-100%); - transform:translateX(-100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-right{ - bottom:0; - right:0; - top:0; - width:50%; } - .bp3-drawer.bp3-position-right.bp3-overlay-enter, .bp3-drawer.bp3-position-right.bp3-overlay-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); } - .bp3-drawer.bp3-position-right.bp3-overlay-enter-active, .bp3-drawer.bp3-position-right.bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-right.bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer.bp3-position-right.bp3-overlay-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical){ - bottom:0; - right:0; - top:0; - width:50%; } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical{ - bottom:0; - height:50%; - left:0; - right:0; } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-appear{ - -webkit-transform:translateY(100%); - transform:translateY(100%); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-exit-active{ - -webkit-transform:translateY(100%); - transform:translateY(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-dark, - .bp3-dark .bp3-drawer{ - background:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - -.bp3-drawer-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border-radius:0; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - min-height:40px; - padding:5px; - padding-left:20px; - position:relative; } - .bp3-drawer-header .bp3-icon-large, - .bp3-drawer-header .bp3-icon{ - color:#5c7080; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin-right:10px; } - .bp3-drawer-header .bp3-heading{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:inherit; - margin:0; } - .bp3-drawer-header .bp3-heading:last-child{ - margin-right:20px; } - .bp3-dark .bp3-drawer-header{ - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-drawer-header .bp3-icon-large, - .bp3-dark .bp3-drawer-header .bp3-icon{ - color:#a7b6c2; } - -.bp3-drawer-body{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:18px; - overflow:auto; } - -.bp3-drawer-footer{ - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - padding:10px 20px; - position:relative; } - .bp3-dark .bp3-drawer-footer{ - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); } -.bp3-editable-text{ - cursor:text; - display:inline-block; - max-width:100%; - position:relative; - vertical-align:top; - white-space:nowrap; } - .bp3-editable-text::before{ - bottom:-3px; - left:-3px; - position:absolute; - right:-3px; - top:-3px; - border-radius:3px; - content:""; - -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-editable-text:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-editable-text.bp3-editable-text-editing::before{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-disabled::before{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-editable-text.bp3-intent-primary .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{ - color:#137cbd; } - .bp3-editable-text.bp3-intent-primary:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); } - .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-success .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{ - color:#0f9960; } - .bp3-editable-text.bp3-intent-success:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); } - .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-warning .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{ - color:#d9822b; } - .bp3-editable-text.bp3-intent-warning:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); } - .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-danger .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{ - color:#db3737; } - .bp3-editable-text.bp3-intent-danger:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); } - .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-editable-text:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); } - .bp3-dark .bp3-editable-text.bp3-editable-text-editing::before{ - background-color:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-disabled::before{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{ - color:#48aff0; } - .bp3-dark .bp3-editable-text.bp3-intent-primary:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); - box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{ - color:#3dcc91; } - .bp3-dark .bp3-editable-text.bp3-intent-success:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); - box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{ - color:#ffb366; } - .bp3-dark .bp3-editable-text.bp3-intent-warning:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); - box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{ - color:#ff7373; } - .bp3-dark .bp3-editable-text.bp3-intent-danger:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); - box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-editable-text-input, -.bp3-editable-text-content{ - color:inherit; - display:inherit; - font:inherit; - letter-spacing:inherit; - max-width:inherit; - min-width:inherit; - position:relative; - resize:none; - text-transform:inherit; - vertical-align:top; } - -.bp3-editable-text-input{ - background:none; - border:none; - -webkit-box-shadow:none; - box-shadow:none; - padding:0; - white-space:pre-wrap; - width:100%; } - .bp3-editable-text-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input:focus{ - outline:none; } - .bp3-editable-text-input::-ms-clear{ - display:none; } - -.bp3-editable-text-content{ - overflow:hidden; - padding-right:2px; - text-overflow:ellipsis; - white-space:pre; } - .bp3-editable-text-editing > .bp3-editable-text-content{ - left:0; - position:absolute; - visibility:hidden; } - .bp3-editable-text-placeholder > .bp3-editable-text-content{ - color:rgba(92, 112, 128, 0.6); } - .bp3-dark .bp3-editable-text-placeholder > .bp3-editable-text-content{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-editable-text.bp3-multiline{ - display:block; } - .bp3-editable-text.bp3-multiline .bp3-editable-text-content{ - overflow:auto; - white-space:pre-wrap; - word-wrap:break-word; } -.bp3-divider{ - border-bottom:1px solid rgba(16, 22, 26, 0.15); - border-right:1px solid rgba(16, 22, 26, 0.15); - margin:5px; } - .bp3-dark .bp3-divider{ - border-color:rgba(16, 22, 26, 0.4); } -.bp3-control-group{ - -webkit-transform:translateZ(0); - transform:translateZ(0); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; } - .bp3-control-group > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-control-group > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-control-group .bp3-button, - .bp3-control-group .bp3-html-select, - .bp3-control-group .bp3-input, - .bp3-control-group .bp3-select{ - position:relative; } - .bp3-control-group .bp3-input{ - border-radius:inherit; - z-index:2; } - .bp3-control-group .bp3-input:focus{ - border-radius:3px; - z-index:14; } - .bp3-control-group .bp3-input[class*="bp3-intent"]{ - z-index:13; } - .bp3-control-group .bp3-input[class*="bp3-intent"]:focus{ - z-index:15; } - .bp3-control-group .bp3-input[readonly], .bp3-control-group .bp3-input:disabled, .bp3-control-group .bp3-input.bp3-disabled{ - z-index:1; } - .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input{ - z-index:13; } - .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input:focus{ - z-index:15; } - .bp3-control-group .bp3-button, - .bp3-control-group .bp3-html-select select, - .bp3-control-group .bp3-select select{ - -webkit-transform:translateZ(0); - transform:translateZ(0); - border-radius:inherit; - z-index:4; } - .bp3-control-group .bp3-button:focus, - .bp3-control-group .bp3-html-select select:focus, - .bp3-control-group .bp3-select select:focus{ - z-index:5; } - .bp3-control-group .bp3-button:hover, - .bp3-control-group .bp3-html-select select:hover, - .bp3-control-group .bp3-select select:hover{ - z-index:6; } - .bp3-control-group .bp3-button:active, - .bp3-control-group .bp3-html-select select:active, - .bp3-control-group .bp3-select select:active{ - z-index:7; } - .bp3-control-group .bp3-button[readonly], .bp3-control-group .bp3-button:disabled, .bp3-control-group .bp3-button.bp3-disabled, - .bp3-control-group .bp3-html-select select[readonly], - .bp3-control-group .bp3-html-select select:disabled, - .bp3-control-group .bp3-html-select select.bp3-disabled, - .bp3-control-group .bp3-select select[readonly], - .bp3-control-group .bp3-select select:disabled, - .bp3-control-group .bp3-select select.bp3-disabled{ - z-index:3; } - .bp3-control-group .bp3-button[class*="bp3-intent"], - .bp3-control-group .bp3-html-select select[class*="bp3-intent"], - .bp3-control-group .bp3-select select[class*="bp3-intent"]{ - z-index:9; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:focus, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:focus, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:focus{ - z-index:10; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:hover, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:hover, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:hover{ - z-index:11; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:active, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:active, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:active{ - z-index:12; } - .bp3-control-group .bp3-button[class*="bp3-intent"][readonly], .bp3-control-group .bp3-button[class*="bp3-intent"]:disabled, .bp3-control-group .bp3-button[class*="bp3-intent"].bp3-disabled, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"][readonly], - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:disabled, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"].bp3-disabled, - .bp3-control-group .bp3-select select[class*="bp3-intent"][readonly], - .bp3-control-group .bp3-select select[class*="bp3-intent"]:disabled, - .bp3-control-group .bp3-select select[class*="bp3-intent"].bp3-disabled{ - z-index:8; } - .bp3-control-group .bp3-input-group > .bp3-icon, - .bp3-control-group .bp3-input-group > .bp3-button, - .bp3-control-group .bp3-input-group > .bp3-input-left-container, - .bp3-control-group .bp3-input-group > .bp3-input-action{ - z-index:16; } - .bp3-control-group .bp3-select::after, - .bp3-control-group .bp3-html-select::after, - .bp3-control-group .bp3-select > .bp3-icon, - .bp3-control-group .bp3-html-select > .bp3-icon{ - z-index:17; } - .bp3-control-group .bp3-select:focus-within{ - z-index:5; } - .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){ - margin-right:-1px; } - .bp3-control-group:not(.bp3-vertical) > .bp3-divider:not(:first-child){ - margin-left:6px; } - .bp3-dark .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){ - margin-right:0; } - .bp3-dark .bp3-control-group:not(.bp3-vertical) > .bp3-button + .bp3-button{ - margin-left:1px; } - .bp3-control-group .bp3-popover-wrapper, - .bp3-control-group .bp3-popover-target{ - border-radius:inherit; } - .bp3-control-group > :first-child{ - border-radius:3px 0 0 3px; } - .bp3-control-group > :last-child{ - border-radius:0 3px 3px 0; - margin-right:0; } - .bp3-control-group > :only-child{ - border-radius:3px; - margin-right:0; } - .bp3-control-group .bp3-input-group .bp3-button{ - border-radius:3px; } - .bp3-control-group .bp3-numeric-input:not(:first-child) .bp3-input-group{ - border-bottom-left-radius:0; - border-top-left-radius:0; } - .bp3-control-group.bp3-fill{ - width:100%; } - .bp3-control-group > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-control-group.bp3-fill > *:not(.bp3-fixed){ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-control-group.bp3-vertical{ - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-control-group.bp3-vertical > *{ - margin-top:-1px; } - .bp3-control-group.bp3-vertical > :first-child{ - border-radius:3px 3px 0 0; - margin-top:0; } - .bp3-control-group.bp3-vertical > :last-child{ - border-radius:0 0 3px 3px; } -.bp3-control{ - cursor:pointer; - display:block; - margin-bottom:10px; - position:relative; - text-transform:none; } - .bp3-control input:checked ~ .bp3-control-indicator{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-control:hover input:checked ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{ - background:#0e5a8a; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control input:disabled:checked ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-control input:checked ~ .bp3-control-indicator{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control:hover input:checked ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{ - background-color:#0e5a8a; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control input:disabled:checked ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-control:not(.bp3-align-right){ - padding-left:26px; } - .bp3-control:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-26px; } - .bp3-control.bp3-align-right{ - padding-right:26px; } - .bp3-control.bp3-align-right .bp3-control-indicator{ - margin-right:-26px; } - .bp3-control.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-control.bp3-inline{ - display:inline-block; - margin-right:20px; } - .bp3-control input{ - left:0; - opacity:0; - position:absolute; - top:0; - z-index:-1; } - .bp3-control .bp3-control-indicator{ - background-clip:padding-box; - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - border:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - cursor:pointer; - display:inline-block; - font-size:16px; - height:1em; - margin-right:10px; - margin-top:-3px; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - vertical-align:middle; - width:1em; } - .bp3-control .bp3-control-indicator::before{ - content:""; - display:block; - height:1em; - width:1em; } - .bp3-control:hover .bp3-control-indicator{ - background-color:#ebf1f5; } - .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{ - background:#d8e1e8; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control input:disabled ~ .bp3-control-indicator{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - cursor:not-allowed; } - .bp3-control input:focus ~ .bp3-control-indicator{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:2px; - -moz-outline-radius:6px; } - .bp3-control.bp3-align-right .bp3-control-indicator{ - float:right; - margin-left:10px; - margin-top:1px; } - .bp3-control.bp3-large{ - font-size:16px; } - .bp3-control.bp3-large:not(.bp3-align-right){ - padding-left:30px; } - .bp3-control.bp3-large:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-30px; } - .bp3-control.bp3-large.bp3-align-right{ - padding-right:30px; } - .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-right:-30px; } - .bp3-control.bp3-large .bp3-control-indicator{ - font-size:20px; } - .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-top:0; } - .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{ - background:#0e5a8a; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{ - background-color:#0e5a8a; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-control.bp3-checkbox .bp3-control-indicator{ - border-radius:3px; } - .bp3-control.bp3-checkbox input:checked ~ .bp3-control-indicator::before{ - background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M12 5c-.28 0-.53.11-.71.29L7 9.59l-2.29-2.3a1.003 1.003 0 00-1.42 1.42l3 3c.18.18.43.29.71.29s.53-.11.71-.29l5-5A1.003 1.003 0 0012 5z' fill='white'/%3e%3c/svg%3e"); } - .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator::before{ - background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M11 7H5c-.55 0-1 .45-1 1s.45 1 1 1h6c.55 0 1-.45 1-1s-.45-1-1-1z' fill='white'/%3e%3c/svg%3e"); } - .bp3-control.bp3-radio .bp3-control-indicator{ - border-radius:50%; } - .bp3-control.bp3-radio input:checked ~ .bp3-control-indicator::before{ - background-image:radial-gradient(#ffffff, #ffffff 28%, transparent 32%); } - .bp3-control.bp3-radio input:checked:disabled ~ .bp3-control-indicator::before{ - opacity:0.5; } - .bp3-control.bp3-radio input:focus ~ .bp3-control-indicator{ - -moz-outline-radius:16px; } - .bp3-control.bp3-switch input ~ .bp3-control-indicator{ - background:rgba(167, 182, 194, 0.5); } - .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{ - background:rgba(115, 134, 148, 0.5); } - .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{ - background:rgba(92, 112, 128, 0.5); } - .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{ - background:rgba(206, 217, 224, 0.5); } - .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{ - background:rgba(255, 255, 255, 0.8); } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{ - background:#137cbd; } - .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{ - background:#106ba3; } - .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{ - background:#0e5a8a; } - .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); } - .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{ - background:rgba(255, 255, 255, 0.8); } - .bp3-control.bp3-switch:not(.bp3-align-right){ - padding-left:38px; } - .bp3-control.bp3-switch:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-38px; } - .bp3-control.bp3-switch.bp3-align-right{ - padding-right:38px; } - .bp3-control.bp3-switch.bp3-align-right .bp3-control-indicator{ - margin-right:-38px; } - .bp3-control.bp3-switch .bp3-control-indicator{ - border:none; - border-radius:1.75em; - -webkit-box-shadow:none !important; - box-shadow:none !important; - min-width:1.75em; - -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:auto; } - .bp3-control.bp3-switch .bp3-control-indicator::before{ - background:#ffffff; - border-radius:50%; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - height:calc(1em - 4px); - left:0; - margin:2px; - position:absolute; - -webkit-transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:calc(1em - 4px); } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{ - left:calc(100% - 1em); } - .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right){ - padding-left:45px; } - .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-45px; } - .bp3-control.bp3-switch.bp3-large.bp3-align-right{ - padding-right:45px; } - .bp3-control.bp3-switch.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-right:-45px; } - .bp3-dark .bp3-control.bp3-switch input ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.5); } - .bp3-dark .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.7); } - .bp3-dark .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.9); } - .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{ - background:rgba(57, 75, 89, 0.5); } - .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{ - background:#137cbd; } - .bp3-dark .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{ - background:#106ba3; } - .bp3-dark .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{ - background:#0e5a8a; } - .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); } - .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch .bp3-control-indicator::before{ - background:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-control.bp3-switch .bp3-switch-inner-text{ - font-size:0.7em; - text-align:center; } - .bp3-control.bp3-switch .bp3-control-indicator-child:first-child{ - line-height:0; - margin-left:0.5em; - margin-right:1.2em; - visibility:hidden; } - .bp3-control.bp3-switch .bp3-control-indicator-child:last-child{ - line-height:1em; - margin-left:1.2em; - margin-right:0.5em; - visibility:visible; } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:first-child{ - line-height:1em; - visibility:visible; } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:last-child{ - line-height:0; - visibility:hidden; } - .bp3-dark .bp3-control{ - color:#f5f8fa; } - .bp3-dark .bp3-control.bp3-disabled{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-control .bp3-control-indicator{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control:hover .bp3-control-indicator{ - background-color:#30404d; } - .bp3-dark .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{ - background:#202b33; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control input:disabled ~ .bp3-control-indicator{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - cursor:not-allowed; } - .bp3-dark .bp3-control.bp3-checkbox input:disabled:checked ~ .bp3-control-indicator, .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - color:rgba(167, 182, 194, 0.6); } -.bp3-file-input{ - cursor:pointer; - display:inline-block; - height:30px; - position:relative; } - .bp3-file-input input{ - margin:0; - min-width:200px; - opacity:0; } - .bp3-file-input input:disabled + .bp3-file-upload-input, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-file-input input:disabled + .bp3-file-upload-input::after, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active:hover, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{ - color:#182026; } - .bp3-dark .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{ - color:#f5f8fa; } - .bp3-file-input.bp3-fill{ - width:100%; } - .bp3-file-input.bp3-large, - .bp3-large .bp3-file-input{ - height:40px; } - .bp3-file-input .bp3-file-upload-input-custom-text::after{ - content:attr(bp3-button-text); } - -.bp3-file-upload-input{ - -webkit-appearance:none; - -moz-appearance:none; - appearance:none; - background:#ffffff; - border:none; - border-radius:3px; - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - color:#182026; - font-size:14px; - font-weight:400; - height:30px; - line-height:30px; - outline:none; - padding:0 10px; - -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - vertical-align:middle; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - color:rgba(92, 112, 128, 0.6); - left:0; - padding-right:80px; - position:absolute; - right:0; - top:0; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-file-upload-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input:focus, .bp3-file-upload-input.bp3-active{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-file-upload-input[type="search"], .bp3-file-upload-input.bp3-round{ - border-radius:30px; - -webkit-box-sizing:border-box; - box-sizing:border-box; - padding-left:10px; } - .bp3-file-upload-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-file-upload-input:disabled, .bp3-file-upload-input.bp3-disabled{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-file-upload-input::after{ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - min-height:24px; - min-width:24px; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - border-radius:3px; - content:"Browse"; - line-height:24px; - margin:3px; - position:absolute; - right:0; - text-align:center; - top:0; - width:70px; } - .bp3-file-upload-input::after:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-file-upload-input::after:active, .bp3-file-upload-input::after.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-file-upload-input::after:disabled, .bp3-file-upload-input::after.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-file-upload-input::after:disabled.bp3-active, .bp3-file-upload-input::after:disabled.bp3-active:hover, .bp3-file-upload-input::after.bp3-disabled.bp3-active, .bp3-file-upload-input::after.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-file-upload-input:hover::after{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-file-upload-input:active::after{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-large .bp3-file-upload-input{ - font-size:16px; - height:40px; - line-height:40px; - padding-right:95px; } - .bp3-large .bp3-file-upload-input[type="search"], .bp3-large .bp3-file-upload-input.bp3-round{ - padding:0 15px; } - .bp3-large .bp3-file-upload-input::after{ - min-height:30px; - min-width:30px; - line-height:30px; - margin:5px; - width:85px; } - .bp3-dark .bp3-file-upload-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input:disabled, .bp3-dark .bp3-file-upload-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::after{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-file-upload-input::after:hover, .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-file-upload-input::after:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-file-upload-input::after:disabled, .bp3-dark .bp3-file-upload-input::after.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::after:disabled.bp3-active, .bp3-dark .bp3-file-upload-input::after.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-file-upload-input::after .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-file-upload-input:hover::after{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input:active::after{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } -.bp3-file-upload-input::after{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } -.bp3-form-group{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:0 0 15px; } - .bp3-form-group label.bp3-label{ - margin-bottom:5px; } - .bp3-form-group .bp3-control{ - margin-top:7px; } - .bp3-form-group .bp3-form-helper-text{ - color:#5c7080; - font-size:12px; - margin-top:5px; } - .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{ - color:#106ba3; } - .bp3-form-group.bp3-intent-success .bp3-form-helper-text{ - color:#0d8050; } - .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{ - color:#bf7326; } - .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{ - color:#c23030; } - .bp3-form-group.bp3-inline{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; } - .bp3-form-group.bp3-inline.bp3-large label.bp3-label{ - line-height:40px; - margin:0 10px 0 0; } - .bp3-form-group.bp3-inline label.bp3-label{ - line-height:30px; - margin:0 10px 0 0; } - .bp3-form-group.bp3-disabled .bp3-label, - .bp3-form-group.bp3-disabled .bp3-text-muted, - .bp3-form-group.bp3-disabled .bp3-form-helper-text{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-dark .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{ - color:#48aff0; } - .bp3-dark .bp3-form-group.bp3-intent-success .bp3-form-helper-text{ - color:#3dcc91; } - .bp3-dark .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{ - color:#ffb366; } - .bp3-dark .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{ - color:#ff7373; } - .bp3-dark .bp3-form-group .bp3-form-helper-text{ - color:#a7b6c2; } - .bp3-dark .bp3-form-group.bp3-disabled .bp3-label, - .bp3-dark .bp3-form-group.bp3-disabled .bp3-text-muted, - .bp3-dark .bp3-form-group.bp3-disabled .bp3-form-helper-text{ - color:rgba(167, 182, 194, 0.6) !important; } -.bp3-input-group{ - display:block; - position:relative; } - .bp3-input-group .bp3-input{ - position:relative; - width:100%; } - .bp3-input-group .bp3-input:not(:first-child){ - padding-left:30px; } - .bp3-input-group .bp3-input:not(:last-child){ - padding-right:30px; } - .bp3-input-group .bp3-input-action, - .bp3-input-group > .bp3-input-left-container, - .bp3-input-group > .bp3-button, - .bp3-input-group > .bp3-icon{ - position:absolute; - top:0; } - .bp3-input-group .bp3-input-action:first-child, - .bp3-input-group > .bp3-input-left-container:first-child, - .bp3-input-group > .bp3-button:first-child, - .bp3-input-group > .bp3-icon:first-child{ - left:0; } - .bp3-input-group .bp3-input-action:last-child, - .bp3-input-group > .bp3-input-left-container:last-child, - .bp3-input-group > .bp3-button:last-child, - .bp3-input-group > .bp3-icon:last-child{ - right:0; } - .bp3-input-group .bp3-button{ - min-height:24px; - min-width:24px; - margin:3px; - padding:0 7px; } - .bp3-input-group .bp3-button:empty{ - padding:0; } - .bp3-input-group > .bp3-input-left-container, - .bp3-input-group > .bp3-icon{ - z-index:1; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon, - .bp3-input-group > .bp3-icon{ - color:#5c7080; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon:empty, - .bp3-input-group > .bp3-icon:empty{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon, - .bp3-input-group > .bp3-icon, - .bp3-input-group .bp3-input-action > .bp3-spinner{ - margin:7px; } - .bp3-input-group .bp3-tag{ - margin:5px; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){ - color:#5c7080; } - .bp3-dark .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), .bp3-dark - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){ - color:#a7b6c2; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large{ - color:#5c7080; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-large, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-standard, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-large{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-input-group.bp3-disabled{ - cursor:not-allowed; } - .bp3-input-group.bp3-disabled .bp3-icon{ - color:rgba(92, 112, 128, 0.6); } - .bp3-input-group.bp3-large .bp3-button{ - min-height:30px; - min-width:30px; - margin:5px; } - .bp3-input-group.bp3-large > .bp3-input-left-container > .bp3-icon, - .bp3-input-group.bp3-large > .bp3-icon, - .bp3-input-group.bp3-large .bp3-input-action > .bp3-spinner{ - margin:12px; } - .bp3-input-group.bp3-large .bp3-input{ - font-size:16px; - height:40px; - line-height:40px; } - .bp3-input-group.bp3-large .bp3-input[type="search"], .bp3-input-group.bp3-large .bp3-input.bp3-round{ - padding:0 15px; } - .bp3-input-group.bp3-large .bp3-input:not(:first-child){ - padding-left:40px; } - .bp3-input-group.bp3-large .bp3-input:not(:last-child){ - padding-right:40px; } - .bp3-input-group.bp3-small .bp3-button{ - min-height:20px; - min-width:20px; - margin:2px; } - .bp3-input-group.bp3-small .bp3-tag{ - min-height:20px; - min-width:20px; - margin:2px; } - .bp3-input-group.bp3-small > .bp3-input-left-container > .bp3-icon, - .bp3-input-group.bp3-small > .bp3-icon, - .bp3-input-group.bp3-small .bp3-input-action > .bp3-spinner{ - margin:4px; } - .bp3-input-group.bp3-small .bp3-input{ - font-size:12px; - height:24px; - line-height:24px; - padding-left:8px; - padding-right:8px; } - .bp3-input-group.bp3-small .bp3-input[type="search"], .bp3-input-group.bp3-small .bp3-input.bp3-round{ - padding:0 12px; } - .bp3-input-group.bp3-small .bp3-input:not(:first-child){ - padding-left:24px; } - .bp3-input-group.bp3-small .bp3-input:not(:last-child){ - padding-right:24px; } - .bp3-input-group.bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - width:100%; } - .bp3-input-group.bp3-round .bp3-button, - .bp3-input-group.bp3-round .bp3-input, - .bp3-input-group.bp3-round .bp3-tag{ - border-radius:30px; } - .bp3-dark .bp3-input-group .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-input-group.bp3-disabled .bp3-icon{ - color:rgba(167, 182, 194, 0.6); } - .bp3-input-group.bp3-intent-primary .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-primary .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-primary .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-input-group.bp3-intent-primary .bp3-input:disabled, .bp3-input-group.bp3-intent-primary .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-primary > .bp3-icon{ - color:#106ba3; } - .bp3-dark .bp3-input-group.bp3-intent-primary > .bp3-icon{ - color:#48aff0; } - .bp3-input-group.bp3-intent-success .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-success .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-success .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-input-group.bp3-intent-success .bp3-input:disabled, .bp3-input-group.bp3-intent-success .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-success > .bp3-icon{ - color:#0d8050; } - .bp3-dark .bp3-input-group.bp3-intent-success > .bp3-icon{ - color:#3dcc91; } - .bp3-input-group.bp3-intent-warning .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-warning .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-warning .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-input-group.bp3-intent-warning .bp3-input:disabled, .bp3-input-group.bp3-intent-warning .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-warning > .bp3-icon{ - color:#bf7326; } - .bp3-dark .bp3-input-group.bp3-intent-warning > .bp3-icon{ - color:#ffb366; } - .bp3-input-group.bp3-intent-danger .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-danger .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-danger .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-input-group.bp3-intent-danger .bp3-input:disabled, .bp3-input-group.bp3-intent-danger .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-danger > .bp3-icon{ - color:#c23030; } - .bp3-dark .bp3-input-group.bp3-intent-danger > .bp3-icon{ - color:#ff7373; } -.bp3-input{ - -webkit-appearance:none; - -moz-appearance:none; - appearance:none; - background:#ffffff; - border:none; - border-radius:3px; - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - color:#182026; - font-size:14px; - font-weight:400; - height:30px; - line-height:30px; - outline:none; - padding:0 10px; - -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - vertical-align:middle; } - .bp3-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input:focus, .bp3-input.bp3-active{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input[type="search"], .bp3-input.bp3-round{ - border-radius:30px; - -webkit-box-sizing:border-box; - box-sizing:border-box; - padding-left:10px; } - .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-input:disabled, .bp3-input.bp3-disabled{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-input.bp3-large{ - font-size:16px; - height:40px; - line-height:40px; } - .bp3-input.bp3-large[type="search"], .bp3-input.bp3-large.bp3-round{ - padding:0 15px; } - .bp3-input.bp3-small{ - font-size:12px; - height:24px; - line-height:24px; - padding-left:8px; - padding-right:8px; } - .bp3-input.bp3-small[type="search"], .bp3-input.bp3-small.bp3-round{ - padding:0 12px; } - .bp3-input.bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - width:100%; } - .bp3-dark .bp3-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input:disabled, .bp3-dark .bp3-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-input.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-primary:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-primary[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-input.bp3-intent-primary:disabled, .bp3-input.bp3-intent-primary.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-primary:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-primary[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-dark .bp3-input.bp3-intent-primary:disabled, .bp3-dark .bp3-input.bp3-intent-primary.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-success{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-success:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-success[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-input.bp3-intent-success:disabled, .bp3-input.bp3-intent-success.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-success{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-success:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-success[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-dark .bp3-input.bp3-intent-success:disabled, .bp3-dark .bp3-input.bp3-intent-success.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-warning:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-warning[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-input.bp3-intent-warning:disabled, .bp3-input.bp3-intent-warning.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-warning:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-warning[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-dark .bp3-input.bp3-intent-warning:disabled, .bp3-dark .bp3-input.bp3-intent-warning.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-danger:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-danger[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-input.bp3-intent-danger:disabled, .bp3-input.bp3-intent-danger.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-danger:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-danger[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-dark .bp3-input.bp3-intent-danger:disabled, .bp3-dark .bp3-input.bp3-intent-danger.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input::-ms-clear{ - display:none; } -textarea.bp3-input{ - max-width:100%; - padding:10px; } - textarea.bp3-input, textarea.bp3-input.bp3-large, textarea.bp3-input.bp3-small{ - height:auto; - line-height:inherit; } - textarea.bp3-input.bp3-small{ - padding:8px; } - .bp3-dark textarea.bp3-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark textarea.bp3-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark textarea.bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark textarea.bp3-input:disabled, .bp3-dark textarea.bp3-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } -label.bp3-label{ - display:block; - margin-bottom:15px; - margin-top:0; } - label.bp3-label .bp3-html-select, - label.bp3-label .bp3-input, - label.bp3-label .bp3-select, - label.bp3-label .bp3-slider, - label.bp3-label .bp3-popover-wrapper{ - display:block; - margin-top:5px; - text-transform:none; } - label.bp3-label .bp3-button-group{ - margin-top:5px; } - label.bp3-label .bp3-select select, - label.bp3-label .bp3-html-select select{ - font-weight:400; - vertical-align:top; - width:100%; } - label.bp3-label.bp3-disabled, - label.bp3-label.bp3-disabled .bp3-text-muted{ - color:rgba(92, 112, 128, 0.6); } - label.bp3-label.bp3-inline{ - line-height:30px; } - label.bp3-label.bp3-inline .bp3-html-select, - label.bp3-label.bp3-inline .bp3-input, - label.bp3-label.bp3-inline .bp3-input-group, - label.bp3-label.bp3-inline .bp3-select, - label.bp3-label.bp3-inline .bp3-popover-wrapper{ - display:inline-block; - margin:0 0 0 5px; - vertical-align:top; } - label.bp3-label.bp3-inline .bp3-button-group{ - margin:0 0 0 5px; } - label.bp3-label.bp3-inline .bp3-input-group .bp3-input{ - margin-left:0; } - label.bp3-label.bp3-inline.bp3-large{ - line-height:40px; } - label.bp3-label:not(.bp3-inline) .bp3-popover-target{ - display:block; } - .bp3-dark label.bp3-label{ - color:#f5f8fa; } - .bp3-dark label.bp3-label.bp3-disabled, - .bp3-dark label.bp3-label.bp3-disabled .bp3-text-muted{ - color:rgba(167, 182, 194, 0.6); } -.bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button{ - -webkit-box-flex:1; - -ms-flex:1 1 14px; - flex:1 1 14px; - min-height:0; - padding:0; - width:30px; } - .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:first-child{ - border-radius:0 3px 0 0; } - .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:last-child{ - border-radius:0 0 3px 0; } - -.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:first-child{ - border-radius:3px 0 0 0; } - -.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:last-child{ - border-radius:0 0 0 3px; } - -.bp3-numeric-input.bp3-large .bp3-button-group.bp3-vertical > .bp3-button{ - width:40px; } - -form{ - display:block; } -.bp3-html-select select, -.bp3-select select{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border:none; - border-radius:3px; - cursor:pointer; - font-size:14px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - padding:5px 10px; - text-align:left; - vertical-align:middle; - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - -moz-appearance:none; - -webkit-appearance:none; - border-radius:3px; - height:30px; - padding:0 25px 0 10px; - width:100%; } - .bp3-html-select select > *, .bp3-select select > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-html-select select > .bp3-fill, .bp3-select select > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-html-select select::before, - .bp3-select select::before, .bp3-html-select select > *, .bp3-select select > *{ - margin-right:7px; } - .bp3-html-select select:empty::before, - .bp3-select select:empty::before, - .bp3-html-select select > :last-child, - .bp3-select select > :last-child{ - margin-right:0; } - .bp3-html-select select:hover, - .bp3-select select:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-html-select select:active, - .bp3-select select:active, .bp3-html-select select.bp3-active, - .bp3-select select.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-html-select select:disabled, - .bp3-select select:disabled, .bp3-html-select select.bp3-disabled, - .bp3-select select.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-html-select select:disabled.bp3-active, - .bp3-select select:disabled.bp3-active, .bp3-html-select select:disabled.bp3-active:hover, - .bp3-select select:disabled.bp3-active:hover, .bp3-html-select select.bp3-disabled.bp3-active, - .bp3-select select.bp3-disabled.bp3-active, .bp3-html-select select.bp3-disabled.bp3-active:hover, - .bp3-select select.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - -.bp3-html-select.bp3-minimal select, -.bp3-select.bp3-minimal select{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-html-select.bp3-minimal select:hover, - .bp3-select.bp3-minimal select:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-html-select.bp3-minimal select:active, - .bp3-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal select.bp3-active, - .bp3-select.bp3-minimal select.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-html-select.bp3-minimal select:disabled, - .bp3-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal select:disabled:hover, - .bp3-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal select.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal select.bp3-disabled:hover, - .bp3-select.bp3-minimal select.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-html-select.bp3-minimal select:disabled.bp3-active, - .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, - .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, - .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-html-select.bp3-minimal select, .bp3-html-select.bp3-minimal .bp3-dark select, - .bp3-dark .bp3-select.bp3-minimal select, .bp3-select.bp3-minimal .bp3-dark select{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover, - .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover, .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active, - .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover, - .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active, - .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-html-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal .bp3-dark select:disabled, - .bp3-dark .bp3-select.bp3-minimal select:disabled, .bp3-select.bp3-minimal .bp3-dark select:disabled, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover, - .bp3-dark .bp3-select.bp3-minimal select:disabled:hover, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-html-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary, - .bp3-select.bp3-minimal select.bp3-intent-primary{ - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, - .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, - .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, - .bp3-select.bp3-minimal select.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, - .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, - .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-success, - .bp3-select.bp3-minimal select.bp3-intent-success{ - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, - .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal select.bp3-intent-success:active, - .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, - .bp3-select.bp3-minimal select.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:active, - .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, - .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning, - .bp3-select.bp3-minimal select.bp3-intent-warning{ - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, - .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, - .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, - .bp3-select.bp3-minimal select.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, - .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, - .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger, - .bp3-select.bp3-minimal select.bp3-intent-danger{ - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, - .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, - .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, - .bp3-select.bp3-minimal select.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, - .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, - .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - -.bp3-html-select.bp3-large select, -.bp3-select.bp3-large select{ - font-size:16px; - height:40px; - padding-right:35px; } - -.bp3-dark .bp3-html-select select, .bp3-dark .bp3-select select{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover, .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-html-select select:disabled, .bp3-dark .bp3-select select:disabled, .bp3-dark .bp3-html-select select.bp3-disabled, .bp3-dark .bp3-select select.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-html-select select:disabled.bp3-active, .bp3-dark .bp3-select select:disabled.bp3-active, .bp3-dark .bp3-html-select select.bp3-disabled.bp3-active, .bp3-dark .bp3-select select.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-html-select select .bp3-button-spinner .bp3-spinner-head, .bp3-dark .bp3-select select .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - -.bp3-html-select select:disabled, -.bp3-select select:disabled{ - background-color:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-html-select .bp3-icon, -.bp3-select .bp3-icon, .bp3-select::after{ - color:#5c7080; - pointer-events:none; - position:absolute; - right:7px; - top:7px; } - .bp3-html-select .bp3-disabled.bp3-icon, - .bp3-select .bp3-disabled.bp3-icon, .bp3-disabled.bp3-select::after{ - color:rgba(92, 112, 128, 0.6); } -.bp3-html-select, -.bp3-select{ - display:inline-block; - letter-spacing:normal; - position:relative; - vertical-align:middle; } - .bp3-html-select select::-ms-expand, - .bp3-select select::-ms-expand{ - display:none; } - .bp3-html-select .bp3-icon, - .bp3-select .bp3-icon{ - color:#5c7080; } - .bp3-html-select .bp3-icon:hover, - .bp3-select .bp3-icon:hover{ - color:#182026; } - .bp3-dark .bp3-html-select .bp3-icon, .bp3-dark - .bp3-select .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-html-select .bp3-icon:hover, .bp3-dark - .bp3-select .bp3-icon:hover{ - color:#f5f8fa; } - .bp3-html-select.bp3-large::after, - .bp3-html-select.bp3-large .bp3-icon, - .bp3-select.bp3-large::after, - .bp3-select.bp3-large .bp3-icon{ - right:12px; - top:12px; } - .bp3-html-select.bp3-fill, - .bp3-html-select.bp3-fill select, - .bp3-select.bp3-fill, - .bp3-select.bp3-fill select{ - width:100%; } - .bp3-dark .bp3-html-select option, .bp3-dark - .bp3-select option{ - background-color:#30404d; - color:#f5f8fa; } - .bp3-dark .bp3-html-select option:disabled, .bp3-dark - .bp3-select option:disabled{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-html-select::after, .bp3-dark - .bp3-select::after{ - color:#a7b6c2; } - -.bp3-select::after{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - content:""; } -.bp3-running-text table, table.bp3-html-table{ - border-spacing:0; - font-size:14px; } - .bp3-running-text table th, table.bp3-html-table th, - .bp3-running-text table td, - table.bp3-html-table td{ - padding:11px; - text-align:left; - vertical-align:top; } - .bp3-running-text table th, table.bp3-html-table th{ - color:#182026; - font-weight:600; } - - .bp3-running-text table td, - table.bp3-html-table td{ - color:#182026; } - .bp3-running-text table tbody tr:first-child th, table.bp3-html-table tbody tr:first-child th, - .bp3-running-text table tbody tr:first-child td, - table.bp3-html-table tbody tr:first-child td, - .bp3-running-text table tfoot tr:first-child th, - table.bp3-html-table tfoot tr:first-child th, - .bp3-running-text table tfoot tr:first-child td, - table.bp3-html-table tfoot tr:first-child td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); } - .bp3-dark .bp3-running-text table th, .bp3-running-text .bp3-dark table th, .bp3-dark table.bp3-html-table th{ - color:#f5f8fa; } - .bp3-dark .bp3-running-text table td, .bp3-running-text .bp3-dark table td, .bp3-dark table.bp3-html-table td{ - color:#f5f8fa; } - .bp3-dark .bp3-running-text table tbody tr:first-child th, .bp3-running-text .bp3-dark table tbody tr:first-child th, .bp3-dark table.bp3-html-table tbody tr:first-child th, - .bp3-dark .bp3-running-text table tbody tr:first-child td, - .bp3-running-text .bp3-dark table tbody tr:first-child td, - .bp3-dark table.bp3-html-table tbody tr:first-child td, - .bp3-dark .bp3-running-text table tfoot tr:first-child th, - .bp3-running-text .bp3-dark table tfoot tr:first-child th, - .bp3-dark table.bp3-html-table tfoot tr:first-child th, - .bp3-dark .bp3-running-text table tfoot tr:first-child td, - .bp3-running-text .bp3-dark table tfoot tr:first-child td, - .bp3-dark table.bp3-html-table tfoot tr:first-child td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); } - -table.bp3-html-table.bp3-html-table-condensed th, -table.bp3-html-table.bp3-html-table-condensed td, table.bp3-html-table.bp3-small th, -table.bp3-html-table.bp3-small td{ - padding-bottom:6px; - padding-top:6px; } - -table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{ - background:rgba(191, 204, 214, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered tbody tr td, -table.bp3-html-table.bp3-html-table-bordered tfoot tr td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); } - table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child), - table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){ - -webkit-box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{ - -webkit-box-shadow:none; - box-shadow:none; } - table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-interactive tbody tr:hover td{ - background-color:rgba(191, 204, 214, 0.3); - cursor:pointer; } - -table.bp3-html-table.bp3-interactive tbody tr:active td{ - background-color:rgba(191, 204, 214, 0.4); } - -.bp3-dark table.bp3-html-table{ } - .bp3-dark table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{ - background:rgba(92, 112, 128, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td, - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child), - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){ - -webkit-box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{ - -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:first-child{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:hover td{ - background-color:rgba(92, 112, 128, 0.3); - cursor:pointer; } - .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:active td{ - background-color:rgba(92, 112, 128, 0.4); } - -.bp3-key-combo{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; } - .bp3-key-combo > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-key-combo > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-key-combo::before, - .bp3-key-combo > *{ - margin-right:5px; } - .bp3-key-combo:empty::before, - .bp3-key-combo > :last-child{ - margin-right:0; } - -.bp3-hotkey-dialog{ - padding-bottom:0; - top:40px; } - .bp3-hotkey-dialog .bp3-dialog-body{ - margin:0; - padding:0; } - .bp3-hotkey-dialog .bp3-hotkey-label{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; } - -.bp3-hotkey-column{ - margin:auto; - max-height:80vh; - overflow-y:auto; - padding:30px; } - .bp3-hotkey-column .bp3-heading{ - margin-bottom:20px; } - .bp3-hotkey-column .bp3-heading:not(:first-child){ - margin-top:40px; } - -.bp3-hotkey{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:justify; - -ms-flex-pack:justify; - justify-content:space-between; - margin-left:0; - margin-right:0; } - .bp3-hotkey:not(:last-child){ - margin-bottom:10px; } -.bp3-icon{ - display:inline-block; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - vertical-align:text-bottom; } - .bp3-icon:not(:empty)::before{ - content:"" !important; - content:unset !important; } - .bp3-icon > svg{ - display:block; } - .bp3-icon > svg:not([fill]){ - fill:currentColor; } - -.bp3-icon.bp3-intent-primary, .bp3-icon-standard.bp3-intent-primary, .bp3-icon-large.bp3-intent-primary{ - color:#106ba3; } - .bp3-dark .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-icon-large.bp3-intent-primary{ - color:#48aff0; } - -.bp3-icon.bp3-intent-success, .bp3-icon-standard.bp3-intent-success, .bp3-icon-large.bp3-intent-success{ - color:#0d8050; } - .bp3-dark .bp3-icon.bp3-intent-success, .bp3-dark .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-icon-large.bp3-intent-success{ - color:#3dcc91; } - -.bp3-icon.bp3-intent-warning, .bp3-icon-standard.bp3-intent-warning, .bp3-icon-large.bp3-intent-warning{ - color:#bf7326; } - .bp3-dark .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-icon-large.bp3-intent-warning{ - color:#ffb366; } - -.bp3-icon.bp3-intent-danger, .bp3-icon-standard.bp3-intent-danger, .bp3-icon-large.bp3-intent-danger{ - color:#c23030; } - .bp3-dark .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-icon-large.bp3-intent-danger{ - color:#ff7373; } - -span.bp3-icon-standard{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - display:inline-block; } - -span.bp3-icon-large{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - display:inline-block; } - -span.bp3-icon:empty{ - font-family:"Icons20"; - font-size:inherit; - font-style:normal; - font-weight:400; - line-height:1; } - span.bp3-icon:empty::before{ - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; } - -.bp3-icon-add::before{ - content:""; } - -.bp3-icon-add-column-left::before{ - content:""; } - -.bp3-icon-add-column-right::before{ - content:""; } - -.bp3-icon-add-row-bottom::before{ - content:""; } - -.bp3-icon-add-row-top::before{ - content:""; } - -.bp3-icon-add-to-artifact::before{ - content:""; } - -.bp3-icon-add-to-folder::before{ - content:""; } - -.bp3-icon-airplane::before{ - content:""; } - -.bp3-icon-align-center::before{ - content:""; } - -.bp3-icon-align-justify::before{ - content:""; } - -.bp3-icon-align-left::before{ - content:""; } - -.bp3-icon-align-right::before{ - content:""; } - -.bp3-icon-alignment-bottom::before{ - content:""; } - -.bp3-icon-alignment-horizontal-center::before{ - content:""; } - -.bp3-icon-alignment-left::before{ - content:""; } - -.bp3-icon-alignment-right::before{ - content:""; } - -.bp3-icon-alignment-top::before{ - content:""; } - -.bp3-icon-alignment-vertical-center::before{ - content:""; } - -.bp3-icon-annotation::before{ - content:""; } - -.bp3-icon-application::before{ - content:""; } - -.bp3-icon-applications::before{ - content:""; } - -.bp3-icon-archive::before{ - content:""; } - -.bp3-icon-arrow-bottom-left::before{ - content:"↙"; } - -.bp3-icon-arrow-bottom-right::before{ - content:"↘"; } - -.bp3-icon-arrow-down::before{ - content:"↓"; } - -.bp3-icon-arrow-left::before{ - content:"←"; } - -.bp3-icon-arrow-right::before{ - content:"→"; } - -.bp3-icon-arrow-top-left::before{ - content:"↖"; } - -.bp3-icon-arrow-top-right::before{ - content:"↗"; } - -.bp3-icon-arrow-up::before{ - content:"↑"; } - -.bp3-icon-arrows-horizontal::before{ - content:"↔"; } - -.bp3-icon-arrows-vertical::before{ - content:"↕"; } - -.bp3-icon-asterisk::before{ - content:"*"; } - -.bp3-icon-automatic-updates::before{ - content:""; } - -.bp3-icon-badge::before{ - content:""; } - -.bp3-icon-ban-circle::before{ - content:""; } - -.bp3-icon-bank-account::before{ - content:""; } - -.bp3-icon-barcode::before{ - content:""; } - -.bp3-icon-blank::before{ - content:""; } - -.bp3-icon-blocked-person::before{ - content:""; } - -.bp3-icon-bold::before{ - content:""; } - -.bp3-icon-book::before{ - content:""; } - -.bp3-icon-bookmark::before{ - content:""; } - -.bp3-icon-box::before{ - content:""; } - -.bp3-icon-briefcase::before{ - content:""; } - -.bp3-icon-bring-data::before{ - content:""; } - -.bp3-icon-build::before{ - content:""; } - -.bp3-icon-calculator::before{ - content:""; } - -.bp3-icon-calendar::before{ - content:""; } - -.bp3-icon-camera::before{ - content:""; } - -.bp3-icon-caret-down::before{ - content:"⌄"; } - -.bp3-icon-caret-left::before{ - content:"〈"; } - -.bp3-icon-caret-right::before{ - content:"〉"; } - -.bp3-icon-caret-up::before{ - content:"⌃"; } - -.bp3-icon-cell-tower::before{ - content:""; } - -.bp3-icon-changes::before{ - content:""; } - -.bp3-icon-chart::before{ - content:""; } - -.bp3-icon-chat::before{ - content:""; } - -.bp3-icon-chevron-backward::before{ - content:""; } - -.bp3-icon-chevron-down::before{ - content:""; } - -.bp3-icon-chevron-forward::before{ - content:""; } - -.bp3-icon-chevron-left::before{ - content:""; } - -.bp3-icon-chevron-right::before{ - content:""; } - -.bp3-icon-chevron-up::before{ - content:""; } - -.bp3-icon-circle::before{ - content:""; } - -.bp3-icon-circle-arrow-down::before{ - content:""; } - -.bp3-icon-circle-arrow-left::before{ - content:""; } - -.bp3-icon-circle-arrow-right::before{ - content:""; } - -.bp3-icon-circle-arrow-up::before{ - content:""; } - -.bp3-icon-citation::before{ - content:""; } - -.bp3-icon-clean::before{ - content:""; } - -.bp3-icon-clipboard::before{ - content:""; } - -.bp3-icon-cloud::before{ - content:"☁"; } - -.bp3-icon-cloud-download::before{ - content:""; } - -.bp3-icon-cloud-upload::before{ - content:""; } - -.bp3-icon-code::before{ - content:""; } - -.bp3-icon-code-block::before{ - content:""; } - -.bp3-icon-cog::before{ - content:""; } - -.bp3-icon-collapse-all::before{ - content:""; } - -.bp3-icon-column-layout::before{ - content:""; } - -.bp3-icon-comment::before{ - content:""; } - -.bp3-icon-comparison::before{ - content:""; } - -.bp3-icon-compass::before{ - content:""; } - -.bp3-icon-compressed::before{ - content:""; } - -.bp3-icon-confirm::before{ - content:""; } - -.bp3-icon-console::before{ - content:""; } - -.bp3-icon-contrast::before{ - content:""; } - -.bp3-icon-control::before{ - content:""; } - -.bp3-icon-credit-card::before{ - content:""; } - -.bp3-icon-cross::before{ - content:"✗"; } - -.bp3-icon-crown::before{ - content:""; } - -.bp3-icon-cube::before{ - content:""; } - -.bp3-icon-cube-add::before{ - content:""; } - -.bp3-icon-cube-remove::before{ - content:""; } - -.bp3-icon-curved-range-chart::before{ - content:""; } - -.bp3-icon-cut::before{ - content:""; } - -.bp3-icon-dashboard::before{ - content:""; } - -.bp3-icon-data-lineage::before{ - content:""; } - -.bp3-icon-database::before{ - content:""; } - -.bp3-icon-delete::before{ - content:""; } - -.bp3-icon-delta::before{ - content:"Δ"; } - -.bp3-icon-derive-column::before{ - content:""; } - -.bp3-icon-desktop::before{ - content:""; } - -.bp3-icon-diagnosis::before{ - content:""; } - -.bp3-icon-diagram-tree::before{ - content:""; } - -.bp3-icon-direction-left::before{ - content:""; } - -.bp3-icon-direction-right::before{ - content:""; } - -.bp3-icon-disable::before{ - content:""; } - -.bp3-icon-document::before{ - content:""; } - -.bp3-icon-document-open::before{ - content:""; } - -.bp3-icon-document-share::before{ - content:""; } - -.bp3-icon-dollar::before{ - content:"$"; } - -.bp3-icon-dot::before{ - content:"•"; } - -.bp3-icon-double-caret-horizontal::before{ - content:""; } - -.bp3-icon-double-caret-vertical::before{ - content:""; } - -.bp3-icon-double-chevron-down::before{ - content:""; } - -.bp3-icon-double-chevron-left::before{ - content:""; } - -.bp3-icon-double-chevron-right::before{ - content:""; } - -.bp3-icon-double-chevron-up::before{ - content:""; } - -.bp3-icon-doughnut-chart::before{ - content:""; } - -.bp3-icon-download::before{ - content:""; } - -.bp3-icon-drag-handle-horizontal::before{ - content:""; } - -.bp3-icon-drag-handle-vertical::before{ - content:""; } - -.bp3-icon-draw::before{ - content:""; } - -.bp3-icon-drive-time::before{ - content:""; } - -.bp3-icon-duplicate::before{ - content:""; } - -.bp3-icon-edit::before{ - content:"✎"; } - -.bp3-icon-eject::before{ - content:"⏏"; } - -.bp3-icon-endorsed::before{ - content:""; } - -.bp3-icon-envelope::before{ - content:"✉"; } - -.bp3-icon-equals::before{ - content:""; } - -.bp3-icon-eraser::before{ - content:""; } - -.bp3-icon-error::before{ - content:""; } - -.bp3-icon-euro::before{ - content:"€"; } - -.bp3-icon-exchange::before{ - content:""; } - -.bp3-icon-exclude-row::before{ - content:""; } - -.bp3-icon-expand-all::before{ - content:""; } - -.bp3-icon-export::before{ - content:""; } - -.bp3-icon-eye-off::before{ - content:""; } - -.bp3-icon-eye-on::before{ - content:""; } - -.bp3-icon-eye-open::before{ - content:""; } - -.bp3-icon-fast-backward::before{ - content:""; } - -.bp3-icon-fast-forward::before{ - content:""; } - -.bp3-icon-feed::before{ - content:""; } - -.bp3-icon-feed-subscribed::before{ - content:""; } - -.bp3-icon-film::before{ - content:""; } - -.bp3-icon-filter::before{ - content:""; } - -.bp3-icon-filter-keep::before{ - content:""; } - -.bp3-icon-filter-list::before{ - content:""; } - -.bp3-icon-filter-open::before{ - content:""; } - -.bp3-icon-filter-remove::before{ - content:""; } - -.bp3-icon-flag::before{ - content:"⚑"; } - -.bp3-icon-flame::before{ - content:""; } - -.bp3-icon-flash::before{ - content:""; } - -.bp3-icon-floppy-disk::before{ - content:""; } - -.bp3-icon-flow-branch::before{ - content:""; } - -.bp3-icon-flow-end::before{ - content:""; } - -.bp3-icon-flow-linear::before{ - content:""; } - -.bp3-icon-flow-review::before{ - content:""; } - -.bp3-icon-flow-review-branch::before{ - content:""; } - -.bp3-icon-flows::before{ - content:""; } - -.bp3-icon-folder-close::before{ - content:""; } - -.bp3-icon-folder-new::before{ - content:""; } - -.bp3-icon-folder-open::before{ - content:""; } - -.bp3-icon-folder-shared::before{ - content:""; } - -.bp3-icon-folder-shared-open::before{ - content:""; } - -.bp3-icon-follower::before{ - content:""; } - -.bp3-icon-following::before{ - content:""; } - -.bp3-icon-font::before{ - content:""; } - -.bp3-icon-fork::before{ - content:""; } - -.bp3-icon-form::before{ - content:""; } - -.bp3-icon-full-circle::before{ - content:""; } - -.bp3-icon-full-stacked-chart::before{ - content:""; } - -.bp3-icon-fullscreen::before{ - content:""; } - -.bp3-icon-function::before{ - content:""; } - -.bp3-icon-gantt-chart::before{ - content:""; } - -.bp3-icon-geolocation::before{ - content:""; } - -.bp3-icon-geosearch::before{ - content:""; } - -.bp3-icon-git-branch::before{ - content:""; } - -.bp3-icon-git-commit::before{ - content:""; } - -.bp3-icon-git-merge::before{ - content:""; } - -.bp3-icon-git-new-branch::before{ - content:""; } - -.bp3-icon-git-pull::before{ - content:""; } - -.bp3-icon-git-push::before{ - content:""; } - -.bp3-icon-git-repo::before{ - content:""; } - -.bp3-icon-glass::before{ - content:""; } - -.bp3-icon-globe::before{ - content:""; } - -.bp3-icon-globe-network::before{ - content:""; } - -.bp3-icon-graph::before{ - content:""; } - -.bp3-icon-graph-remove::before{ - content:""; } - -.bp3-icon-greater-than::before{ - content:""; } - -.bp3-icon-greater-than-or-equal-to::before{ - content:""; } - -.bp3-icon-grid::before{ - content:""; } - -.bp3-icon-grid-view::before{ - content:""; } - -.bp3-icon-group-objects::before{ - content:""; } - -.bp3-icon-grouped-bar-chart::before{ - content:""; } - -.bp3-icon-hand::before{ - content:""; } - -.bp3-icon-hand-down::before{ - content:""; } - -.bp3-icon-hand-left::before{ - content:""; } - -.bp3-icon-hand-right::before{ - content:""; } - -.bp3-icon-hand-up::before{ - content:""; } - -.bp3-icon-header::before{ - content:""; } - -.bp3-icon-header-one::before{ - content:""; } - -.bp3-icon-header-two::before{ - content:""; } - -.bp3-icon-headset::before{ - content:""; } - -.bp3-icon-heart::before{ - content:"♥"; } - -.bp3-icon-heart-broken::before{ - content:""; } - -.bp3-icon-heat-grid::before{ - content:""; } - -.bp3-icon-heatmap::before{ - content:""; } - -.bp3-icon-help::before{ - content:"?"; } - -.bp3-icon-helper-management::before{ - content:""; } - -.bp3-icon-highlight::before{ - content:""; } - -.bp3-icon-history::before{ - content:""; } - -.bp3-icon-home::before{ - content:"⌂"; } - -.bp3-icon-horizontal-bar-chart::before{ - content:""; } - -.bp3-icon-horizontal-bar-chart-asc::before{ - content:""; } - -.bp3-icon-horizontal-bar-chart-desc::before{ - content:""; } - -.bp3-icon-horizontal-distribution::before{ - content:""; } - -.bp3-icon-id-number::before{ - content:""; } - -.bp3-icon-image-rotate-left::before{ - content:""; } - -.bp3-icon-image-rotate-right::before{ - content:""; } - -.bp3-icon-import::before{ - content:""; } - -.bp3-icon-inbox::before{ - content:""; } - -.bp3-icon-inbox-filtered::before{ - content:""; } - -.bp3-icon-inbox-geo::before{ - content:""; } - -.bp3-icon-inbox-search::before{ - content:""; } - -.bp3-icon-inbox-update::before{ - content:""; } - -.bp3-icon-info-sign::before{ - content:"ℹ"; } - -.bp3-icon-inheritance::before{ - content:""; } - -.bp3-icon-inner-join::before{ - content:""; } - -.bp3-icon-insert::before{ - content:""; } - -.bp3-icon-intersection::before{ - content:""; } - -.bp3-icon-ip-address::before{ - content:""; } - -.bp3-icon-issue::before{ - content:""; } - -.bp3-icon-issue-closed::before{ - content:""; } - -.bp3-icon-issue-new::before{ - content:""; } - -.bp3-icon-italic::before{ - content:""; } - -.bp3-icon-join-table::before{ - content:""; } - -.bp3-icon-key::before{ - content:""; } - -.bp3-icon-key-backspace::before{ - content:""; } - -.bp3-icon-key-command::before{ - content:""; } - -.bp3-icon-key-control::before{ - content:""; } - -.bp3-icon-key-delete::before{ - content:""; } - -.bp3-icon-key-enter::before{ - content:""; } - -.bp3-icon-key-escape::before{ - content:""; } - -.bp3-icon-key-option::before{ - content:""; } - -.bp3-icon-key-shift::before{ - content:""; } - -.bp3-icon-key-tab::before{ - content:""; } - -.bp3-icon-known-vehicle::before{ - content:""; } - -.bp3-icon-lab-test::before{ - content:""; } - -.bp3-icon-label::before{ - content:""; } - -.bp3-icon-layer::before{ - content:""; } - -.bp3-icon-layers::before{ - content:""; } - -.bp3-icon-layout::before{ - content:""; } - -.bp3-icon-layout-auto::before{ - content:""; } - -.bp3-icon-layout-balloon::before{ - content:""; } - -.bp3-icon-layout-circle::before{ - content:""; } - -.bp3-icon-layout-grid::before{ - content:""; } - -.bp3-icon-layout-group-by::before{ - content:""; } - -.bp3-icon-layout-hierarchy::before{ - content:""; } - -.bp3-icon-layout-linear::before{ - content:""; } - -.bp3-icon-layout-skew-grid::before{ - content:""; } - -.bp3-icon-layout-sorted-clusters::before{ - content:""; } - -.bp3-icon-learning::before{ - content:""; } - -.bp3-icon-left-join::before{ - content:""; } - -.bp3-icon-less-than::before{ - content:""; } - -.bp3-icon-less-than-or-equal-to::before{ - content:""; } - -.bp3-icon-lifesaver::before{ - content:""; } - -.bp3-icon-lightbulb::before{ - content:""; } - -.bp3-icon-link::before{ - content:""; } - -.bp3-icon-list::before{ - content:"☰"; } - -.bp3-icon-list-columns::before{ - content:""; } - -.bp3-icon-list-detail-view::before{ - content:""; } - -.bp3-icon-locate::before{ - content:""; } - -.bp3-icon-lock::before{ - content:""; } - -.bp3-icon-log-in::before{ - content:""; } - -.bp3-icon-log-out::before{ - content:""; } - -.bp3-icon-manual::before{ - content:""; } - -.bp3-icon-manually-entered-data::before{ - content:""; } - -.bp3-icon-map::before{ - content:""; } - -.bp3-icon-map-create::before{ - content:""; } - -.bp3-icon-map-marker::before{ - content:""; } - -.bp3-icon-maximize::before{ - content:""; } - -.bp3-icon-media::before{ - content:""; } - -.bp3-icon-menu::before{ - content:""; } - -.bp3-icon-menu-closed::before{ - content:""; } - -.bp3-icon-menu-open::before{ - content:""; } - -.bp3-icon-merge-columns::before{ - content:""; } - -.bp3-icon-merge-links::before{ - content:""; } - -.bp3-icon-minimize::before{ - content:""; } - -.bp3-icon-minus::before{ - content:"−"; } - -.bp3-icon-mobile-phone::before{ - content:""; } - -.bp3-icon-mobile-video::before{ - content:""; } - -.bp3-icon-moon::before{ - content:""; } - -.bp3-icon-more::before{ - content:""; } - -.bp3-icon-mountain::before{ - content:""; } - -.bp3-icon-move::before{ - content:""; } - -.bp3-icon-mugshot::before{ - content:""; } - -.bp3-icon-multi-select::before{ - content:""; } - -.bp3-icon-music::before{ - content:""; } - -.bp3-icon-new-drawing::before{ - content:""; } - -.bp3-icon-new-grid-item::before{ - content:""; } - -.bp3-icon-new-layer::before{ - content:""; } - -.bp3-icon-new-layers::before{ - content:""; } - -.bp3-icon-new-link::before{ - content:""; } - -.bp3-icon-new-object::before{ - content:""; } - -.bp3-icon-new-person::before{ - content:""; } - -.bp3-icon-new-prescription::before{ - content:""; } - -.bp3-icon-new-text-box::before{ - content:""; } - -.bp3-icon-ninja::before{ - content:""; } - -.bp3-icon-not-equal-to::before{ - content:""; } - -.bp3-icon-notifications::before{ - content:""; } - -.bp3-icon-notifications-updated::before{ - content:""; } - -.bp3-icon-numbered-list::before{ - content:""; } - -.bp3-icon-numerical::before{ - content:""; } - -.bp3-icon-office::before{ - content:""; } - -.bp3-icon-offline::before{ - content:""; } - -.bp3-icon-oil-field::before{ - content:""; } - -.bp3-icon-one-column::before{ - content:""; } - -.bp3-icon-outdated::before{ - content:""; } - -.bp3-icon-page-layout::before{ - content:""; } - -.bp3-icon-panel-stats::before{ - content:""; } - -.bp3-icon-panel-table::before{ - content:""; } - -.bp3-icon-paperclip::before{ - content:""; } - -.bp3-icon-paragraph::before{ - content:""; } - -.bp3-icon-path::before{ - content:""; } - -.bp3-icon-path-search::before{ - content:""; } - -.bp3-icon-pause::before{ - content:""; } - -.bp3-icon-people::before{ - content:""; } - -.bp3-icon-percentage::before{ - content:""; } - -.bp3-icon-person::before{ - content:""; } - -.bp3-icon-phone::before{ - content:"☎"; } - -.bp3-icon-pie-chart::before{ - content:""; } - -.bp3-icon-pin::before{ - content:""; } - -.bp3-icon-pivot::before{ - content:""; } - -.bp3-icon-pivot-table::before{ - content:""; } - -.bp3-icon-play::before{ - content:""; } - -.bp3-icon-plus::before{ - content:"+"; } - -.bp3-icon-polygon-filter::before{ - content:""; } - -.bp3-icon-power::before{ - content:""; } - -.bp3-icon-predictive-analysis::before{ - content:""; } - -.bp3-icon-prescription::before{ - content:""; } - -.bp3-icon-presentation::before{ - content:""; } - -.bp3-icon-print::before{ - content:"⎙"; } - -.bp3-icon-projects::before{ - content:""; } - -.bp3-icon-properties::before{ - content:""; } - -.bp3-icon-property::before{ - content:""; } - -.bp3-icon-publish-function::before{ - content:""; } - -.bp3-icon-pulse::before{ - content:""; } - -.bp3-icon-random::before{ - content:""; } - -.bp3-icon-record::before{ - content:""; } - -.bp3-icon-redo::before{ - content:""; } - -.bp3-icon-refresh::before{ - content:""; } - -.bp3-icon-regression-chart::before{ - content:""; } - -.bp3-icon-remove::before{ - content:""; } - -.bp3-icon-remove-column::before{ - content:""; } - -.bp3-icon-remove-column-left::before{ - content:""; } - -.bp3-icon-remove-column-right::before{ - content:""; } - -.bp3-icon-remove-row-bottom::before{ - content:""; } - -.bp3-icon-remove-row-top::before{ - content:""; } - -.bp3-icon-repeat::before{ - content:""; } - -.bp3-icon-reset::before{ - content:""; } - -.bp3-icon-resolve::before{ - content:""; } - -.bp3-icon-rig::before{ - content:""; } - -.bp3-icon-right-join::before{ - content:""; } - -.bp3-icon-ring::before{ - content:""; } - -.bp3-icon-rotate-document::before{ - content:""; } - -.bp3-icon-rotate-page::before{ - content:""; } - -.bp3-icon-satellite::before{ - content:""; } - -.bp3-icon-saved::before{ - content:""; } - -.bp3-icon-scatter-plot::before{ - content:""; } - -.bp3-icon-search::before{ - content:""; } - -.bp3-icon-search-around::before{ - content:""; } - -.bp3-icon-search-template::before{ - content:""; } - -.bp3-icon-search-text::before{ - content:""; } - -.bp3-icon-segmented-control::before{ - content:""; } - -.bp3-icon-select::before{ - content:""; } - -.bp3-icon-selection::before{ - content:"⦿"; } - -.bp3-icon-send-to::before{ - content:""; } - -.bp3-icon-send-to-graph::before{ - content:""; } - -.bp3-icon-send-to-map::before{ - content:""; } - -.bp3-icon-series-add::before{ - content:""; } - -.bp3-icon-series-configuration::before{ - content:""; } - -.bp3-icon-series-derived::before{ - content:""; } - -.bp3-icon-series-filtered::before{ - content:""; } - -.bp3-icon-series-search::before{ - content:""; } - -.bp3-icon-settings::before{ - content:""; } - -.bp3-icon-share::before{ - content:""; } - -.bp3-icon-shield::before{ - content:""; } - -.bp3-icon-shop::before{ - content:""; } - -.bp3-icon-shopping-cart::before{ - content:""; } - -.bp3-icon-signal-search::before{ - content:""; } - -.bp3-icon-sim-card::before{ - content:""; } - -.bp3-icon-slash::before{ - content:""; } - -.bp3-icon-small-cross::before{ - content:""; } - -.bp3-icon-small-minus::before{ - content:""; } - -.bp3-icon-small-plus::before{ - content:""; } - -.bp3-icon-small-tick::before{ - content:""; } - -.bp3-icon-snowflake::before{ - content:""; } - -.bp3-icon-social-media::before{ - content:""; } - -.bp3-icon-sort::before{ - content:""; } - -.bp3-icon-sort-alphabetical::before{ - content:""; } - -.bp3-icon-sort-alphabetical-desc::before{ - content:""; } - -.bp3-icon-sort-asc::before{ - content:""; } - -.bp3-icon-sort-desc::before{ - content:""; } - -.bp3-icon-sort-numerical::before{ - content:""; } - -.bp3-icon-sort-numerical-desc::before{ - content:""; } - -.bp3-icon-split-columns::before{ - content:""; } - -.bp3-icon-square::before{ - content:""; } - -.bp3-icon-stacked-chart::before{ - content:""; } - -.bp3-icon-star::before{ - content:"★"; } - -.bp3-icon-star-empty::before{ - content:"☆"; } - -.bp3-icon-step-backward::before{ - content:""; } - -.bp3-icon-step-chart::before{ - content:""; } - -.bp3-icon-step-forward::before{ - content:""; } - -.bp3-icon-stop::before{ - content:""; } - -.bp3-icon-stopwatch::before{ - content:""; } - -.bp3-icon-strikethrough::before{ - content:""; } - -.bp3-icon-style::before{ - content:""; } - -.bp3-icon-swap-horizontal::before{ - content:""; } - -.bp3-icon-swap-vertical::before{ - content:""; } - -.bp3-icon-symbol-circle::before{ - content:""; } - -.bp3-icon-symbol-cross::before{ - content:""; } - -.bp3-icon-symbol-diamond::before{ - content:""; } - -.bp3-icon-symbol-square::before{ - content:""; } - -.bp3-icon-symbol-triangle-down::before{ - content:""; } - -.bp3-icon-symbol-triangle-up::before{ - content:""; } - -.bp3-icon-tag::before{ - content:""; } - -.bp3-icon-take-action::before{ - content:""; } - -.bp3-icon-taxi::before{ - content:""; } - -.bp3-icon-text-highlight::before{ - content:""; } - -.bp3-icon-th::before{ - content:""; } - -.bp3-icon-th-derived::before{ - content:""; } - -.bp3-icon-th-disconnect::before{ - content:""; } - -.bp3-icon-th-filtered::before{ - content:""; } - -.bp3-icon-th-list::before{ - content:""; } - -.bp3-icon-thumbs-down::before{ - content:""; } - -.bp3-icon-thumbs-up::before{ - content:""; } - -.bp3-icon-tick::before{ - content:"✓"; } - -.bp3-icon-tick-circle::before{ - content:""; } - -.bp3-icon-time::before{ - content:"⏲"; } - -.bp3-icon-timeline-area-chart::before{ - content:""; } - -.bp3-icon-timeline-bar-chart::before{ - content:""; } - -.bp3-icon-timeline-events::before{ - content:""; } - -.bp3-icon-timeline-line-chart::before{ - content:""; } - -.bp3-icon-tint::before{ - content:""; } - -.bp3-icon-torch::before{ - content:""; } - -.bp3-icon-tractor::before{ - content:""; } - -.bp3-icon-train::before{ - content:""; } - -.bp3-icon-translate::before{ - content:""; } - -.bp3-icon-trash::before{ - content:""; } - -.bp3-icon-tree::before{ - content:""; } - -.bp3-icon-trending-down::before{ - content:""; } - -.bp3-icon-trending-up::before{ - content:""; } - -.bp3-icon-truck::before{ - content:""; } - -.bp3-icon-two-columns::before{ - content:""; } - -.bp3-icon-unarchive::before{ - content:""; } - -.bp3-icon-underline::before{ - content:"⎁"; } - -.bp3-icon-undo::before{ - content:"⎌"; } - -.bp3-icon-ungroup-objects::before{ - content:""; } - -.bp3-icon-unknown-vehicle::before{ - content:""; } - -.bp3-icon-unlock::before{ - content:""; } - -.bp3-icon-unpin::before{ - content:""; } - -.bp3-icon-unresolve::before{ - content:""; } - -.bp3-icon-updated::before{ - content:""; } - -.bp3-icon-upload::before{ - content:""; } - -.bp3-icon-user::before{ - content:""; } - -.bp3-icon-variable::before{ - content:""; } - -.bp3-icon-vertical-bar-chart-asc::before{ - content:""; } - -.bp3-icon-vertical-bar-chart-desc::before{ - content:""; } - -.bp3-icon-vertical-distribution::before{ - content:""; } - -.bp3-icon-video::before{ - content:""; } - -.bp3-icon-volume-down::before{ - content:""; } - -.bp3-icon-volume-off::before{ - content:""; } - -.bp3-icon-volume-up::before{ - content:""; } - -.bp3-icon-walk::before{ - content:""; } - -.bp3-icon-warning-sign::before{ - content:""; } - -.bp3-icon-waterfall-chart::before{ - content:""; } - -.bp3-icon-widget::before{ - content:""; } - -.bp3-icon-widget-button::before{ - content:""; } - -.bp3-icon-widget-footer::before{ - content:""; } - -.bp3-icon-widget-header::before{ - content:""; } - -.bp3-icon-wrench::before{ - content:""; } - -.bp3-icon-zoom-in::before{ - content:""; } - -.bp3-icon-zoom-out::before{ - content:""; } - -.bp3-icon-zoom-to-fit::before{ - content:""; } -.bp3-submenu > .bp3-popover-wrapper{ - display:block; } - -.bp3-submenu .bp3-popover-target{ - display:block; } - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ } - -.bp3-submenu.bp3-popover{ - -webkit-box-shadow:none; - box-shadow:none; - padding:0 5px; } - .bp3-submenu.bp3-popover > .bp3-popover-content{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-submenu.bp3-popover, .bp3-submenu.bp3-popover.bp3-dark{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-submenu.bp3-popover > .bp3-popover-content, .bp3-submenu.bp3-popover.bp3-dark > .bp3-popover-content{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } -.bp3-menu{ - background:#ffffff; - border-radius:3px; - color:#182026; - list-style:none; - margin:0; - min-width:180px; - padding:5px; - text-align:left; } - -.bp3-menu-divider{ - border-top:1px solid rgba(16, 22, 26, 0.15); - display:block; - margin:5px; } - .bp3-dark .bp3-menu-divider{ - border-top-color:rgba(255, 255, 255, 0.15); } - -.bp3-menu-item{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - border-radius:2px; - color:inherit; - line-height:20px; - padding:5px 7px; - text-decoration:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-menu-item > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-menu-item > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-menu-item::before, - .bp3-menu-item > *{ - margin-right:7px; } - .bp3-menu-item:empty::before, - .bp3-menu-item > :last-child{ - margin-right:0; } - .bp3-menu-item > .bp3-fill{ - word-break:break-word; } - .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - background-color:rgba(167, 182, 194, 0.3); - cursor:pointer; - text-decoration:none; } - .bp3-menu-item.bp3-disabled{ - background-color:inherit; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-menu-item{ - color:inherit; } - .bp3-dark .bp3-menu-item:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - background-color:rgba(138, 155, 168, 0.15); - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-disabled{ - background-color:inherit; - color:rgba(167, 182, 194, 0.6); } - .bp3-menu-item.bp3-intent-primary{ - color:#106ba3; } - .bp3-menu-item.bp3-intent-primary .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-primary::before, .bp3-menu-item.bp3-intent-primary::after, - .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{ - color:#106ba3; } - .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary.bp3-active{ - background-color:#137cbd; } - .bp3-menu-item.bp3-intent-primary:active{ - background-color:#106ba3; } - .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary:active, .bp3-menu-item.bp3-intent-primary:active::before, .bp3-menu-item.bp3-intent-primary:active::after, - .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-menu-item.bp3-intent-primary.bp3-active::after, - .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-success{ - color:#0d8050; } - .bp3-menu-item.bp3-intent-success .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-success::before, .bp3-menu-item.bp3-intent-success::after, - .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{ - color:#0d8050; } - .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success.bp3-active{ - background-color:#0f9960; } - .bp3-menu-item.bp3-intent-success:active{ - background-color:#0d8050; } - .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-menu-item.bp3-intent-success:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success:active, .bp3-menu-item.bp3-intent-success:active::before, .bp3-menu-item.bp3-intent-success:active::after, - .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-menu-item.bp3-intent-success.bp3-active::after, - .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-warning{ - color:#bf7326; } - .bp3-menu-item.bp3-intent-warning .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-warning::before, .bp3-menu-item.bp3-intent-warning::after, - .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{ - color:#bf7326; } - .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning.bp3-active{ - background-color:#d9822b; } - .bp3-menu-item.bp3-intent-warning:active{ - background-color:#bf7326; } - .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning:active, .bp3-menu-item.bp3-intent-warning:active::before, .bp3-menu-item.bp3-intent-warning:active::after, - .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-menu-item.bp3-intent-warning.bp3-active::after, - .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-danger{ - color:#c23030; } - .bp3-menu-item.bp3-intent-danger .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-danger::before, .bp3-menu-item.bp3-intent-danger::after, - .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{ - color:#c23030; } - .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger.bp3-active{ - background-color:#db3737; } - .bp3-menu-item.bp3-intent-danger:active{ - background-color:#c23030; } - .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger:active, .bp3-menu-item.bp3-intent-danger:active::before, .bp3-menu-item.bp3-intent-danger:active::after, - .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-menu-item.bp3-intent-danger.bp3-active::after, - .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - margin-right:7px; } - .bp3-menu-item::before, - .bp3-menu-item > .bp3-icon{ - color:#5c7080; - margin-top:2px; } - .bp3-menu-item .bp3-menu-item-label{ - color:#5c7080; } - .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - color:inherit; } - .bp3-menu-item.bp3-active, .bp3-menu-item:active{ - background-color:rgba(115, 134, 148, 0.3); } - .bp3-menu-item.bp3-disabled{ - background-color:inherit !important; - color:rgba(92, 112, 128, 0.6) !important; - cursor:not-allowed !important; - outline:none !important; } - .bp3-menu-item.bp3-disabled::before, - .bp3-menu-item.bp3-disabled > .bp3-icon, - .bp3-menu-item.bp3-disabled .bp3-menu-item-label{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-large .bp3-menu-item{ - font-size:16px; - line-height:22px; - padding:9px 7px; } - .bp3-large .bp3-menu-item .bp3-icon{ - margin-top:3px; } - .bp3-large .bp3-menu-item::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - margin-right:10px; - margin-top:1px; } - -button.bp3-menu-item{ - background:none; - border:none; - text-align:left; - width:100%; } -.bp3-menu-header{ - border-top:1px solid rgba(16, 22, 26, 0.15); - display:block; - margin:5px; - cursor:default; - padding-left:2px; } - .bp3-dark .bp3-menu-header{ - border-top-color:rgba(255, 255, 255, 0.15); } - .bp3-menu-header:first-of-type{ - border-top:none; } - .bp3-menu-header > h6{ - color:#182026; - font-weight:600; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - line-height:17px; - margin:0; - padding:10px 7px 0 1px; } - .bp3-dark .bp3-menu-header > h6{ - color:#f5f8fa; } - .bp3-menu-header:first-of-type > h6{ - padding-top:0; } - .bp3-large .bp3-menu-header > h6{ - font-size:18px; - padding-bottom:5px; - padding-top:15px; } - .bp3-large .bp3-menu-header:first-of-type > h6{ - padding-top:0; } - -.bp3-dark .bp3-menu{ - background:#30404d; - color:#f5f8fa; } - -.bp3-dark .bp3-menu-item{ } - .bp3-dark .bp3-menu-item.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-primary::before, .bp3-dark .bp3-menu-item.bp3-intent-primary::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{ - color:#48aff0; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active{ - background-color:#137cbd; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:active{ - background-color:#106ba3; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary:active, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-success::before, .bp3-dark .bp3-menu-item.bp3-intent-success::after, - .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{ - color:#3dcc91; } - .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active{ - background-color:#0f9960; } - .bp3-dark .bp3-menu-item.bp3-intent-success:active{ - background-color:#0d8050; } - .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success:active, .bp3-dark .bp3-menu-item.bp3-intent-success:active::before, .bp3-dark .bp3-menu-item.bp3-intent-success:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-warning::before, .bp3-dark .bp3-menu-item.bp3-intent-warning::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{ - color:#ffb366; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active{ - background-color:#d9822b; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:active{ - background-color:#bf7326; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning:active, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-danger::before, .bp3-dark .bp3-menu-item.bp3-intent-danger::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{ - color:#ff7373; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active{ - background-color:#db3737; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:active{ - background-color:#c23030; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger:active, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item::before, - .bp3-dark .bp3-menu-item > .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-menu-item .bp3-menu-item-label{ - color:#a7b6c2; } - .bp3-dark .bp3-menu-item.bp3-active, .bp3-dark .bp3-menu-item:active{ - background-color:rgba(138, 155, 168, 0.3); } - .bp3-dark .bp3-menu-item.bp3-disabled{ - color:rgba(167, 182, 194, 0.6) !important; } - .bp3-dark .bp3-menu-item.bp3-disabled::before, - .bp3-dark .bp3-menu-item.bp3-disabled > .bp3-icon, - .bp3-dark .bp3-menu-item.bp3-disabled .bp3-menu-item-label{ - color:rgba(167, 182, 194, 0.6) !important; } - -.bp3-dark .bp3-menu-divider, -.bp3-dark .bp3-menu-header{ - border-color:rgba(255, 255, 255, 0.15); } - -.bp3-dark .bp3-menu-header > h6{ - color:#f5f8fa; } - -.bp3-label .bp3-menu{ - margin-top:5px; } -.bp3-navbar{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - height:50px; - padding:0 15px; - position:relative; - width:100%; - z-index:10; } - .bp3-navbar.bp3-dark, - .bp3-dark .bp3-navbar{ - background-color:#394b59; } - .bp3-navbar.bp3-dark{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-navbar{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-navbar.bp3-fixed-top{ - left:0; - position:fixed; - right:0; - top:0; } - -.bp3-navbar-heading{ - font-size:16px; - margin-right:15px; } - -.bp3-navbar-group{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:50px; } - .bp3-navbar-group.bp3-align-left{ - float:left; } - .bp3-navbar-group.bp3-align-right{ - float:right; } - -.bp3-navbar-divider{ - border-left:1px solid rgba(16, 22, 26, 0.15); - height:20px; - margin:0 10px; } - .bp3-dark .bp3-navbar-divider{ - border-left-color:rgba(255, 255, 255, 0.15); } -.bp3-non-ideal-state{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - height:100%; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - text-align:center; - width:100%; } - .bp3-non-ideal-state > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-non-ideal-state > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-non-ideal-state::before, - .bp3-non-ideal-state > *{ - margin-bottom:20px; } - .bp3-non-ideal-state:empty::before, - .bp3-non-ideal-state > :last-child{ - margin-bottom:0; } - .bp3-non-ideal-state > *{ - max-width:400px; } - -.bp3-non-ideal-state-visual{ - color:rgba(92, 112, 128, 0.6); - font-size:60px; } - .bp3-dark .bp3-non-ideal-state-visual{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-overflow-list{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-wrap:nowrap; - flex-wrap:nowrap; - min-width:0; } - -.bp3-overflow-list-spacer{ - -ms-flex-negative:1; - flex-shrink:1; - width:1px; } - -body.bp3-overlay-open{ - overflow:hidden; } - -.bp3-overlay{ - bottom:0; - left:0; - position:static; - right:0; - top:0; - z-index:20; } - .bp3-overlay:not(.bp3-overlay-open){ - pointer-events:none; } - .bp3-overlay.bp3-overlay-container{ - overflow:hidden; - position:fixed; } - .bp3-overlay.bp3-overlay-container.bp3-overlay-inline{ - position:absolute; } - .bp3-overlay.bp3-overlay-scroll-container{ - overflow:auto; - position:fixed; } - .bp3-overlay.bp3-overlay-scroll-container.bp3-overlay-inline{ - position:absolute; } - .bp3-overlay.bp3-overlay-inline{ - display:inline; - overflow:visible; } - -.bp3-overlay-content{ - position:fixed; - z-index:20; } - .bp3-overlay-inline .bp3-overlay-content, - .bp3-overlay-scroll-container .bp3-overlay-content{ - position:absolute; } - -.bp3-overlay-backdrop{ - bottom:0; - left:0; - position:fixed; - right:0; - top:0; - opacity:1; - background-color:rgba(16, 22, 26, 0.7); - overflow:auto; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - z-index:20; } - .bp3-overlay-backdrop.bp3-overlay-enter, .bp3-overlay-backdrop.bp3-overlay-appear{ - opacity:0; } - .bp3-overlay-backdrop.bp3-overlay-enter-active, .bp3-overlay-backdrop.bp3-overlay-appear-active{ - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-overlay-backdrop.bp3-overlay-exit{ - opacity:1; } - .bp3-overlay-backdrop.bp3-overlay-exit-active{ - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-overlay-backdrop:focus{ - outline:none; } - .bp3-overlay-inline .bp3-overlay-backdrop{ - position:absolute; } -.bp3-panel-stack{ - overflow:hidden; - position:relative; } - -.bp3-panel-stack-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 1px rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-negative:0; - flex-shrink:0; - height:30px; - z-index:1; } - .bp3-dark .bp3-panel-stack-header{ - -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 1px rgba(255, 255, 255, 0.15); } - .bp3-panel-stack-header > span{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; } - .bp3-panel-stack-header .bp3-heading{ - margin:0 5px; } - -.bp3-button.bp3-panel-stack-header-back{ - margin-left:5px; - padding-left:0; - white-space:nowrap; } - .bp3-button.bp3-panel-stack-header-back .bp3-icon{ - margin:0 2px; } - -.bp3-panel-stack-view{ - bottom:0; - left:0; - position:absolute; - right:0; - top:0; - background-color:#ffffff; - border-right:1px solid rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin-right:-1px; - overflow-y:auto; - z-index:1; } - .bp3-dark .bp3-panel-stack-view{ - background-color:#30404d; } - .bp3-panel-stack-view:nth-last-child(n + 4){ - display:none; } - -.bp3-panel-stack-push .bp3-panel-stack-enter, .bp3-panel-stack-push .bp3-panel-stack-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; } - -.bp3-panel-stack-push .bp3-panel-stack-enter-active, .bp3-panel-stack-push .bp3-panel-stack-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-push .bp3-panel-stack-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack-push .bp3-panel-stack-exit-active{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-pop .bp3-panel-stack-enter, .bp3-panel-stack-pop .bp3-panel-stack-appear{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; } - -.bp3-panel-stack-pop .bp3-panel-stack-enter-active, .bp3-panel-stack-pop .bp3-panel-stack-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-pop .bp3-panel-stack-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack-pop .bp3-panel-stack-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } -.bp3-panel-stack2{ - overflow:hidden; - position:relative; } - -.bp3-panel-stack2-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 1px rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-negative:0; - flex-shrink:0; - height:30px; - z-index:1; } - .bp3-dark .bp3-panel-stack2-header{ - -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 1px rgba(255, 255, 255, 0.15); } - .bp3-panel-stack2-header > span{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; } - .bp3-panel-stack2-header .bp3-heading{ - margin:0 5px; } - -.bp3-button.bp3-panel-stack2-header-back{ - margin-left:5px; - padding-left:0; - white-space:nowrap; } - .bp3-button.bp3-panel-stack2-header-back .bp3-icon{ - margin:0 2px; } - -.bp3-panel-stack2-view{ - bottom:0; - left:0; - position:absolute; - right:0; - top:0; - background-color:#ffffff; - border-right:1px solid rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin-right:-1px; - overflow-y:auto; - z-index:1; } - .bp3-dark .bp3-panel-stack2-view{ - background-color:#30404d; } - .bp3-panel-stack2-view:nth-last-child(n + 4){ - display:none; } - -.bp3-panel-stack2-push .bp3-panel-stack2-enter, .bp3-panel-stack2-push .bp3-panel-stack2-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; } - -.bp3-panel-stack2-push .bp3-panel-stack2-enter-active, .bp3-panel-stack2-push .bp3-panel-stack2-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-push .bp3-panel-stack2-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack2-push .bp3-panel-stack2-exit-active{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-enter, .bp3-panel-stack2-pop .bp3-panel-stack2-appear{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-enter-active, .bp3-panel-stack2-pop .bp3-panel-stack2-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } -.bp3-popover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - -webkit-transform:scale(1); - transform:scale(1); - border-radius:3px; - display:inline-block; - z-index:20; } - .bp3-popover .bp3-popover-arrow{ - height:30px; - position:absolute; - width:30px; } - .bp3-popover .bp3-popover-arrow::before{ - height:20px; - margin:5px; - width:20px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover{ - margin-bottom:17px; - margin-top:-17px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{ - bottom:-11px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(-90deg); - transform:rotate(-90deg); } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover{ - margin-left:17px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{ - left:-11px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(0); - transform:rotate(0); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover{ - margin-top:17px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{ - top:-11px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover{ - margin-left:-17px; - margin-right:17px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{ - right:-11px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(180deg); - transform:rotate(180deg); } - .bp3-tether-element-attached-middle > .bp3-popover > .bp3-popover-arrow{ - top:50%; - -webkit-transform:translateY(-50%); - transform:translateY(-50%); } - .bp3-tether-element-attached-center > .bp3-popover > .bp3-popover-arrow{ - right:50%; - -webkit-transform:translateX(50%); - transform:translateX(50%); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{ - top:-0.3934px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{ - right:-0.3934px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{ - left:-0.3934px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{ - bottom:-0.3934px; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:top left; - transform-origin:top left; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:top center; - transform-origin:top center; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:top right; - transform-origin:top right; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:center left; - transform-origin:center left; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:center center; - transform-origin:center center; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:center right; - transform-origin:center right; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:bottom left; - transform-origin:bottom left; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:bottom center; - transform-origin:bottom center; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:bottom right; - transform-origin:bottom right; } - .bp3-popover .bp3-popover-content{ - background:#ffffff; - color:inherit; } - .bp3-popover .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); } - .bp3-popover .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.1; } - .bp3-popover .bp3-popover-arrow-fill{ - fill:#ffffff; } - .bp3-popover-enter > .bp3-popover, .bp3-popover-appear > .bp3-popover{ - -webkit-transform:scale(0.3); - transform:scale(0.3); } - .bp3-popover-enter-active > .bp3-popover, .bp3-popover-appear-active > .bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-popover-exit > .bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-popover{ - -webkit-transform:scale(0.3); - transform:scale(0.3); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-popover .bp3-popover-content{ - border-radius:3px; - position:relative; } - .bp3-popover.bp3-popover-content-sizing .bp3-popover-content{ - max-width:350px; - padding:20px; } - .bp3-popover-target + .bp3-overlay .bp3-popover.bp3-popover-content-sizing{ - width:350px; } - .bp3-popover.bp3-minimal{ - margin:0 !important; } - .bp3-popover.bp3-minimal .bp3-popover-arrow{ - display:none; } - .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-enter > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-enter-active > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear-active > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover-exit > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover.bp3-dark, - .bp3-dark .bp3-popover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-popover.bp3-dark .bp3-popover-content, - .bp3-dark .bp3-popover .bp3-popover-content{ - background:#30404d; - color:inherit; } - .bp3-popover.bp3-dark .bp3-popover-arrow::before, - .bp3-dark .bp3-popover .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); } - .bp3-popover.bp3-dark .bp3-popover-arrow-border, - .bp3-dark .bp3-popover .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.2; } - .bp3-popover.bp3-dark .bp3-popover-arrow-fill, - .bp3-dark .bp3-popover .bp3-popover-arrow-fill{ - fill:#30404d; } - -.bp3-popover-arrow::before{ - border-radius:2px; - content:""; - display:block; - position:absolute; - -webkit-transform:rotate(45deg); - transform:rotate(45deg); } - -.bp3-tether-pinned .bp3-popover-arrow{ - display:none; } - -.bp3-popover-backdrop{ - background:rgba(255, 255, 255, 0); } - -.bp3-transition-container{ - opacity:1; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - z-index:20; } - .bp3-transition-container.bp3-popover-enter, .bp3-transition-container.bp3-popover-appear{ - opacity:0; } - .bp3-transition-container.bp3-popover-enter-active, .bp3-transition-container.bp3-popover-appear-active{ - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-transition-container.bp3-popover-exit{ - opacity:1; } - .bp3-transition-container.bp3-popover-exit-active{ - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-transition-container:focus{ - outline:none; } - .bp3-transition-container.bp3-popover-leave .bp3-popover-content{ - pointer-events:none; } - .bp3-transition-container[data-x-out-of-boundaries]{ - display:none; } - -span.bp3-popover-target{ - display:inline-block; } - -.bp3-popover-wrapper.bp3-fill{ - width:100%; } - -.bp3-portal{ - left:0; - position:absolute; - right:0; - top:0; } -@-webkit-keyframes linear-progress-bar-stripes{ - from{ - background-position:0 0; } - to{ - background-position:30px 0; } } -@keyframes linear-progress-bar-stripes{ - from{ - background-position:0 0; } - to{ - background-position:30px 0; } } - -.bp3-progress-bar{ - background:rgba(92, 112, 128, 0.2); - border-radius:40px; - display:block; - height:8px; - overflow:hidden; - position:relative; - width:100%; } - .bp3-progress-bar .bp3-progress-meter{ - background:linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, transparent 75%); - background-color:rgba(92, 112, 128, 0.8); - background-size:30px 30px; - border-radius:40px; - height:100%; - position:absolute; - -webkit-transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:100%; } - .bp3-progress-bar:not(.bp3-no-animation):not(.bp3-no-stripes) .bp3-progress-meter{ - animation:linear-progress-bar-stripes 300ms linear infinite reverse; } - .bp3-progress-bar.bp3-no-stripes .bp3-progress-meter{ - background-image:none; } - -.bp3-dark .bp3-progress-bar{ - background:rgba(16, 22, 26, 0.5); } - .bp3-dark .bp3-progress-bar .bp3-progress-meter{ - background-color:#8a9ba8; } - -.bp3-progress-bar.bp3-intent-primary .bp3-progress-meter{ - background-color:#137cbd; } - -.bp3-progress-bar.bp3-intent-success .bp3-progress-meter{ - background-color:#0f9960; } - -.bp3-progress-bar.bp3-intent-warning .bp3-progress-meter{ - background-color:#d9822b; } - -.bp3-progress-bar.bp3-intent-danger .bp3-progress-meter{ - background-color:#db3737; } -@-webkit-keyframes skeleton-glow{ - from{ - background:rgba(206, 217, 224, 0.2); - border-color:rgba(206, 217, 224, 0.2); } - to{ - background:rgba(92, 112, 128, 0.2); - border-color:rgba(92, 112, 128, 0.2); } } -@keyframes skeleton-glow{ - from{ - background:rgba(206, 217, 224, 0.2); - border-color:rgba(206, 217, 224, 0.2); } - to{ - background:rgba(92, 112, 128, 0.2); - border-color:rgba(92, 112, 128, 0.2); } } -.bp3-skeleton{ - -webkit-animation:1000ms linear infinite alternate skeleton-glow; - animation:1000ms linear infinite alternate skeleton-glow; - background:rgba(206, 217, 224, 0.2); - background-clip:padding-box !important; - border-color:rgba(206, 217, 224, 0.2) !important; - border-radius:2px; - -webkit-box-shadow:none !important; - box-shadow:none !important; - color:transparent !important; - cursor:default; - pointer-events:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-skeleton::before, .bp3-skeleton::after, - .bp3-skeleton *{ - visibility:hidden !important; } -.bp3-slider{ - height:40px; - min-width:150px; - width:100%; - cursor:default; - outline:none; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-slider:hover{ - cursor:pointer; } - .bp3-slider:active{ - cursor:-webkit-grabbing; - cursor:grabbing; } - .bp3-slider.bp3-disabled{ - cursor:not-allowed; - opacity:0.5; } - .bp3-slider.bp3-slider-unlabeled{ - height:16px; } - -.bp3-slider-track, -.bp3-slider-progress{ - height:6px; - left:0; - right:0; - top:5px; - position:absolute; } - -.bp3-slider-track{ - border-radius:3px; - overflow:hidden; } - -.bp3-slider-progress{ - background:rgba(92, 112, 128, 0.2); } - .bp3-dark .bp3-slider-progress{ - background:rgba(16, 22, 26, 0.5); } - .bp3-slider-progress.bp3-intent-primary{ - background-color:#137cbd; } - .bp3-slider-progress.bp3-intent-success{ - background-color:#0f9960; } - .bp3-slider-progress.bp3-intent-warning{ - background-color:#d9822b; } - .bp3-slider-progress.bp3-intent-danger{ - background-color:#db3737; } - -.bp3-slider-handle{ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - cursor:pointer; - height:16px; - left:0; - position:absolute; - top:0; - width:16px; } - .bp3-slider-handle:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-slider-handle:active, .bp3-slider-handle.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-slider-handle:disabled, .bp3-slider-handle.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-slider-handle:disabled.bp3-active, .bp3-slider-handle:disabled.bp3-active:hover, .bp3-slider-handle.bp3-disabled.bp3-active, .bp3-slider-handle.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-slider-handle:focus{ - z-index:1; } - .bp3-slider-handle:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - cursor:-webkit-grab; - cursor:grab; - z-index:2; } - .bp3-slider-handle.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1); - cursor:-webkit-grabbing; - cursor:grabbing; } - .bp3-disabled .bp3-slider-handle{ - background:#bfccd6; - -webkit-box-shadow:none; - box-shadow:none; - pointer-events:none; } - .bp3-dark .bp3-slider-handle{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-slider-handle:hover, .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-slider-handle:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-slider-handle:disabled, .bp3-dark .bp3-slider-handle.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-slider-handle:disabled.bp3-active, .bp3-dark .bp3-slider-handle.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-slider-handle .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-slider-handle, .bp3-dark .bp3-slider-handle:hover{ - background-color:#394b59; } - .bp3-dark .bp3-slider-handle.bp3-active{ - background-color:#293742; } - .bp3-dark .bp3-disabled .bp3-slider-handle{ - background:#5c7080; - border-color:#5c7080; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-slider-handle .bp3-slider-label{ - background:#394b59; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - color:#f5f8fa; - margin-left:8px; } - .bp3-dark .bp3-slider-handle .bp3-slider-label{ - background:#e1e8ed; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - color:#394b59; } - .bp3-disabled .bp3-slider-handle .bp3-slider-label{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-slider-handle.bp3-start, .bp3-slider-handle.bp3-end{ - width:8px; } - .bp3-slider-handle.bp3-start{ - border-bottom-right-radius:0; - border-top-right-radius:0; } - .bp3-slider-handle.bp3-end{ - border-bottom-left-radius:0; - border-top-left-radius:0; - margin-left:8px; } - .bp3-slider-handle.bp3-end .bp3-slider-label{ - margin-left:0; } - -.bp3-slider-label{ - -webkit-transform:translate(-50%, 20px); - transform:translate(-50%, 20px); - display:inline-block; - font-size:12px; - line-height:1; - padding:2px 5px; - position:absolute; - vertical-align:top; } - -.bp3-slider.bp3-vertical{ - height:150px; - min-width:40px; - width:40px; } - .bp3-slider.bp3-vertical .bp3-slider-track, - .bp3-slider.bp3-vertical .bp3-slider-progress{ - bottom:0; - height:auto; - left:5px; - top:0; - width:6px; } - .bp3-slider.bp3-vertical .bp3-slider-progress{ - top:auto; } - .bp3-slider.bp3-vertical .bp3-slider-label{ - -webkit-transform:translate(20px, 50%); - transform:translate(20px, 50%); } - .bp3-slider.bp3-vertical .bp3-slider-handle{ - top:auto; } - .bp3-slider.bp3-vertical .bp3-slider-handle .bp3-slider-label{ - margin-left:0; - margin-top:-8px; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end, .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{ - height:8px; - margin-left:0; - width:16px; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{ - border-bottom-right-radius:3px; - border-top-left-radius:0; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start .bp3-slider-label{ - -webkit-transform:translate(20px); - transform:translate(20px); } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end{ - border-bottom-left-radius:0; - border-bottom-right-radius:0; - border-top-left-radius:3px; - margin-bottom:8px; } - -@-webkit-keyframes pt-spinner-animation{ - from{ - -webkit-transform:rotate(0deg); - transform:rotate(0deg); } - to{ - -webkit-transform:rotate(360deg); - transform:rotate(360deg); } } - -@keyframes pt-spinner-animation{ - from{ - -webkit-transform:rotate(0deg); - transform:rotate(0deg); } - to{ - -webkit-transform:rotate(360deg); - transform:rotate(360deg); } } - -.bp3-spinner{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - overflow:visible; - vertical-align:middle; } - .bp3-spinner svg{ - display:block; } - .bp3-spinner path{ - fill-opacity:0; } - .bp3-spinner .bp3-spinner-head{ - stroke:rgba(92, 112, 128, 0.8); - stroke-linecap:round; - -webkit-transform-origin:center; - transform-origin:center; - -webkit-transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-spinner .bp3-spinner-track{ - stroke:rgba(92, 112, 128, 0.2); } - -.bp3-spinner-animation{ - -webkit-animation:pt-spinner-animation 500ms linear infinite; - animation:pt-spinner-animation 500ms linear infinite; } - .bp3-no-spin > .bp3-spinner-animation{ - -webkit-animation:none; - animation:none; } - -.bp3-dark .bp3-spinner .bp3-spinner-head{ - stroke:#8a9ba8; } - -.bp3-dark .bp3-spinner .bp3-spinner-track{ - stroke:rgba(16, 22, 26, 0.5); } - -.bp3-spinner.bp3-intent-primary .bp3-spinner-head{ - stroke:#137cbd; } - -.bp3-spinner.bp3-intent-success .bp3-spinner-head{ - stroke:#0f9960; } - -.bp3-spinner.bp3-intent-warning .bp3-spinner-head{ - stroke:#d9822b; } - -.bp3-spinner.bp3-intent-danger .bp3-spinner-head{ - stroke:#db3737; } -.bp3-tabs.bp3-vertical{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-tabs.bp3-vertical > .bp3-tab-list{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab{ - border-radius:3px; - padding:0 10px; - width:100%; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab[aria-selected="true"]{ - background-color:rgba(19, 124, 189, 0.2); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab-indicator-wrapper .bp3-tab-indicator{ - background-color:rgba(19, 124, 189, 0.2); - border-radius:3px; - bottom:0; - height:auto; - left:0; - right:0; - top:0; } - .bp3-tabs.bp3-vertical > .bp3-tab-panel{ - margin-top:0; - padding-left:20px; } - -.bp3-tab-list{ - -webkit-box-align:end; - -ms-flex-align:end; - align-items:flex-end; - border:none; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - list-style:none; - margin:0; - padding:0; - position:relative; } - .bp3-tab-list > *:not(:last-child){ - margin-right:20px; } - -.bp3-tab{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - color:#182026; - cursor:pointer; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - font-size:14px; - line-height:30px; - max-width:100%; - position:relative; - vertical-align:top; } - .bp3-tab a{ - color:inherit; - display:block; - text-decoration:none; } - .bp3-tab-indicator-wrapper ~ .bp3-tab{ - background-color:transparent !important; - -webkit-box-shadow:none !important; - box-shadow:none !important; } - .bp3-tab[aria-disabled="true"]{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-tab[aria-selected="true"]{ - border-radius:0; - -webkit-box-shadow:inset 0 -3px 0 #106ba3; - box-shadow:inset 0 -3px 0 #106ba3; } - .bp3-tab[aria-selected="true"], .bp3-tab:not([aria-disabled="true"]):hover{ - color:#106ba3; } - .bp3-tab:focus{ - -moz-outline-radius:0; } - .bp3-large > .bp3-tab{ - font-size:16px; - line-height:40px; } - -.bp3-tab-panel{ - margin-top:20px; } - .bp3-tab-panel[aria-hidden="true"]{ - display:none; } - -.bp3-tab-indicator-wrapper{ - left:0; - pointer-events:none; - position:absolute; - top:0; - -webkit-transform:translateX(0), translateY(0); - transform:translateX(0), translateY(0); - -webkit-transition:height, width, -webkit-transform; - transition:height, width, -webkit-transform; - transition:height, transform, width; - transition:height, transform, width, -webkit-transform; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tab-indicator-wrapper .bp3-tab-indicator{ - background-color:#106ba3; - bottom:0; - height:3px; - left:0; - position:absolute; - right:0; } - .bp3-tab-indicator-wrapper.bp3-no-animation{ - -webkit-transition:none; - transition:none; } - -.bp3-dark .bp3-tab{ - color:#f5f8fa; } - .bp3-dark .bp3-tab[aria-disabled="true"]{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tab[aria-selected="true"]{ - -webkit-box-shadow:inset 0 -3px 0 #48aff0; - box-shadow:inset 0 -3px 0 #48aff0; } - .bp3-dark .bp3-tab[aria-selected="true"], .bp3-dark .bp3-tab:not([aria-disabled="true"]):hover{ - color:#48aff0; } - -.bp3-dark .bp3-tab-indicator{ - background-color:#48aff0; } - -.bp3-flex-expander{ - -webkit-box-flex:1; - -ms-flex:1 1; - flex:1 1; } -.bp3-tag{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:#5c7080; - border:none; - border-radius:3px; - -webkit-box-shadow:none; - box-shadow:none; - color:#f5f8fa; - font-size:12px; - line-height:16px; - max-width:100%; - min-height:20px; - min-width:20px; - padding:2px 6px; - position:relative; } - .bp3-tag.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-interactive:hover{ - background-color:rgba(92, 112, 128, 0.85); } - .bp3-tag.bp3-interactive.bp3-active, .bp3-tag.bp3-interactive:active{ - background-color:rgba(92, 112, 128, 0.7); } - .bp3-tag > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag::before, - .bp3-tag > *{ - margin-right:4px; } - .bp3-tag:empty::before, - .bp3-tag > :last-child{ - margin-right:0; } - .bp3-tag:focus{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:0; - -moz-outline-radius:6px; } - .bp3-tag.bp3-round{ - border-radius:30px; - padding-left:8px; - padding-right:8px; } - .bp3-dark .bp3-tag{ - background-color:#bfccd6; - color:#182026; } - .bp3-dark .bp3-tag.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-interactive:hover{ - background-color:rgba(191, 204, 214, 0.85); } - .bp3-dark .bp3-tag.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-interactive:active{ - background-color:rgba(191, 204, 214, 0.7); } - .bp3-dark .bp3-tag > .bp3-icon, .bp3-dark .bp3-tag .bp3-icon-standard, .bp3-dark .bp3-tag .bp3-icon-large{ - fill:currentColor; } - .bp3-tag > .bp3-icon, .bp3-tag .bp3-icon-standard, .bp3-tag .bp3-icon-large{ - fill:#ffffff; } - .bp3-tag.bp3-large, - .bp3-large .bp3-tag{ - font-size:14px; - line-height:20px; - min-height:30px; - min-width:30px; - padding:5px 10px; } - .bp3-tag.bp3-large::before, - .bp3-tag.bp3-large > *, - .bp3-large .bp3-tag::before, - .bp3-large .bp3-tag > *{ - margin-right:7px; } - .bp3-tag.bp3-large:empty::before, - .bp3-tag.bp3-large > :last-child, - .bp3-large .bp3-tag:empty::before, - .bp3-large .bp3-tag > :last-child{ - margin-right:0; } - .bp3-tag.bp3-large.bp3-round, - .bp3-large .bp3-tag.bp3-round{ - padding-left:12px; - padding-right:12px; } - .bp3-tag.bp3-intent-primary{ - background:#137cbd; - color:#ffffff; } - .bp3-tag.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.85); } - .bp3-tag.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.7); } - .bp3-tag.bp3-intent-success{ - background:#0f9960; - color:#ffffff; } - .bp3-tag.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.85); } - .bp3-tag.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.7); } - .bp3-tag.bp3-intent-warning{ - background:#d9822b; - color:#ffffff; } - .bp3-tag.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.85); } - .bp3-tag.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.7); } - .bp3-tag.bp3-intent-danger{ - background:#db3737; - color:#ffffff; } - .bp3-tag.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.85); } - .bp3-tag.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.7); } - .bp3-tag.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-tag.bp3-minimal > .bp3-icon, .bp3-tag.bp3-minimal .bp3-icon-standard, .bp3-tag.bp3-minimal .bp3-icon-large{ - fill:#5c7080; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){ - background-color:rgba(138, 155, 168, 0.2); - color:#182026; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{ - background-color:rgba(92, 112, 128, 0.3); } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{ - background-color:rgba(92, 112, 128, 0.4); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){ - color:#f5f8fa; } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{ - background-color:rgba(191, 204, 214, 0.3); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{ - background-color:rgba(191, 204, 214, 0.4); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) > .bp3-icon, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-large{ - fill:#a7b6c2; } - .bp3-tag.bp3-minimal.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-primary > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-large{ - fill:#137cbd; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.25); - color:#48aff0; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-success > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-large{ - fill:#0f9960; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.25); - color:#3dcc91; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-warning > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-large{ - fill:#d9822b; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.25); - color:#ffb366; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-danger > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-large{ - fill:#db3737; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.25); - color:#ff7373; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.45); } - -.bp3-tag-remove{ - background:none; - border:none; - color:inherit; - cursor:pointer; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin-bottom:-2px; - margin-right:-6px !important; - margin-top:-2px; - opacity:0.5; - padding:2px; - padding-left:0; } - .bp3-tag-remove:hover{ - background:none; - opacity:0.8; - text-decoration:none; } - .bp3-tag-remove:active{ - opacity:1; } - .bp3-tag-remove:empty::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - content:""; } - .bp3-large .bp3-tag-remove{ - margin-right:-10px !important; - padding:0 5px 0 0; } - .bp3-large .bp3-tag-remove:empty::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; } -.bp3-tag-input{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - cursor:text; - height:auto; - line-height:inherit; - min-height:30px; - padding-left:5px; - padding-right:0; } - .bp3-tag-input > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag-input > .bp3-tag-input-values{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag-input .bp3-tag-input-icon{ - color:#5c7080; - margin-left:2px; - margin-right:7px; - margin-top:7px; } - .bp3-tag-input .bp3-tag-input-values{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -ms-flex-item-align:stretch; - align-self:stretch; - -ms-flex-wrap:wrap; - flex-wrap:wrap; - margin-right:7px; - margin-top:5px; - min-width:0; } - .bp3-tag-input .bp3-tag-input-values > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag-input .bp3-tag-input-values > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag-input .bp3-tag-input-values::before, - .bp3-tag-input .bp3-tag-input-values > *{ - margin-right:5px; } - .bp3-tag-input .bp3-tag-input-values:empty::before, - .bp3-tag-input .bp3-tag-input-values > :last-child{ - margin-right:0; } - .bp3-tag-input .bp3-tag-input-values:first-child .bp3-input-ghost:first-child{ - padding-left:5px; } - .bp3-tag-input .bp3-tag-input-values > *{ - margin-bottom:5px; } - .bp3-tag-input .bp3-tag{ - overflow-wrap:break-word; } - .bp3-tag-input .bp3-tag.bp3-active{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:0; - -moz-outline-radius:6px; } - .bp3-tag-input .bp3-input-ghost{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:20px; - width:80px; } - .bp3-tag-input .bp3-input-ghost:disabled, .bp3-tag-input .bp3-input-ghost.bp3-disabled{ - cursor:not-allowed; } - .bp3-tag-input .bp3-button, - .bp3-tag-input .bp3-spinner{ - margin:3px; - margin-left:0; } - .bp3-tag-input .bp3-button{ - min-height:24px; - min-width:24px; - padding:0 7px; } - .bp3-tag-input.bp3-large{ - height:auto; - min-height:40px; } - .bp3-tag-input.bp3-large::before, - .bp3-tag-input.bp3-large > *{ - margin-right:10px; } - .bp3-tag-input.bp3-large:empty::before, - .bp3-tag-input.bp3-large > :last-child{ - margin-right:0; } - .bp3-tag-input.bp3-large .bp3-tag-input-icon{ - margin-left:5px; - margin-top:10px; } - .bp3-tag-input.bp3-large .bp3-input-ghost{ - line-height:30px; } - .bp3-tag-input.bp3-large .bp3-button{ - min-height:30px; - min-width:30px; - padding:5px 10px; - margin:5px; - margin-left:0; } - .bp3-tag-input.bp3-large .bp3-spinner{ - margin:8px; - margin-left:0; } - .bp3-tag-input.bp3-active{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-success{ - -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-tag-input .bp3-tag-input-icon, .bp3-tag-input.bp3-dark .bp3-tag-input-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-tag-input .bp3-input-ghost, .bp3-tag-input.bp3-dark .bp3-input-ghost{ - color:#f5f8fa; } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-webkit-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-moz-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost:-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input.bp3-active, .bp3-tag-input.bp3-dark.bp3-active{ - background-color:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-primary, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-success, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-success{ - -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-warning, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-danger, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-input-ghost{ - background:none; - border:none; - -webkit-box-shadow:none; - box-shadow:none; - padding:0; } - .bp3-input-ghost::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost:focus{ - outline:none !important; } -.bp3-toast{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin:20px 0 0; - max-width:500px; - min-width:300px; - pointer-events:all; - position:relative !important; } - .bp3-toast.bp3-toast-enter, .bp3-toast.bp3-toast-appear{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); } - .bp3-toast.bp3-toast-enter-active, .bp3-toast.bp3-toast-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-toast.bp3-toast-enter ~ .bp3-toast, .bp3-toast.bp3-toast-appear ~ .bp3-toast{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); } - .bp3-toast.bp3-toast-enter-active ~ .bp3-toast, .bp3-toast.bp3-toast-appear-active ~ .bp3-toast{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-toast.bp3-toast-exit{ - opacity:1; - -webkit-filter:blur(0); - filter:blur(0); } - .bp3-toast.bp3-toast-exit-active{ - opacity:0; - -webkit-filter:blur(10px); - filter:blur(10px); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:opacity, filter; - transition-property:opacity, filter, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-toast.bp3-toast-exit ~ .bp3-toast{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-toast.bp3-toast-exit-active ~ .bp3-toast{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); - -webkit-transition-delay:50ms; - transition-delay:50ms; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-toast .bp3-button-group{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - padding:5px; - padding-left:0; } - .bp3-toast > .bp3-icon{ - color:#5c7080; - margin:12px; - margin-right:0; } - .bp3-toast.bp3-dark, - .bp3-dark .bp3-toast{ - background-color:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-toast.bp3-dark > .bp3-icon, - .bp3-dark .bp3-toast > .bp3-icon{ - color:#a7b6c2; } - .bp3-toast[class*="bp3-intent-"] a{ - color:rgba(255, 255, 255, 0.7); } - .bp3-toast[class*="bp3-intent-"] a:hover{ - color:#ffffff; } - .bp3-toast[class*="bp3-intent-"] > .bp3-icon{ - color:#ffffff; } - .bp3-toast[class*="bp3-intent-"] .bp3-button, .bp3-toast[class*="bp3-intent-"] .bp3-button::before, - .bp3-toast[class*="bp3-intent-"] .bp3-button .bp3-icon, .bp3-toast[class*="bp3-intent-"] .bp3-button:active{ - color:rgba(255, 255, 255, 0.7) !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button:focus{ - outline-color:rgba(255, 255, 255, 0.5); } - .bp3-toast[class*="bp3-intent-"] .bp3-button:hover{ - background-color:rgba(255, 255, 255, 0.15) !important; - color:#ffffff !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button:active{ - background-color:rgba(255, 255, 255, 0.3) !important; - color:#ffffff !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button::after{ - background:rgba(255, 255, 255, 0.3) !important; } - .bp3-toast.bp3-intent-primary{ - background-color:#137cbd; - color:#ffffff; } - .bp3-toast.bp3-intent-success{ - background-color:#0f9960; - color:#ffffff; } - .bp3-toast.bp3-intent-warning{ - background-color:#d9822b; - color:#ffffff; } - .bp3-toast.bp3-intent-danger{ - background-color:#db3737; - color:#ffffff; } - -.bp3-toast-message{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - padding:11px; - word-break:break-word; } - -.bp3-toast-container{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box !important; - display:-ms-flexbox !important; - display:flex !important; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - left:0; - overflow:hidden; - padding:0 20px 20px; - pointer-events:none; - right:0; - z-index:40; } - .bp3-toast-container.bp3-toast-container-in-portal{ - position:fixed; } - .bp3-toast-container.bp3-toast-container-inline{ - position:absolute; } - .bp3-toast-container.bp3-toast-container-top{ - top:0; } - .bp3-toast-container.bp3-toast-container-bottom{ - bottom:0; - -webkit-box-orient:vertical; - -webkit-box-direction:reverse; - -ms-flex-direction:column-reverse; - flex-direction:column-reverse; - top:auto; } - .bp3-toast-container.bp3-toast-container-left{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; } - .bp3-toast-container.bp3-toast-container-right{ - -webkit-box-align:end; - -ms-flex-align:end; - align-items:flex-end; } - -.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active), -.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active) ~ .bp3-toast, .bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active), -.bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active) ~ .bp3-toast, -.bp3-toast-container-bottom .bp3-toast.bp3-toast-exit-active ~ .bp3-toast, -.bp3-toast-container-bottom .bp3-toast.bp3-toast-leave-active ~ .bp3-toast{ - -webkit-transform:translateY(60px); - transform:translateY(60px); } -.bp3-tooltip{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-tooltip .bp3-popover-arrow{ - height:22px; - position:absolute; - width:22px; } - .bp3-tooltip .bp3-popover-arrow::before{ - height:14px; - margin:4px; - width:14px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip{ - margin-bottom:11px; - margin-top:-11px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{ - bottom:-8px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(-90deg); - transform:rotate(-90deg); } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip{ - margin-left:11px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{ - left:-8px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(0); - transform:rotate(0); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip{ - margin-top:11px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{ - top:-8px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip{ - margin-left:-11px; - margin-right:11px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{ - right:-8px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(180deg); - transform:rotate(180deg); } - .bp3-tether-element-attached-middle > .bp3-tooltip > .bp3-popover-arrow{ - top:50%; - -webkit-transform:translateY(-50%); - transform:translateY(-50%); } - .bp3-tether-element-attached-center > .bp3-tooltip > .bp3-popover-arrow{ - right:50%; - -webkit-transform:translateX(50%); - transform:translateX(50%); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{ - top:-0.22183px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{ - right:-0.22183px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{ - left:-0.22183px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{ - bottom:-0.22183px; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:top left; - transform-origin:top left; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:top center; - transform-origin:top center; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:top right; - transform-origin:top right; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:center left; - transform-origin:center left; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:center center; - transform-origin:center center; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:center right; - transform-origin:center right; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:bottom left; - transform-origin:bottom left; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:bottom center; - transform-origin:bottom center; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:bottom right; - transform-origin:bottom right; } - .bp3-tooltip .bp3-popover-content{ - background:#394b59; - color:#f5f8fa; } - .bp3-tooltip .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); } - .bp3-tooltip .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.1; } - .bp3-tooltip .bp3-popover-arrow-fill{ - fill:#394b59; } - .bp3-popover-enter > .bp3-tooltip, .bp3-popover-appear > .bp3-tooltip{ - -webkit-transform:scale(0.8); - transform:scale(0.8); } - .bp3-popover-enter-active > .bp3-tooltip, .bp3-popover-appear-active > .bp3-tooltip{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover-exit > .bp3-tooltip{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-tooltip{ - -webkit-transform:scale(0.8); - transform:scale(0.8); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tooltip .bp3-popover-content{ - padding:10px 12px; } - .bp3-tooltip.bp3-dark, - .bp3-dark .bp3-tooltip{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-tooltip.bp3-dark .bp3-popover-content, - .bp3-dark .bp3-tooltip .bp3-popover-content{ - background:#e1e8ed; - color:#394b59; } - .bp3-tooltip.bp3-dark .bp3-popover-arrow::before, - .bp3-dark .bp3-tooltip .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); } - .bp3-tooltip.bp3-dark .bp3-popover-arrow-border, - .bp3-dark .bp3-tooltip .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.2; } - .bp3-tooltip.bp3-dark .bp3-popover-arrow-fill, - .bp3-dark .bp3-tooltip .bp3-popover-arrow-fill{ - fill:#e1e8ed; } - .bp3-tooltip.bp3-intent-primary .bp3-popover-content{ - background:#137cbd; - color:#ffffff; } - .bp3-tooltip.bp3-intent-primary .bp3-popover-arrow-fill{ - fill:#137cbd; } - .bp3-tooltip.bp3-intent-success .bp3-popover-content{ - background:#0f9960; - color:#ffffff; } - .bp3-tooltip.bp3-intent-success .bp3-popover-arrow-fill{ - fill:#0f9960; } - .bp3-tooltip.bp3-intent-warning .bp3-popover-content{ - background:#d9822b; - color:#ffffff; } - .bp3-tooltip.bp3-intent-warning .bp3-popover-arrow-fill{ - fill:#d9822b; } - .bp3-tooltip.bp3-intent-danger .bp3-popover-content{ - background:#db3737; - color:#ffffff; } - .bp3-tooltip.bp3-intent-danger .bp3-popover-arrow-fill{ - fill:#db3737; } - -.bp3-tooltip-indicator{ - border-bottom:dotted 1px; - cursor:help; } -.bp3-tree .bp3-icon, .bp3-tree .bp3-icon-standard, .bp3-tree .bp3-icon-large{ - color:#5c7080; } - .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-tree .bp3-icon-large.bp3-intent-primary{ - color:#137cbd; } - .bp3-tree .bp3-icon.bp3-intent-success, .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-tree .bp3-icon-large.bp3-intent-success{ - color:#0f9960; } - .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-tree .bp3-icon-large.bp3-intent-warning{ - color:#d9822b; } - .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-tree .bp3-icon-large.bp3-intent-danger{ - color:#db3737; } - -.bp3-tree-node-list{ - list-style:none; - margin:0; - padding-left:0; } - -.bp3-tree-root{ - background-color:transparent; - cursor:default; - padding-left:0; - position:relative; } - -.bp3-tree-node-content-0{ - padding-left:0px; } - -.bp3-tree-node-content-1{ - padding-left:23px; } - -.bp3-tree-node-content-2{ - padding-left:46px; } - -.bp3-tree-node-content-3{ - padding-left:69px; } - -.bp3-tree-node-content-4{ - padding-left:92px; } - -.bp3-tree-node-content-5{ - padding-left:115px; } - -.bp3-tree-node-content-6{ - padding-left:138px; } - -.bp3-tree-node-content-7{ - padding-left:161px; } - -.bp3-tree-node-content-8{ - padding-left:184px; } - -.bp3-tree-node-content-9{ - padding-left:207px; } - -.bp3-tree-node-content-10{ - padding-left:230px; } - -.bp3-tree-node-content-11{ - padding-left:253px; } - -.bp3-tree-node-content-12{ - padding-left:276px; } - -.bp3-tree-node-content-13{ - padding-left:299px; } - -.bp3-tree-node-content-14{ - padding-left:322px; } - -.bp3-tree-node-content-15{ - padding-left:345px; } - -.bp3-tree-node-content-16{ - padding-left:368px; } - -.bp3-tree-node-content-17{ - padding-left:391px; } - -.bp3-tree-node-content-18{ - padding-left:414px; } - -.bp3-tree-node-content-19{ - padding-left:437px; } - -.bp3-tree-node-content-20{ - padding-left:460px; } - -.bp3-tree-node-content{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:30px; - padding-right:5px; - width:100%; } - .bp3-tree-node-content:hover{ - background-color:rgba(191, 204, 214, 0.4); } - -.bp3-tree-node-caret, -.bp3-tree-node-caret-none{ - min-width:30px; } - -.bp3-tree-node-caret{ - color:#5c7080; - cursor:pointer; - padding:7px; - -webkit-transform:rotate(0deg); - transform:rotate(0deg); - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tree-node-caret:hover{ - color:#182026; } - .bp3-dark .bp3-tree-node-caret{ - color:#a7b6c2; } - .bp3-dark .bp3-tree-node-caret:hover{ - color:#f5f8fa; } - .bp3-tree-node-caret.bp3-tree-node-caret-open{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tree-node-caret.bp3-icon-standard::before{ - content:""; } - -.bp3-tree-node-icon{ - margin-right:7px; - position:relative; } - -.bp3-tree-node-label{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-tree-node-label span{ - display:inline; } - -.bp3-tree-node-secondary-label{ - padding:0 5px; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-tree-node-secondary-label .bp3-popover-wrapper, - .bp3-tree-node-secondary-label .bp3-popover-target{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - -.bp3-tree-node.bp3-disabled .bp3-tree-node-content{ - background-color:inherit; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-tree-node.bp3-disabled .bp3-tree-node-caret, -.bp3-tree-node.bp3-disabled .bp3-tree-node-icon{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{ - background-color:#137cbd; } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content, - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-standard, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-large{ - color:#ffffff; } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret::before{ - color:rgba(255, 255, 255, 0.7); } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret:hover::before{ - color:#ffffff; } - -.bp3-dark .bp3-tree-node-content:hover{ - background-color:rgba(92, 112, 128, 0.3); } - -.bp3-dark .bp3-tree .bp3-icon, .bp3-dark .bp3-tree .bp3-icon-standard, .bp3-dark .bp3-tree .bp3-icon-large{ - color:#a7b6c2; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-primary{ - color:#137cbd; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-success{ - color:#0f9960; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-warning{ - color:#d9822b; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-danger{ - color:#db3737; } - -.bp3-dark .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{ - background-color:#137cbd; } -.bp3-omnibar{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - left:calc(50% - 250px); - top:20vh; - width:500px; - z-index:21; } - .bp3-omnibar.bp3-overlay-enter, .bp3-omnibar.bp3-overlay-appear{ - -webkit-filter:blur(20px); - filter:blur(20px); - opacity:0.2; } - .bp3-omnibar.bp3-overlay-enter-active, .bp3-omnibar.bp3-overlay-appear-active{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:filter, opacity; - transition-property:filter, opacity, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-omnibar.bp3-overlay-exit{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; } - .bp3-omnibar.bp3-overlay-exit-active{ - -webkit-filter:blur(20px); - filter:blur(20px); - opacity:0.2; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:filter, opacity; - transition-property:filter, opacity, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-omnibar .bp3-input{ - background-color:transparent; - border-radius:0; } - .bp3-omnibar .bp3-input, .bp3-omnibar .bp3-input:focus{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-omnibar .bp3-menu{ - background-color:transparent; - border-radius:0; - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - max-height:calc(60vh - 40px); - overflow:auto; } - .bp3-omnibar .bp3-menu:empty{ - display:none; } - .bp3-dark .bp3-omnibar, .bp3-omnibar.bp3-dark{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); } - -.bp3-omnibar-overlay .bp3-overlay-backdrop{ - background-color:rgba(16, 22, 26, 0.2); } - -.bp3-select-popover .bp3-popover-content{ - padding:5px; } - -.bp3-select-popover .bp3-input-group{ - margin-bottom:0; } - -.bp3-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; - padding:0; } - .bp3-select-popover .bp3-menu:not(:first-child){ - padding-top:5px; } - -.bp3-multi-select{ - min-width:150px; } - -.bp3-multi-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; } - -.bp3-select-popover .bp3-popover-content{ - padding:5px; } - -.bp3-select-popover .bp3-input-group{ - margin-bottom:0; } - -.bp3-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; - padding:0; } - .bp3-select-popover .bp3-menu:not(:first-child){ - padding-top:5px; } -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */ - -/** - * (DEPRECATED) Support for consuming icons as CSS background images - */ - -/* Icons urls */ - -:root { - --jp-icon-add: url(); - --jp-icon-bug: url(); - --jp-icon-build: url(); - --jp-icon-caret-down-empty-thin: url(); - --jp-icon-caret-down-empty: url(); - --jp-icon-caret-down: url(); - --jp-icon-caret-left: url(); - --jp-icon-caret-right: url(); - --jp-icon-caret-up-empty-thin: url(); - --jp-icon-caret-up: url(); - --jp-icon-case-sensitive: url(); - --jp-icon-check: url(); - --jp-icon-circle-empty: url(); - --jp-icon-circle: url(); - --jp-icon-clear: url(); - --jp-icon-close: url(); - --jp-icon-code: url(); - --jp-icon-console: url(); - --jp-icon-copy: url(); - --jp-icon-copyright: url(); - --jp-icon-cut: url(); - --jp-icon-download: url(); - --jp-icon-edit: url(); - --jp-icon-ellipses: url(); - --jp-icon-extension: url(); - --jp-icon-fast-forward: url(); - --jp-icon-file-upload: url(); - --jp-icon-file: url(); - --jp-icon-filter-list: url(); - --jp-icon-folder: url(); - --jp-icon-html5: url(); - --jp-icon-image: url(); - --jp-icon-inspector: url(); - --jp-icon-json: url(); - --jp-icon-julia: url(); - --jp-icon-jupyter-favicon: url(); - --jp-icon-jupyter: url(); - --jp-icon-jupyterlab-wordmark: url(); - --jp-icon-kernel: url(); - --jp-icon-keyboard: url(); - --jp-icon-launcher: url(); - --jp-icon-line-form: url(); - --jp-icon-link: url(); - --jp-icon-list: url(); - --jp-icon-listings-info: url(); - --jp-icon-markdown: url(); - --jp-icon-new-folder: url(); - --jp-icon-not-trusted: url(); - --jp-icon-notebook: url(); - --jp-icon-numbering: url(); - --jp-icon-offline-bolt: url(); - --jp-icon-palette: url(); - --jp-icon-paste: url(); - --jp-icon-pdf: url(); - --jp-icon-python: url(); - --jp-icon-r-kernel: url(); - --jp-icon-react: url(); - --jp-icon-redo: url(); - --jp-icon-refresh: url(); - --jp-icon-regex: url(); - --jp-icon-run: url(); - --jp-icon-running: url(); - --jp-icon-save: url(); - --jp-icon-search: url(); - --jp-icon-settings: url(); - --jp-icon-spreadsheet: url(); - --jp-icon-stop: url(); - --jp-icon-tab: url(); - --jp-icon-table-rows: url(); - --jp-icon-tag: url(); - --jp-icon-terminal: url(); - --jp-icon-text-editor: url(); - --jp-icon-toc: url(); - --jp-icon-tree-view: url(); - --jp-icon-trusted: url(); - --jp-icon-undo: url(); - --jp-icon-vega: url(); - --jp-icon-yaml: url(); -} - -/* Icon CSS class declarations */ - -.jp-AddIcon { - background-image: var(--jp-icon-add); -} -.jp-BugIcon { - background-image: var(--jp-icon-bug); -} -.jp-BuildIcon { - background-image: var(--jp-icon-build); -} -.jp-CaretDownEmptyIcon { - background-image: var(--jp-icon-caret-down-empty); -} -.jp-CaretDownEmptyThinIcon { - background-image: var(--jp-icon-caret-down-empty-thin); -} -.jp-CaretDownIcon { - background-image: var(--jp-icon-caret-down); -} -.jp-CaretLeftIcon { - background-image: var(--jp-icon-caret-left); -} -.jp-CaretRightIcon { - background-image: var(--jp-icon-caret-right); -} -.jp-CaretUpEmptyThinIcon { - background-image: var(--jp-icon-caret-up-empty-thin); -} -.jp-CaretUpIcon { - background-image: var(--jp-icon-caret-up); -} -.jp-CaseSensitiveIcon { - background-image: var(--jp-icon-case-sensitive); -} -.jp-CheckIcon { - background-image: var(--jp-icon-check); -} -.jp-CircleEmptyIcon { - background-image: var(--jp-icon-circle-empty); -} -.jp-CircleIcon { - background-image: var(--jp-icon-circle); -} -.jp-ClearIcon { - background-image: var(--jp-icon-clear); -} -.jp-CloseIcon { - background-image: var(--jp-icon-close); -} -.jp-CodeIcon { - background-image: var(--jp-icon-code); -} -.jp-ConsoleIcon { - background-image: var(--jp-icon-console); -} -.jp-CopyIcon { - background-image: var(--jp-icon-copy); -} -.jp-CopyrightIcon { - background-image: var(--jp-icon-copyright); -} -.jp-CutIcon { - background-image: var(--jp-icon-cut); -} -.jp-DownloadIcon { - background-image: var(--jp-icon-download); -} -.jp-EditIcon { - background-image: var(--jp-icon-edit); -} -.jp-EllipsesIcon { - background-image: var(--jp-icon-ellipses); -} -.jp-ExtensionIcon { - background-image: var(--jp-icon-extension); -} -.jp-FastForwardIcon { - background-image: var(--jp-icon-fast-forward); -} -.jp-FileIcon { - background-image: var(--jp-icon-file); -} -.jp-FileUploadIcon { - background-image: var(--jp-icon-file-upload); -} -.jp-FilterListIcon { - background-image: var(--jp-icon-filter-list); -} -.jp-FolderIcon { - background-image: var(--jp-icon-folder); -} -.jp-Html5Icon { - background-image: var(--jp-icon-html5); -} -.jp-ImageIcon { - background-image: var(--jp-icon-image); -} -.jp-InspectorIcon { - background-image: var(--jp-icon-inspector); -} -.jp-JsonIcon { - background-image: var(--jp-icon-json); -} -.jp-JuliaIcon { - background-image: var(--jp-icon-julia); -} -.jp-JupyterFaviconIcon { - background-image: var(--jp-icon-jupyter-favicon); -} -.jp-JupyterIcon { - background-image: var(--jp-icon-jupyter); -} -.jp-JupyterlabWordmarkIcon { - background-image: var(--jp-icon-jupyterlab-wordmark); -} -.jp-KernelIcon { - background-image: var(--jp-icon-kernel); -} -.jp-KeyboardIcon { - background-image: var(--jp-icon-keyboard); -} -.jp-LauncherIcon { - background-image: var(--jp-icon-launcher); -} -.jp-LineFormIcon { - background-image: var(--jp-icon-line-form); -} -.jp-LinkIcon { - background-image: var(--jp-icon-link); -} -.jp-ListIcon { - background-image: var(--jp-icon-list); -} -.jp-ListingsInfoIcon { - background-image: var(--jp-icon-listings-info); -} -.jp-MarkdownIcon { - background-image: var(--jp-icon-markdown); -} -.jp-NewFolderIcon { - background-image: var(--jp-icon-new-folder); -} -.jp-NotTrustedIcon { - background-image: var(--jp-icon-not-trusted); -} -.jp-NotebookIcon { - background-image: var(--jp-icon-notebook); -} -.jp-NumberingIcon { - background-image: var(--jp-icon-numbering); -} -.jp-OfflineBoltIcon { - background-image: var(--jp-icon-offline-bolt); -} -.jp-PaletteIcon { - background-image: var(--jp-icon-palette); -} -.jp-PasteIcon { - background-image: var(--jp-icon-paste); -} -.jp-PdfIcon { - background-image: var(--jp-icon-pdf); -} -.jp-PythonIcon { - background-image: var(--jp-icon-python); -} -.jp-RKernelIcon { - background-image: var(--jp-icon-r-kernel); -} -.jp-ReactIcon { - background-image: var(--jp-icon-react); -} -.jp-RedoIcon { - background-image: var(--jp-icon-redo); -} -.jp-RefreshIcon { - background-image: var(--jp-icon-refresh); -} -.jp-RegexIcon { - background-image: var(--jp-icon-regex); -} -.jp-RunIcon { - background-image: var(--jp-icon-run); -} -.jp-RunningIcon { - background-image: var(--jp-icon-running); -} -.jp-SaveIcon { - background-image: var(--jp-icon-save); -} -.jp-SearchIcon { - background-image: var(--jp-icon-search); -} -.jp-SettingsIcon { - background-image: var(--jp-icon-settings); -} -.jp-SpreadsheetIcon { - background-image: var(--jp-icon-spreadsheet); -} -.jp-StopIcon { - background-image: var(--jp-icon-stop); -} -.jp-TabIcon { - background-image: var(--jp-icon-tab); -} -.jp-TableRowsIcon { - background-image: var(--jp-icon-table-rows); -} -.jp-TagIcon { - background-image: var(--jp-icon-tag); -} -.jp-TerminalIcon { - background-image: var(--jp-icon-terminal); -} -.jp-TextEditorIcon { - background-image: var(--jp-icon-text-editor); -} -.jp-TocIcon { - background-image: var(--jp-icon-toc); -} -.jp-TreeViewIcon { - background-image: var(--jp-icon-tree-view); -} -.jp-TrustedIcon { - background-image: var(--jp-icon-trusted); -} -.jp-UndoIcon { - background-image: var(--jp-icon-undo); -} -.jp-VegaIcon { - background-image: var(--jp-icon-vega); -} -.jp-YamlIcon { - background-image: var(--jp-icon-yaml); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * (DEPRECATED) Support for consuming icons as CSS background images - */ - -.jp-Icon, -.jp-MaterialIcon { - background-position: center; - background-repeat: no-repeat; - background-size: 16px; - min-width: 16px; - min-height: 16px; -} - -.jp-Icon-cover { - background-position: center; - background-repeat: no-repeat; - background-size: cover; -} - -/** - * (DEPRECATED) Support for specific CSS icon sizes - */ - -.jp-Icon-16 { - background-size: 16px; - min-width: 16px; - min-height: 16px; -} - -.jp-Icon-18 { - background-size: 18px; - min-width: 18px; - min-height: 18px; -} - -.jp-Icon-20 { - background-size: 20px; - min-width: 20px; - min-height: 20px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * Support for icons as inline SVG HTMLElements - */ - -/* recolor the primary elements of an icon */ -.jp-icon0[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon1[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon2[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon3[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon4[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon0[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon1[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon2[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon3[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon4[stroke] { - stroke: var(--jp-inverse-layout-color4); -} -/* recolor the accent elements of an icon */ -.jp-icon-accent0[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-accent1[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-accent2[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-accent3[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-accent4[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-accent0[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-accent1[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-accent2[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-accent3[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-accent4[stroke] { - stroke: var(--jp-layout-color4); -} -/* set the color of an icon to transparent */ -.jp-icon-none[fill] { - fill: none; -} - -.jp-icon-none[stroke] { - stroke: none; -} -/* brand icon colors. Same for light and dark */ -.jp-icon-brand0[fill] { - fill: var(--jp-brand-color0); -} -.jp-icon-brand1[fill] { - fill: var(--jp-brand-color1); -} -.jp-icon-brand2[fill] { - fill: var(--jp-brand-color2); -} -.jp-icon-brand3[fill] { - fill: var(--jp-brand-color3); -} -.jp-icon-brand4[fill] { - fill: var(--jp-brand-color4); -} - -.jp-icon-brand0[stroke] { - stroke: var(--jp-brand-color0); -} -.jp-icon-brand1[stroke] { - stroke: var(--jp-brand-color1); -} -.jp-icon-brand2[stroke] { - stroke: var(--jp-brand-color2); -} -.jp-icon-brand3[stroke] { - stroke: var(--jp-brand-color3); -} -.jp-icon-brand4[stroke] { - stroke: var(--jp-brand-color4); -} -/* warn icon colors. Same for light and dark */ -.jp-icon-warn0[fill] { - fill: var(--jp-warn-color0); -} -.jp-icon-warn1[fill] { - fill: var(--jp-warn-color1); -} -.jp-icon-warn2[fill] { - fill: var(--jp-warn-color2); -} -.jp-icon-warn3[fill] { - fill: var(--jp-warn-color3); -} - -.jp-icon-warn0[stroke] { - stroke: var(--jp-warn-color0); -} -.jp-icon-warn1[stroke] { - stroke: var(--jp-warn-color1); -} -.jp-icon-warn2[stroke] { - stroke: var(--jp-warn-color2); -} -.jp-icon-warn3[stroke] { - stroke: var(--jp-warn-color3); -} -/* icon colors that contrast well with each other and most backgrounds */ -.jp-icon-contrast0[fill] { - fill: var(--jp-icon-contrast-color0); -} -.jp-icon-contrast1[fill] { - fill: var(--jp-icon-contrast-color1); -} -.jp-icon-contrast2[fill] { - fill: var(--jp-icon-contrast-color2); -} -.jp-icon-contrast3[fill] { - fill: var(--jp-icon-contrast-color3); -} - -.jp-icon-contrast0[stroke] { - stroke: var(--jp-icon-contrast-color0); -} -.jp-icon-contrast1[stroke] { - stroke: var(--jp-icon-contrast-color1); -} -.jp-icon-contrast2[stroke] { - stroke: var(--jp-icon-contrast-color2); -} -.jp-icon-contrast3[stroke] { - stroke: var(--jp-icon-contrast-color3); -} - -/* CSS for icons in selected items in the settings editor */ -#setting-editor .jp-PluginList .jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} -#setting-editor - .jp-PluginList - .jp-mod-selected - .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} - -/* CSS for icons in selected filebrowser listing items */ -.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} -.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} - -/* CSS for icons in selected tabs in the sidebar tab manager */ -#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable[fill] { - fill: #fff; -} - -#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} -#tab-manager - .lm-TabBar-tab.jp-mod-active - .jp-icon-hover - :hover - .jp-icon-selectable[fill] { - fill: var(--jp-brand-color1); -} - -#tab-manager - .lm-TabBar-tab.jp-mod-active - .jp-icon-hover - :hover - .jp-icon-selectable-inverse[fill] { - fill: #fff; -} - -/** - * TODO: come up with non css-hack solution for showing the busy icon on top - * of the close icon - * CSS for complex behavior of close icon of tabs in the sidebar tab manager - */ -#tab-manager - .lm-TabBar-tab.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon3[fill] { - fill: none; -} -#tab-manager - .lm-TabBar-tab.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: var(--jp-inverse-layout-color3); -} - -#tab-manager - .lm-TabBar-tab.jp-mod-dirty.jp-mod-active - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: #fff; -} - -/** -* TODO: come up with non css-hack solution for showing the busy icon on top -* of the close icon -* CSS for complex behavior of close icon of tabs in the main area tabbar -*/ -.lm-DockPanel-tabBar - .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon3[fill] { - fill: none; -} -.lm-DockPanel-tabBar - .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: var(--jp-inverse-layout-color3); -} - -/* CSS for icons in status bar */ -#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} - -#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} -/* special handling for splash icon CSS. While the theme CSS reloads during - splash, the splash icon can loose theming. To prevent that, we set a - default for its color variable */ -:root { - --jp-warn-color0: var(--md-orange-700); -} - -/* not sure what to do with this one, used in filebrowser listing */ -.jp-DragIcon { - margin-right: 4px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * Support for alt colors for icons as inline SVG HTMLElements - */ - -/* alt recolor the primary elements of an icon */ -.jp-icon-alt .jp-icon0[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-alt .jp-icon1[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-alt .jp-icon2[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-alt .jp-icon3[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-alt .jp-icon4[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-alt .jp-icon0[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-alt .jp-icon1[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-alt .jp-icon2[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-alt .jp-icon3[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-alt .jp-icon4[stroke] { - stroke: var(--jp-layout-color4); -} - -/* alt recolor the accent elements of an icon */ -.jp-icon-alt .jp-icon-accent0[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-alt .jp-icon-accent1[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-alt .jp-icon-accent2[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-alt .jp-icon-accent3[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-alt .jp-icon-accent4[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-alt .jp-icon-accent0[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-alt .jp-icon-accent1[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-alt .jp-icon-accent2[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-alt .jp-icon-accent3[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-alt .jp-icon-accent4[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-icon-hoverShow:not(:hover) svg { - display: none !important; -} - -/** - * Support for hover colors for icons as inline SVG HTMLElements - */ - -/** - * regular colors - */ - -/* recolor the primary elements of an icon */ -.jp-icon-hover :hover .jp-icon0-hover[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-hover :hover .jp-icon1-hover[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-hover :hover .jp-icon2-hover[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-hover :hover .jp-icon3-hover[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-hover :hover .jp-icon4-hover[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-hover :hover .jp-icon0-hover[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-hover :hover .jp-icon1-hover[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-hover :hover .jp-icon2-hover[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-hover :hover .jp-icon3-hover[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-hover :hover .jp-icon4-hover[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/* recolor the accent elements of an icon */ -.jp-icon-hover :hover .jp-icon-accent0-hover[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-hover :hover .jp-icon-accent1-hover[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-hover :hover .jp-icon-accent2-hover[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-hover :hover .jp-icon-accent3-hover[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-hover :hover .jp-icon-accent4-hover[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] { - stroke: var(--jp-layout-color4); -} - -/* set the color of an icon to transparent */ -.jp-icon-hover :hover .jp-icon-none-hover[fill] { - fill: none; -} - -.jp-icon-hover :hover .jp-icon-none-hover[stroke] { - stroke: none; -} - -/** - * inverse colors - */ - -/* inverse recolor the primary elements of an icon */ -.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] { - stroke: var(--jp-layout-color4); -} - -/* inverse recolor the accent elements of an icon */ -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-switch { - display: flex; - align-items: center; - padding-left: 4px; - padding-right: 4px; - font-size: var(--jp-ui-font-size1); - background-color: transparent; - color: var(--jp-ui-font-color1); - border: none; - height: 20px; -} - -.jp-switch:hover { - background-color: var(--jp-layout-color2); -} - -.jp-switch-label { - margin-right: 5px; -} - -.jp-switch-track { - cursor: pointer; - background-color: var(--jp-border-color1); - -webkit-transition: 0.4s; - transition: 0.4s; - border-radius: 34px; - height: 16px; - width: 35px; - position: relative; -} - -.jp-switch-track::before { - content: ''; - position: absolute; - height: 10px; - width: 10px; - margin: 3px; - left: 0px; - background-color: var(--jp-ui-inverse-font-color1); - -webkit-transition: 0.4s; - transition: 0.4s; - border-radius: 50%; -} - -.jp-switch[aria-checked='true'] .jp-switch-track { - background-color: var(--jp-warn-color0); -} - -.jp-switch[aria-checked='true'] .jp-switch-track::before { - /* track width (35) - margins (3 + 3) - thumb width (10) */ - left: 19px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* Sibling imports */ - -/* Override Blueprint's _reset.scss styles */ -html { - box-sizing: unset; -} - -*, -*::before, -*::after { - box-sizing: unset; -} - -body { - color: unset; - font-family: var(--jp-ui-font-family); -} - -p { - margin-top: unset; - margin-bottom: unset; -} - -small { - font-size: unset; -} - -strong { - font-weight: unset; -} - -/* Override Blueprint's _typography.scss styles */ -a { - text-decoration: unset; - color: unset; -} -a:hover { - text-decoration: unset; - color: unset; -} - -/* Override Blueprint's _accessibility.scss styles */ -:focus { - outline: unset; - outline-offset: unset; - -moz-outline-radius: unset; -} - -/* Styles for ui-components */ -.jp-Button { - border-radius: var(--jp-border-radius); - padding: 0px 12px; - font-size: var(--jp-ui-font-size1); -} - -/* Use our own theme for hover styles */ -button.jp-Button.bp3-button.bp3-minimal:hover { - background-color: var(--jp-layout-color2); -} -.jp-Button.minimal { - color: unset !important; -} - -.jp-Button.jp-ToolbarButtonComponent { - text-transform: none; -} - -.jp-InputGroup input { - box-sizing: border-box; - border-radius: 0; - background-color: transparent; - color: var(--jp-ui-font-color0); - box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); -} - -.jp-InputGroup input:focus { - box-shadow: inset 0 0 0 var(--jp-border-width) - var(--jp-input-active-box-shadow-color), - inset 0 0 0 3px var(--jp-input-active-box-shadow-color); -} - -.jp-InputGroup input::placeholder, -input::placeholder { - color: var(--jp-ui-font-color3); -} - -.jp-BPIcon { - display: inline-block; - vertical-align: middle; - margin: auto; -} - -/* Stop blueprint futzing with our icon fills */ -.bp3-icon.jp-BPIcon > svg:not([fill]) { - fill: var(--jp-inverse-layout-color3); -} - -.jp-InputGroupAction { - padding: 6px; -} - -.jp-HTMLSelect.jp-DefaultStyle select { - background-color: initial; - border: none; - border-radius: 0; - box-shadow: none; - color: var(--jp-ui-font-color0); - display: block; - font-size: var(--jp-ui-font-size1); - height: 24px; - line-height: 14px; - padding: 0 25px 0 10px; - text-align: left; - -moz-appearance: none; - -webkit-appearance: none; -} - -/* Use our own theme for hover and option styles */ -.jp-HTMLSelect.jp-DefaultStyle select:hover, -.jp-HTMLSelect.jp-DefaultStyle select > option { - background-color: var(--jp-layout-color2); - color: var(--jp-ui-font-color0); -} -select { - box-sizing: border-box; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Collapse { - display: flex; - flex-direction: column; - align-items: stretch; - border-top: 1px solid var(--jp-border-color2); - border-bottom: 1px solid var(--jp-border-color2); -} - -.jp-Collapse-header { - padding: 1px 12px; - color: var(--jp-ui-font-color1); - background-color: var(--jp-layout-color1); - font-size: var(--jp-ui-font-size2); -} - -.jp-Collapse-header:hover { - background-color: var(--jp-layout-color2); -} - -.jp-Collapse-contents { - padding: 0px 12px 0px 12px; - background-color: var(--jp-layout-color1); - color: var(--jp-ui-font-color1); - overflow: auto; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-commandpalette-search-height: 28px; -} - -/*----------------------------------------------------------------------------- -| Overall styles -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette { - padding-bottom: 0px; - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); -} - -/*----------------------------------------------------------------------------- -| Modal variant -|----------------------------------------------------------------------------*/ - -.jp-ModalCommandPalette { - position: absolute; - z-index: 10000; - top: 38px; - left: 30%; - margin: 0; - padding: 4px; - width: 40%; - box-shadow: var(--jp-elevation-z4); - border-radius: 4px; - background: var(--jp-layout-color0); -} - -.jp-ModalCommandPalette .lm-CommandPalette { - max-height: 40vh; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after { - display: none; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header { - display: none; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item { - margin-left: 4px; - margin-right: 4px; -} - -.jp-ModalCommandPalette - .lm-CommandPalette - .lm-CommandPalette-item.lm-mod-disabled { - display: none; -} - -/*----------------------------------------------------------------------------- -| Search -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette-search { - padding: 4px; - background-color: var(--jp-layout-color1); - z-index: 2; -} - -.lm-CommandPalette-wrapper { - overflow: overlay; - padding: 0px 9px; - background-color: var(--jp-input-active-background); - height: 30px; - box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); -} - -.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper { - box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color), - inset 0 0 0 3px var(--jp-input-active-box-shadow-color); -} - -.jp-SearchIconGroup { - color: white; - background-color: var(--jp-brand-color1); - position: absolute; - top: 4px; - right: 4px; - padding: 5px 5px 1px 5px; -} - -.jp-SearchIconGroup svg { - height: 20px; - width: 20px; -} - -.jp-SearchIconGroup .jp-icon3[fill] { - fill: var(--jp-layout-color0); -} - -.lm-CommandPalette-input { - background: transparent; - width: calc(100% - 18px); - float: left; - border: none; - outline: none; - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - line-height: var(--jp-private-commandpalette-search-height); -} - -.lm-CommandPalette-input::-webkit-input-placeholder, -.lm-CommandPalette-input::-moz-placeholder, -.lm-CommandPalette-input:-ms-input-placeholder { - color: var(--jp-ui-font-color2); - font-size: var(--jp-ui-font-size1); -} - -/*----------------------------------------------------------------------------- -| Results -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette-header:first-child { - margin-top: 0px; -} - -.lm-CommandPalette-header { - border-bottom: solid var(--jp-border-width) var(--jp-border-color2); - color: var(--jp-ui-font-color1); - cursor: pointer; - display: flex; - font-size: var(--jp-ui-font-size0); - font-weight: 600; - letter-spacing: 1px; - margin-top: 8px; - padding: 8px 0 8px 12px; - text-transform: uppercase; -} - -.lm-CommandPalette-header.lm-mod-active { - background: var(--jp-layout-color2); -} - -.lm-CommandPalette-header > mark { - background-color: transparent; - font-weight: bold; - color: var(--jp-ui-font-color1); -} - -.lm-CommandPalette-item { - padding: 4px 12px 4px 4px; - color: var(--jp-ui-font-color1); - font-size: var(--jp-ui-font-size1); - font-weight: 400; - display: flex; -} - -.lm-CommandPalette-item.lm-mod-disabled { - color: var(--jp-ui-font-color2); -} - -.lm-CommandPalette-item.lm-mod-active { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-inverse-font-color0); -} - -.lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] { - fill: var(--jp-layout-color0); -} - -.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-inverse-font-color0); -} - -.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) { - background: var(--jp-layout-color2); -} - -.lm-CommandPalette-itemContent { - overflow: hidden; -} - -.lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-font-color0); - background-color: transparent; - font-weight: bold; -} - -.lm-CommandPalette-item.lm-mod-disabled mark { - color: var(--jp-ui-font-color2); -} - -.lm-CommandPalette-item .lm-CommandPalette-itemIcon { - margin: 0 4px 0 0; - position: relative; - width: 16px; - top: 2px; - flex: 0 0 auto; -} - -.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon { - opacity: 0.6; -} - -.lm-CommandPalette-item .lm-CommandPalette-itemShortcut { - flex: 0 0 auto; -} - -.lm-CommandPalette-itemCaption { - display: none; -} - -.lm-CommandPalette-content { - background-color: var(--jp-layout-color1); -} - -.lm-CommandPalette-content:empty:after { - content: 'No results'; - margin: auto; - margin-top: 20px; - width: 100px; - display: block; - font-size: var(--jp-ui-font-size2); - font-family: var(--jp-ui-font-family); - font-weight: lighter; -} - -.lm-CommandPalette-emptyMessage { - text-align: center; - margin-top: 24px; - line-height: 1.32; - padding: 0px 8px; - color: var(--jp-content-font-color3); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Dialog { - position: absolute; - z-index: 10000; - display: flex; - flex-direction: column; - align-items: center; - justify-content: center; - top: 0px; - left: 0px; - margin: 0; - padding: 0; - width: 100%; - height: 100%; - background: var(--jp-dialog-background); -} - -.jp-Dialog-content { - display: flex; - flex-direction: column; - margin-left: auto; - margin-right: auto; - background: var(--jp-layout-color1); - padding: 24px; - padding-bottom: 12px; - min-width: 300px; - min-height: 150px; - max-width: 1000px; - max-height: 500px; - box-sizing: border-box; - box-shadow: var(--jp-elevation-z20); - word-wrap: break-word; - border-radius: var(--jp-border-radius); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color1); - resize: both; -} - -.jp-Dialog-button { - overflow: visible; -} - -button.jp-Dialog-button:focus { - outline: 1px solid var(--jp-brand-color1); - outline-offset: 4px; - -moz-outline-radius: 0px; -} - -button.jp-Dialog-button:focus::-moz-focus-inner { - border: 0; -} - -button.jp-Dialog-close-button { - padding: 0; - height: 100%; - min-width: unset; - min-height: unset; -} - -.jp-Dialog-header { - display: flex; - justify-content: space-between; - flex: 0 0 auto; - padding-bottom: 12px; - font-size: var(--jp-ui-font-size3); - font-weight: 400; - color: var(--jp-ui-font-color0); -} - -.jp-Dialog-body { - display: flex; - flex-direction: column; - flex: 1 1 auto; - font-size: var(--jp-ui-font-size1); - background: var(--jp-layout-color1); - overflow: auto; -} - -.jp-Dialog-footer { - display: flex; - flex-direction: row; - justify-content: flex-end; - flex: 0 0 auto; - margin-left: -12px; - margin-right: -12px; - padding: 12px; -} - -.jp-Dialog-title { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.jp-Dialog-body > .jp-select-wrapper { - width: 100%; -} - -.jp-Dialog-body > button { - padding: 0px 16px; -} - -.jp-Dialog-body > label { - line-height: 1.4; - color: var(--jp-ui-font-color0); -} - -.jp-Dialog-button.jp-mod-styled:not(:last-child) { - margin-right: 12px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-HoverBox { - position: fixed; -} - -.jp-HoverBox.jp-mod-outofview { - display: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-IFrame { - width: 100%; - height: 100%; -} - -.jp-IFrame > iframe { - border: none; -} - -/* -When drag events occur, `p-mod-override-cursor` is added to the body. -Because iframes steal all cursor events, the following two rules are necessary -to suppress pointer events while resize drags are occurring. There may be a -better solution to this problem. -*/ -body.lm-mod-override-cursor .jp-IFrame { - position: relative; -} - -body.lm-mod-override-cursor .jp-IFrame:before { - content: ''; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; -} - -.jp-Input-Boolean-Dialog { - flex-direction: row-reverse; - align-items: end; - width: 100%; -} - -.jp-Input-Boolean-Dialog > label { - flex: 1 1 auto; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-MainAreaWidget > :focus { - outline: none; -} - -/** - * google-material-color v1.2.6 - * https://github.com/danlevan/google-material-color - */ -:root { - --md-red-50: #ffebee; - --md-red-100: #ffcdd2; - --md-red-200: #ef9a9a; - --md-red-300: #e57373; - --md-red-400: #ef5350; - --md-red-500: #f44336; - --md-red-600: #e53935; - --md-red-700: #d32f2f; - --md-red-800: #c62828; - --md-red-900: #b71c1c; - --md-red-A100: #ff8a80; - --md-red-A200: #ff5252; - --md-red-A400: #ff1744; - --md-red-A700: #d50000; - - --md-pink-50: #fce4ec; - --md-pink-100: #f8bbd0; - --md-pink-200: #f48fb1; - --md-pink-300: #f06292; - --md-pink-400: #ec407a; - --md-pink-500: #e91e63; - --md-pink-600: #d81b60; - --md-pink-700: #c2185b; - --md-pink-800: #ad1457; - --md-pink-900: #880e4f; - --md-pink-A100: #ff80ab; - --md-pink-A200: #ff4081; - --md-pink-A400: #f50057; - --md-pink-A700: #c51162; - - --md-purple-50: #f3e5f5; - --md-purple-100: #e1bee7; - --md-purple-200: #ce93d8; - --md-purple-300: #ba68c8; - --md-purple-400: #ab47bc; - --md-purple-500: #9c27b0; - --md-purple-600: #8e24aa; - --md-purple-700: #7b1fa2; - --md-purple-800: #6a1b9a; - --md-purple-900: #4a148c; - --md-purple-A100: #ea80fc; - --md-purple-A200: #e040fb; - --md-purple-A400: #d500f9; - --md-purple-A700: #aa00ff; - - --md-deep-purple-50: #ede7f6; - --md-deep-purple-100: #d1c4e9; - --md-deep-purple-200: #b39ddb; - --md-deep-purple-300: #9575cd; - --md-deep-purple-400: #7e57c2; - --md-deep-purple-500: #673ab7; - --md-deep-purple-600: #5e35b1; - --md-deep-purple-700: #512da8; - --md-deep-purple-800: #4527a0; - --md-deep-purple-900: #311b92; - --md-deep-purple-A100: #b388ff; - --md-deep-purple-A200: #7c4dff; - --md-deep-purple-A400: #651fff; - --md-deep-purple-A700: #6200ea; - - --md-indigo-50: #e8eaf6; - --md-indigo-100: #c5cae9; - --md-indigo-200: #9fa8da; - --md-indigo-300: #7986cb; - --md-indigo-400: #5c6bc0; - --md-indigo-500: #3f51b5; - --md-indigo-600: #3949ab; - --md-indigo-700: #303f9f; - --md-indigo-800: #283593; - --md-indigo-900: #1a237e; - --md-indigo-A100: #8c9eff; - --md-indigo-A200: #536dfe; - --md-indigo-A400: #3d5afe; - --md-indigo-A700: #304ffe; - - --md-blue-50: #e3f2fd; - --md-blue-100: #bbdefb; - --md-blue-200: #90caf9; - --md-blue-300: #64b5f6; - --md-blue-400: #42a5f5; - --md-blue-500: #2196f3; - --md-blue-600: #1e88e5; - --md-blue-700: #1976d2; - --md-blue-800: #1565c0; - --md-blue-900: #0d47a1; - --md-blue-A100: #82b1ff; - --md-blue-A200: #448aff; - --md-blue-A400: #2979ff; - --md-blue-A700: #2962ff; - - --md-light-blue-50: #e1f5fe; - --md-light-blue-100: #b3e5fc; - --md-light-blue-200: #81d4fa; - --md-light-blue-300: #4fc3f7; - --md-light-blue-400: #29b6f6; - --md-light-blue-500: #03a9f4; - --md-light-blue-600: #039be5; - --md-light-blue-700: #0288d1; - --md-light-blue-800: #0277bd; - --md-light-blue-900: #01579b; - --md-light-blue-A100: #80d8ff; - --md-light-blue-A200: #40c4ff; - --md-light-blue-A400: #00b0ff; - --md-light-blue-A700: #0091ea; - - --md-cyan-50: #e0f7fa; - --md-cyan-100: #b2ebf2; - --md-cyan-200: #80deea; - --md-cyan-300: #4dd0e1; - --md-cyan-400: #26c6da; - --md-cyan-500: #00bcd4; - --md-cyan-600: #00acc1; - --md-cyan-700: #0097a7; - --md-cyan-800: #00838f; - --md-cyan-900: #006064; - --md-cyan-A100: #84ffff; - --md-cyan-A200: #18ffff; - --md-cyan-A400: #00e5ff; - --md-cyan-A700: #00b8d4; - - --md-teal-50: #e0f2f1; - --md-teal-100: #b2dfdb; - --md-teal-200: #80cbc4; - --md-teal-300: #4db6ac; - --md-teal-400: #26a69a; - --md-teal-500: #009688; - --md-teal-600: #00897b; - --md-teal-700: #00796b; - --md-teal-800: #00695c; - --md-teal-900: #004d40; - --md-teal-A100: #a7ffeb; - --md-teal-A200: #64ffda; - --md-teal-A400: #1de9b6; - --md-teal-A700: #00bfa5; - - --md-green-50: #e8f5e9; - --md-green-100: #c8e6c9; - --md-green-200: #a5d6a7; - --md-green-300: #81c784; - --md-green-400: #66bb6a; - --md-green-500: #4caf50; - --md-green-600: #43a047; - --md-green-700: #388e3c; - --md-green-800: #2e7d32; - --md-green-900: #1b5e20; - --md-green-A100: #b9f6ca; - --md-green-A200: #69f0ae; - --md-green-A400: #00e676; - --md-green-A700: #00c853; - - --md-light-green-50: #f1f8e9; - --md-light-green-100: #dcedc8; - --md-light-green-200: #c5e1a5; - --md-light-green-300: #aed581; - --md-light-green-400: #9ccc65; - --md-light-green-500: #8bc34a; - --md-light-green-600: #7cb342; - --md-light-green-700: #689f38; - --md-light-green-800: #558b2f; - --md-light-green-900: #33691e; - --md-light-green-A100: #ccff90; - --md-light-green-A200: #b2ff59; - --md-light-green-A400: #76ff03; - --md-light-green-A700: #64dd17; - - --md-lime-50: #f9fbe7; - --md-lime-100: #f0f4c3; - --md-lime-200: #e6ee9c; - --md-lime-300: #dce775; - --md-lime-400: #d4e157; - --md-lime-500: #cddc39; - --md-lime-600: #c0ca33; - --md-lime-700: #afb42b; - --md-lime-800: #9e9d24; - --md-lime-900: #827717; - --md-lime-A100: #f4ff81; - --md-lime-A200: #eeff41; - --md-lime-A400: #c6ff00; - --md-lime-A700: #aeea00; - - --md-yellow-50: #fffde7; - --md-yellow-100: #fff9c4; - --md-yellow-200: #fff59d; - --md-yellow-300: #fff176; - --md-yellow-400: #ffee58; - --md-yellow-500: #ffeb3b; - --md-yellow-600: #fdd835; - --md-yellow-700: #fbc02d; - --md-yellow-800: #f9a825; - --md-yellow-900: #f57f17; - --md-yellow-A100: #ffff8d; - --md-yellow-A200: #ffff00; - --md-yellow-A400: #ffea00; - --md-yellow-A700: #ffd600; - - --md-amber-50: #fff8e1; - --md-amber-100: #ffecb3; - --md-amber-200: #ffe082; - --md-amber-300: #ffd54f; - --md-amber-400: #ffca28; - --md-amber-500: #ffc107; - --md-amber-600: #ffb300; - --md-amber-700: #ffa000; - --md-amber-800: #ff8f00; - --md-amber-900: #ff6f00; - --md-amber-A100: #ffe57f; - --md-amber-A200: #ffd740; - --md-amber-A400: #ffc400; - --md-amber-A700: #ffab00; - - --md-orange-50: #fff3e0; - --md-orange-100: #ffe0b2; - --md-orange-200: #ffcc80; - --md-orange-300: #ffb74d; - --md-orange-400: #ffa726; - --md-orange-500: #ff9800; - --md-orange-600: #fb8c00; - --md-orange-700: #f57c00; - --md-orange-800: #ef6c00; - --md-orange-900: #e65100; - --md-orange-A100: #ffd180; - --md-orange-A200: #ffab40; - --md-orange-A400: #ff9100; - --md-orange-A700: #ff6d00; - - --md-deep-orange-50: #fbe9e7; - --md-deep-orange-100: #ffccbc; - --md-deep-orange-200: #ffab91; - --md-deep-orange-300: #ff8a65; - --md-deep-orange-400: #ff7043; - --md-deep-orange-500: #ff5722; - --md-deep-orange-600: #f4511e; - --md-deep-orange-700: #e64a19; - --md-deep-orange-800: #d84315; - --md-deep-orange-900: #bf360c; - --md-deep-orange-A100: #ff9e80; - --md-deep-orange-A200: #ff6e40; - --md-deep-orange-A400: #ff3d00; - --md-deep-orange-A700: #dd2c00; - - --md-brown-50: #efebe9; - --md-brown-100: #d7ccc8; - --md-brown-200: #bcaaa4; - --md-brown-300: #a1887f; - --md-brown-400: #8d6e63; - --md-brown-500: #795548; - --md-brown-600: #6d4c41; - --md-brown-700: #5d4037; - --md-brown-800: #4e342e; - --md-brown-900: #3e2723; - - --md-grey-50: #fafafa; - --md-grey-100: #f5f5f5; - --md-grey-200: #eeeeee; - --md-grey-300: #e0e0e0; - --md-grey-400: #bdbdbd; - --md-grey-500: #9e9e9e; - --md-grey-600: #757575; - --md-grey-700: #616161; - --md-grey-800: #424242; - --md-grey-900: #212121; - - --md-blue-grey-50: #eceff1; - --md-blue-grey-100: #cfd8dc; - --md-blue-grey-200: #b0bec5; - --md-blue-grey-300: #90a4ae; - --md-blue-grey-400: #78909c; - --md-blue-grey-500: #607d8b; - --md-blue-grey-600: #546e7a; - --md-blue-grey-700: #455a64; - --md-blue-grey-800: #37474f; - --md-blue-grey-900: #263238; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Spinner { - position: absolute; - display: flex; - justify-content: center; - align-items: center; - z-index: 10; - left: 0; - top: 0; - width: 100%; - height: 100%; - background: var(--jp-layout-color0); - outline: none; -} - -.jp-SpinnerContent { - font-size: 10px; - margin: 50px auto; - text-indent: -9999em; - width: 3em; - height: 3em; - border-radius: 50%; - background: var(--jp-brand-color3); - background: linear-gradient( - to right, - #f37626 10%, - rgba(255, 255, 255, 0) 42% - ); - position: relative; - animation: load3 1s infinite linear, fadeIn 1s; -} - -.jp-SpinnerContent:before { - width: 50%; - height: 50%; - background: #f37626; - border-radius: 100% 0 0 0; - position: absolute; - top: 0; - left: 0; - content: ''; -} - -.jp-SpinnerContent:after { - background: var(--jp-layout-color0); - width: 75%; - height: 75%; - border-radius: 50%; - content: ''; - margin: auto; - position: absolute; - top: 0; - left: 0; - bottom: 0; - right: 0; -} - -@keyframes fadeIn { - 0% { - opacity: 0; - } - 100% { - opacity: 1; - } -} - -@keyframes load3 { - 0% { - transform: rotate(0deg); - } - 100% { - transform: rotate(360deg); - } -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -button.jp-mod-styled { - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - border: none; - box-sizing: border-box; - text-align: center; - line-height: 32px; - height: 32px; - padding: 0px 12px; - letter-spacing: 0.8px; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -input.jp-mod-styled { - background: var(--jp-input-background); - height: 28px; - box-sizing: border-box; - border: var(--jp-border-width) solid var(--jp-border-color1); - padding-left: 7px; - padding-right: 7px; - font-size: var(--jp-ui-font-size2); - color: var(--jp-ui-font-color0); - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -input[type='checkbox'].jp-mod-styled { - appearance: checkbox; - -webkit-appearance: checkbox; - -moz-appearance: checkbox; - height: auto; -} - -input.jp-mod-styled:focus { - border: var(--jp-border-width) solid var(--md-blue-500); - box-shadow: inset 0 0 4px var(--md-blue-300); -} - -.jp-FileDialog-Checkbox { - margin-top: 35px; - display: flex; - flex-direction: row; - align-items: end; - width: 100%; -} - -.jp-FileDialog-Checkbox > label { - flex: 1 1 auto; -} - -.jp-select-wrapper { - display: flex; - position: relative; - flex-direction: column; - padding: 1px; - background-color: var(--jp-layout-color1); - height: 28px; - box-sizing: border-box; - margin-bottom: 12px; -} - -.jp-select-wrapper.jp-mod-focused select.jp-mod-styled { - border: var(--jp-border-width) solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); - background-color: var(--jp-input-active-background); -} - -select.jp-mod-styled:hover { - background-color: var(--jp-layout-color1); - cursor: pointer; - color: var(--jp-ui-font-color0); - background-color: var(--jp-input-hover-background); - box-shadow: inset 0 0px 1px rgba(0, 0, 0, 0.5); -} - -select.jp-mod-styled { - flex: 1 1 auto; - height: 32px; - width: 100%; - font-size: var(--jp-ui-font-size2); - background: var(--jp-input-background); - color: var(--jp-ui-font-color0); - padding: 0 25px 0 8px; - border: var(--jp-border-width) solid var(--jp-input-border-color); - border-radius: 0px; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-toolbar-height: calc( - 28px + var(--jp-border-width) - ); /* leave 28px for content */ -} - -.jp-Toolbar { - color: var(--jp-ui-font-color1); - flex: 0 0 auto; - display: flex; - flex-direction: row; - border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); - box-shadow: var(--jp-toolbar-box-shadow); - background: var(--jp-toolbar-background); - min-height: var(--jp-toolbar-micro-height); - padding: 2px; - z-index: 1; - overflow-x: auto; -} - -/* Toolbar items */ - -.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer { - flex-grow: 1; - flex-shrink: 1; -} - -.jp-Toolbar-item.jp-Toolbar-kernelStatus { - display: inline-block; - width: 32px; - background-repeat: no-repeat; - background-position: center; - background-size: 16px; -} - -.jp-Toolbar > .jp-Toolbar-item { - flex: 0 0 auto; - display: flex; - padding-left: 1px; - padding-right: 1px; - font-size: var(--jp-ui-font-size1); - line-height: var(--jp-private-toolbar-height); - height: 100%; -} - -/* Toolbar buttons */ - -/* This is the div we use to wrap the react component into a Widget */ -div.jp-ToolbarButton { - color: transparent; - border: none; - box-sizing: border-box; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; - padding: 0px; - margin: 0px; -} - -button.jp-ToolbarButtonComponent { - background: var(--jp-layout-color1); - border: none; - box-sizing: border-box; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; - padding: 0px 6px; - margin: 0px; - height: 24px; - border-radius: var(--jp-border-radius); - display: flex; - align-items: center; - text-align: center; - font-size: 14px; - min-width: unset; - min-height: unset; -} - -button.jp-ToolbarButtonComponent:disabled { - opacity: 0.4; -} - -button.jp-ToolbarButtonComponent span { - padding: 0px; - flex: 0 0 auto; -} - -button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label { - font-size: var(--jp-ui-font-size1); - line-height: 100%; - padding-left: 2px; - color: var(--jp-ui-font-color1); -} - -#jp-main-dock-panel[data-mode='single-document'] - .jp-MainAreaWidget - > .jp-Toolbar.jp-Toolbar-micro { - padding: 0; - min-height: 0; -} - -#jp-main-dock-panel[data-mode='single-document'] - .jp-MainAreaWidget - > .jp-Toolbar { - border: none; - box-shadow: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ body.p-mod-override-cursor *, /* </DEPRECATED> */ -body.lm-mod-override-cursor * { - cursor: inherit !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-JSONEditor { - display: flex; - flex-direction: column; - width: 100%; -} - -.jp-JSONEditor-host { - flex: 1 1 auto; - border: var(--jp-border-width) solid var(--jp-input-border-color); - border-radius: 0px; - background: var(--jp-layout-color0); - min-height: 50px; - padding: 1px; -} - -.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host { - border-color: red; - outline-color: red; -} - -.jp-JSONEditor-header { - display: flex; - flex: 1 0 auto; - padding: 0 0 0 12px; -} - -.jp-JSONEditor-header label { - flex: 0 0 auto; -} - -.jp-JSONEditor-commitButton { - height: 16px; - width: 16px; - background-size: 18px; - background-repeat: no-repeat; - background-position: center; -} - -.jp-JSONEditor-host.jp-mod-focused { - background-color: var(--jp-input-active-background); - border: 1px solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); -} - -.jp-Editor.jp-mod-dropTarget { - border: var(--jp-border-width) solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); -} - -/* BASICS */ - -.CodeMirror { - /* Set height, width, borders, and global font properties here */ - font-family: monospace; - height: 300px; - color: black; - direction: ltr; -} - -/* PADDING */ - -.CodeMirror-lines { - padding: 4px 0; /* Vertical padding around content */ -} -.CodeMirror pre.CodeMirror-line, -.CodeMirror pre.CodeMirror-line-like { - padding: 0 4px; /* Horizontal padding of content */ -} - -.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { - background-color: white; /* The little square between H and V scrollbars */ -} - -/* GUTTER */ - -.CodeMirror-gutters { - border-right: 1px solid #ddd; - background-color: #f7f7f7; - white-space: nowrap; -} -.CodeMirror-linenumbers {} -.CodeMirror-linenumber { - padding: 0 3px 0 5px; - min-width: 20px; - text-align: right; - color: #999; - white-space: nowrap; -} - -.CodeMirror-guttermarker { color: black; } -.CodeMirror-guttermarker-subtle { color: #999; } - -/* CURSOR */ - -.CodeMirror-cursor { - border-left: 1px solid black; - border-right: none; - width: 0; -} -/* Shown when moving in bi-directional text */ -.CodeMirror div.CodeMirror-secondarycursor { - border-left: 1px solid silver; -} -.cm-fat-cursor .CodeMirror-cursor { - width: auto; - border: 0 !important; - background: #7e7; -} -.cm-fat-cursor div.CodeMirror-cursors { - z-index: 1; -} -.cm-fat-cursor-mark { - background-color: rgba(20, 255, 20, 0.5); - -webkit-animation: blink 1.06s steps(1) infinite; - -moz-animation: blink 1.06s steps(1) infinite; - animation: blink 1.06s steps(1) infinite; -} -.cm-animate-fat-cursor { - width: auto; - border: 0; - -webkit-animation: blink 1.06s steps(1) infinite; - -moz-animation: blink 1.06s steps(1) infinite; - animation: blink 1.06s steps(1) infinite; - background-color: #7e7; -} -@-moz-keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} -@-webkit-keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} -@keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} - -/* Can style cursor different in overwrite (non-insert) mode */ -.CodeMirror-overwrite .CodeMirror-cursor {} - -.cm-tab { display: inline-block; text-decoration: inherit; } - -.CodeMirror-rulers { - position: absolute; - left: 0; right: 0; top: -50px; bottom: 0; - overflow: hidden; -} -.CodeMirror-ruler { - border-left: 1px solid #ccc; - top: 0; bottom: 0; - position: absolute; -} - -/* DEFAULT THEME */ - -.cm-s-default .cm-header {color: blue;} -.cm-s-default .cm-quote {color: #090;} -.cm-negative {color: #d44;} -.cm-positive {color: #292;} -.cm-header, .cm-strong {font-weight: bold;} -.cm-em {font-style: italic;} -.cm-link {text-decoration: underline;} -.cm-strikethrough {text-decoration: line-through;} - -.cm-s-default .cm-keyword {color: #708;} -.cm-s-default .cm-atom {color: #219;} -.cm-s-default .cm-number {color: #164;} -.cm-s-default .cm-def {color: #00f;} -.cm-s-default .cm-variable, -.cm-s-default .cm-punctuation, -.cm-s-default .cm-property, -.cm-s-default .cm-operator {} -.cm-s-default .cm-variable-2 {color: #05a;} -.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;} -.cm-s-default .cm-comment {color: #a50;} -.cm-s-default .cm-string {color: #a11;} -.cm-s-default .cm-string-2 {color: #f50;} -.cm-s-default .cm-meta {color: #555;} -.cm-s-default .cm-qualifier {color: #555;} -.cm-s-default .cm-builtin {color: #30a;} -.cm-s-default .cm-bracket {color: #997;} -.cm-s-default .cm-tag {color: #170;} -.cm-s-default .cm-attribute {color: #00c;} -.cm-s-default .cm-hr {color: #999;} -.cm-s-default .cm-link {color: #00c;} - -.cm-s-default .cm-error {color: #f00;} -.cm-invalidchar {color: #f00;} - -.CodeMirror-composing { border-bottom: 2px solid; } - -/* Default styles for common addons */ - -div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;} -div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;} -.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); } -.CodeMirror-activeline-background {background: #e8f2ff;} - -/* STOP */ - -/* The rest of this file contains styles related to the mechanics of - the editor. You probably shouldn't touch them. */ - -.CodeMirror { - position: relative; - overflow: hidden; - background: white; -} - -.CodeMirror-scroll { - overflow: scroll !important; /* Things will break if this is overridden */ - /* 50px is the magic margin used to hide the element's real scrollbars */ - /* See overflow: hidden in .CodeMirror */ - margin-bottom: -50px; margin-right: -50px; - padding-bottom: 50px; - height: 100%; - outline: none; /* Prevent dragging from highlighting the element */ - position: relative; -} -.CodeMirror-sizer { - position: relative; - border-right: 50px solid transparent; -} - -/* The fake, visible scrollbars. Used to force redraw during scrolling - before actual scrolling happens, thus preventing shaking and - flickering artifacts. */ -.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { - position: absolute; - z-index: 6; - display: none; - outline: none; -} -.CodeMirror-vscrollbar { - right: 0; top: 0; - overflow-x: hidden; - overflow-y: scroll; -} -.CodeMirror-hscrollbar { - bottom: 0; left: 0; - overflow-y: hidden; - overflow-x: scroll; -} -.CodeMirror-scrollbar-filler { - right: 0; bottom: 0; -} -.CodeMirror-gutter-filler { - left: 0; bottom: 0; -} - -.CodeMirror-gutters { - position: absolute; left: 0; top: 0; - min-height: 100%; - z-index: 3; -} -.CodeMirror-gutter { - white-space: normal; - height: 100%; - display: inline-block; - vertical-align: top; - margin-bottom: -50px; -} -.CodeMirror-gutter-wrapper { - position: absolute; - z-index: 4; - background: none !important; - border: none !important; -} -.CodeMirror-gutter-background { - position: absolute; - top: 0; bottom: 0; - z-index: 4; -} -.CodeMirror-gutter-elt { - position: absolute; - cursor: default; - z-index: 4; -} -.CodeMirror-gutter-wrapper ::selection { background-color: transparent } -.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent } - -.CodeMirror-lines { - cursor: text; - min-height: 1px; /* prevents collapsing before first draw */ -} -.CodeMirror pre.CodeMirror-line, -.CodeMirror pre.CodeMirror-line-like { - /* Reset some styles that the rest of the page might have set */ - -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; - border-width: 0; - background: transparent; - font-family: inherit; - font-size: inherit; - margin: 0; - white-space: pre; - word-wrap: normal; - line-height: inherit; - color: inherit; - z-index: 2; - position: relative; - overflow: visible; - -webkit-tap-highlight-color: transparent; - -webkit-font-variant-ligatures: contextual; - font-variant-ligatures: contextual; -} -.CodeMirror-wrap pre.CodeMirror-line, -.CodeMirror-wrap pre.CodeMirror-line-like { - word-wrap: break-word; - white-space: pre-wrap; - word-break: normal; -} - -.CodeMirror-linebackground { - position: absolute; - left: 0; right: 0; top: 0; bottom: 0; - z-index: 0; -} - -.CodeMirror-linewidget { - position: relative; - z-index: 2; - padding: 0.1px; /* Force widget margins to stay inside of the container */ -} - -.CodeMirror-widget {} - -.CodeMirror-rtl pre { direction: rtl; } - -.CodeMirror-code { - outline: none; -} - -/* Force content-box sizing for the elements where we expect it */ -.CodeMirror-scroll, -.CodeMirror-sizer, -.CodeMirror-gutter, -.CodeMirror-gutters, -.CodeMirror-linenumber { - -moz-box-sizing: content-box; - box-sizing: content-box; -} - -.CodeMirror-measure { - position: absolute; - width: 100%; - height: 0; - overflow: hidden; - visibility: hidden; -} - -.CodeMirror-cursor { - position: absolute; - pointer-events: none; -} -.CodeMirror-measure pre { position: static; } - -div.CodeMirror-cursors { - visibility: hidden; - position: relative; - z-index: 3; -} -div.CodeMirror-dragcursors { - visibility: visible; -} - -.CodeMirror-focused div.CodeMirror-cursors { - visibility: visible; -} - -.CodeMirror-selected { background: #d9d9d9; } -.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; } -.CodeMirror-crosshair { cursor: crosshair; } -.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; } -.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; } - -.cm-searching { - background-color: #ffa; - background-color: rgba(255, 255, 0, .4); -} - -/* Used to force a border model for a node */ -.cm-force-border { padding-right: .1px; } - -@media print { - /* Hide the cursor when printing */ - .CodeMirror div.CodeMirror-cursors { - visibility: hidden; - } -} - -/* See issue #2901 */ -.cm-tab-wrap-hack:after { content: ''; } - -/* Help users use markselection to safely style text background */ -span.CodeMirror-selectedtext { background: none; } - -.CodeMirror-dialog { - position: absolute; - left: 0; right: 0; - background: inherit; - z-index: 15; - padding: .1em .8em; - overflow: hidden; - color: inherit; -} - -.CodeMirror-dialog-top { - border-bottom: 1px solid #eee; - top: 0; -} - -.CodeMirror-dialog-bottom { - border-top: 1px solid #eee; - bottom: 0; -} - -.CodeMirror-dialog input { - border: none; - outline: none; - background: transparent; - width: 20em; - color: inherit; - font-family: monospace; -} - -.CodeMirror-dialog button { - font-size: 70%; -} - -.CodeMirror-foldmarker { - color: blue; - text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px; - font-family: arial; - line-height: .3; - cursor: pointer; -} -.CodeMirror-foldgutter { - width: .7em; -} -.CodeMirror-foldgutter-open, -.CodeMirror-foldgutter-folded { - cursor: pointer; -} -.CodeMirror-foldgutter-open:after { - content: "\25BE"; -} -.CodeMirror-foldgutter-folded:after { - content: "\25B8"; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.CodeMirror { - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - font-family: var(--jp-code-font-family); - border: 0; - border-radius: 0; - height: auto; - /* Changed to auto to autogrow */ -} - -.CodeMirror pre { - padding: 0 var(--jp-code-padding); -} - -.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-dialog { - background-color: var(--jp-layout-color0); - color: var(--jp-content-font-color1); -} - -/* This causes https://github.com/jupyter/jupyterlab/issues/522 */ -/* May not cause it not because we changed it! */ -.CodeMirror-lines { - padding: var(--jp-code-padding) 0; -} - -.CodeMirror-linenumber { - padding: 0 8px; -} - -.jp-CodeMirrorEditor { - cursor: text; -} - -.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color); -} - -/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */ -@media screen and (min-width: 2138px) and (max-width: 4319px) { - .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width1) solid - var(--jp-editor-cursor-color); - } -} - -/* When zoomed out less than 33% */ -@media screen and (min-width: 4320px) { - .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width2) solid - var(--jp-editor-cursor-color); - } -} - -.CodeMirror.jp-mod-readOnly .CodeMirror-cursor { - display: none; -} - -.CodeMirror-gutters { - border-right: 1px solid var(--jp-border-color2); - background-color: var(--jp-layout-color0); -} - -.jp-CollaboratorCursor { - border-left: 5px solid transparent; - border-right: 5px solid transparent; - border-top: none; - border-bottom: 3px solid; - background-clip: content-box; - margin-left: -5px; - margin-right: -5px; -} - -.CodeMirror-selectedtext.cm-searching { - background-color: var(--jp-search-selected-match-background-color) !important; - color: var(--jp-search-selected-match-color) !important; -} - -.cm-searching { - background-color: var( - --jp-search-unselected-match-background-color - ) !important; - color: var(--jp-search-unselected-match-color) !important; -} - -.CodeMirror-focused .CodeMirror-selected { - background-color: var(--jp-editor-selected-focused-background); -} - -.CodeMirror-selected { - background-color: var(--jp-editor-selected-background); -} - -.jp-CollaboratorCursor-hover { - position: absolute; - z-index: 1; - transform: translateX(-50%); - color: white; - border-radius: 3px; - padding-left: 4px; - padding-right: 4px; - padding-top: 1px; - padding-bottom: 1px; - text-align: center; - font-size: var(--jp-ui-font-size1); - white-space: nowrap; -} - -.jp-CodeMirror-ruler { - border-left: 1px dashed var(--jp-border-color2); -} - -/** - * Here is our jupyter theme for CodeMirror syntax highlighting - * This is used in our marked.js syntax highlighting and CodeMirror itself - * The string "jupyter" is set in ../codemirror/widget.DEFAULT_CODEMIRROR_THEME - * This came from the classic notebook, which came form highlight.js/GitHub - */ - -/** - * CodeMirror themes are handling the background/color in this way. This works - * fine for CodeMirror editors outside the notebook, but the notebook styles - * these things differently. - */ -.CodeMirror.cm-s-jupyter { - background: var(--jp-layout-color0); - color: var(--jp-content-font-color1); -} - -/* In the notebook, we want this styling to be handled by its container */ -.jp-CodeConsole .CodeMirror.cm-s-jupyter, -.jp-Notebook .CodeMirror.cm-s-jupyter { - background: transparent; -} - -.cm-s-jupyter .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color); -} -.cm-s-jupyter span.cm-keyword { - color: var(--jp-mirror-editor-keyword-color); - font-weight: bold; -} -.cm-s-jupyter span.cm-atom { - color: var(--jp-mirror-editor-atom-color); -} -.cm-s-jupyter span.cm-number { - color: var(--jp-mirror-editor-number-color); -} -.cm-s-jupyter span.cm-def { - color: var(--jp-mirror-editor-def-color); -} -.cm-s-jupyter span.cm-variable { - color: var(--jp-mirror-editor-variable-color); -} -.cm-s-jupyter span.cm-variable-2 { - color: var(--jp-mirror-editor-variable-2-color); -} -.cm-s-jupyter span.cm-variable-3 { - color: var(--jp-mirror-editor-variable-3-color); -} -.cm-s-jupyter span.cm-punctuation { - color: var(--jp-mirror-editor-punctuation-color); -} -.cm-s-jupyter span.cm-property { - color: var(--jp-mirror-editor-property-color); -} -.cm-s-jupyter span.cm-operator { - color: var(--jp-mirror-editor-operator-color); - font-weight: bold; -} -.cm-s-jupyter span.cm-comment { - color: var(--jp-mirror-editor-comment-color); - font-style: italic; -} -.cm-s-jupyter span.cm-string { - color: var(--jp-mirror-editor-string-color); -} -.cm-s-jupyter span.cm-string-2 { - color: var(--jp-mirror-editor-string-2-color); -} -.cm-s-jupyter span.cm-meta { - color: var(--jp-mirror-editor-meta-color); -} -.cm-s-jupyter span.cm-qualifier { - color: var(--jp-mirror-editor-qualifier-color); -} -.cm-s-jupyter span.cm-builtin { - color: var(--jp-mirror-editor-builtin-color); -} -.cm-s-jupyter span.cm-bracket { - color: var(--jp-mirror-editor-bracket-color); -} -.cm-s-jupyter span.cm-tag { - color: var(--jp-mirror-editor-tag-color); -} -.cm-s-jupyter span.cm-attribute { - color: var(--jp-mirror-editor-attribute-color); -} -.cm-s-jupyter span.cm-header { - color: var(--jp-mirror-editor-header-color); -} -.cm-s-jupyter span.cm-quote { - color: var(--jp-mirror-editor-quote-color); -} -.cm-s-jupyter span.cm-link { - color: var(--jp-mirror-editor-link-color); -} -.cm-s-jupyter span.cm-error { - color: var(--jp-mirror-editor-error-color); -} -.cm-s-jupyter span.cm-hr { - color: #999; -} - -.cm-s-jupyter span.cm-tab { - background: url(); - background-position: right; - background-repeat: no-repeat; -} - -.cm-s-jupyter .CodeMirror-activeline-background, -.cm-s-jupyter .CodeMirror-gutter { - background-color: var(--jp-layout-color2); -} - -/* Styles for shared cursors (remote cursor locations and selected ranges) */ -.jp-CodeMirrorEditor .remote-caret { - position: relative; - border-left: 2px solid black; - margin-left: -1px; - margin-right: -1px; - box-sizing: border-box; -} - -.jp-CodeMirrorEditor .remote-caret > div { - white-space: nowrap; - position: absolute; - top: -1.15em; - padding-bottom: 0.05em; - left: -2px; - font-size: 0.95em; - background-color: rgb(250, 129, 0); - font-family: var(--jp-ui-font-family); - font-weight: bold; - line-height: normal; - user-select: none; - color: white; - padding-left: 2px; - padding-right: 2px; - z-index: 3; - transition: opacity 0.3s ease-in-out; -} - -.jp-CodeMirrorEditor .remote-caret.hide-name > div { - transition-delay: 0.7s; - opacity: 0; -} - -.jp-CodeMirrorEditor .remote-caret:hover > div { - opacity: 1; - transition-delay: 0s; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| RenderedText -|----------------------------------------------------------------------------*/ - -:root { - /* This is the padding value to fill the gaps between lines containing spans with background color. */ - --jp-private-code-span-padding: calc( - (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2 - ); -} - -.jp-RenderedText { - text-align: left; - padding-left: var(--jp-code-padding); - line-height: var(--jp-code-line-height); - font-family: var(--jp-code-font-family); -} - -.jp-RenderedText pre, -.jp-RenderedJavaScript pre, -.jp-RenderedHTMLCommon pre { - color: var(--jp-content-font-color1); - font-size: var(--jp-code-font-size); - border: none; - margin: 0px; - padding: 0px; -} - -.jp-RenderedText pre a:link { - text-decoration: none; - color: var(--jp-content-link-color); -} -.jp-RenderedText pre a:hover { - text-decoration: underline; - color: var(--jp-content-link-color); -} -.jp-RenderedText pre a:visited { - text-decoration: none; - color: var(--jp-content-link-color); -} - -/* console foregrounds and backgrounds */ -.jp-RenderedText pre .ansi-black-fg { - color: #3e424d; -} -.jp-RenderedText pre .ansi-red-fg { - color: #e75c58; -} -.jp-RenderedText pre .ansi-green-fg { - color: #00a250; -} -.jp-RenderedText pre .ansi-yellow-fg { - color: #ddb62b; -} -.jp-RenderedText pre .ansi-blue-fg { - color: #208ffb; -} -.jp-RenderedText pre .ansi-magenta-fg { - color: #d160c4; -} -.jp-RenderedText pre .ansi-cyan-fg { - color: #60c6c8; -} -.jp-RenderedText pre .ansi-white-fg { - color: #c5c1b4; -} - -.jp-RenderedText pre .ansi-black-bg { - background-color: #3e424d; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-red-bg { - background-color: #e75c58; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-green-bg { - background-color: #00a250; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-yellow-bg { - background-color: #ddb62b; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-blue-bg { - background-color: #208ffb; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-magenta-bg { - background-color: #d160c4; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-cyan-bg { - background-color: #60c6c8; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-white-bg { - background-color: #c5c1b4; - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-black-intense-fg { - color: #282c36; -} -.jp-RenderedText pre .ansi-red-intense-fg { - color: #b22b31; -} -.jp-RenderedText pre .ansi-green-intense-fg { - color: #007427; -} -.jp-RenderedText pre .ansi-yellow-intense-fg { - color: #b27d12; -} -.jp-RenderedText pre .ansi-blue-intense-fg { - color: #0065ca; -} -.jp-RenderedText pre .ansi-magenta-intense-fg { - color: #a03196; -} -.jp-RenderedText pre .ansi-cyan-intense-fg { - color: #258f8f; -} -.jp-RenderedText pre .ansi-white-intense-fg { - color: #a1a6b2; -} - -.jp-RenderedText pre .ansi-black-intense-bg { - background-color: #282c36; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-red-intense-bg { - background-color: #b22b31; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-green-intense-bg { - background-color: #007427; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-yellow-intense-bg { - background-color: #b27d12; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-blue-intense-bg { - background-color: #0065ca; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-magenta-intense-bg { - background-color: #a03196; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-cyan-intense-bg { - background-color: #258f8f; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-white-intense-bg { - background-color: #a1a6b2; - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-default-inverse-fg { - color: var(--jp-ui-inverse-font-color0); -} -.jp-RenderedText pre .ansi-default-inverse-bg { - background-color: var(--jp-inverse-layout-color0); - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-bold { - font-weight: bold; -} -.jp-RenderedText pre .ansi-underline { - text-decoration: underline; -} - -.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] { - background: var(--jp-rendermime-error-background); - padding-top: var(--jp-code-padding); -} - -/*----------------------------------------------------------------------------- -| RenderedLatex -|----------------------------------------------------------------------------*/ - -.jp-RenderedLatex { - color: var(--jp-content-font-color1); - font-size: var(--jp-content-font-size1); - line-height: var(--jp-content-line-height); -} - -/* Left-justify outputs.*/ -.jp-OutputArea-output.jp-RenderedLatex { - padding: var(--jp-code-padding); - text-align: left; -} - -/*----------------------------------------------------------------------------- -| RenderedHTML -|----------------------------------------------------------------------------*/ - -.jp-RenderedHTMLCommon { - color: var(--jp-content-font-color1); - font-family: var(--jp-content-font-family); - font-size: var(--jp-content-font-size1); - line-height: var(--jp-content-line-height); - /* Give a bit more R padding on Markdown text to keep line lengths reasonable */ - padding-right: 20px; -} - -.jp-RenderedHTMLCommon em { - font-style: italic; -} - -.jp-RenderedHTMLCommon strong { - font-weight: bold; -} - -.jp-RenderedHTMLCommon u { - text-decoration: underline; -} - -.jp-RenderedHTMLCommon a:link { - text-decoration: none; - color: var(--jp-content-link-color); -} - -.jp-RenderedHTMLCommon a:hover { - text-decoration: underline; - color: var(--jp-content-link-color); -} - -.jp-RenderedHTMLCommon a:visited { - text-decoration: none; - color: var(--jp-content-link-color); -} - -/* Headings */ - -.jp-RenderedHTMLCommon h1, -.jp-RenderedHTMLCommon h2, -.jp-RenderedHTMLCommon h3, -.jp-RenderedHTMLCommon h4, -.jp-RenderedHTMLCommon h5, -.jp-RenderedHTMLCommon h6 { - line-height: var(--jp-content-heading-line-height); - font-weight: var(--jp-content-heading-font-weight); - font-style: normal; - margin: var(--jp-content-heading-margin-top) 0 - var(--jp-content-heading-margin-bottom) 0; -} - -.jp-RenderedHTMLCommon h1:first-child, -.jp-RenderedHTMLCommon h2:first-child, -.jp-RenderedHTMLCommon h3:first-child, -.jp-RenderedHTMLCommon h4:first-child, -.jp-RenderedHTMLCommon h5:first-child, -.jp-RenderedHTMLCommon h6:first-child { - margin-top: calc(0.5 * var(--jp-content-heading-margin-top)); -} - -.jp-RenderedHTMLCommon h1:last-child, -.jp-RenderedHTMLCommon h2:last-child, -.jp-RenderedHTMLCommon h3:last-child, -.jp-RenderedHTMLCommon h4:last-child, -.jp-RenderedHTMLCommon h5:last-child, -.jp-RenderedHTMLCommon h6:last-child { - margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom)); -} - -.jp-RenderedHTMLCommon h1 { - font-size: var(--jp-content-font-size5); -} - -.jp-RenderedHTMLCommon h2 { - font-size: var(--jp-content-font-size4); -} - -.jp-RenderedHTMLCommon h3 { - font-size: var(--jp-content-font-size3); -} - -.jp-RenderedHTMLCommon h4 { - font-size: var(--jp-content-font-size2); -} - -.jp-RenderedHTMLCommon h5 { - font-size: var(--jp-content-font-size1); -} - -.jp-RenderedHTMLCommon h6 { - font-size: var(--jp-content-font-size0); -} - -/* Lists */ - -.jp-RenderedHTMLCommon ul:not(.list-inline), -.jp-RenderedHTMLCommon ol:not(.list-inline) { - padding-left: 2em; -} - -.jp-RenderedHTMLCommon ul { - list-style: disc; -} - -.jp-RenderedHTMLCommon ul ul { - list-style: square; -} - -.jp-RenderedHTMLCommon ul ul ul { - list-style: circle; -} - -.jp-RenderedHTMLCommon ol { - list-style: decimal; -} - -.jp-RenderedHTMLCommon ol ol { - list-style: upper-alpha; -} - -.jp-RenderedHTMLCommon ol ol ol { - list-style: lower-alpha; -} - -.jp-RenderedHTMLCommon ol ol ol ol { - list-style: lower-roman; -} - -.jp-RenderedHTMLCommon ol ol ol ol ol { - list-style: decimal; -} - -.jp-RenderedHTMLCommon ol, -.jp-RenderedHTMLCommon ul { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon ul ul, -.jp-RenderedHTMLCommon ul ol, -.jp-RenderedHTMLCommon ol ul, -.jp-RenderedHTMLCommon ol ol { - margin-bottom: 0em; -} - -.jp-RenderedHTMLCommon hr { - color: var(--jp-border-color2); - background-color: var(--jp-border-color1); - margin-top: 1em; - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon > pre { - margin: 1.5em 2em; -} - -.jp-RenderedHTMLCommon pre, -.jp-RenderedHTMLCommon code { - border: 0; - background-color: var(--jp-layout-color0); - color: var(--jp-content-font-color1); - font-family: var(--jp-code-font-family); - font-size: inherit; - line-height: var(--jp-code-line-height); - padding: 0; - white-space: pre-wrap; -} - -.jp-RenderedHTMLCommon :not(pre) > code { - background-color: var(--jp-layout-color2); - padding: 1px 5px; -} - -/* Tables */ - -.jp-RenderedHTMLCommon table { - border-collapse: collapse; - border-spacing: 0; - border: none; - color: var(--jp-ui-font-color1); - font-size: 12px; - table-layout: fixed; - margin-left: auto; - margin-right: auto; -} - -.jp-RenderedHTMLCommon thead { - border-bottom: var(--jp-border-width) solid var(--jp-border-color1); - vertical-align: bottom; -} - -.jp-RenderedHTMLCommon td, -.jp-RenderedHTMLCommon th, -.jp-RenderedHTMLCommon tr { - vertical-align: middle; - padding: 0.5em 0.5em; - line-height: normal; - white-space: normal; - max-width: none; - border: none; -} - -.jp-RenderedMarkdown.jp-RenderedHTMLCommon td, -.jp-RenderedMarkdown.jp-RenderedHTMLCommon th { - max-width: none; -} - -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td, -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th, -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr { - text-align: right; -} - -.jp-RenderedHTMLCommon th { - font-weight: bold; -} - -.jp-RenderedHTMLCommon tbody tr:nth-child(odd) { - background: var(--jp-layout-color0); -} - -.jp-RenderedHTMLCommon tbody tr:nth-child(even) { - background: var(--jp-rendermime-table-row-background); -} - -.jp-RenderedHTMLCommon tbody tr:hover { - background: var(--jp-rendermime-table-row-hover-background); -} - -.jp-RenderedHTMLCommon table { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon p { - text-align: left; - margin: 0px; -} - -.jp-RenderedHTMLCommon p { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon img { - -moz-force-broken-image-icon: 1; -} - -/* Restrict to direct children as other images could be nested in other content. */ -.jp-RenderedHTMLCommon > img { - display: block; - margin-left: 0; - margin-right: 0; - margin-bottom: 1em; -} - -/* Change color behind transparent images if they need it... */ -[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background { - background-color: var(--jp-inverse-layout-color1); -} -[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background { - background-color: var(--jp-inverse-layout-color1); -} -/* ...or leave it untouched if they don't */ -[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-dark-background { -} -[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-light-background { -} - -.jp-RenderedHTMLCommon img, -.jp-RenderedImage img, -.jp-RenderedHTMLCommon svg, -.jp-RenderedSVG svg { - max-width: 100%; - height: auto; -} - -.jp-RenderedHTMLCommon img.jp-mod-unconfined, -.jp-RenderedImage img.jp-mod-unconfined, -.jp-RenderedHTMLCommon svg.jp-mod-unconfined, -.jp-RenderedSVG svg.jp-mod-unconfined { - max-width: none; -} - -.jp-RenderedHTMLCommon .alert { - padding: var(--jp-notebook-padding); - border: var(--jp-border-width) solid transparent; - border-radius: var(--jp-border-radius); - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon .alert-info { - color: var(--jp-info-color0); - background-color: var(--jp-info-color3); - border-color: var(--jp-info-color2); -} -.jp-RenderedHTMLCommon .alert-info hr { - border-color: var(--jp-info-color3); -} -.jp-RenderedHTMLCommon .alert-info > p:last-child, -.jp-RenderedHTMLCommon .alert-info > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-warning { - color: var(--jp-warn-color0); - background-color: var(--jp-warn-color3); - border-color: var(--jp-warn-color2); -} -.jp-RenderedHTMLCommon .alert-warning hr { - border-color: var(--jp-warn-color3); -} -.jp-RenderedHTMLCommon .alert-warning > p:last-child, -.jp-RenderedHTMLCommon .alert-warning > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-success { - color: var(--jp-success-color0); - background-color: var(--jp-success-color3); - border-color: var(--jp-success-color2); -} -.jp-RenderedHTMLCommon .alert-success hr { - border-color: var(--jp-success-color3); -} -.jp-RenderedHTMLCommon .alert-success > p:last-child, -.jp-RenderedHTMLCommon .alert-success > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-danger { - color: var(--jp-error-color0); - background-color: var(--jp-error-color3); - border-color: var(--jp-error-color2); -} -.jp-RenderedHTMLCommon .alert-danger hr { - border-color: var(--jp-error-color3); -} -.jp-RenderedHTMLCommon .alert-danger > p:last-child, -.jp-RenderedHTMLCommon .alert-danger > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon blockquote { - margin: 1em 2em; - padding: 0 1em; - border-left: 5px solid var(--jp-border-color2); -} - -a.jp-InternalAnchorLink { - visibility: hidden; - margin-left: 8px; - color: var(--md-blue-800); -} - -h1:hover .jp-InternalAnchorLink, -h2:hover .jp-InternalAnchorLink, -h3:hover .jp-InternalAnchorLink, -h4:hover .jp-InternalAnchorLink, -h5:hover .jp-InternalAnchorLink, -h6:hover .jp-InternalAnchorLink { - visibility: visible; -} - -.jp-RenderedHTMLCommon kbd { - background-color: var(--jp-rendermime-table-row-background); - border: 1px solid var(--jp-border-color0); - border-bottom-color: var(--jp-border-color2); - border-radius: 3px; - box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25); - display: inline-block; - font-size: 0.8em; - line-height: 1em; - padding: 0.2em 0.5em; -} - -/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0. - * At the bottom of cells this is a bit too much as there is also spacing - * between cells. Going all the way to 0 gets too tight between markdown and - * code cells. - */ -.jp-RenderedHTMLCommon > *:last-child { - margin-bottom: 0.5em; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-MimeDocument { - outline: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-filebrowser-button-height: 28px; - --jp-private-filebrowser-button-width: 48px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-FileBrowser { - display: flex; - flex-direction: column; - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); -} - -.jp-FileBrowser-toolbar.jp-Toolbar { - border-bottom: none; - height: auto; - margin: var(--jp-toolbar-header-margin); - box-shadow: none; -} - -.jp-BreadCrumbs { - flex: 0 0 auto; - margin: 8px 12px 8px 12px; -} - -.jp-BreadCrumbs-item { - margin: 0px 2px; - padding: 0px 2px; - border-radius: var(--jp-border-radius); - cursor: pointer; -} - -.jp-BreadCrumbs-item:hover { - background-color: var(--jp-layout-color2); -} - -.jp-BreadCrumbs-item:first-child { - margin-left: 0px; -} - -.jp-BreadCrumbs-item.jp-mod-dropTarget { - background-color: var(--jp-brand-color2); - opacity: 0.7; -} - -/*----------------------------------------------------------------------------- -| Buttons -|----------------------------------------------------------------------------*/ - -.jp-FileBrowser-toolbar.jp-Toolbar { - padding: 0px; - margin: 8px 12px 0px 12px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar { - justify-content: flex-start; -} - -.jp-FileBrowser-toolbar.jp-Toolbar .jp-Toolbar-item { - flex: 0 0 auto; - padding-left: 0px; - padding-right: 2px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar .jp-ToolbarButtonComponent { - width: 40px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent { - width: 72px; - background: var(--jp-brand-color1); -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent:focus-visible { - background-color: var(--jp-brand-color0); -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent - .jp-icon3 { - fill: white; -} - -/*----------------------------------------------------------------------------- -| Other styles -|----------------------------------------------------------------------------*/ - -.jp-FileDialog.jp-mod-conflict input { - color: var(--jp-error-color1); -} - -.jp-FileDialog .jp-new-name-title { - margin-top: 12px; -} - -.jp-LastModified-hidden { - display: none; -} - -.jp-FileBrowser-filterBox { - padding: 0px; - flex: 0 0 auto; - margin: 8px 12px 0px 12px; -} - -/*----------------------------------------------------------------------------- -| DirListing -|----------------------------------------------------------------------------*/ - -.jp-DirListing { - flex: 1 1 auto; - display: flex; - flex-direction: column; - outline: 0; -} - -.jp-DirListing:focus-visible { - border: 1px solid var(--jp-brand-color1); -} - -.jp-DirListing-header { - flex: 0 0 auto; - display: flex; - flex-direction: row; - overflow: hidden; - border-top: var(--jp-border-width) solid var(--jp-border-color2); - border-bottom: var(--jp-border-width) solid var(--jp-border-color1); - box-shadow: var(--jp-toolbar-box-shadow); - z-index: 2; -} - -.jp-DirListing-headerItem { - padding: 4px 12px 2px 12px; - font-weight: 500; -} - -.jp-DirListing-headerItem:hover { - background: var(--jp-layout-color2); -} - -.jp-DirListing-headerItem.jp-id-name { - flex: 1 0 84px; -} - -.jp-DirListing-headerItem.jp-id-modified { - flex: 0 0 112px; - border-left: var(--jp-border-width) solid var(--jp-border-color2); - text-align: right; -} - -.jp-id-narrow { - display: none; - flex: 0 0 5px; - padding: 4px 4px; - border-left: var(--jp-border-width) solid var(--jp-border-color2); - text-align: right; - color: var(--jp-border-color2); -} - -.jp-DirListing-narrow .jp-id-narrow { - display: block; -} - -.jp-DirListing-narrow .jp-id-modified, -.jp-DirListing-narrow .jp-DirListing-itemModified { - display: none; -} - -.jp-DirListing-headerItem.jp-mod-selected { - font-weight: 600; -} - -/* increase specificity to override bundled default */ -.jp-DirListing-content { - flex: 1 1 auto; - margin: 0; - padding: 0; - list-style-type: none; - overflow: auto; - background-color: var(--jp-layout-color1); -} - -.jp-DirListing-content mark { - color: var(--jp-ui-font-color0); - background-color: transparent; - font-weight: bold; -} - -.jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark { - color: var(--jp-ui-inverse-font-color0); -} - -/* Style the directory listing content when a user drops a file to upload */ -.jp-DirListing.jp-mod-native-drop .jp-DirListing-content { - outline: 5px dashed rgba(128, 128, 128, 0.5); - outline-offset: -10px; - cursor: copy; -} - -.jp-DirListing-item { - display: flex; - flex-direction: row; - padding: 4px 12px; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -.jp-DirListing-item[data-is-dot] { - opacity: 75%; -} - -.jp-DirListing-item.jp-mod-selected { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.jp-DirListing-item.jp-mod-dropTarget { - background: var(--jp-brand-color3); -} - -.jp-DirListing-item:hover:not(.jp-mod-selected) { - background: var(--jp-layout-color2); -} - -.jp-DirListing-itemIcon { - flex: 0 0 20px; - margin-right: 4px; -} - -.jp-DirListing-itemText { - flex: 1 0 64px; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - user-select: none; -} - -.jp-DirListing-itemModified { - flex: 0 0 125px; - text-align: right; -} - -.jp-DirListing-editor { - flex: 1 0 64px; - outline: none; - border: none; -} - -.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon:before { - color: var(--jp-success-color1); - content: '\25CF'; - font-size: 8px; - position: absolute; - left: -8px; -} - -.jp-DirListing-item.jp-mod-running.jp-mod-selected - .jp-DirListing-itemIcon:before { - color: var(--jp-ui-inverse-font-color1); -} - -.jp-DirListing-item.lm-mod-drag-image, -.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image { - font-size: var(--jp-ui-font-size1); - padding-left: 4px; - margin-left: 4px; - width: 160px; - background-color: var(--jp-ui-inverse-font-color2); - box-shadow: var(--jp-elevation-z2); - border-radius: 0px; - color: var(--jp-ui-font-color1); - transform: translateX(-40%) translateY(-58%); -} - -.jp-DirListing-deadSpace { - flex: 1 1 auto; - margin: 0; - padding: 0; - list-style-type: none; - overflow: auto; - background-color: var(--jp-layout-color1); -} - -.jp-Document { - min-width: 120px; - min-height: 120px; - outline: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { -} - -/*----------------------------------------------------------------------------- -| Main OutputArea -| OutputArea has a list of Outputs -|----------------------------------------------------------------------------*/ - -.jp-OutputArea { - overflow-y: auto; -} - -.jp-OutputArea-child { - display: flex; - flex-direction: row; -} - -body[data-format='mobile'] .jp-OutputArea-child { - flex-direction: column; -} - -.jp-OutputPrompt { - flex: 0 0 var(--jp-cell-prompt-width); - color: var(--jp-cell-outprompt-font-color); - font-family: var(--jp-cell-prompt-font-family); - padding: var(--jp-code-padding); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; - opacity: var(--jp-cell-prompt-opacity); - /* Right align prompt text, don't wrap to handle large prompt numbers */ - text-align: right; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - /* Disable text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -body[data-format='mobile'] .jp-OutputPrompt { - flex: 0 0 auto; - text-align: left; -} - -.jp-OutputArea-output { - height: auto; - overflow: auto; - user-select: text; - -moz-user-select: text; - -webkit-user-select: text; - -ms-user-select: text; -} - -.jp-OutputArea-child .jp-OutputArea-output { - flex-grow: 1; - flex-shrink: 1; -} - -body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output { - margin-left: var(--jp-notebook-padding); -} - -/** - * Isolated output. - */ -.jp-OutputArea-output.jp-mod-isolated { - width: 100%; - display: block; -} - -/* -When drag events occur, `p-mod-override-cursor` is added to the body. -Because iframes steal all cursor events, the following two rules are necessary -to suppress pointer events while resize drags are occurring. There may be a -better solution to this problem. -*/ -body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated { - position: relative; -} - -body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated:before { - content: ''; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; -} - -/* pre */ - -.jp-OutputArea-output pre { - border: none; - margin: 0px; - padding: 0px; - overflow-x: auto; - overflow-y: auto; - word-break: break-all; - word-wrap: break-word; - white-space: pre-wrap; -} - -/* tables */ - -.jp-OutputArea-output.jp-RenderedHTMLCommon table { - margin-left: 0; - margin-right: 0; -} - -/* description lists */ - -.jp-OutputArea-output dl, -.jp-OutputArea-output dt, -.jp-OutputArea-output dd { - display: block; -} - -.jp-OutputArea-output dl { - width: 100%; - overflow: hidden; - padding: 0; - margin: 0; -} - -.jp-OutputArea-output dt { - font-weight: bold; - float: left; - width: 20%; - padding: 0; - margin: 0; -} - -.jp-OutputArea-output dd { - float: left; - width: 80%; - padding: 0; - margin: 0; -} - -/* Hide the gutter in case of - * - nested output areas (e.g. in the case of output widgets) - * - mirrored output areas - */ -.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt { - display: none; -} - -/*----------------------------------------------------------------------------- -| executeResult is added to any Output-result for the display of the object -| returned by a cell -|----------------------------------------------------------------------------*/ - -.jp-OutputArea-output.jp-OutputArea-executeResult { - margin-left: 0px; - flex: 1 1 auto; -} - -/* Text output with the Out[] prompt needs a top padding to match the - * alignment of the Out[] prompt itself. - */ -.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output { - padding-top: var(--jp-code-padding); - border-top: var(--jp-border-width) solid transparent; -} - -/*----------------------------------------------------------------------------- -| The Stdin output -|----------------------------------------------------------------------------*/ - -.jp-OutputArea-stdin { - line-height: var(--jp-code-line-height); - padding-top: var(--jp-code-padding); - display: flex; -} - -.jp-Stdin-prompt { - color: var(--jp-content-font-color0); - padding-right: var(--jp-code-padding); - vertical-align: baseline; - flex: 0 0 auto; -} - -.jp-Stdin-input { - font-family: var(--jp-code-font-family); - font-size: inherit; - color: inherit; - background-color: inherit; - width: 42%; - min-width: 200px; - /* make sure input baseline aligns with prompt */ - vertical-align: baseline; - /* padding + margin = 0.5em between prompt and cursor */ - padding: 0em 0.25em; - margin: 0em 0.25em; - flex: 0 0 70%; -} - -.jp-Stdin-input:focus { - box-shadow: none; -} - -/*----------------------------------------------------------------------------- -| Output Area View -|----------------------------------------------------------------------------*/ - -.jp-LinkedOutputView .jp-OutputArea { - height: 100%; - display: block; -} - -.jp-LinkedOutputView .jp-OutputArea-output:only-child { - height: 100%; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Collapser { - flex: 0 0 var(--jp-cell-collapser-width); - padding: 0px; - margin: 0px; - border: none; - outline: none; - background: transparent; - border-radius: var(--jp-border-radius); - opacity: 1; -} - -.jp-Collapser-child { - display: block; - width: 100%; - box-sizing: border-box; - /* height: 100% doesn't work because the height of its parent is computed from content */ - position: absolute; - top: 0px; - bottom: 0px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Header/Footer -|----------------------------------------------------------------------------*/ - -/* Hidden by zero height by default */ -.jp-CellHeader, -.jp-CellFooter { - height: 0px; - width: 100%; - padding: 0px; - margin: 0px; - border: none; - outline: none; - background: transparent; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Input -|----------------------------------------------------------------------------*/ - -/* All input areas */ -.jp-InputArea { - display: flex; - flex-direction: row; - overflow: hidden; -} - -body[data-format='mobile'] .jp-InputArea { - flex-direction: column; -} - -.jp-InputArea-editor { - flex: 1 1 auto; - overflow: hidden; -} - -.jp-InputArea-editor { - /* This is the non-active, default styling */ - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - border-radius: 0px; - background: var(--jp-cell-editor-background); -} - -body[data-format='mobile'] .jp-InputArea-editor { - margin-left: var(--jp-notebook-padding); -} - -.jp-InputPrompt { - flex: 0 0 var(--jp-cell-prompt-width); - color: var(--jp-cell-inprompt-font-color); - font-family: var(--jp-cell-prompt-font-family); - padding: var(--jp-code-padding); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - opacity: var(--jp-cell-prompt-opacity); - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; - opacity: var(--jp-cell-prompt-opacity); - /* Right align prompt text, don't wrap to handle large prompt numbers */ - text-align: right; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - /* Disable text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -body[data-format='mobile'] .jp-InputPrompt { - flex: 0 0 auto; - text-align: left; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Placeholder -|----------------------------------------------------------------------------*/ - -.jp-Placeholder { - display: flex; - flex-direction: row; - flex: 1 1 auto; -} - -.jp-Placeholder-prompt { - box-sizing: border-box; -} - -.jp-Placeholder-content { - flex: 1 1 auto; - border: none; - background: transparent; - height: 20px; - box-sizing: border-box; -} - -.jp-Placeholder-content .jp-MoreHorizIcon { - width: 32px; - height: 16px; - border: 1px solid transparent; - border-radius: var(--jp-border-radius); -} - -.jp-Placeholder-content .jp-MoreHorizIcon:hover { - border: 1px solid var(--jp-border-color1); - box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.25); - background-color: var(--jp-layout-color0); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-cell-scrolling-output-offset: 5px; -} - -/*----------------------------------------------------------------------------- -| Cell -|----------------------------------------------------------------------------*/ - -.jp-Cell { - padding: var(--jp-cell-padding); - margin: 0px; - border: none; - outline: none; - background: transparent; -} - -/*----------------------------------------------------------------------------- -| Common input/output -|----------------------------------------------------------------------------*/ - -.jp-Cell-inputWrapper, -.jp-Cell-outputWrapper { - display: flex; - flex-direction: row; - padding: 0px; - margin: 0px; - /* Added to reveal the box-shadow on the input and output collapsers. */ - overflow: visible; -} - -/* Only input/output areas inside cells */ -.jp-Cell-inputArea, -.jp-Cell-outputArea { - flex: 1 1 auto; -} - -/*----------------------------------------------------------------------------- -| Collapser -|----------------------------------------------------------------------------*/ - -/* Make the output collapser disappear when there is not output, but do so - * in a manner that leaves it in the layout and preserves its width. - */ -.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser { - border: none !important; - background: transparent !important; -} - -.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser { - min-height: var(--jp-cell-collapser-min-height); -} - -/*----------------------------------------------------------------------------- -| Output -|----------------------------------------------------------------------------*/ - -/* Put a space between input and output when there IS output */ -.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper { - margin-top: 5px; -} - -.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea { - overflow-y: auto; - max-height: 200px; - box-shadow: inset 0 0 6px 2px rgba(0, 0, 0, 0.3); - margin-left: var(--jp-private-cell-scrolling-output-offset); -} - -.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { - flex: 0 0 - calc( - var(--jp-cell-prompt-width) - - var(--jp-private-cell-scrolling-output-offset) - ); -} - -/*----------------------------------------------------------------------------- -| CodeCell -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| MarkdownCell -|----------------------------------------------------------------------------*/ - -.jp-MarkdownOutput { - flex: 1 1 auto; - margin-top: 0; - margin-bottom: 0; - padding-left: var(--jp-code-padding); -} - -.jp-MarkdownOutput.jp-RenderedHTMLCommon { - overflow: auto; -} - -.jp-showHiddenCellsButton { - margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding)); - margin-top: var(--jp-code-padding); - border: 1px solid var(--jp-border-color2); - background-color: var(--jp-border-color3) !important; - color: var(--jp-content-font-color0) !important; -} - -.jp-showHiddenCellsButton:hover { - background-color: var(--jp-border-color2) !important; -} - -.jp-collapseHeadingButton { - display: none; -} - -.jp-MarkdownCell:hover .jp-collapseHeadingButton { - display: flex; - min-height: var(--jp-cell-collapser-min-height); - position: absolute; - right: 0; - top: 0; - bottom: 0; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- - -/*----------------------------------------------------------------------------- -| Styles -|----------------------------------------------------------------------------*/ - -.jp-NotebookPanel-toolbar { - padding: 2px; -} - -.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused { - border: none; - box-shadow: none; -} - -.jp-Notebook-toolbarCellTypeDropdown select { - height: 24px; - font-size: var(--jp-ui-font-size1); - line-height: 14px; - border-radius: 0; - display: block; -} - -.jp-Notebook-toolbarCellTypeDropdown span { - top: 5px !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-notebook-dragImage-width: 304px; - --jp-private-notebook-dragImage-height: 36px; - --jp-private-notebook-selected-color: var(--md-blue-400); - --jp-private-notebook-active-color: var(--md-green-400); -} - -/*----------------------------------------------------------------------------- -| Imports -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Notebook -|----------------------------------------------------------------------------*/ - -.jp-NotebookPanel { - display: block; - height: 100%; -} - -.jp-NotebookPanel.jp-Document { - min-width: 240px; - min-height: 120px; -} - -.jp-Notebook { - padding: var(--jp-notebook-padding); - outline: none; - overflow: auto; - background: var(--jp-layout-color0); -} - -.jp-Notebook.jp-mod-scrollPastEnd::after { - display: block; - content: ''; - min-height: var(--jp-notebook-scroll-padding); -} - -.jp-MainAreaWidget-ContainStrict .jp-Notebook * { - contain: strict; -} - -.jp-Notebook-render * { - contain: none !important; -} - -.jp-Notebook .jp-Cell { - overflow: visible; -} - -.jp-Notebook .jp-Cell .jp-InputPrompt { - cursor: move; - float: left; -} - -/*----------------------------------------------------------------------------- -| Notebook state related styling -| -| The notebook and cells each have states, here are the possibilities: -| -| - Notebook -| - Command -| - Edit -| - Cell -| - None -| - Active (only one can be active) -| - Selected (the cells actions are applied to) -| - Multiselected (when multiple selected, the cursor) -| - No outputs -|----------------------------------------------------------------------------*/ - -/* Command or edit modes */ - -.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt { - opacity: var(--jp-cell-prompt-not-active-opacity); - color: var(--jp-cell-prompt-not-active-font-color); -} - -.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt { - opacity: var(--jp-cell-prompt-not-active-opacity); - color: var(--jp-cell-prompt-not-active-font-color); -} - -/* cell is active */ -.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser { - background: var(--jp-brand-color1); -} - -/* cell is dirty */ -.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt { - color: var(--jp-warn-color1); -} -.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt:before { - color: var(--jp-warn-color1); - content: '•'; -} - -.jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser { - background: var(--jp-warn-color1); -} - -/* collapser is hovered */ -.jp-Notebook .jp-Cell .jp-Collapser:hover { - box-shadow: var(--jp-elevation-z2); - background: var(--jp-brand-color1); - opacity: var(--jp-cell-collapser-not-active-hover-opacity); -} - -/* cell is active and collapser is hovered */ -.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover { - background: var(--jp-brand-color0); - opacity: 1; -} - -/* Command mode */ - -.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected { - background: var(--jp-notebook-multiselected-color); -} - -.jp-Notebook.jp-mod-commandMode - .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) { - background: transparent; -} - -/* Edit mode */ - -.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor { - border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color); - box-shadow: var(--jp-input-box-shadow); - background-color: var(--jp-cell-editor-active-background); -} - -/*----------------------------------------------------------------------------- -| Notebook drag and drop -|----------------------------------------------------------------------------*/ - -.jp-Notebook-cell.jp-mod-dropSource { - opacity: 0.5; -} - -.jp-Notebook-cell.jp-mod-dropTarget, -.jp-Notebook.jp-mod-commandMode - .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget { - border-top-color: var(--jp-private-notebook-selected-color); - border-top-style: solid; - border-top-width: 2px; -} - -.jp-dragImage { - display: block; - flex-direction: row; - width: var(--jp-private-notebook-dragImage-width); - height: var(--jp-private-notebook-dragImage-height); - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - background: var(--jp-cell-editor-background); - overflow: visible; -} - -.jp-dragImage-singlePrompt { - box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); -} - -.jp-dragImage .jp-dragImage-content { - flex: 1 1 auto; - z-index: 2; - font-size: var(--jp-code-font-size); - font-family: var(--jp-code-font-family); - line-height: var(--jp-code-line-height); - padding: var(--jp-code-padding); - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - background: var(--jp-cell-editor-background-color); - color: var(--jp-content-font-color3); - text-align: left; - margin: 4px 4px 4px 0px; -} - -.jp-dragImage .jp-dragImage-prompt { - flex: 0 0 auto; - min-width: 36px; - color: var(--jp-cell-inprompt-font-color); - padding: var(--jp-code-padding); - padding-left: 12px; - font-family: var(--jp-cell-prompt-font-family); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - line-height: 1.9; - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; -} - -.jp-dragImage-multipleBack { - z-index: -1; - position: absolute; - height: 32px; - width: 300px; - top: 8px; - left: 8px; - background: var(--jp-layout-color2); - border: var(--jp-border-width) solid var(--jp-input-border-color); - box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); -} - -/*----------------------------------------------------------------------------- -| Cell toolbar -|----------------------------------------------------------------------------*/ - -.jp-NotebookTools { - display: block; - min-width: var(--jp-sidebar-min-width); - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); - overflow: auto; -} - -.jp-NotebookTools-tool { - padding: 0px 12px 0 12px; -} - -.jp-ActiveCellTool { - padding: 12px; - background-color: var(--jp-layout-color1); - border-top: none !important; -} - -.jp-ActiveCellTool .jp-InputArea-prompt { - flex: 0 0 auto; - padding-left: 0px; -} - -.jp-ActiveCellTool .jp-InputArea-editor { - flex: 1 1 auto; - background: var(--jp-cell-editor-background); - border-color: var(--jp-cell-editor-border-color); -} - -.jp-ActiveCellTool .jp-InputArea-editor .CodeMirror { - background: transparent; -} - -.jp-MetadataEditorTool { - flex-direction: column; - padding: 12px 0px 12px 0px; -} - -.jp-RankedPanel > :not(:first-child) { - margin-top: 12px; -} - -.jp-KeySelector select.jp-mod-styled { - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - border: var(--jp-border-width) solid var(--jp-border-color1); -} - -.jp-KeySelector label, -.jp-MetadataEditorTool label { - line-height: 1.4; -} - -.jp-NotebookTools .jp-select-wrapper { - margin-top: 4px; - margin-bottom: 0px; -} - -.jp-NotebookTools .jp-Collapse { - margin-top: 16px; -} - -/*----------------------------------------------------------------------------- -| Presentation Mode (.jp-mod-presentationMode) -|----------------------------------------------------------------------------*/ - -.jp-mod-presentationMode .jp-Notebook { - --jp-content-font-size1: var(--jp-content-presentation-font-size1); - --jp-code-font-size: var(--jp-code-presentation-font-size); -} - -.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt, -.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt { - flex: 0 0 110px; -} - -/*----------------------------------------------------------------------------- -| Placeholder -|----------------------------------------------------------------------------*/ - -.jp-Cell-Placeholder { - padding-left: 55px; -} - -.jp-Cell-Placeholder-wrapper { - background: #fff; - border: 1px solid; - border-color: #e5e6e9 #dfe0e4 #d0d1d5; - border-radius: 4px; - -webkit-border-radius: 4px; - margin: 10px 15px; -} - -.jp-Cell-Placeholder-wrapper-inner { - padding: 15px; - position: relative; -} - -.jp-Cell-Placeholder-wrapper-body { - background-repeat: repeat; - background-size: 50% auto; -} - -.jp-Cell-Placeholder-wrapper-body div { - background: #f6f7f8; - background-image: -webkit-linear-gradient( - left, - #f6f7f8 0%, - #edeef1 20%, - #f6f7f8 40%, - #f6f7f8 100% - ); - background-repeat: no-repeat; - background-size: 800px 104px; - height: 104px; - position: relative; -} - -.jp-Cell-Placeholder-wrapper-body div { - position: absolute; - right: 15px; - left: 15px; - top: 15px; -} - -div.jp-Cell-Placeholder-h1 { - top: 20px; - height: 20px; - left: 15px; - width: 150px; -} - -div.jp-Cell-Placeholder-h2 { - left: 15px; - top: 50px; - height: 10px; - width: 100px; -} - -div.jp-Cell-Placeholder-content-1, -div.jp-Cell-Placeholder-content-2, -div.jp-Cell-Placeholder-content-3 { - left: 15px; - right: 15px; - height: 10px; -} - -div.jp-Cell-Placeholder-content-1 { - top: 100px; -} - -div.jp-Cell-Placeholder-content-2 { - top: 120px; -} - -div.jp-Cell-Placeholder-content-3 { - top: 140px; -} - -</style> - - <style type="text/css"> -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* -The following CSS variables define the main, public API for styling JupyterLab. -These variables should be used by all plugins wherever possible. In other -words, plugins should not define custom colors, sizes, etc unless absolutely -necessary. This enables users to change the visual theme of JupyterLab -by changing these variables. - -Many variables appear in an ordered sequence (0,1,2,3). These sequences -are designed to work well together, so for example, `--jp-border-color1` should -be used with `--jp-layout-color1`. The numbers have the following meanings: - -* 0: super-primary, reserved for special emphasis -* 1: primary, most important under normal situations -* 2: secondary, next most important under normal situations -* 3: tertiary, next most important under normal situations - -Throughout JupyterLab, we are mostly following principles from Google's -Material Design when selecting colors. We are not, however, following -all of MD as it is not optimized for dense, information rich UIs. -*/ - -:root { - /* Elevation - * - * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here: - * - * https://github.com/material-components/material-components-web - * https://material-components-web.appspot.com/elevation.html - */ - - --jp-shadow-base-lightness: 0; - --jp-shadow-umbra-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.2 - ); - --jp-shadow-penumbra-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.14 - ); - --jp-shadow-ambient-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.12 - ); - --jp-elevation-z0: none; - --jp-elevation-z1: 0px 2px 1px -1px var(--jp-shadow-umbra-color), - 0px 1px 1px 0px var(--jp-shadow-penumbra-color), - 0px 1px 3px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z2: 0px 3px 1px -2px var(--jp-shadow-umbra-color), - 0px 2px 2px 0px var(--jp-shadow-penumbra-color), - 0px 1px 5px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z4: 0px 2px 4px -1px var(--jp-shadow-umbra-color), - 0px 4px 5px 0px var(--jp-shadow-penumbra-color), - 0px 1px 10px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z6: 0px 3px 5px -1px var(--jp-shadow-umbra-color), - 0px 6px 10px 0px var(--jp-shadow-penumbra-color), - 0px 1px 18px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z8: 0px 5px 5px -3px var(--jp-shadow-umbra-color), - 0px 8px 10px 1px var(--jp-shadow-penumbra-color), - 0px 3px 14px 2px var(--jp-shadow-ambient-color); - --jp-elevation-z12: 0px 7px 8px -4px var(--jp-shadow-umbra-color), - 0px 12px 17px 2px var(--jp-shadow-penumbra-color), - 0px 5px 22px 4px var(--jp-shadow-ambient-color); - --jp-elevation-z16: 0px 8px 10px -5px var(--jp-shadow-umbra-color), - 0px 16px 24px 2px var(--jp-shadow-penumbra-color), - 0px 6px 30px 5px var(--jp-shadow-ambient-color); - --jp-elevation-z20: 0px 10px 13px -6px var(--jp-shadow-umbra-color), - 0px 20px 31px 3px var(--jp-shadow-penumbra-color), - 0px 8px 38px 7px var(--jp-shadow-ambient-color); - --jp-elevation-z24: 0px 11px 15px -7px var(--jp-shadow-umbra-color), - 0px 24px 38px 3px var(--jp-shadow-penumbra-color), - 0px 9px 46px 8px var(--jp-shadow-ambient-color); - - /* Borders - * - * The following variables, specify the visual styling of borders in JupyterLab. - */ - - --jp-border-width: 1px; - --jp-border-color0: var(--md-grey-400); - --jp-border-color1: var(--md-grey-400); - --jp-border-color2: var(--md-grey-300); - --jp-border-color3: var(--md-grey-200); - --jp-border-radius: 2px; - - /* UI Fonts - * - * The UI font CSS variables are used for the typography all of the JupyterLab - * user interface elements that are not directly user generated content. - * - * The font sizing here is done assuming that the body font size of --jp-ui-font-size1 - * is applied to a parent element. When children elements, such as headings, are sized - * in em all things will be computed relative to that body size. - */ - - --jp-ui-font-scale-factor: 1.2; - --jp-ui-font-size0: 0.83333em; - --jp-ui-font-size1: 13px; /* Base font size */ - --jp-ui-font-size2: 1.2em; - --jp-ui-font-size3: 1.44em; - - --jp-ui-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, - Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; - - /* - * Use these font colors against the corresponding main layout colors. - * In a light theme, these go from dark to light. - */ - - /* Defaults use Material Design specification */ - --jp-ui-font-color0: rgba(0, 0, 0, 1); - --jp-ui-font-color1: rgba(0, 0, 0, 0.87); - --jp-ui-font-color2: rgba(0, 0, 0, 0.54); - --jp-ui-font-color3: rgba(0, 0, 0, 0.38); - - /* - * Use these against the brand/accent/warn/error colors. - * These will typically go from light to darker, in both a dark and light theme. - */ - - --jp-ui-inverse-font-color0: rgba(255, 255, 255, 1); - --jp-ui-inverse-font-color1: rgba(255, 255, 255, 1); - --jp-ui-inverse-font-color2: rgba(255, 255, 255, 0.7); - --jp-ui-inverse-font-color3: rgba(255, 255, 255, 0.5); - - /* Content Fonts - * - * Content font variables are used for typography of user generated content. - * - * The font sizing here is done assuming that the body font size of --jp-content-font-size1 - * is applied to a parent element. When children elements, such as headings, are sized - * in em all things will be computed relative to that body size. - */ - - --jp-content-line-height: 1.6; - --jp-content-font-scale-factor: 1.2; - --jp-content-font-size0: 0.83333em; - --jp-content-font-size1: 14px; /* Base font size */ - --jp-content-font-size2: 1.2em; - --jp-content-font-size3: 1.44em; - --jp-content-font-size4: 1.728em; - --jp-content-font-size5: 2.0736em; - - /* This gives a magnification of about 125% in presentation mode over normal. */ - --jp-content-presentation-font-size1: 17px; - - --jp-content-heading-line-height: 1; - --jp-content-heading-margin-top: 1.2em; - --jp-content-heading-margin-bottom: 0.8em; - --jp-content-heading-font-weight: 500; - - /* Defaults use Material Design specification */ - --jp-content-font-color0: rgba(0, 0, 0, 1); - --jp-content-font-color1: rgba(0, 0, 0, 0.87); - --jp-content-font-color2: rgba(0, 0, 0, 0.54); - --jp-content-font-color3: rgba(0, 0, 0, 0.38); - - --jp-content-link-color: var(--md-blue-700); - - --jp-content-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', - Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', - 'Segoe UI Symbol'; - - /* - * Code Fonts - * - * Code font variables are used for typography of code and other monospaces content. - */ - - --jp-code-font-size: 13px; - --jp-code-line-height: 1.3077; /* 17px for 13px base */ - --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */ - --jp-code-font-family-default: Menlo, Consolas, 'DejaVu Sans Mono', monospace; - --jp-code-font-family: var(--jp-code-font-family-default); - - /* This gives a magnification of about 125% in presentation mode over normal. */ - --jp-code-presentation-font-size: 16px; - - /* may need to tweak cursor width if you change font size */ - --jp-code-cursor-width0: 1.4px; - --jp-code-cursor-width1: 2px; - --jp-code-cursor-width2: 4px; - - /* Layout - * - * The following are the main layout colors use in JupyterLab. In a light - * theme these would go from light to dark. - */ - - --jp-layout-color0: white; - --jp-layout-color1: white; - --jp-layout-color2: var(--md-grey-200); - --jp-layout-color3: var(--md-grey-400); - --jp-layout-color4: var(--md-grey-600); - - /* Inverse Layout - * - * The following are the inverse layout colors use in JupyterLab. In a light - * theme these would go from dark to light. - */ - - --jp-inverse-layout-color0: #111111; - --jp-inverse-layout-color1: var(--md-grey-900); - --jp-inverse-layout-color2: var(--md-grey-800); - --jp-inverse-layout-color3: var(--md-grey-700); - --jp-inverse-layout-color4: var(--md-grey-600); - - /* Brand/accent */ - - --jp-brand-color0: var(--md-blue-900); - --jp-brand-color1: var(--md-blue-700); - --jp-brand-color2: var(--md-blue-300); - --jp-brand-color3: var(--md-blue-100); - --jp-brand-color4: var(--md-blue-50); - - --jp-accent-color0: var(--md-green-900); - --jp-accent-color1: var(--md-green-700); - --jp-accent-color2: var(--md-green-300); - --jp-accent-color3: var(--md-green-100); - - /* State colors (warn, error, success, info) */ - - --jp-warn-color0: var(--md-orange-900); - --jp-warn-color1: var(--md-orange-700); - --jp-warn-color2: var(--md-orange-300); - --jp-warn-color3: var(--md-orange-100); - - --jp-error-color0: var(--md-red-900); - --jp-error-color1: var(--md-red-700); - --jp-error-color2: var(--md-red-300); - --jp-error-color3: var(--md-red-100); - - --jp-success-color0: var(--md-green-900); - --jp-success-color1: var(--md-green-700); - --jp-success-color2: var(--md-green-300); - --jp-success-color3: var(--md-green-100); - - --jp-info-color0: var(--md-cyan-900); - --jp-info-color1: var(--md-cyan-700); - --jp-info-color2: var(--md-cyan-300); - --jp-info-color3: var(--md-cyan-100); - - /* Cell specific styles */ - - --jp-cell-padding: 5px; - - --jp-cell-collapser-width: 8px; - --jp-cell-collapser-min-height: 20px; - --jp-cell-collapser-not-active-hover-opacity: 0.6; - - --jp-cell-editor-background: var(--md-grey-100); - --jp-cell-editor-border-color: var(--md-grey-300); - --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300); - --jp-cell-editor-active-background: var(--jp-layout-color0); - --jp-cell-editor-active-border-color: var(--jp-brand-color1); - - --jp-cell-prompt-width: 64px; - --jp-cell-prompt-font-family: var(--jp-code-font-family-default); - --jp-cell-prompt-letter-spacing: 0px; - --jp-cell-prompt-opacity: 1; - --jp-cell-prompt-not-active-opacity: 0.5; - --jp-cell-prompt-not-active-font-color: var(--md-grey-700); - /* A custom blend of MD grey and blue 600 - * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */ - --jp-cell-inprompt-font-color: #307fc1; - /* A custom blend of MD grey and orange 600 - * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */ - --jp-cell-outprompt-font-color: #bf5b3d; - - /* Notebook specific styles */ - - --jp-notebook-padding: 10px; - --jp-notebook-select-background: var(--jp-layout-color1); - --jp-notebook-multiselected-color: var(--md-blue-50); - - /* The scroll padding is calculated to fill enough space at the bottom of the - notebook to show one single-line cell (with appropriate padding) at the top - when the notebook is scrolled all the way to the bottom. We also subtract one - pixel so that no scrollbar appears if we have just one single-line cell in the - notebook. This padding is to enable a 'scroll past end' feature in a notebook. - */ - --jp-notebook-scroll-padding: calc( - 100% - var(--jp-code-font-size) * var(--jp-code-line-height) - - var(--jp-code-padding) - var(--jp-cell-padding) - 1px - ); - - /* Rendermime styles */ - - --jp-rendermime-error-background: #fdd; - --jp-rendermime-table-row-background: var(--md-grey-100); - --jp-rendermime-table-row-hover-background: var(--md-light-blue-50); - - /* Dialog specific styles */ - - --jp-dialog-background: rgba(0, 0, 0, 0.25); - - /* Console specific styles */ - - --jp-console-padding: 10px; - - /* Toolbar specific styles */ - - --jp-toolbar-border-color: var(--jp-border-color1); - --jp-toolbar-micro-height: 8px; - --jp-toolbar-background: var(--jp-layout-color1); - --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.24); - --jp-toolbar-header-margin: 4px 4px 0px 4px; - --jp-toolbar-active-background: var(--md-grey-300); - - /* Statusbar specific styles */ - - --jp-statusbar-height: 24px; - - /* Input field styles */ - - --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300); - --jp-input-active-background: var(--jp-layout-color1); - --jp-input-hover-background: var(--jp-layout-color1); - --jp-input-background: var(--md-grey-100); - --jp-input-border-color: var(--jp-border-color1); - --jp-input-active-border-color: var(--jp-brand-color1); - --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3); - - /* General editor styles */ - - --jp-editor-selected-background: #d9d9d9; - --jp-editor-selected-focused-background: #d7d4f0; - --jp-editor-cursor-color: var(--jp-ui-font-color0); - - /* Code mirror specific styles */ - - --jp-mirror-editor-keyword-color: #008000; - --jp-mirror-editor-atom-color: #88f; - --jp-mirror-editor-number-color: #080; - --jp-mirror-editor-def-color: #00f; - --jp-mirror-editor-variable-color: var(--md-grey-900); - --jp-mirror-editor-variable-2-color: #05a; - --jp-mirror-editor-variable-3-color: #085; - --jp-mirror-editor-punctuation-color: #05a; - --jp-mirror-editor-property-color: #05a; - --jp-mirror-editor-operator-color: #aa22ff; - --jp-mirror-editor-comment-color: #408080; - --jp-mirror-editor-string-color: #ba2121; - --jp-mirror-editor-string-2-color: #708; - --jp-mirror-editor-meta-color: #aa22ff; - --jp-mirror-editor-qualifier-color: #555; - --jp-mirror-editor-builtin-color: #008000; - --jp-mirror-editor-bracket-color: #997; - --jp-mirror-editor-tag-color: #170; - --jp-mirror-editor-attribute-color: #00c; - --jp-mirror-editor-header-color: blue; - --jp-mirror-editor-quote-color: #090; - --jp-mirror-editor-link-color: #00c; - --jp-mirror-editor-error-color: #f00; - --jp-mirror-editor-hr-color: #999; - - /* Vega extension styles */ - - --jp-vega-background: white; - - /* Sidebar-related styles */ - - --jp-sidebar-min-width: 250px; - - /* Search-related styles */ - - --jp-search-toggle-off-opacity: 0.5; - --jp-search-toggle-hover-opacity: 0.8; - --jp-search-toggle-on-opacity: 1; - --jp-search-selected-match-background-color: rgb(245, 200, 0); - --jp-search-selected-match-color: black; - --jp-search-unselected-match-background-color: var( - --jp-inverse-layout-color0 - ); - --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0); - - /* Icon colors that work well with light or dark backgrounds */ - --jp-icon-contrast-color0: var(--md-purple-600); - --jp-icon-contrast-color1: var(--md-green-600); - --jp-icon-contrast-color2: var(--md-pink-600); - --jp-icon-contrast-color3: var(--md-blue-600); -} -</style> - -<style type="text/css"> -/* Force rendering true colors when outputing to pdf */ -* { - -webkit-print-color-adjust: exact; -} - -/* Misc */ -a.anchor-link { - display: none; -} - -.highlight { - margin: 0.4em; -} - -/* Input area styling */ -.jp-InputArea { - overflow: hidden; -} - -.jp-InputArea-editor { - overflow: hidden; -} - -.CodeMirror pre { - margin: 0; - padding: 0; -} - -/* Using table instead of flexbox so that we can use break-inside property */ -/* CSS rules under this comment should not be required anymore after we move to the JupyterLab 4.0 CSS */ - - -.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { - min-width: calc( - var(--jp-cell-prompt-width) - var(--jp-private-cell-scrolling-output-offset) - ); -} - -.jp-OutputArea-child { - display: table; - width: 100%; -} - -.jp-OutputPrompt { - display: table-cell; - vertical-align: top; - min-width: var(--jp-cell-prompt-width); -} - -body[data-format='mobile'] .jp-OutputPrompt { - display: table-row; -} - -.jp-OutputArea-output { - display: table-cell; - width: 100%; -} - -body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output { - display: table-row; -} - -.jp-OutputArea-output.jp-OutputArea-executeResult { - width: 100%; -} - -/* Hiding the collapser by default */ -.jp-Collapser { - display: none; -} - -@media print { - .jp-Cell-inputWrapper, - .jp-Cell-outputWrapper { - display: block; - } - - .jp-OutputArea-child { - break-inside: avoid-page; - } -} -</style> - -<!-- Load mathjax --> - <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML-full,Safe"> </script> - <!-- MathJax configuration --> - <script type="text/x-mathjax-config"> - init_mathjax = function() { - if (window.MathJax) { - // MathJax loaded - MathJax.Hub.Config({ - TeX: { - equationNumbers: { - autoNumber: "AMS", - useLabelIds: true - } - }, - tex2jax: { - inlineMath: [ ['$','$'], ["\\(","\\)"] ], - displayMath: [ ['$$','$$'], ["\\[","\\]"] ], - processEscapes: true, - processEnvironments: true - }, - displayAlign: 'center', - CommonHTML: { - linebreaks: { - automatic: true - } - } - }); - - MathJax.Hub.Queue(["Typeset", MathJax.Hub]); - } - } - init_mathjax(); - </script> - <!-- End of mathjax configuration --></head> -<body class="jp-Notebook" data-jp-theme-light="true" data-jp-theme-name="JupyterLab Light"> -<div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [63]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># fetch all functions from there for testing (__name__ hack to avoid executing main)</span> -<span class="vm">__name__</span> <span class="o">=</span> <span class="s2">"test"</span> -<span class="n">execfile</span><span class="p">(</span><span class="s2">"./scripts/translate2modelcif.py"</span><span class="p">)</span> -<span class="n">_main</span><span class="p">()</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>PROTEINS ONLY in fasta_file: ['c104827_g1_i1', 'c104894_g1_i2'] -Working on ./PKG Cut... - translating c103531_g3_i1_unrelaxed_rank_1_model_3... - preparing data... (0.02s) - generating ModelCIF objects... (0.00s) - processing QA scores... (0.20s) - write to disk... (1.15s) - ... done with c103531_g3_i1_unrelaxed_rank_1_model_3 (1.37s). - translating c103545_g3_i2_unrelaxed_rank_1_model_3... - preparing data... (0.08s) - generating ModelCIF objects... (0.00s) - processing QA scores... (5.47s) - write to disk... (19.48s) - ... done with c103545_g3_i2_unrelaxed_rank_1_model_3 (25.13s). -... done with ./PKG Cut. -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [3]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> <span class="c1"># HC filepaths</span> - <span class="n">cnfg_file</span> <span class="o">=</span> <span class="s2">"./PKG/config.json"</span> - <span class="n">metadata_file</span> <span class="o">=</span> <span class="s2">"./PKG/model_archive_metadata.csv"</span> - <span class="n">fasta_file</span> <span class="o">=</span> <span class="s2">"./PKG/Spongilla_lacustris_translated_proteome_fixed.fasta"</span> - <span class="n">model_dir</span> <span class="o">=</span> <span class="s2">"./PKG Cut"</span> - <span class="c1"># model_dir = "./PKG-all"</span> - <span class="n">out_dir</span> <span class="o">=</span> <span class="s2">"./modelcif"</span> - <span class="n">compress</span> <span class="o">=</span> <span class="kc">False</span> - <span class="c1">#</span> - - <span class="c1"># parse/fetch global data</span> - <span class="n">config_data</span> <span class="o">=</span> <span class="n">_parse_colabfold_config</span><span class="p">(</span><span class="n">cnfg_file</span><span class="p">)</span> - <span class="n">metadata</span> <span class="o">=</span> <span class="n">_get_metadata</span><span class="p">(</span><span class="n">metadata_file</span><span class="p">)</span> - <span class="n">seq_dict</span> <span class="o">=</span> <span class="n">_get_sequences</span><span class="p">(</span><span class="n">fasta_file</span><span class="p">,</span> <span class="n">metadata</span><span class="p">)</span> - <span class="k">if</span> <span class="n">compress</span><span class="p">:</span> - <span class="n">cifext</span> <span class="o">=</span> <span class="s2">"cif.gz"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">cifext</span> <span class="o">=</span> <span class="s2">"cif"</span> - <span class="c1"># fetch a single randomly chosen UniProt entry for tax info</span> - <span class="n">upkb_data</span> <span class="o">=</span> <span class="n">_fetch_upkb_entry</span><span class="p">(</span><span class="s2">"P42690"</span><span class="p">)</span> - <span class="n">tax_info</span> <span class="o">=</span> <span class="p">{</span><span class="n">k</span><span class="p">:</span> <span class="n">v</span> <span class="k">for</span> <span class="n">k</span><span class="p">,</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">upkb_data</span><span class="o">.</span><span class="n">items</span><span class="p">()</span> \ - <span class="k">if</span> <span class="n">k</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">"up_organism"</span><span class="p">,</span> <span class="s2">"up_ncbi_taxid"</span><span class="p">]}</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>PROTEINS ONLY in fasta_file: ['c104827_g1_i1', 'c104894_g1_i2'] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [4]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">fle</span> <span class="o">=</span> <span class="s2">"c103531_g3_i1_unrelaxed_rank_1_model_3.pdb"</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [5]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> <span class="n">file_prfx</span><span class="p">,</span> <span class="n">mdl_name</span> <span class="o">=</span> <span class="n">_check_model_extra_files_present</span><span class="p">(</span><span class="n">model_dir</span><span class="p">,</span> - <span class="n">fle</span><span class="p">)</span> - <span class="n">fle</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">model_dir</span><span class="p">,</span> <span class="n">fle</span><span class="p">)</span> - <span class="n">mdlcf_json</span> <span class="o">=</span> <span class="n">_create_json</span><span class="p">(</span><span class="n">config_data</span><span class="p">)</span> - <span class="n">mdlcf_json</span><span class="p">[</span><span class="s2">"tax_info"</span><span class="p">]</span> <span class="o">=</span> <span class="n">tax_info</span> - <span class="c1"># mdl_name = [TITLE]_unrelaxed_rank_X_model_Y.pdb</span> - <span class="n">mdl_name_parts</span> <span class="o">=</span> <span class="n">mdl_name</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)</span> - <span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">mdl_name_parts</span><span class="p">)</span> <span class="o">==</span> <span class="mi">8</span> - <span class="k">assert</span> <span class="nb">int</span><span class="p">(</span><span class="n">mdl_name_parts</span><span class="p">[</span><span class="mi">5</span><span class="p">])</span> <span class="o">==</span> <span class="mi">1</span> <span class="c1"># rank 1 only</span> - <span class="n">mdlcf_json</span><span class="p">[</span><span class="s2">"mdl_num"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">mdl_name_parts</span><span class="p">[</span><span class="mi">7</span><span class="p">])</span> - <span class="n">mdlcf_json</span><span class="p">[</span><span class="s2">"mdl_title"</span><span class="p">]</span> <span class="o">=</span> <span class="s1">'_'</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">mdl_name_parts</span><span class="p">[:</span><span class="mi">3</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [6]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> <span class="n">ost_ent</span> <span class="o">=</span> <span class="n">_create_model_json</span><span class="p">(</span><span class="n">mdlcf_json</span><span class="p">,</span> <span class="n">fle</span><span class="p">,</span> <span class="n">seq_dict</span><span class="p">,</span> <span class="n">metadata</span><span class="p">)</span> - - <span class="c1"># read quality scores from JSON file</span> - <span class="n">_get_scores</span><span class="p">(</span><span class="n">mdlcf_json</span><span class="p">,</span> <span class="n">file_prfx</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [7]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> <span class="n">_store_as_modelcif</span><span class="p">(</span><span class="n">mdlcf_json</span><span class="p">,</span> <span class="n">ost_ent</span><span class="p">,</span> <span class="n">out_dir</span><span class="p">,</span> <span class="n">mdl_name</span><span class="p">,</span> <span class="n">compress</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre> generating ModelCIF objects... (0.00s) - processing QA scores... (0.34s) - write to disk... (1.04s) -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [8]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">scores</span> <span class="o">=</span> <span class="n">json</span><span class="o">.</span><span class="n">load</span><span class="p">(</span><span class="nb">open</span><span class="p">(</span><span class="s2">"./PKG Cut/c103545_g3_i2_unrelaxed_rank_1_model_3_scores.json"</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="n">scores</span><span class="o">.</span><span class="n">keys</span><span class="p">())</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>dict_keys(['max_pae', 'pae', 'plddt', 'ptm']) -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [9]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check files</span> -<span class="n">pdb_files</span> <span class="o">=</span> <span class="nb">open</span><span class="p">(</span><span class="s2">"./PKG/files_PDB.txt"</span><span class="p">)</span><span class="o">.</span><span class="n">readlines</span><span class="p">()</span> -<span class="n">json_files</span> <span class="o">=</span> <span class="nb">open</span><span class="p">(</span><span class="s2">"./PKG/files_JSON.txt"</span><span class="p">)</span><span class="o">.</span><span class="n">readlines</span><span class="p">()</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdb_files</span><span class="p">)</span> <span class="o">==</span> <span class="nb">len</span><span class="p">(</span><span class="n">json_files</span><span class="p">)</span> - -<span class="n">mdl_titles</span> <span class="o">=</span> <span class="p">[]</span> -<span class="k">for</span> <span class="n">pdb_file</span><span class="p">,</span> <span class="n">json_file</span> <span class="ow">in</span> <span class="nb">zip</span><span class="p">(</span><span class="nb">sorted</span><span class="p">(</span><span class="n">pdb_files</span><span class="p">),</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">json_files</span><span class="p">)):</span> - <span class="n">splitfile</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="n">pdb_file</span><span class="o">.</span><span class="n">strip</span><span class="p">())</span> - <span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">splitfile</span><span class="p">)</span> <span class="o">==</span> <span class="mi">2</span> - <span class="k">if</span> <span class="n">splitfile</span><span class="p">[</span><span class="mi">1</span><span class="p">]:</span> - <span class="n">mdl_name</span><span class="p">,</span> <span class="n">mdl_ext</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">splitext</span><span class="p">(</span><span class="n">splitfile</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> - <span class="k">assert</span> <span class="n">mdl_ext</span> <span class="o">==</span> <span class="s2">".pdb"</span> - <span class="n">splitfile_j</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="n">json_file</span><span class="o">.</span><span class="n">strip</span><span class="p">())</span> - <span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">splitfile_j</span><span class="p">)</span> <span class="o">==</span> <span class="mi">2</span> - <span class="k">assert</span> <span class="n">splitfile_j</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span> <span class="o">==</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">mdl_name</span><span class="si">}</span><span class="s2">_scores.json"</span> - <span class="n">mdl_name_parts</span> <span class="o">=</span> <span class="n">mdl_name</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">mdl_name_parts</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">8</span> <span class="ow">or</span> <span class="n">mdl_name_parts</span><span class="p">[</span><span class="mi">5</span><span class="p">]</span> <span class="o">!=</span> <span class="s1">'1'</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"WEIRD NAME"</span><span class="p">,</span> <span class="n">mdl_name</span><span class="p">)</span> - <span class="n">mdl_title</span> <span class="o">=</span> <span class="s1">'_'</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">mdl_name_parts</span><span class="p">[:</span><span class="mi">3</span><span class="p">])</span> - <span class="n">mdl_titles</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">mdl_title</span><span class="p">)</span> - -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">))</span> <span class="o">==</span> <span class="nb">len</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>WEIRD NAME c100000_g1_i2_unrelaxed_rank_c100000_g1_i2_model_3 -WEIRD NAME c100001_g1_i1_unrelaxed_rank_1_model_c100001_g1_i1 -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [10]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># all in metadata?</span> -<span class="n">only_in_metadata</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">index</span><span class="p">)</span> <span class="o">-</span> <span class="nb">set</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">)</span> -<span class="k">if</span> <span class="n">only_in_metadata</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"PROTEINS ONLY in metadata:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">only_in_metadata</span><span class="p">))</span> -<span class="n">only_in_seqs</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">)</span> <span class="o">-</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">index</span><span class="p">)</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">only_in_seqs</span><span class="p">)</span> <span class="o">==</span> <span class="mi">0</span> -<span class="nb">len</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">),</span> <span class="nb">len</span><span class="p">(</span><span class="n">metadata</span><span class="p">),</span> <span class="nb">len</span><span class="p">(</span><span class="n">only_in_metadata</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>PROTEINS ONLY in metadata: ['c104658_g3_i5', 'c104704_g1_i1', 'c104839_g1_i1', 'c104839_g1_i3', 'c104872_g1_i1', 'c104894_g1_i3', 'c104922_g1_i2', 'c104954_g1_i2', 'c104956_g1_i1', 'c104958_g1_i1', 'c104973_g1_i2'] -</pre> -</div> -</div> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[10]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>(41932, 41943, 11)</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [11]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check files that were converted (input is std out from run cut to only include "translating...")</span> -<span class="n">log_lines</span> <span class="o">=</span> <span class="nb">open</span><span class="p">(</span><span class="s2">"./FromWork/docker_out_clean.txt"</span><span class="p">)</span><span class="o">.</span><span class="n">readlines</span><span class="p">()</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [12]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># plenty of assertions in here should also catch any errors...</span> -<span class="n">idx</span> <span class="o">=</span> <span class="mi">0</span> -<span class="n">timings</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> -<span class="k">while</span> <span class="n">idx</span> <span class="o"><</span> <span class="nb">len</span><span class="p">(</span><span class="n">log_lines</span><span class="p">):</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">if</span> <span class="s2">"already done..."</span> <span class="ow">in</span> <span class="n">l</span><span class="p">:</span> - <span class="n">idx</span> <span class="o">+=</span> <span class="mi">1</span> - <span class="k">continue</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"translating"</span><span class="p">)</span> - <span class="n">mdl_title</span> <span class="o">=</span> <span class="s2">"_"</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)[:</span><span class="mi">3</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"preparing data"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_prep</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"generating ModelCIF objects"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_cif</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">3</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"processing QA scores"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_qa</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">4</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"write to disk"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_write</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">5</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"... done with"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)."</span><span class="p">)</span> - <span class="n">t_all</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">3</span><span class="p">])</span> - <span class="n">timings</span><span class="p">[</span><span class="n">mdl_title</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span> - <span class="s2">"seq_len"</span><span class="p">:</span> <span class="nb">len</span><span class="p">(</span><span class="n">seq_dict</span><span class="p">[</span><span class="n">mdl_title</span><span class="p">]),</span> - <span class="s2">"t_prep"</span><span class="p">:</span> <span class="n">t_prep</span><span class="p">,</span> - <span class="s2">"t_cif"</span><span class="p">:</span> <span class="n">t_cif</span><span class="p">,</span> - <span class="s2">"t_qa"</span><span class="p">:</span> <span class="n">t_qa</span><span class="p">,</span> - <span class="s2">"t_write"</span><span class="p">:</span> <span class="n">t_write</span><span class="p">,</span> - <span class="s2">"t_all"</span><span class="p">:</span> <span class="n">t_all</span> - <span class="p">}</span> - <span class="n">idx</span> <span class="o">+=</span> <span class="mi">6</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [13]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"DONE </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">timings</span><span class="p">)</span><span class="si">}</span><span class="s2"> models"</span><span class="p">)</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">timings</span><span class="p">)</span> <span class="o">-</span> <span class="nb">set</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">))</span> <span class="o">==</span> <span class="mi">0</span> -<span class="n">missing_ones</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">mdl_titles</span><span class="p">)</span> <span class="o">-</span> <span class="nb">set</span><span class="p">(</span><span class="n">timings</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"MISSING </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">missing_ones</span><span class="p">)</span><span class="si">}</span><span class="s2"> models"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>DONE 37738 models -MISSING 4194 models -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [14]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="o">%</span><span class="k">matplotlib</span> inline -<span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span> -<span class="n">x</span> <span class="o">=</span> <span class="p">[]</span> -<span class="n">y</span> <span class="o">=</span> <span class="p">[]</span> -<span class="n">y2</span> <span class="o">=</span> <span class="p">[]</span> -<span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">timings</span><span class="o">.</span><span class="n">values</span><span class="p">():</span> - <span class="n">x</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">v</span><span class="p">[</span><span class="s2">"seq_len"</span><span class="p">])</span> - <span class="n">y</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">v</span><span class="p">[</span><span class="s2">"t_all"</span><span class="p">])</span> - <span class="n">y2</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">v</span><span class="p">[</span><span class="s2">"t_write"</span><span class="p">])</span> -<span class="c1"># fit quadratic function (for fun)</span> -<span class="n">model</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">poly1d</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">polyfit</span><span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">y</span><span class="p">,</span> <span class="mi">2</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="n">model</span><span class="p">)</span> -<span class="c1"># plot it</span> -<span class="n">plt</span><span class="o">.</span><span class="n">scatter</span><span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">y</span><span class="p">)</span> -<span class="n">plt</span><span class="o">.</span><span class="n">scatter</span><span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">y2</span><span class="p">)</span> -<span class="n">polyline</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">linspace</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="nb">max</span><span class="p">(</span><span class="n">x</span><span class="p">),</span> <span class="mi">50</span><span class="p">)</span> -<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">polyline</span><span class="p">,</span> <span class="n">model</span><span class="p">(</span><span class="n">polyline</span><span class="p">))</span> -<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s2">"seq. length"</span><span class="p">)</span> -<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s2">"conversion time"</span><span class="p">)</span> -<span class="n">plt</span><span class="o">.</span><span class="n">legend</span><span class="p">([</span><span class="s2">"quadratic fit"</span><span class="p">,</span> <span class="s2">"total time"</span><span class="p">,</span> <span class="s2">"write time"</span><span class="p">])</span> -<span class="n">plt</span><span class="o">.</span><span class="n">gcf</span><span class="p">()</span><span class="o">.</span><span class="n">patch</span><span class="o">.</span><span class="n">set_facecolor</span><span class="p">(</span><span class="s1">'white'</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"Average time per model (s):"</span><span class="p">,</span> <span class="nb">sum</span><span class="p">(</span><span class="n">y</span><span class="p">)</span> <span class="o">/</span> <span class="nb">len</span><span class="p">(</span><span class="n">y</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre> 2 -2.106e-05 x - 4.487e-05 x + 0.05244 -Average time per model (s): 2.1000026498489452 -</pre> -</div> -</div> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - - - -<div class="jp-RenderedImage jp-OutputArea-output "> -<img src=" -" -class=" -" -> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [16]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check results (self-contained version)</span> -<span class="kn">from</span> <span class="nn">ost</span> <span class="kn">import</span> <span class="n">io</span> -<span class="n">fasta_file</span> <span class="o">=</span> <span class="s2">"./PKG/Spongilla_lacustris_translated_proteome_fixed.fasta"</span> -<span class="n">out_dir</span> <span class="o">=</span> <span class="s2">"./modelcif"</span> -<span class="n">cifext</span> <span class="o">=</span> <span class="s2">"cif"</span> -<span class="n">seqs</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadSequenceList</span><span class="p">(</span><span class="n">fasta_file</span><span class="p">)</span> -<span class="n">seq_dict</span> <span class="o">=</span> <span class="p">{</span><span class="s1">'_'</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">s</span><span class="o">.</span><span class="n">name</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)[:</span><span class="mi">3</span><span class="p">]):</span> <span class="n">s</span><span class="o">.</span><span class="n">string</span> <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">seqs</span><span class="p">}</span> -<span class="k">for</span> <span class="n">out_fle</span> <span class="ow">in</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">listdir</span><span class="p">(</span><span class="n">out_dir</span><span class="p">)):</span> - <span class="k">if</span> <span class="ow">not</span> <span class="n">out_fle</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="n">cifext</span><span class="p">)</span> <span class="ow">or</span> <span class="s2">"_local_pairwise_qa"</span> <span class="ow">in</span> <span class="n">out_fle</span><span class="p">:</span> - <span class="k">continue</span> - <span class="n">mdl_name</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">splitext</span><span class="p">(</span><span class="n">out_fle</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">mdl_title</span> <span class="o">=</span> <span class="s1">'_'</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">mdl_name</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)[:</span><span class="mi">3</span><span class="p">])</span> - <span class="c1"># check if result can be read and has expected seq.</span> - <span class="n">ent</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadMMCIF</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">out_dir</span><span class="p">,</span> <span class="n">out_fle</span><span class="p">))</span> - <span class="k">assert</span> <span class="n">ent</span><span class="o">.</span><span class="n">chain_count</span> <span class="o">==</span> <span class="mi">1</span><span class="p">,</span> <span class="sa">f</span><span class="s2">"Bad chain count </span><span class="si">{</span><span class="n">mdl_title</span><span class="si">}</span><span class="s2">"</span> - <span class="n">ent_seq</span> <span class="o">=</span> <span class="s2">""</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">res</span><span class="o">.</span><span class="n">one_letter_code</span> <span class="k">for</span> <span class="n">res</span> <span class="ow">in</span> <span class="n">ent</span><span class="o">.</span><span class="n">residues</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">ent_seq</span> <span class="o">==</span> <span class="n">seq_dict</span><span class="p">[</span><span class="n">mdl_title</span><span class="p">],</span> <span class="sa">f</span><span class="s2">"Bad seq. </span><span class="si">{</span><span class="n">mdl_title</span><span class="si">}</span><span class="s2">"</span> - <span class="c1"># NOTE: can use only this bit in main loop with os.path.join(out_dir, f"{mdl_name}.{cifext}")</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [17]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check ,-separation in metadata</span> -<span class="k">for</span> <span class="n">title</span><span class="p">,</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">iterrows</span><span class="p">():</span> - <span class="n">desc</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">description</span> - <span class="k">for</span> <span class="n">line</span> <span class="ow">in</span> <span class="n">desc</span><span class="o">.</span><span class="n">splitlines</span><span class="p">():</span> - <span class="k">if</span> <span class="s2">","</span> <span class="ow">in</span> <span class="n">line</span><span class="p">:</span> - <span class="k">assert</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"CoFFE orthogroups"</span><span class="p">)</span> <span class="ow">or</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"CoFFE GO terms"</span><span class="p">),</span> <span class="n">title</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr"> -<pre> -<span class="ansi-red-fg">---------------------------------------------------------------------------</span> -<span class="ansi-red-fg">AssertionError</span> Traceback (most recent call last) -Input <span class="ansi-green-fg">In [17]</span>, in <span class="ansi-cyan-fg"><cell line: 2></span><span class="ansi-blue-fg">()</span> -<span class="ansi-green-intense-fg ansi-bold"> 4</span> <span class="ansi-bold" style="color: rgb(0,135,0)">for</span> line <span class="ansi-bold" style="color: rgb(175,0,255)">in</span> desc<span style="color: rgb(98,98,98)">.</span>splitlines(): -<span class="ansi-green-intense-fg ansi-bold"> 5</span> <span class="ansi-bold" style="color: rgb(0,135,0)">if</span> <span style="color: rgb(175,0,0)">"</span><span style="color: rgb(175,0,0)">,</span><span style="color: rgb(175,0,0)">"</span> <span class="ansi-bold" style="color: rgb(175,0,255)">in</span> line: -<span class="ansi-green-fg">----> 6</span> <span class="ansi-bold" style="color: rgb(0,135,0)">assert</span> line<span style="color: rgb(98,98,98)">.</span>startswith(<span style="color: rgb(175,0,0)">"</span><span style="color: rgb(175,0,0)">CoFFE orthogroups</span><span style="color: rgb(175,0,0)">"</span>) <span class="ansi-bold" style="color: rgb(175,0,255)">or</span> line<span style="color: rgb(98,98,98)">.</span>startswith(<span style="color: rgb(175,0,0)">"</span><span style="color: rgb(175,0,0)">CoFFE GO terms</span><span style="color: rgb(175,0,0)">"</span>), title - -<span class="ansi-red-fg">AssertionError</span>: c103545_g3_i2</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [18]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">line</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[18]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>'CoFFE UniProt function: FUNCTION: Involved in hearing and vision as member of the USH2 complex. Necessary for elongation and maintenance of inner and outer hair cell stereocilia in the organ of Corti in the inner ear. Involved in the maintenance of the hair bundle ankle region, which connects stereocilia in cochlear hair cells of the inner ear. In retina photoreceptors, required for the maintenance of periciliary membrane complex that seems to play a role in regulating intracellular protein transport. {ECO:0000250|UniProtKB:Q80VW5}.'</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [19]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># ok so we cannot blindly assume that commas are bad...</span> - -<span class="c1"># check longest tokens in metadata</span> -<span class="n">new_desc</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> -<span class="k">for</span> <span class="n">title</span><span class="p">,</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">iterrows</span><span class="p">():</span> - <span class="n">desc</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">description</span> - <span class="n">new_lines</span> <span class="o">=</span> <span class="p">[]</span> - <span class="k">for</span> <span class="n">line</span> <span class="ow">in</span> <span class="n">desc</span><span class="o">.</span><span class="n">splitlines</span><span class="p">():</span> - <span class="n">is_loi</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"CoFFE orthogroups"</span><span class="p">)</span> \ - <span class="ow">or</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"CoFFE GO terms"</span><span class="p">)</span> \ - <span class="ow">or</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"Emapper orthogroups"</span><span class="p">)</span> \ - <span class="ow">or</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"Emapper GO terms"</span><span class="p">)</span> \ - <span class="ow">or</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"CoFFE PFAM domains"</span><span class="p">)</span> \ - <span class="ow">or</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"Emapper PFAM domains"</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">","</span> <span class="ow">in</span> <span class="n">line</span> <span class="ow">and</span> <span class="n">is_loi</span><span class="p">:</span> - <span class="n">new_line</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">","</span><span class="p">,</span> <span class="s2">", "</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">new_line</span> <span class="o">=</span> <span class="n">line</span> - <span class="n">token_lengths</span> <span class="o">=</span> <span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="n">token</span><span class="p">)</span> <span class="k">for</span> <span class="n">token</span> <span class="ow">in</span> <span class="n">new_line</span><span class="o">.</span><span class="n">split</span><span class="p">()]</span> - <span class="k">if</span> <span class="n">token_lengths</span> <span class="ow">and</span> <span class="nb">max</span><span class="p">(</span><span class="n">token_lengths</span><span class="p">)</span> <span class="o">></span> <span class="mi">80</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">title</span><span class="p">,</span> <span class="n">new_line</span><span class="p">)</span> - <span class="n">new_lines</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">new_line</span><span class="p">)</span> - <span class="n">new_desc</span><span class="p">[</span><span class="n">title</span><span class="p">]</span> <span class="o">=</span> <span class="s2">"</span><span class="se">\n</span><span class="s2">"</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">new_lines</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>c2495_g1_i1 CoFFE UniProt function: FUNCTION: Protein O-mannose kinase that specifically mediates phosphorylation at the 6-position of an O-mannose of the trisaccharide (N-acetylgalactosamine (GalNAc)-beta-1,3-N-acetylglucosamine (GlcNAc)-beta-1,4-mannose) to generate phosphorylated O-mannosyl trisaccharide (N-acetylgalactosamine-beta-1,3-N-acetylglucosamine-beta-1,4-(phosphate-6-)mannose). Phosphorylated O-mannosyl trisaccharide is a carbohydrate structure present in alpha-dystroglycan (DAG1), which is required for binding laminin G-like domain-containing extracellular proteins with high affinity. Only shows kinase activity when the GalNAc-beta-3-GlcNAc-beta-terminus is linked to the 4-position of O-mannose, suggesting that this disaccharide serves as the substrate recognition motif (By similarity). {ECO:0000250}. -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [20]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># c2495_g1_i1 tested in MA and ok...let's check largest ones</span> -<span class="nb">sorted</span><span class="p">([</span><span class="nb">len</span><span class="p">(</span><span class="n">desc</span><span class="p">),</span> <span class="n">title</span><span class="p">]</span> <span class="k">for</span> <span class="n">title</span><span class="p">,</span> <span class="n">desc</span> <span class="ow">in</span> <span class="n">new_desc</span><span class="o">.</span><span class="n">items</span><span class="p">())[</span><span class="o">-</span><span class="mi">5</span><span class="p">:]</span> -<span class="c1"># looks ok too...</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[20]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>[[19286, 'c90048_g1_i1'], - [20561, 'c104513_g1_i1'], - [22685, 'c91485_g1_i1'], - [27674, 'c95514_g1_i1'], - [27687, 'c95514_g1_i3']]</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [35]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># checking multiline details and markdown</span> -<span class="kn">from</span> <span class="nn">ost</span> <span class="kn">import</span> <span class="n">io</span> -<span class="kn">import</span> <span class="nn">modelcif.reader</span> -<span class="n">file_path</span> <span class="o">=</span> <span class="s2">"./modelcif/c103531_g3_i1_unrelaxed_rank_1_model_3.cif"</span> -<span class="n">ent</span><span class="p">,</span> <span class="n">info</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadMMCIF</span><span class="p">(</span><span class="n">file_path</span><span class="p">,</span> <span class="n">info</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span> -<span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="n">file_path</span><span class="p">)</span> <span class="k">as</span> <span class="n">fh</span><span class="p">:</span> - <span class="n">s</span><span class="p">,</span> <span class="o">=</span> <span class="n">modelcif</span><span class="o">.</span><span class="n">reader</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">fh</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="n">info</span><span class="o">.</span><span class="n">GetStructDetails</span><span class="p">()</span><span class="o">.</span><span class="n">model_details</span><span class="p">[:</span><span class="mi">300</span><span class="p">])</span> -<span class="nb">print</span><span class="p">(</span><span class="s1">'-'</span> <span class="o">*</span> <span class="mi">80</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="n">s</span><span class="o">.</span><span class="n">model_details</span><span class="p">[:</span><span class="mi">300</span><span class="p">])</span> -<span class="c1"># NOTE: there may be a bug in OST's multiline parsing in terms of keeping line breaks intact...</span> -<span class="c1"># ...and lines are stripped so that we lose the trailing 2 spaces...</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>Model generated using ColabFold v1.2.0 with AlphaFold producing 5 models with 3 recycles each without model relaxation without templates ranked by pLDDT starting from an MSA from MMseqs2 (UniRef+Environmental) -Emapper preferred name [EggNOG]: - -Emapper description [EggNOG]: - -CoFFE preferred name [E --------------------------------------------------------------------------------- -Model generated using ColabFold v1.2.0 with AlphaFold producing 5 models with 3 recycles each without model relaxation without templates ranked by pLDDT starting from an MSA from MMseqs2 (UniRef+Environmental) - -Emapper preferred name [EggNOG]: - -Emapper description [EggNOG]: - -CoFFE preferred name [ -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [36]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">markdown</span> -<span class="n">markdown_test</span> <span class="o">=</span> <span class="s2">"""isoform ID: c103531_g3_i1</span> - -<span class="s2">And **fat** and *emphasized* markdown with lists:</span> - -<span class="s2">- item1</span> -<span class="s2">- item2</span> - -<span class="s2">and [links](https://github.com).</span> - -<span class="s2">Note that markdown ignores linebreaks</span> -<span class="s2">unless two spaces at end </span> -<span class="s2"><- as in line above"""</span> -<span class="nb">print</span><span class="p">(</span><span class="n">markdown_test</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="s1">'-'</span> <span class="o">*</span> <span class="mi">80</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="n">markdown</span><span class="o">.</span><span class="n">markdown</span><span class="p">(</span><span class="n">markdown_test</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>isoform ID: c103531_g3_i1 - -And **fat** and *emphasized* markdown with lists: - -- item1 -- item2 - -and [links](https://github.com). - -Note that markdown ignores linebreaks -unless two spaces at end -<- as in line above --------------------------------------------------------------------------------- -<p>isoform ID: c103531_g3_i1</p> -<p>And <strong>fat</strong> and <em>emphasized</em> markdown with lists:</p> -<ul> -<li>item1</li> -<li>item2</li> -</ul> -<p>and <a href="https://github.com">links</a>.</p> -<p>Note that markdown ignores linebreaks -unless two spaces at end<br /> -&lt;- as in line above</p> -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [2]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># test zip file speed and size</span> -<span class="kn">from</span> <span class="nn">timeit</span> <span class="kn">import</span> <span class="n">default_timer</span> <span class="k">as</span> <span class="n">timer</span> -<span class="kn">import</span> <span class="nn">os</span><span class="o">,</span> <span class="nn">zipfile</span><span class="o">,</span> <span class="nn">gzip</span><span class="o">,</span> <span class="nn">shutil</span> - -<span class="k">def</span> <span class="nf">zip_test</span><span class="p">(</span><span class="n">compression</span><span class="p">,</span> <span class="n">level</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span> - <span class="n">zip_file</span> <span class="o">=</span> <span class="s2">"test.zip"</span> - <span class="n">files</span> <span class="o">=</span> <span class="p">[</span><span class="s2">"modelcif/c103531_g3_i1_unrelaxed_rank_1_model_3_local_pairwise_qa.cif"</span><span class="p">]</span> - <span class="n">files</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="s2">"modelcif/c103545_g3_i2_unrelaxed_rank_1_model_3_local_pairwise_qa.cif"</span><span class="p">)</span> - <span class="n">pstart</span> <span class="o">=</span> <span class="n">timer</span><span class="p">()</span> - <span class="k">if</span> <span class="n">compression</span> <span class="o">==</span> <span class="s2">"gzip"</span><span class="p">:</span> - <span class="n">file_size</span> <span class="o">=</span> <span class="mi">0</span> - <span class="k">for</span> <span class="n">file</span> <span class="ow">in</span> <span class="n">files</span><span class="p">:</span> - <span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="n">file</span><span class="p">,</span> <span class="s1">'rb'</span><span class="p">)</span> <span class="k">as</span> <span class="n">f_in</span><span class="p">:</span> - <span class="k">with</span> <span class="n">gzip</span><span class="o">.</span><span class="n">open</span><span class="p">(</span><span class="n">zip_file</span><span class="p">,</span> <span class="s1">'wb'</span><span class="p">)</span> <span class="k">as</span> <span class="n">f_out</span><span class="p">:</span> - <span class="n">shutil</span><span class="o">.</span><span class="n">copyfileobj</span><span class="p">(</span><span class="n">f_in</span><span class="p">,</span> <span class="n">f_out</span><span class="p">)</span> - <span class="n">file_size</span> <span class="o">+=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="n">zip_file</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="k">with</span> <span class="n">zipfile</span><span class="o">.</span><span class="n">ZipFile</span><span class="p">(</span><span class="n">zip_file</span><span class="p">,</span> <span class="s1">'w'</span><span class="p">,</span> <span class="n">compression</span><span class="p">,</span> <span class="n">compresslevel</span><span class="o">=</span><span class="n">level</span><span class="p">)</span> <span class="k">as</span> <span class="n">myzip</span><span class="p">:</span> - <span class="k">for</span> <span class="n">file</span> <span class="ow">in</span> <span class="n">files</span><span class="p">:</span> - <span class="n">myzip</span><span class="o">.</span><span class="n">write</span><span class="p">(</span><span class="n">file</span><span class="p">)</span> - <span class="n">file_size</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="n">zip_file</span><span class="p">)</span> - <span class="c1"># for comparison full translation time for the files (i.e. from running _main)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">files</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">ref_time</span> <span class="o">=</span> <span class="s2">"1.38s"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">ref_time</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="mf">1.38</span><span class="o">+</span><span class="mf">24.21</span><span class="si">}</span><span class="s2">s"</span> - <span class="k">if</span> <span class="n">compression</span> <span class="o">==</span> <span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_STORED</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="s2">"none "</span> - <span class="k">elif</span> <span class="n">compression</span> <span class="o">==</span> <span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_DEFLATED</span><span class="p">:</span> - <span class="k">if</span> <span class="n">level</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"gz(</span><span class="si">{</span><span class="n">level</span><span class="si">}</span><span class="s2">)"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="s2">"gz "</span> - <span class="k">elif</span> <span class="n">compression</span> <span class="o">==</span> <span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_BZIP2</span><span class="p">:</span> - <span class="k">if</span> <span class="n">level</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"bz(</span><span class="si">{</span><span class="n">level</span><span class="si">}</span><span class="s2">)"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="s2">"bz "</span> - <span class="k">elif</span> <span class="n">compression</span> <span class="o">==</span> <span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_LZMA</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="s2">"lzma "</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">label</span> <span class="o">=</span> <span class="s2">"gzip "</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"- </span><span class="si">{</span><span class="n">label</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="n">timer</span><span class="p">()</span><span class="o">-</span><span class="n">pstart</span><span class="si">:</span><span class="s2">.2f</span><span class="si">}</span><span class="s2">s vs </span><span class="si">{</span><span class="n">ref_time</span><span class="si">}</span><span class="s2">, </span><span class="si">{</span><span class="n">file_size</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="n">os</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">zip_file</span><span class="p">)</span> - -<span class="n">zip_test</span><span class="p">(</span><span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_STORED</span><span class="p">)</span> -<span class="n">zip_test</span><span class="p">(</span><span class="s2">"gzip"</span><span class="p">)</span> -<span class="n">zip_test</span><span class="p">(</span><span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_DEFLATED</span><span class="p">)</span> -<span class="n">zip_test</span><span class="p">(</span><span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_DEFLATED</span><span class="p">,</span> <span class="mi">9</span><span class="p">)</span> -<span class="n">zip_test</span><span class="p">(</span><span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_BZIP2</span><span class="p">)</span> -<span class="n">zip_test</span><span class="p">(</span><span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_BZIP2</span><span class="p">,</span> <span class="mi">9</span><span class="p">)</span> -<span class="n">zip_test</span><span class="p">(</span><span class="n">zipfile</span><span class="o">.</span><span class="n">ZIP_LZMA</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>- none : 3.84s vs 25.59s, 27824253 -- gzip : 2.70s vs 25.59s, 5417406 -- gz : 0.87s vs 25.59s, 5389143 -- gz(9): 2.74s vs 25.59s, 5417802 -- bz : 1.61s vs 25.59s, 3802066 -- bz(9): 1.56s vs 25.59s, 3802066 -- lzma : 22.27s vs 25.59s, 2083062 -</pre> -</div> -</div> - -</div> - -</div> - -</div> -<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell"> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> -</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown"> -<p>FAZIT: lzma is too slow but bzip2 has good compromise of size vs speed</p> - -</div> -</div> -</div> -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [1]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check out pdbx</span> -<span class="kn">import</span> <span class="nn">os</span> -<span class="kn">from</span> <span class="nn">timeit</span> <span class="kn">import</span> <span class="n">default_timer</span> <span class="k">as</span> <span class="n">timer</span> -<span class="kn">from</span> <span class="nn">pdbx.reader.PdbxReader</span> <span class="kn">import</span> <span class="n">PdbxReader</span> -<span class="kn">from</span> <span class="nn">pdbx.writer.PdbxWriter</span> <span class="kn">import</span> <span class="n">PdbxWriter</span> -<span class="n">test_file</span> <span class="o">=</span> <span class="s2">"modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif"</span> -<span class="c1"># test_file = "modelcif_MA_test/AF-P38129-F1-model_v3.cif"</span> -<span class="c1"># test_file = "modelcif_MA_test/ma-bak-cepc-0001.cif"</span> -<span class="c1"># test_file = "modelcif_MA_test/1crn.cif"</span> -<span class="n">test_file_out</span> <span class="o">=</span> <span class="s2">"modelcif_MA_test/test.cif"</span> -<span class="n">pstart</span> <span class="o">=</span> <span class="n">timer</span><span class="p">()</span> -<span class="n">pdbx_data</span> <span class="o">=</span> <span class="p">[]</span> -<span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="n">test_file</span><span class="p">,</span> <span class="s1">'r'</span><span class="p">)</span> <span class="k">as</span> <span class="n">f_in</span><span class="p">:</span> - <span class="n">pdbxR</span> <span class="o">=</span> <span class="n">PdbxReader</span><span class="p">(</span><span class="n">f_in</span><span class="p">)</span> - <span class="n">pdbxR</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">pdbx_data</span><span class="p">)</span> -<span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="n">test_file_out</span><span class="p">,</span> <span class="s1">'w'</span><span class="p">)</span> <span class="k">as</span> <span class="n">f_out</span><span class="p">:</span> - <span class="n">pdbxW</span> <span class="o">=</span> <span class="n">PdbxWriter</span><span class="p">(</span><span class="n">f_out</span><span class="p">)</span> - <span class="n">pdbxW</span><span class="o">.</span><span class="n">write</span><span class="p">(</span><span class="n">pdbx_data</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span><span class="si">}</span><span class="s2"> vs </span><span class="si">{</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="n">test_file_out</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> \ - <span class="sa">f</span><span class="s2">" in </span><span class="si">{</span><span class="n">timer</span><span class="p">()</span><span class="o">-</span><span class="n">pstart</span><span class="si">:</span><span class="s2">.2f</span><span class="si">}</span><span class="s2">s"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>137179 vs 184836 in 0.25s -</pre> -</div> -</div> - -</div> - -</div> - -</div> -<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell"> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> -</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown"> -<p>FAZIT: adds lots of spaces but doesn't remove anything<br> -ISSUE: quotes around "stop_..." removed...</p> - -</div> -</div> -</div> -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [2]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check out gemmi</span> -<span class="kn">import</span> <span class="nn">gemmi</span> -<span class="n">pstart</span> <span class="o">=</span> <span class="n">timer</span><span class="p">()</span> -<span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -<span class="n">doc</span><span class="o">.</span><span class="n">write_file</span><span class="p">(</span><span class="n">test_file_out</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span><span class="si">}</span><span class="s2"> vs </span><span class="si">{</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="n">test_file_out</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> \ - <span class="sa">f</span><span class="s2">" in </span><span class="si">{</span><span class="n">timer</span><span class="p">()</span><span class="o">-</span><span class="n">pstart</span><span class="si">:</span><span class="s2">.2f</span><span class="si">}</span><span class="s2">s"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>137179 vs 137099 in 0.03s -</pre> -</div> -</div> - -</div> - -</div> - -</div> -<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell"> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> -</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown"> -<p>FAZIT: much faster than pdbx, space handling similar to python-modelcif and also not removing anything and handling "stop_..." properly</p> -<p>Also note that neither of the two messes up the order of tables and so files are easily comparable!</p> -<p><strong>FAZIT</strong>: gemmi is good!</p> - -</div> -</div> -</div> -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [14]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># quick test changing data_ block name</span> -<span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -<span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span><span class="o">.</span><span class="n">name</span> <span class="o">=</span> <span class="s1">'test'</span> -<span class="n">doc</span><span class="o">.</span><span class="n">write_file</span><span class="p">(</span><span class="n">test_file_out</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [3]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># parsing pdbx</span> -<span class="c1"># see https://mmcif.wwpdb.org/docs/sw-examples/python/html/</span> -<span class="c1"># -> all very low level</span> -<span class="n">block</span> <span class="o">=</span> <span class="n">pdbx_data</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> -<span class="k">if</span> <span class="n">block</span><span class="o">.</span><span class="n">exists</span><span class="p">(</span><span class="s2">"ma_qa_metric"</span><span class="p">):</span> - <span class="n">dc</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">getObj</span><span class="p">(</span><span class="s2">"ma_qa_metric"</span><span class="p">)</span> - <span class="n">categoryName</span><span class="p">,</span> <span class="n">attributeNameList</span><span class="p">,</span> <span class="n">rowList</span> <span class="o">=</span> <span class="n">dc</span><span class="o">.</span><span class="n">get</span><span class="p">()</span> - <span class="nb">print</span><span class="p">(</span><span class="n">categoryName</span><span class="p">)</span> - <span class="nb">print</span><span class="p">(</span><span class="n">attributeNameList</span><span class="p">)</span> - <span class="nb">print</span><span class="p">(</span><span class="n">rowList</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>ma_qa_metric -['id', 'name', 'description', 'type', 'mode', 'type_other_details', 'software_group_id'] -[['1', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'global', '.', '.'], ['2', 'pTM', 'Predicted accuracy according to the TM-score score in [0,1]', 'pTM', 'global', '.', '.'], ['3', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'local', '.', '.'], ['4', 'PAE', 'Predicted aligned error (in Angstroms)', 'PAE', 'local-pairwise', '.', '.']] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [4]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># parsing gemmi</span> -<span class="c1"># see https://gemmi.readthedocs.io/en/latest/cif.html#block</span> -<span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> -<span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find_mmcif_category</span><span class="p">(</span><span class="s2">"_ma_qa_metric."</span><span class="p">)</span> -<span class="k">if</span> <span class="n">table</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">table</span><span class="o">.</span><span class="n">get_prefix</span><span class="p">())</span> - <span class="nb">print</span><span class="p">([</span><span class="n">tag</span> <span class="k">for</span> <span class="n">tag</span> <span class="ow">in</span> <span class="n">table</span><span class="o">.</span><span class="n">tags</span><span class="p">])</span> - <span class="nb">print</span><span class="p">([[</span><span class="n">col</span> <span class="k">for</span> <span class="n">col</span> <span class="ow">in</span> <span class="n">row</span><span class="p">]</span> <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>_ma_qa_metric. -['_ma_qa_metric.id', '_ma_qa_metric.name', '_ma_qa_metric.description', '_ma_qa_metric.type', '_ma_qa_metric.mode', '_ma_qa_metric.type_other_details', '_ma_qa_metric.software_group_id'] -[['1', 'pLDDT', "'Predicted accuracy according to the CA-only lDDT in [0,100]'", 'pLDDT', 'global', '.', '.'], ['2', 'pTM', "'Predicted accuracy according to the TM-score score in [0,1]'", 'pTM', 'global', '.', '.'], ['3', 'pLDDT', "'Predicted accuracy according to the CA-only lDDT in [0,100]'", 'pLDDT', 'local', '.', '.'], ['4', 'PAE', "'Predicted aligned error (in Angstroms)'", 'PAE', 'local-pairwise', '.', '.']] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [15]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># note: "row.str(#) or "gemmi.cif.as_string" map "." or "?" to "" and remove quotes from strings</span> -<span class="k">if</span> <span class="n">table</span><span class="p">:</span> - <span class="nb">print</span><span class="p">([[</span><span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="n">col</span><span class="p">)</span> <span class="k">for</span> <span class="n">col</span> <span class="ow">in</span> <span class="n">row</span><span class="p">]</span> <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">])</span> -<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s1">'"</span><span class="si">{</span><span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="s2">"?"</span><span class="p">)</span><span class="si">}</span><span class="s1">"'</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>[['1', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'global', '', ''], ['2', 'pTM', 'Predicted accuracy according to the TM-score score in [0,1]', 'pTM', 'global', '', ''], ['3', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'local', '', ''], ['4', 'PAE', 'Predicted aligned error (in Angstroms)', 'PAE', 'local-pairwise', '', '']] -"" -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [8]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># use find with desired columns (incl. optional ones)</span> -<span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_qa_metric."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"id"</span><span class="p">,</span> <span class="s2">"mode"</span><span class="p">,</span> <span class="s2">"name"</span><span class="p">,</span> <span class="s2">"type"</span><span class="p">,</span> <span class="s2">"?meh"</span><span class="p">])</span> -<span class="nb">print</span><span class="p">(</span><span class="n">table</span><span class="o">.</span><span class="n">has_column</span><span class="p">(</span><span class="mi">4</span><span class="p">))</span> -<span class="c1"># and look for rows according to first column</span> -<span class="nb">print</span><span class="p">(</span><span class="n">table</span><span class="o">.</span><span class="n">find_row</span><span class="p">(</span><span class="s2">"3"</span><span class="p">))</span> -<span class="c1"># and get dictionary (as is)</span> -<span class="nb">print</span><span class="p">(</span><span class="n">block</span><span class="o">.</span><span class="n">get_mmcif_category</span><span class="p">(</span><span class="s2">"_ma_qa_metric."</span><span class="p">,</span> <span class="n">raw</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span> -<span class="c1"># or nicely processed (? and . becoming None)</span> -<span class="n">block</span><span class="o">.</span><span class="n">get_mmcif_category</span><span class="p">(</span><span class="s2">"_ma_qa_metric."</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>False -<gemmi.cif.Table.Row: 3 local pLDDT pLDDT None> -{'id': ['1', '2', '3', '4'], 'name': ['pLDDT', 'pTM', 'pLDDT', 'PAE'], 'description': ["'Predicted accuracy according to the CA-only lDDT in [0,100]'", "'Predicted accuracy according to the TM-score score in [0,1]'", "'Predicted accuracy according to the CA-only lDDT in [0,100]'", "'Predicted aligned error (in Angstroms)'"], 'type': ['pLDDT', 'pTM', 'pLDDT', 'PAE'], 'mode': ['global', 'global', 'local', 'local-pairwise'], 'type_other_details': ['.', '.', '.', '.'], 'software_group_id': ['.', '.', '.', '.']} -</pre> -</div> -</div> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[8]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>{'id': ['1', '2', '3', '4'], - 'name': ['pLDDT', 'pTM', 'pLDDT', 'PAE'], - 'description': ['Predicted accuracy according to the CA-only lDDT in [0,100]', - 'Predicted accuracy according to the TM-score score in [0,1]', - 'Predicted accuracy according to the CA-only lDDT in [0,100]', - 'Predicted aligned error (in Angstroms)'], - 'type': ['pLDDT', 'pTM', 'pLDDT', 'PAE'], - 'mode': ['global', 'global', 'local', 'local-pairwise'], - 'type_other_details': [False, False, False, False], - 'software_group_id': [False, False, False, False]}</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [206]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># some ways to deal with optional and missing (? or .) data</span> -<span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_software."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"name"</span><span class="p">,</span> <span class="s2">"?location"</span><span class="p">,</span> <span class="s2">"?version"</span><span class="p">,</span> <span class="s2">"?citation_id"</span><span class="p">,</span> <span class="s2">"?meh"</span><span class="p">])</span> -<span class="n">display</span><span class="p">([[(</span><span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span> <span class="ow">and</span> <span class="nb">bool</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">idx</span><span class="p">)))</span> <span class="k">for</span> <span class="n">idx</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">row</span><span class="p">))]</span> <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">])</span> -<span class="n">display</span><span class="p">([[(</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span> <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span> <span class="k">else</span> <span class="s1">''</span><span class="p">)</span> <span class="k">for</span> <span class="n">idx</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">row</span><span class="p">))]</span> <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - - - -<div class="jp-RenderedText jp-OutputArea-output " data-mime-type="text/plain"> -<pre>[[True, True, True, True, False], - [True, True, False, True, False], - [True, True, False, True, False]]</pre> -</div> - -</div> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - - - -<div class="jp-RenderedText jp-OutputArea-output " data-mime-type="text/plain"> -<pre>[['ColabFold', 'https://github.com/sokrypton/ColabFold', '1.2.0', '1', ''], - ['MMseqs2', 'https://github.com/soedinglab/mmseqs2', '', '2', ''], - ['AlphaFold', 'https://github.com/deepmind/alphafold', '', '3', '']]</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [17]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># note that the above also works for completely missing tables</span> -<span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_meh."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"name"</span><span class="p">,</span> <span class="s2">"?location"</span><span class="p">,</span> <span class="s2">"?version"</span><span class="p">,</span> <span class="s2">"?citation_id"</span><span class="p">,</span> <span class="s2">"?meh"</span><span class="p">])</span> -<span class="n">display</span><span class="p">([[(</span><span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span> <span class="ow">and</span> <span class="nb">bool</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">idx</span><span class="p">)))</span> <span class="k">for</span> <span class="n">idx</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">row</span><span class="p">))]</span> <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - - - -<div class="jp-RenderedText jp-OutputArea-output " data-mime-type="text/plain"> -<pre>[]</pre> -</div> - -</div> - -</div> - -</div> - -</div> -<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell"> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> -</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown"> -<h1 id="ModelCIF--%3E-MA">ModelCIF -> MA<a class="anchor-link" href="#ModelCIF--%3E-MA">¶</a></h1> -</div> -</div> -</div> -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [2]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">gemmi</span> - -<span class="c1"># define converters for printing or for html (here markdown used for display)</span> -<span class="k">def</span> <span class="nf">_make_url</span><span class="p">(</span><span class="n">link_text</span><span class="p">,</span> <span class="n">link_url</span><span class="p">):</span> - <span class="k">return</span> <span class="sa">f</span><span class="s2">"[</span><span class="si">{</span><span class="n">link_text</span><span class="si">}</span><span class="s2">](</span><span class="si">{</span><span class="n">link_url</span><span class="si">}</span><span class="s2">)"</span> -<span class="k">def</span> <span class="nf">_make_list</span><span class="p">(</span><span class="n">list_top</span><span class="p">,</span> <span class="n">list_items</span><span class="p">):</span> - <span class="n">list_texts</span> <span class="o">=</span> <span class="p">[</span><span class="sa">f</span><span class="s2">"- </span><span class="si">{</span><span class="n">item</span><span class="si">}</span><span class="s2">"</span> <span class="k">for</span> <span class="n">item</span> <span class="ow">in</span> <span class="n">list_items</span><span class="p">]</span> - <span class="n">list_text</span> <span class="o">=</span> <span class="s1">'</span><span class="se">\n</span><span class="s1">'</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">list_texts</span><span class="p">)</span> - <span class="k">if</span> <span class="n">list_texts</span><span class="p">:</span> - <span class="k">return</span><span class="p">(</span><span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">list_top</span><span class="si">}</span><span class="se">\n</span><span class="si">{</span><span class="n">list_text</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> -<span class="k">def</span> <span class="nf">_make_multiline_text</span><span class="p">(</span><span class="n">lines</span><span class="p">):</span> - <span class="k">return</span> <span class="s1">'</span><span class="se">\n</span><span class="s1">'</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">lines</span><span class="p">)</span> -<span class="k">def</span> <span class="nf">_make_paragraph</span><span class="p">(</span><span class="n">text</span><span class="p">):</span> - <span class="k">return</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">text</span><span class="si">}</span><span class="se">\n\n</span><span class="s2">"</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [24]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># define test files for translations below</span> -<span class="n">test_files</span> <span class="o">=</span> <span class="p">[</span> - <span class="s2">"modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/AF-P38129-F1-model_v3.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/ma-bak-cepc-0001.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/1crn.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/Var3D_I6XD65_1046.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/Var3D_L7N665_1046.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/Var3D_P9WIE5_3767.cif"</span><span class="p">,</span> - <span class="s2">"modelcif_MA_test/ORNL_F0JBU9_9DELT.cif"</span><span class="p">,</span> -<span class="p">]</span> - -<span class="c1"># open one for quick testing</span> -<span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_files</span><span class="p">[</span><span class="o">-</span><span class="mi">4</span><span class="p">])</span> -<span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [18]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># easy: look for unique model details (same for title; already in ParseCIF)</span> -<span class="n">abstract</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find_value</span><span class="p">(</span><span class="s2">"_struct.pdbx_model_details"</span><span class="p">)</span> -<span class="k">if</span> <span class="n">abstract</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="n">abstract</span><span class="p">)[:</span><span class="mi">400</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>Model generated using ColabFold v1.2.0 with AlphaFold producing 5 models with 3 recycles each without model relaxation without templates ranked by pLDDT starting from an MSA from MMseqs2 (UniRef+Environmental) - -Emapper preferred name [EggNOG]: - -Emapper description [EggNOG]: - -CoFFE preferred name [EggNOG]: PLA2G15 -CoFFE description [EggNOG]: Lecithin:cholesterol acyltransferase -CoFFE UniProt func -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [10]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check out entity parsing from ParseCIF</span> -<span class="c1"># -> CHANGES: asym_ids as list of chains (wasn't used anyways), make align and </span> -<span class="k">def</span> <span class="nf">_get_chain_entity</span><span class="p">(</span><span class="n">block</span><span class="p">):</span> - <span class="n">chain_entity</span> <span class="o">=</span> <span class="p">{}</span> - - <span class="n">ma_target_entity</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span> - <span class="s2">"_ma_target_entity_instance."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"asym_id"</span><span class="p">,</span> <span class="s2">"entity_id"</span><span class="p">]</span> - <span class="p">)</span> - <span class="k">if</span> <span class="n">ma_target_entity</span><span class="p">:</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">ma_target_entity</span><span class="p">:</span> - <span class="k">if</span> <span class="n">row</span><span class="p">[</span><span class="s2">"entity_id"</span><span class="p">]</span> <span class="ow">in</span> <span class="n">chain_entity</span><span class="p">:</span> - <span class="n">chain_entity</span><span class="p">[</span><span class="n">row</span><span class="p">[</span><span class="s2">"entity_id"</span><span class="p">]][</span><span class="s2">"asym_ids"</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span> - <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="n">row</span><span class="p">[</span><span class="s2">"asym_id"</span><span class="p">])</span> - <span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">chain_entity</span><span class="p">[</span><span class="n">row</span><span class="p">[</span><span class="s2">"entity_id"</span><span class="p">]]</span> <span class="o">=</span> <span class="p">{</span> - <span class="s2">"asym_ids"</span><span class="p">:</span> <span class="p">[</span><span class="n">row</span><span class="p">[</span><span class="s2">"asym_id"</span><span class="p">]],</span> - <span class="s2">"ma_target_ref_db_details"</span><span class="p">:</span> <span class="p">[],</span> - <span class="p">}</span> - - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_entity."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"id"</span><span class="p">,</span> <span class="s2">"pdbx_description"</span><span class="p">]):</span> - <span class="n">chain_entity</span><span class="p">[</span><span class="n">row</span><span class="p">[</span><span class="s2">"id"</span><span class="p">]]</span><span class="o">.</span><span class="n">update</span><span class="p">(</span> - <span class="p">{</span><span class="s2">"pdbx_description"</span><span class="p">:</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="n">row</span><span class="p">[</span><span class="s2">"pdbx_description"</span><span class="p">])}</span> - <span class="p">)</span> - - <span class="n">cols</span> <span class="o">=</span> <span class="p">[</span> - <span class="s2">"target_entity_id"</span><span class="p">,</span> - <span class="s2">"db_accession"</span><span class="p">,</span> - <span class="s2">"db_name"</span><span class="p">,</span> - <span class="s2">"?db_name_other_details"</span><span class="p">,</span> - <span class="s2">"?organism_scientific"</span><span class="p">,</span> - <span class="s2">"?seq_db_align_begin"</span><span class="p">,</span> - <span class="s2">"?seq_db_align_end"</span><span class="p">,</span> - <span class="p">]</span> - <span class="c1"># NOTE: row[col] doesn't work with '?' in find! Bad crashed happen if you try...</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_target_ref_db_details."</span><span class="p">,</span> <span class="n">cols</span><span class="p">):</span> - <span class="n">json_obj</span> <span class="o">=</span> <span class="p">{}</span> - <span class="n">target_entity_id</span> <span class="o">=</span> <span class="n">row</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="c1"># make sure this stays at idx 0 in cols!</span> - <span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">cq</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">cols</span><span class="p">):</span> - <span class="k">if</span> <span class="n">cq</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s1">'?'</span><span class="p">):</span> - <span class="n">col</span> <span class="o">=</span> <span class="n">cq</span><span class="p">[</span><span class="mi">1</span><span class="p">:]</span> - <span class="k">if</span> <span class="ow">not</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="n">idx</span><span class="p">):</span> - <span class="n">json_obj</span><span class="p">[</span><span class="n">col</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span> - <span class="k">continue</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">col</span> <span class="o">=</span> <span class="n">cq</span> - <span class="k">if</span> <span class="n">col</span> <span class="o">!=</span> <span class="s2">"target_entity_id"</span><span class="p">:</span> - <span class="k">if</span> <span class="n">col</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"seq_db_align"</span><span class="p">)</span> <span class="o">></span> <span class="o">-</span><span class="mi">1</span><span class="p">:</span> - <span class="n">json_obj</span><span class="p">[</span><span class="n">col</span><span class="p">]</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_int</span><span class="p">(</span><span class="n">row</span><span class="p">[</span><span class="n">idx</span><span class="p">])</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">json_obj</span><span class="p">[</span><span class="n">col</span><span class="p">]</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="n">row</span><span class="p">[</span><span class="n">idx</span><span class="p">])</span> - <span class="n">chain_entity</span><span class="p">[</span><span class="n">target_entity_id</span><span class="p">][</span> - <span class="s2">"ma_target_ref_db_details"</span> - <span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">json_obj</span><span class="p">)</span> - - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span> - <span class="s2">"_entity_poly."</span><span class="p">,</span> - <span class="p">[</span><span class="s2">"entity_id"</span><span class="p">,</span> <span class="s2">"pdbx_strand_id"</span><span class="p">,</span> <span class="s2">"pdbx_seq_one_letter_code"</span><span class="p">],</span> - <span class="p">):</span> - <span class="n">chain_entity</span><span class="p">[</span><span class="n">row</span><span class="p">[</span><span class="s2">"entity_id"</span><span class="p">]][</span><span class="s2">"olc"</span><span class="p">]</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span> - <span class="n">row</span><span class="p">[</span><span class="s2">"pdbx_seq_one_letter_code"</span><span class="p">]</span> - <span class="p">)</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">"</span><span class="se">\n</span><span class="s2">"</span><span class="p">,</span> <span class="s2">""</span><span class="p">)</span> - - <span class="k">return</span> <span class="n">chain_entity</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [14]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># do entity parsing</span> -<span class="k">def</span> <span class="nf">_test_entity_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">):</span> - <span class="c1"># get file for testing</span> - <span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - <span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> - <span class="c1"># reuse (updated!) code from ParseCIF</span> - <span class="n">chain_entity</span> <span class="o">=</span> <span class="n">_get_chain_entity</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> - <span class="c1"># do it</span> - <span class="n">item_strings</span> <span class="o">=</span> <span class="p">[]</span> - <span class="k">for</span> <span class="n">ent</span> <span class="ow">in</span> <span class="n">chain_entity</span><span class="p">:</span> - <span class="n">item_title</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">chain_entity</span><span class="p">[</span><span class="n">ent</span><span class="p">][</span><span class="s1">'pdbx_description'</span><span class="p">]</span><span class="si">}</span><span class="s2"> "</span> \ - <span class="sa">f</span><span class="s2">"(chains: </span><span class="si">{</span><span class="s1">', '</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">chain_entity</span><span class="p">[</span><span class="n">ent</span><span class="p">][</span><span class="s1">'asym_ids'</span><span class="p">])</span><span class="si">}</span><span class="s2">)"</span> - <span class="n">db_links</span> <span class="o">=</span> <span class="p">[</span><span class="n">item_title</span><span class="p">]</span> - <span class="k">for</span> <span class="n">i</span><span class="p">,</span> <span class="n">ref</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">chain_entity</span><span class="p">[</span><span class="n">ent</span><span class="p">][</span><span class="s2">"ma_target_ref_db_details"</span><span class="p">]):</span> - <span class="k">if</span> <span class="n">ref</span><span class="p">[</span><span class="s2">"db_name"</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"UNP"</span><span class="p">:</span> - <span class="n">link_text</span> <span class="o">=</span> <span class="n">ref</span><span class="p">[</span><span class="s1">'db_accession'</span><span class="p">]</span> - <span class="n">link_url</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"https://www.uniprot.org/uniprot/</span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'db_accession'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="n">db_link</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"UniProt: </span><span class="si">{</span><span class="n">_make_url</span><span class="p">(</span><span class="n">link_text</span><span class="p">,</span> <span class="n">link_url</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">elif</span> <span class="n">ref</span><span class="p">[</span><span class="s2">"db_name"</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"OrthoDB"</span><span class="p">:</span> - <span class="n">link_text</span> <span class="o">=</span> <span class="n">ref</span><span class="p">[</span><span class="s1">'db_accession'</span><span class="p">]</span> - <span class="n">link_url</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"https://www.orthodb.org/?query=</span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'db_accession'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="n">db_link</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"OrthoDB: </span><span class="si">{</span><span class="n">_make_url</span><span class="p">(</span><span class="n">link_text</span><span class="p">,</span> <span class="n">link_url</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">elif</span> <span class="n">ref</span><span class="p">[</span><span class="s2">"db_name"</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"Other"</span> <span class="ow">and</span> <span class="n">ref</span><span class="p">[</span><span class="s2">"db_name_other_details"</span><span class="p">]:</span> - <span class="n">db_link</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'db_name_other_details'</span><span class="p">]</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'db_accession'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">db_link</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'db_accession'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="k">if</span> <span class="n">ref</span><span class="p">[</span><span class="s1">'seq_db_align_begin'</span><span class="p">]</span> <span class="ow">and</span> <span class="n">ref</span><span class="p">[</span><span class="s1">'seq_db_align_end'</span><span class="p">]:</span> - <span class="n">db_link</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" </span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'seq_db_align_begin'</span><span class="p">]</span><span class="si">}</span><span class="s2">-</span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'seq_db_align_end'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="k">if</span> <span class="n">ref</span><span class="p">[</span><span class="s1">'organism_scientific'</span><span class="p">]:</span> - <span class="n">db_link</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">"; </span><span class="si">{</span><span class="n">ref</span><span class="p">[</span><span class="s1">'organism_scientific'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="n">db_links</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">db_link</span><span class="p">)</span> - <span class="n">item_strings</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">_make_multiline_text</span><span class="p">(</span><span class="n">db_links</span><span class="p">))</span> - <span class="c1"># and show me...</span> - <span class="k">if</span> <span class="n">item_strings</span><span class="p">:</span> - <span class="n">list_top</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"The following molecular entities are in the model: (</span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">)"</span> - <span class="nb">print</span><span class="p">(</span><span class="n">_make_list</span><span class="p">(</span><span class="n">list_top</span><span class="p">,</span> <span class="n">item_strings</span><span class="p">))</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No molecular entities listed in </span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">()</span> - -<span class="k">for</span> <span class="n">test_file</span> <span class="ow">in</span> <span class="n">test_files</span><span class="p">:</span> - <span class="n">_test_entity_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>The following molecular entities are in the model: (modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif) -- Spongilla lacustris c103531_g3_i1 protein (chains: A) - -The following molecular entities are in the model: (modelcif_MA_test/AF-P38129-F1-model_v3.cif) -- Transcription initiation factor TFIID subunit 5 (chains: A) -UniProt: [P38129](https://www.uniprot.org/uniprot/P38129) 1-798; Saccharomyces cerevisiae (strain ATCC 204508 / S288c) - -The following molecular entities are in the model: (modelcif_MA_test/ma-bak-cepc-0001.cif) -- TAF4 (chains: A) -OrthoDB: [1294385_1:000f0d](https://www.orthodb.org/?query=1294385_1:000f0d) 1-388; Saccharomyces cerevisiae YJM1573 -UniProt: [A6ZM67](https://www.uniprot.org/uniprot/A6ZM67) 1-388; Saccharomyces cerevisiae (strain YJM789) (Baker's yeast) -- TAF5 (chains: B) -OrthoDB: [1294385_1:000051](https://www.orthodb.org/?query=1294385_1:000051) 1-798; Saccharomyces cerevisiae YJM1573 -UniProt: [P38129](https://www.uniprot.org/uniprot/P38129) 1-798; Saccharomyces cerevisiae (strain ATCC 204508 / S288c) (Baker's yeast) - -No molecular entities listed in modelcif_MA_test/1crn.cif - -The following molecular entities are in the model: (modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif) -- Model of ZC3H11B (A0A1B0GTU1) (chains: A) -UniProt: [A0A1B0GTU1](https://www.uniprot.org/uniprot/A0A1B0GTU1) 1-805; Homo sapiens (Human) -- Model of ZC3H11A (O75152) (chains: B) -UniProt: [O75152](https://www.uniprot.org/uniprot/O75152) 1-810; Homo sapiens (Human) - -The following molecular entities are in the model: (modelcif_MA_test/Var3D_I6XD65_1046.cif) -- Model subunit of I6XD65 (chains: A) -UniProt: [I6XD65](https://www.uniprot.org/uniprot/I6XD65) 1-185; Mycobacterium tuberculosis (strain ATCC 25618 / H37Rv) -- FE (II) ION (chains: B) -- Pyrazinamide (chains: C) - -The following molecular entities are in the model: (modelcif_MA_test/Var3D_L7N665_1046.cif) -- Model subunit of L7N665 (chains: A, B) -UniProt: [L7N665](https://www.uniprot.org/uniprot/L7N665) 1-385; Mycobacterium tuberculosis (strain ATCC 25618 / H37Rv) - -The following molecular entities are in the model: (modelcif_MA_test/Var3D_P9WIE5_3767.cif) -- Model subunit of P9WIE5 (chains: A, B) -UniProt: [P9WIE5](https://www.uniprot.org/uniprot/P9WIE5) 24-740; Mycobacterium tuberculosis (strain ATCC 25618 / H37Rv) -- Isoniazid (chains: C, D) -- SODIUM ION (chains: E, F) -- CHLORIDE ION (chains: G, H) -- PROTOPORPHYRIN IX CONTAINING FE (chains: I, J) -- GLYCEROL (chains: K, L, M, N, O, P) - -The following molecular entities are in the model: (modelcif_MA_test/ORNL_F0JBU9_9DELT.cif) -- DND132RS05775 (chains: A) -UniProt: [F0JBU9](https://www.uniprot.org/uniprot/F0JBU9) 1-123 -RefSeq: NC_016803 1-123 - -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># do SW parsing</span> -<span class="k">def</span> <span class="nf">_test_sw_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">):</span> - <span class="c1"># get file for testing</span> - <span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - <span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> - <span class="c1"># get author names for each citation</span> - <span class="n">tmp</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_citation_author."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"citation_id"</span><span class="p">,</span> <span class="s2">"name"</span><span class="p">]):</span> - <span class="n">cid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="n">name</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> - <span class="k">if</span> <span class="n">cid</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">tmp</span><span class="p">:</span> - <span class="n">tmp</span><span class="p">[</span><span class="n">cid</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="s2">"name"</span><span class="p">:</span> <span class="n">name</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">","</span><span class="p">)[</span><span class="mi">0</span><span class="p">],</span> <span class="s2">"etal"</span><span class="p">:</span> <span class="s2">""</span><span class="p">}</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">tmp</span><span class="p">[</span><span class="n">cid</span><span class="p">][</span><span class="s2">"etal"</span><span class="p">]</span> <span class="o">=</span> <span class="s2">" et al."</span> - <span class="n">cit_names</span> <span class="o">=</span> <span class="p">{</span><span class="n">cid</span><span class="p">:</span> <span class="p">(</span><span class="n">d</span><span class="p">[</span><span class="s2">"name"</span><span class="p">]</span> <span class="o">+</span> <span class="n">d</span><span class="p">[</span><span class="s2">"etal"</span><span class="p">])</span> <span class="k">for</span> <span class="n">cid</span><span class="p">,</span> <span class="n">d</span> <span class="ow">in</span> <span class="n">tmp</span><span class="o">.</span><span class="n">items</span><span class="p">()}</span> - <span class="c1"># add year if available</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_citation."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"id"</span><span class="p">,</span> <span class="s2">"?year"</span><span class="p">])</span> - <span class="k">if</span> <span class="n">table</span><span class="o">.</span><span class="n">has_column</span><span class="p">(</span><span class="mi">1</span><span class="p">):</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">cid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="n">year</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> - <span class="k">if</span> <span class="n">cid</span> <span class="ow">in</span> <span class="n">cit_names</span> <span class="ow">and</span> <span class="n">year</span><span class="p">:</span> - <span class="n">cit_names</span><span class="p">[</span><span class="n">cid</span><span class="p">]</span> <span class="o">+=</span> <span class="s2">" "</span> <span class="o">+</span> <span class="n">year</span> - <span class="c1"># add URL if available</span> - <span class="n">cit_urls</span> <span class="o">=</span> <span class="p">{}</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_citation."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"id"</span><span class="p">,</span> <span class="s2">"?pdbx_database_id_DOI"</span><span class="p">,</span> <span class="s2">"?pdbx_database_id_PubMed"</span><span class="p">])</span> - <span class="n">formatters</span> <span class="o">=</span> <span class="p">[</span><span class="s2">"https://doi.org/</span><span class="si">%s</span><span class="s2">"</span><span class="p">,</span> - <span class="s2">"https://www.ncbi.nlm.nih.gov/pubmed/</span><span class="si">%s</span><span class="s2">"</span><span class="p">]</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">cid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="c1"># add whichever URL we find first</span> - <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="n">table</span><span class="o">.</span><span class="n">width</span><span class="p">()):</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="n">i</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">i</span><span class="p">):</span> - <span class="n">cit_urls</span><span class="p">[</span><span class="n">cid</span><span class="p">]</span> <span class="o">=</span> <span class="n">formatters</span><span class="p">[</span><span class="n">i</span> <span class="o">-</span> <span class="mi">1</span><span class="p">]</span> <span class="o">%</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">i</span><span class="p">)</span> - <span class="k">break</span> - <span class="c1"># now map this to software</span> - <span class="n">item_strings</span> <span class="o">=</span> <span class="p">[]</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_software."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"name"</span><span class="p">,</span> <span class="s2">"?location"</span><span class="p">,</span> <span class="s2">"?version"</span><span class="p">,</span> <span class="s2">"?citation_id"</span><span class="p">])</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">sw_name</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">):</span> - <span class="n">item</span> <span class="o">=</span> <span class="n">_make_url</span><span class="p">(</span><span class="n">sw_name</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">))</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="n">sw_name</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">):</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" (</span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span><span class="si">}</span><span class="s2">)"</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> <span class="ow">in</span> <span class="n">cit_names</span><span class="p">:</span> - <span class="n">cid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> - <span class="k">if</span> <span class="n">cid</span> <span class="ow">in</span> <span class="n">cit_urls</span><span class="p">:</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" (</span><span class="si">{</span><span class="n">_make_url</span><span class="p">(</span><span class="n">cit_names</span><span class="p">[</span><span class="n">cid</span><span class="p">],</span> <span class="n">cit_urls</span><span class="p">[</span><span class="n">cid</span><span class="p">])</span><span class="si">}</span><span class="s2">)"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" (</span><span class="si">{</span><span class="n">cit_names</span><span class="p">[</span><span class="n">cid</span><span class="p">]</span><span class="si">}</span><span class="s2">)"</span> - <span class="n">item_strings</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="c1"># and show me...</span> - <span class="k">if</span> <span class="n">item_strings</span><span class="p">:</span> - <span class="n">list_top</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"The following software was used: (</span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">)"</span> - <span class="nb">print</span><span class="p">(</span><span class="n">_make_list</span><span class="p">(</span><span class="n">list_top</span><span class="p">,</span> <span class="n">item_strings</span><span class="p">))</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No software was listed for </span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">()</span> - -<span class="k">for</span> <span class="n">test_file</span> <span class="ow">in</span> <span class="n">test_files</span><span class="p">:</span> - <span class="n">_test_sw_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [182]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># do ref. DB parsing</span> -<span class="k">def</span> <span class="nf">_test_ref_db_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">):</span> - <span class="c1"># get file for testing</span> - <span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - <span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> - <span class="c1"># look for DBs with version or release date</span> - <span class="n">item_strings</span> <span class="o">=</span> <span class="p">[]</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_data_ref_db."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"name"</span><span class="p">,</span> <span class="s2">"?version"</span><span class="p">,</span> <span class="s2">"?release_date"</span><span class="p">])</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="c1"># add whichever version we find first</span> - <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">3</span><span class="p">):</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="n">i</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">i</span><span class="p">):</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" (</span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">i</span><span class="p">)</span><span class="si">}</span><span class="s2">)"</span> - <span class="k">break</span> - <span class="n">item_strings</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="c1"># and show me...</span> - <span class="k">if</span> <span class="n">item_strings</span><span class="p">:</span> - <span class="n">list_top</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"The following reference databases were used: (</span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">)"</span> - <span class="nb">print</span><span class="p">(</span><span class="n">_make_list</span><span class="p">(</span><span class="n">list_top</span><span class="p">,</span> <span class="n">item_strings</span><span class="p">))</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No reference databases were listed for </span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">()</span> - -<span class="k">for</span> <span class="n">test_file</span> <span class="ow">in</span> <span class="n">test_files</span><span class="p">:</span> - <span class="n">_test_ref_db_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>The following reference databases were used: (modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif) -- UniRef30 (2021_03) -- ColabFold DB (2021_08) - -No reference databases were listed for modelcif_MA_test/AF-P38129-F1-model_v3.cif - -No reference databases were listed for modelcif_MA_test/ma-bak-cepc-0001.cif - -No reference databases were listed for modelcif_MA_test/1crn.cif - -No reference databases were listed for modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif - -No reference databases were listed for modelcif_MA_test/Var3D_I6XD65_1046.cif - -The following reference databases were used: (modelcif_MA_test/Var3D_L7N665_1046.cif) -- BFD (6a634dc6eb105c2e9b4cba7bbae93412) -- MGnify (2018_12) -- Uniclust30 (2018_08) -- Swiss-Prot (2021_03) -- TrEMBL (2021_03) -- UniRef90 (2021_03) - -No reference databases were listed for modelcif_MA_test/Var3D_P9WIE5_3767.cif - -No reference databases were listed for modelcif_MA_test/ORNL_F0JBU9_9DELT.cif - -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [47]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># do template parsing</span> -<span class="k">def</span> <span class="nf">_test_tpl_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">):</span> - <span class="c1"># get file for testing</span> - <span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - <span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> - <span class="c1"># collect info per tpl-id</span> - <span class="n">tpl_dict</span> <span class="o">=</span> <span class="p">{}</span> <span class="c1"># keyed on template_id</span> - <span class="c1"># fetch main info</span> - <span class="n">cols</span> <span class="o">=</span> <span class="p">[</span><span class="s2">"template_id"</span><span class="p">,</span> <span class="s2">"target_asym_id"</span><span class="p">,</span> <span class="s2">"template_auth_asym_id"</span><span class="p">,</span> - <span class="s2">"?template_label_asym_id"</span><span class="p">]</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_template_details."</span><span class="p">,</span> <span class="n">cols</span><span class="p">):</span> - <span class="n">tid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span> - <span class="s2">"trg_asym_id"</span><span class="p">:</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">),</span> - <span class="s2">"tpl_auth_asym_id"</span><span class="p">:</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> - <span class="p">}</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">3</span><span class="p">):</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="s2">"tpl_label_asym_id"</span><span class="p">]</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> - <span class="c1"># add ref DBs</span> - <span class="n">cols</span> <span class="o">=</span> <span class="p">[</span><span class="s2">"template_id"</span><span class="p">,</span> <span class="s2">"db_accession_code"</span><span class="p">,</span> <span class="s2">"db_name"</span><span class="p">,</span> - <span class="s2">"?db_name_other_details"</span><span class="p">]</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_template_ref_db_details."</span><span class="p">,</span> <span class="n">cols</span><span class="p">):</span> - <span class="n">tid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="k">if</span> <span class="n">tid</span> <span class="ow">in</span> <span class="n">tpl_dict</span><span class="p">:</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="s2">"db_acc"</span><span class="p">]</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> <span class="o">==</span> <span class="s2">"Other"</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">3</span><span class="p">):</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="s2">"db_name"</span><span class="p">]</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="s2">"db_name"</span><span class="p">]</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> - <span class="c1"># add info for small molecules</span> - <span class="n">cols</span> <span class="o">=</span> <span class="p">[</span><span class="s2">"template_id"</span><span class="p">,</span> <span class="s2">"?comp_id"</span><span class="p">,</span> <span class="s2">"?details"</span><span class="p">]</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_template_non_poly."</span><span class="p">,</span> <span class="n">cols</span><span class="p">):</span> - <span class="n">tid</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="k">if</span> <span class="n">tid</span> <span class="ow">in</span> <span class="n">tpl_dict</span><span class="p">:</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">):</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="s2">"non_poly_comp_id"</span><span class="p">]</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">):</span> - <span class="n">tpl_dict</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="s2">"non_poly_details"</span><span class="p">]</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> - <span class="c1"># aggregate per template for diplaying</span> - <span class="n">tpl_td</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> - <span class="k">for</span> <span class="n">tpl</span> <span class="ow">in</span> <span class="n">tpl_dict</span><span class="o">.</span><span class="n">values</span><span class="p">():</span> - <span class="n">did</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span><span class="si">}</span><span class="s2">-</span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_acc'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="k">if</span> <span class="n">did</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">tpl_td</span><span class="p">:</span> - <span class="k">if</span> <span class="n">tpl</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"PDB"</span><span class="p">:</span> - <span class="n">link_url</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"http://dx.doi.org/10.2210/pdb</span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_acc'</span><span class="p">]</span><span class="si">}</span><span class="s2">/pdb"</span> - <span class="k">elif</span> <span class="n">tpl</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"PubChem"</span><span class="p">:</span> - <span class="n">link_url</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"https://pubchem.ncbi.nlm.nih.gov/compound/</span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_acc'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">link_url</span> <span class="o">=</span> <span class="kc">None</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"URLs for </span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span><span class="si">}</span><span class="s2"> NOT SUPPORTED YET"</span><span class="p">)</span> - <span class="k">if</span> <span class="n">link_url</span><span class="p">:</span> - <span class="n">tpl_text</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="n">_make_url</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_acc'</span><span class="p">],</span> <span class="n">link_url</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">tpl_text</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_name'</span><span class="p">]</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'db_acc'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="n">tpl_td</span><span class="p">[</span><span class="n">did</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span> - <span class="s2">"tpl_text"</span><span class="p">:</span> <span class="n">tpl_text</span><span class="p">,</span> - <span class="s2">"tpl_chains_label"</span><span class="p">:</span> <span class="p">[],</span> - <span class="s2">"tpl_chains_auth"</span><span class="p">:</span> <span class="p">[],</span> - <span class="s2">"tpl_chains_all_label"</span><span class="p">:</span> <span class="kc">True</span><span class="p">,</span> - <span class="s2">"tpl_non_poly_ids"</span><span class="p">:</span> <span class="p">[]</span> - <span class="p">}</span> - <span class="c1"># collect chain names</span> - <span class="k">if</span> <span class="s2">"tpl_label_asym_id"</span> <span class="ow">in</span> <span class="n">tpl</span><span class="p">:</span> - <span class="c1"># if here it is guaranteed to be non-empty</span> - <span class="n">tpl_td</span><span class="p">[</span><span class="n">did</span><span class="p">][</span><span class="s2">"tpl_chains_label"</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_label_asym_id"</span><span class="p">])</span> - <span class="k">else</span><span class="p">:</span> - <span class="c1"># if any missing, we set all to False and fall back to auth</span> - <span class="n">tpl_td</span><span class="p">[</span><span class="n">did</span><span class="p">][</span><span class="s2">"tpl_chains_all_label"</span><span class="p">]</span> <span class="o">=</span> <span class="kc">False</span> - <span class="k">if</span> <span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_auth_asym_id"</span><span class="p">]:</span> - <span class="c1"># only add non empty ones</span> - <span class="n">tpl_td</span><span class="p">[</span><span class="n">did</span><span class="p">][</span><span class="s2">"tpl_chains_auth"</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_auth_asym_id"</span><span class="p">])</span> - <span class="c1"># collect info on non poly if available (prefer short comp. ID)</span> - <span class="k">if</span> <span class="s2">"non_poly_comp_id"</span> <span class="ow">in</span> <span class="n">tpl</span><span class="p">:</span> - <span class="n">tpl_td</span><span class="p">[</span><span class="n">did</span><span class="p">][</span><span class="s2">"tpl_non_poly_ids"</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s2">"non_poly_comp_id"</span><span class="p">])</span> - <span class="k">elif</span> <span class="s2">"non_poly_details"</span> <span class="ow">in</span> <span class="n">tpl</span><span class="p">:</span> - <span class="n">tpl_td</span><span class="p">[</span><span class="n">did</span><span class="p">][</span><span class="s2">"tpl_non_poly_ids"</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s2">"non_poly_details"</span><span class="p">])</span> - <span class="c1"># turn into text</span> - <span class="n">item_strings</span> <span class="o">=</span> <span class="p">[]</span> - <span class="k">for</span> <span class="n">tpl</span> <span class="ow">in</span> <span class="n">tpl_td</span><span class="o">.</span><span class="n">values</span><span class="p">():</span> - <span class="n">item</span> <span class="o">=</span> <span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_text"</span><span class="p">]</span> - <span class="k">if</span> <span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_chains_all_label"</span><span class="p">]</span> <span class="ow">and</span> <span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_chains_label"</span><span class="p">]:</span> - <span class="n">chain_ids</span> <span class="o">=</span> <span class="nb">sorted</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'tpl_chains_label'</span><span class="p">]))</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">"; chains (label_asym_id): </span><span class="si">{</span><span class="s1">', '</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">chain_ids</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">elif</span> <span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_chains_auth"</span><span class="p">]:</span> - <span class="n">chain_ids</span> <span class="o">=</span> <span class="nb">sorted</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'tpl_chains_auth'</span><span class="p">]))</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">"; chains (auth_asym_id): </span><span class="si">{</span><span class="s1">', '</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">chain_ids</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">if</span> <span class="n">tpl</span><span class="p">[</span><span class="s2">"tpl_non_poly_ids"</span><span class="p">]:</span> - <span class="n">np_ids</span> <span class="o">=</span> <span class="nb">sorted</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">tpl</span><span class="p">[</span><span class="s1">'tpl_non_poly_ids'</span><span class="p">]))</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">"; non-polymers: </span><span class="si">{</span><span class="s1">', '</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">np_ids</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="n">item_strings</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="c1"># and show me...</span> - <span class="k">if</span> <span class="n">item_strings</span><span class="p">:</span> - <span class="n">list_top</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"The following templates were used: (</span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">)"</span> - <span class="nb">print</span><span class="p">(</span><span class="n">_make_list</span><span class="p">(</span><span class="n">list_top</span><span class="p">,</span> <span class="n">item_strings</span><span class="p">))</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No templates were listed for </span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">()</span> - -<span class="k">for</span> <span class="n">test_file</span> <span class="ow">in</span> <span class="n">test_files</span><span class="p">:</span> - <span class="n">_test_tpl_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>No templates were listed for modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif - -The following templates were used: (modelcif_MA_test/AF-P38129-F1-model_v3.cif) -- PDB: [6TBM](http://dx.doi.org/10.2210/pdb6TBM/pdb); chains (auth_asym_id): G -- PDB: [6TB4](http://dx.doi.org/10.2210/pdb6TB4/pdb); chains (auth_asym_id): G -- PDB: [6F3T](http://dx.doi.org/10.2210/pdb6F3T/pdb); chains (auth_asym_id): A -- PDB: [6MZC](http://dx.doi.org/10.2210/pdb6MZC/pdb); chains (auth_asym_id): G - -No templates were listed for modelcif_MA_test/ma-bak-cepc-0001.cif - -No templates were listed for modelcif_MA_test/1crn.cif - -No templates were listed for modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif - -The following templates were used: (modelcif_MA_test/Var3D_I6XD65_1046.cif) -- PDB: [3PL1](http://dx.doi.org/10.2210/pdb3PL1/pdb); chains (label_asym_id): A, B; non-polymers: FE2 -- PubChem: [1046](https://pubchem.ncbi.nlm.nih.gov/compound/1046); non-polymers: PZA - -No templates were listed for modelcif_MA_test/Var3D_L7N665_1046.cif - -The following templates were used: (modelcif_MA_test/Var3D_P9WIE5_3767.cif) -- PDB: [1SJ2](http://dx.doi.org/10.2210/pdb1SJ2/pdb); chains (label_asym_id): A, B, C, D, E, F, G, H, I, J; non-polymers: GOL, HEM -- PDB: [6CDQ](http://dx.doi.org/10.2210/pdb6CDQ/pdb); chains (label_asym_id): D, E, K, M, N, S; non-polymers: CL, NA, NIZ - -No templates were listed for modelcif_MA_test/ORNL_F0JBU9_9DELT.cif - -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [183]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># do protocol steps parsing</span> -<span class="k">def</span> <span class="nf">_test_protocol_steps_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">):</span> - <span class="c1"># get file for testing</span> - <span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - <span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> - <span class="c1"># do it</span> - <span class="n">item_strings</span> <span class="o">=</span> <span class="p">[]</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_protocol_step."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"step_id"</span><span class="p">,</span> <span class="s2">"method_type"</span><span class="p">,</span> <span class="s2">"?details"</span><span class="p">])</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"Step </span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span><span class="si">}</span><span class="s2"> - </span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">):</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" : </span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="n">item_strings</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="c1"># and show me...</span> - <span class="k">if</span> <span class="n">item_strings</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"(</span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">)"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">(</span><span class="n">_make_multiline_text</span><span class="p">(</span><span class="n">item_strings</span><span class="p">))</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No protocol steps listed in </span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">()</span> - -<span class="k">for</span> <span class="n">test_file</span> <span class="ow">in</span> <span class="n">test_files</span><span class="p">:</span> - <span class="n">_test_protocol_steps_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - -<span class="c1"># NOTE: compared with code in ParseCIF (8.8.22): block.find used without optional '?' there</span> -<span class="c1"># -> i.e. code above works also if it is lacking details</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>(modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif) -Step 1 - modeling : Model generated using ColabFold v1.2.0 with AlphaFold producing 5 models with 3 recycles each without model relaxation without templates ranked by pLDDT starting from an MSA from MMseqs2 (UniRef+Environmental) - -(modelcif_MA_test/AF-P38129-F1-model_v3.cif) -Step 1 - coevolution MSA -Step 2 - template search -Step 3 - modeling - -(modelcif_MA_test/ma-bak-cepc-0001.cif) -Step 1 - coevolution MSA : Create paired MSAs for the dimers -Step 2 - modeling : Model using AlphaFold with a 200 residue gap between the two chains - -No protocol steps listed in modelcif_MA_test/1crn.cif - -(modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif) -Step 1 - modeling : Model using AlphaFold-Multimer (AlphaFold v2.2.0), without amber relaxation and producing 5 models with up to 3 recycles each, starting from paired and unparied MSAs for the dimers using MMseqs2. -Step 2 - model selection : Select best model, which is either the top-ranked model as determined by the ColabFold pipeline (iptmscore*0.8+ptmscore*0.2), or else the model with best congruence with crosslinks reported in the related study. - -(modelcif_MA_test/Var3D_I6XD65_1046.cif) -Step 1 - modeling : Docking of ligand PZA in structure - -(modelcif_MA_test/Var3D_L7N665_1046.cif) -Step 1 - modeling : Modelled the sequence of L7N665 with AlphaFold-Multimer as a homo-2-mer - -(modelcif_MA_test/Var3D_P9WIE5_3767.cif) -Step 1 - modeling : transferred ligand NIZ from experimental structure 6cdq into protein structure - -(modelcif_MA_test/ORNL_F0JBU9_9DELT.cif) -Step 1 - modeling -Step 2 - model selection - -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [184]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">_fetch_qa_data</span><span class="p">(</span><span class="n">block</span><span class="p">):</span> - <span class="c1"># fetch main info</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_qa_metric."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"id"</span><span class="p">,</span> <span class="s2">"name"</span><span class="p">,</span> <span class="s2">"mode"</span><span class="p">,</span> <span class="s2">"type"</span><span class="p">])</span> - <span class="n">qa_dict</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> <span class="c1"># for easy access: keyed on "id" and rest as dict</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">d</span> <span class="o">=</span> <span class="p">{</span><span class="n">key</span><span class="p">:</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">1</span><span class="p">)</span> <span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">key</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">([</span><span class="s2">"name"</span><span class="p">,</span> <span class="s2">"mode"</span><span class="p">,</span> <span class="s2">"type"</span><span class="p">])}</span> - <span class="n">qa_dict</span><span class="p">[</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)]</span> <span class="o">=</span> <span class="n">d</span> - <span class="c1"># fetch global scores</span> - <span class="n">qa_global</span> <span class="o">=</span> <span class="p">[]</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_qa_metric_global."</span><span class="p">,</span> <span class="p">[</span><span class="s2">"metric_id"</span><span class="p">,</span> <span class="s2">"metric_value"</span><span class="p">])</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">metric_id</span> <span class="o">=</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> - <span class="n">metric_value</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_number</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="mi">1</span><span class="p">))</span> - <span class="k">if</span> <span class="n">metric_id</span> <span class="ow">in</span> <span class="n">qa_dict</span><span class="p">:</span> - <span class="k">assert</span> <span class="n">qa_dict</span><span class="p">[</span><span class="n">metric_id</span><span class="p">][</span><span class="s2">"mode"</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"global"</span> - <span class="n">qa_dict</span><span class="p">[</span><span class="n">metric_id</span><span class="p">][</span><span class="s2">"value"</span><span class="p">]</span> <span class="o">=</span> <span class="n">metric_value</span> - <span class="n">qa_global</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">qa_dict</span><span class="p">[</span><span class="n">metric_id</span><span class="p">])</span> - <span class="c1"># fetch local scores</span> - <span class="n">qa_local</span> <span class="o">=</span> <span class="p">[</span><span class="n">d</span> <span class="k">for</span> <span class="n">d</span> <span class="ow">in</span> <span class="n">qa_dict</span><span class="o">.</span><span class="n">values</span><span class="p">()</span> <span class="k">if</span> <span class="n">d</span><span class="p">[</span><span class="s2">"mode"</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"local"</span><span class="p">]</span> - <span class="n">qa_local_pairwise</span> <span class="o">=</span> <span class="p">[</span><span class="n">d</span> <span class="k">for</span> <span class="n">d</span> <span class="ow">in</span> <span class="n">qa_dict</span><span class="o">.</span><span class="n">values</span><span class="p">()</span> <span class="k">if</span> <span class="n">d</span><span class="p">[</span><span class="s2">"mode"</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"local-pairwise"</span><span class="p">]</span> - <span class="k">return</span> <span class="n">qa_global</span><span class="p">,</span> <span class="n">qa_local</span><span class="p">,</span> <span class="n">qa_local_pairwise</span> - -<span class="n">_fetch_qa_data</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[184]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>([{'name': 'pLDDT', 'mode': 'global', 'type': 'pLDDT', 'value': 88.312}, - {'name': 'pTM', 'mode': 'global', 'type': 'pTM', 'value': 0.78}], - [{'name': 'pLDDT', 'mode': 'local', 'type': 'pLDDT'}], - [{'name': 'PAE', 'mode': 'local-pairwise', 'type': 'PAE'}])</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [185]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># do parsing of QA part and acc. data</span> -<span class="k">def</span> <span class="nf">_test_qa_acc_data_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">):</span> - <span class="c1"># get file for testing</span> - <span class="n">doc</span> <span class="o">=</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">read</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> - <span class="n">block</span> <span class="o">=</span> <span class="n">doc</span><span class="o">.</span><span class="n">sole_block</span><span class="p">()</span> - <span class="c1"># get QA part (can reuse if already used elsewhere)</span> - <span class="n">qa_global</span><span class="p">,</span> <span class="n">qa_local</span><span class="p">,</span> <span class="n">qa_local_pairwise</span> <span class="o">=</span> <span class="n">_fetch_qa_data</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> - <span class="c1"># parse accompanying data</span> - <span class="n">file_contents</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find_values</span><span class="p">(</span><span class="s2">"_ma_entry_associated_files.file_content"</span><span class="p">)</span> - <span class="n">has_single_zip_file</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">file_contents</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> <span class="ow">and</span> \ - <span class="n">file_contents</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> <span class="o">==</span> <span class="s2">"archive with multiple files"</span> - <span class="k">if</span> <span class="n">has_single_zip_file</span><span class="p">:</span> - <span class="c1"># override with data from other block</span> - <span class="n">file_contents</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find_values</span><span class="p">(</span><span class="s2">"_ma_associated_archive_file_details.file_content"</span><span class="p">)</span> - <span class="n">has_loc_pw_in_acc</span> <span class="o">=</span> <span class="nb">any</span><span class="p">(</span><span class="kc">True</span> <span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">file_contents</span> \ - <span class="k">if</span> <span class="n">gemmi</span><span class="o">.</span><span class="n">cif</span><span class="o">.</span><span class="n">as_string</span><span class="p">(</span><span class="n">v</span><span class="p">)</span> <span class="o">==</span> <span class="s2">"local pairwise QA scores"</span><span class="p">)</span> - <span class="c1"># put together text</span> - <span class="n">text</span> <span class="o">=</span> <span class="s2">""</span> - <span class="c1"># text for QA</span> - <span class="n">item</span> <span class="o">=</span> <span class="s2">""</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">qa_global</span><span class="p">)</span> <span class="o">></span> <span class="mi">1</span><span class="p">:</span> - <span class="n">score_strings</span> <span class="o">=</span> <span class="p">[</span><span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">v</span><span class="p">[</span><span class="s1">'name'</span><span class="p">]</span><span class="si">}</span><span class="s2"> of </span><span class="si">{</span><span class="n">v</span><span class="p">[</span><span class="s1">'value'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> <span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">qa_global</span><span class="p">]</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"The model has the following global model confidence scores:"</span> \ - <span class="sa">f</span><span class="s2">" </span><span class="si">{</span><span class="s1">', '</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">score_strings</span><span class="p">)</span><span class="si">}</span><span class="s2">."</span> - <span class="k">elif</span> <span class="nb">len</span><span class="p">(</span><span class="n">qa_global</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"The model has a global model confidence score "</span> \ - <span class="sa">f</span><span class="s2">"(</span><span class="si">{</span><span class="n">qa_global</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="s1">'name'</span><span class="p">]</span><span class="si">}</span><span class="s2">) of </span><span class="si">{</span><span class="n">qa_global</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="s1">'value'</span><span class="p">]</span><span class="si">}</span><span class="s2">."</span> - <span class="k">if</span> <span class="n">item</span><span class="p">:</span> - <span class="n">text</span> <span class="o">+=</span> <span class="n">_make_paragraph</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="c1"># lots of options for local QA string</span> - <span class="n">item</span> <span class="o">=</span> <span class="s2">""</span> - <span class="n">qa_local_names</span> <span class="o">=</span> <span class="s2">", "</span><span class="o">.</span><span class="n">join</span><span class="p">([</span><span class="n">v</span><span class="p">[</span><span class="s2">"name"</span><span class="p">]</span> <span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">qa_local</span><span class="p">])</span> - <span class="n">qa_loc_pw_names</span> <span class="o">=</span> <span class="s2">", "</span><span class="o">.</span><span class="n">join</span><span class="p">([</span><span class="n">v</span><span class="p">[</span><span class="s2">"name"</span><span class="p">]</span> <span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">qa_local_pairwise</span><span class="p">])</span> - <span class="k">if</span> <span class="n">qa_local_names</span> <span class="ow">and</span> <span class="n">qa_loc_pw_names</span> <span class="ow">and</span> <span class="n">has_loc_pw_in_acc</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"Local per-residue model confidence scores (</span><span class="si">{</span><span class="n">qa_local_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"are available in the model mmCIF file "</span> \ - <span class="sa">f</span><span class="s2">"and local per-residue-pair scores (</span><span class="si">{</span><span class="n">qa_loc_pw_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"in the accompanying data download."</span> - <span class="k">elif</span> <span class="n">qa_local_names</span> <span class="ow">and</span> <span class="n">qa_loc_pw_names</span> <span class="ow">and</span> <span class="ow">not</span> <span class="n">has_loc_pw_in_acc</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"Local per-residue model confidence scores (</span><span class="si">{</span><span class="n">qa_local_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"and local per-residue-pair scores (</span><span class="si">{</span><span class="n">qa_loc_pw_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"are available in the model mmCIF file."</span> - <span class="k">elif</span> <span class="n">qa_local_names</span> <span class="ow">and</span> <span class="ow">not</span> <span class="n">qa_loc_pw_names</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"Local per-residue model confidence scores (</span><span class="si">{</span><span class="n">qa_local_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"are available in the model mmCIF file."</span> - <span class="k">elif</span> <span class="ow">not</span> <span class="n">qa_local_names</span> <span class="ow">and</span> <span class="n">qa_loc_pw_names</span> <span class="ow">and</span> <span class="n">has_loc_pw_in_acc</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"Local per-residue-pair model confidence scores (</span><span class="si">{</span><span class="n">qa_loc_pw_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"are available in the accompanying data download."</span> - <span class="k">elif</span> <span class="ow">not</span> <span class="n">qa_local_names</span> <span class="ow">and</span> <span class="n">qa_loc_pw_names</span> <span class="ow">and</span> <span class="ow">not</span> <span class="n">has_loc_pw_in_acc</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"Local per-residue-pair model confidence scores (</span><span class="si">{</span><span class="n">qa_loc_pw_names</span><span class="si">}</span><span class="s2">) "</span> \ - <span class="sa">f</span><span class="s2">"are available in the model mmCIF file."</span> - <span class="k">if</span> <span class="n">item</span><span class="p">:</span> - <span class="n">text</span> <span class="o">+=</span> <span class="n">_make_paragraph</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="c1"># list files in accompanying data (if any)</span> - <span class="k">if</span> <span class="n">has_single_zip_file</span><span class="p">:</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_associated_archive_file_details."</span><span class="p">,</span> - <span class="p">[</span><span class="s2">"file_path"</span><span class="p">,</span> <span class="s2">"?file_content"</span><span class="p">,</span> <span class="s2">"?description"</span><span class="p">])</span> - <span class="k">else</span><span class="p">:</span> - <span class="c1"># NOTE: aimed to work legacy-style for Baker-models but should be obsoleted</span> - <span class="c1"># -> can replace below with "table = None" in future</span> - <span class="n">table</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s2">"_ma_entry_associated_files."</span><span class="p">,</span> - <span class="p">[</span><span class="s2">"file_url"</span><span class="p">,</span> <span class="s2">"?file_content"</span><span class="p">,</span> <span class="s2">"?details"</span><span class="p">])</span> - <span class="k">if</span> <span class="n">table</span><span class="p">:</span> - <span class="n">list_top</span> <span class="o">=</span> <span class="s2">"Files in accompanying data:"</span> - <span class="n">list_items</span> <span class="o">=</span> <span class="p">[]</span> - <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">table</span><span class="p">:</span> - <span class="n">item</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">):</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">" (</span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span><span class="si">}</span><span class="s2">)"</span> - <span class="k">if</span> <span class="n">row</span><span class="o">.</span><span class="n">has</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> <span class="ow">and</span> <span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">):</span> - <span class="n">item</span> <span class="o">+=</span> <span class="sa">f</span><span class="s2">": </span><span class="si">{</span><span class="n">row</span><span class="o">.</span><span class="n">str</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span><span class="si">}</span><span class="s2">"</span> - <span class="n">list_items</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">item</span><span class="p">)</span> - <span class="n">text</span> <span class="o">+=</span> <span class="n">_make_paragraph</span><span class="p">(</span><span class="n">_make_list</span><span class="p">(</span><span class="n">list_top</span><span class="p">,</span> <span class="n">list_items</span><span class="p">))</span> - <span class="c1"># conclude with standard pointer to ModelCIF file</span> - <span class="n">model_cif_link</span> <span class="o">=</span> <span class="n">_make_url</span><span class="p">(</span> - <span class="s2">"ModelCIF format"</span><span class="p">,</span> - <span class="s2">"https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/"</span> - <span class="p">)</span> - <span class="n">text</span> <span class="o">+=</span> <span class="n">_make_paragraph</span><span class="p">(</span> - <span class="sa">f</span><span class="s2">"Full details are available in </span><span class="si">{</span><span class="n">model_cif_link</span><span class="si">}</span><span class="s2">"</span> \ - <span class="sa">f</span><span class="s2">"in the model mmCIF file."</span> - <span class="p">)</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"(</span><span class="si">{</span><span class="n">test_file</span><span class="si">}</span><span class="s2">)"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">(</span><span class="n">text</span><span class="p">)</span> - -<span class="k">for</span> <span class="n">test_file</span> <span class="ow">in</span> <span class="n">test_files</span><span class="p">:</span> - <span class="n">_test_qa_acc_data_parsing</span><span class="p">(</span><span class="n">test_file</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>(modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif) -The model has the following global model confidence scores: pLDDT of 88.312, pTM of 0.78. - -Local per-residue model confidence scores (pLDDT) are available in the model mmCIF file and local per-residue-pair scores (PAE) in the accompanying data download. - -Files in accompanying data: -- c103531_g3_i1_unrelaxed_rank_1_model_3_local_pairwise_qa.cif (local pairwise QA scores): Predicted aligned error - -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/AF-P38129-F1-model_v3.cif) -The model has a global model confidence score (pLDDT) of 73.91. - -Local per-residue model confidence scores (pLDDT) are available in the model mmCIF file. - -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/ma-bak-cepc-0001.cif) -The model has a global model confidence score (pLDDT) of 67.43. - -Local per-residue model confidence scores (pLDDT) are available in the model mmCIF file and local per-residue-pair scores (PAE, contact probability) in the accompanying data download. - -Files in accompanying data: -- ma-bak-cepc-0001_local_pairwise_qa.cif (local pairwise QA scores) -- ma-bak-cepc-0001_i95.a3m (multiple sequence alignments) - -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/1crn.cif) -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif) -The model has the following global model confidence scores: pLDDT of 32.232, pTM of 0.24. - -Local per-residue model confidence scores (pLDDT) are available in the model mmCIF file and local per-residue-pair scores (PAE) in the accompanying data download. - -Files in accompanying data: -- A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1_local_pairwise_qa.cif (local pairwise QA scores): Predicted aligned error. - -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/Var3D_I6XD65_1046.cif) -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/Var3D_L7N665_1046.cif) -The model has the following global model confidence scores: pLDDT of 88.204, pTM of 0.884, ipTM of 0.874. - -Local per-residue model confidence scores (pLDDT) are available in the model mmCIF file and local per-residue-pair scores (PAE) in the accompanying data download. - -Files in accompanying data: -- tmp/L7N665_1046_local_pairwise_qa.cif (local pairwise QA scores): Predicted aligned error. - -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/Var3D_P9WIE5_3767.cif) -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -(modelcif_MA_test/ORNL_F0JBU9_9DELT.cif) -The model has a global model confidence score (pLDDT) of 92.31. - -Local per-residue model confidence scores (pLDDT) and local per-residue-pair scores (PAE) are available in the model mmCIF file. - -Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file. - - -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div> -</body> - - - - - - - -</html> diff --git a/projects/CoFFE-sponge-proteins/tests/test.ipynb b/projects/CoFFE-sponge-proteins/tests/test.ipynb deleted file mode 100644 index e63d7dff0c5aea066e3d97160a1c1ca379c8b4aa..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/test.ipynb +++ /dev/null @@ -1,1110 +0,0 @@ -{ - "cells": [ - { - "cell_type": "code", - "execution_count": 63, - "id": "a2436da9", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "PROTEINS ONLY in fasta_file: ['c104827_g1_i1', 'c104894_g1_i2']\n", - "Working on ./PKG Cut...\n", - " translating c103531_g3_i1_unrelaxed_rank_1_model_3...\n", - " preparing data... (0.02s)\n", - " generating ModelCIF objects... (0.00s)\n", - " processing QA scores... (0.20s)\n", - " write to disk... (1.15s)\n", - " ... done with c103531_g3_i1_unrelaxed_rank_1_model_3 (1.37s).\n", - " translating c103545_g3_i2_unrelaxed_rank_1_model_3...\n", - " preparing data... (0.08s)\n", - " generating ModelCIF objects... (0.00s)\n", - " processing QA scores... (5.47s)\n", - " write to disk... (19.48s)\n", - " ... done with c103545_g3_i2_unrelaxed_rank_1_model_3 (25.13s).\n", - "... done with ./PKG Cut.\n" - ] - } - ], - "source": [ - "# fetch all functions from there for testing (__name__ hack to avoid executing main)\n", - "__name__ = \"test\"\n", - "execfile(\"./scripts/translate2modelcif.py\")\n", - "_main()" - ] - }, - { - "cell_type": "code", - "execution_count": 3, - "id": "3c15acf4", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "PROTEINS ONLY in fasta_file: ['c104827_g1_i1', 'c104894_g1_i2']\n" - ] - } - ], - "source": [ - " # HC filepaths\n", - " cnfg_file = \"./PKG/config.json\"\n", - " metadata_file = \"./PKG/model_archive_metadata.csv\"\n", - " fasta_file = \"./PKG/Spongilla_lacustris_translated_proteome_fixed.fasta\"\n", - " model_dir = \"./PKG Cut\"\n", - " # model_dir = \"./PKG-all\"\n", - " out_dir = \"./modelcif\"\n", - " compress = False\n", - " #\n", - "\n", - " # parse/fetch global data\n", - " config_data = _parse_colabfold_config(cnfg_file)\n", - " metadata = _get_metadata(metadata_file)\n", - " seq_dict = _get_sequences(fasta_file, metadata)\n", - " if compress:\n", - " cifext = \"cif.gz\"\n", - " else:\n", - " cifext = \"cif\"\n", - " # fetch a single randomly chosen UniProt entry for tax info\n", - " upkb_data = _fetch_upkb_entry(\"P42690\")\n", - " tax_info = {k: v for k, v in upkb_data.items() \\\n", - " if k in [\"up_organism\", \"up_ncbi_taxid\"]}" - ] - }, - { - "cell_type": "code", - "execution_count": 4, - "id": "91657e38", - "metadata": {}, - "outputs": [], - "source": [ - "fle = \"c103531_g3_i1_unrelaxed_rank_1_model_3.pdb\"" - ] - }, - { - "cell_type": "code", - "execution_count": 5, - "id": "281944d3", - "metadata": {}, - "outputs": [], - "source": [ - " file_prfx, mdl_name = _check_model_extra_files_present(model_dir,\n", - " fle)\n", - " fle = os.path.join(model_dir, fle)\n", - " mdlcf_json = _create_json(config_data)\n", - " mdlcf_json[\"tax_info\"] = tax_info\n", - " # mdl_name = [TITLE]_unrelaxed_rank_X_model_Y.pdb\n", - " mdl_name_parts = mdl_name.split('_')\n", - " assert len(mdl_name_parts) == 8\n", - " assert int(mdl_name_parts[5]) == 1 # rank 1 only\n", - " mdlcf_json[\"mdl_num\"] = int(mdl_name_parts[7])\n", - " mdlcf_json[\"mdl_title\"] = '_'.join(mdl_name_parts[:3])" - ] - }, - { - "cell_type": "code", - "execution_count": 6, - "id": "0c9e86af", - "metadata": {}, - "outputs": [], - "source": [ - " ost_ent = _create_model_json(mdlcf_json, fle, seq_dict, metadata)\n", - "\n", - " # read quality scores from JSON file\n", - " _get_scores(mdlcf_json, file_prfx)" - ] - }, - { - "cell_type": "code", - "execution_count": 7, - "id": "aaa3c7d8", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - " generating ModelCIF objects... (0.00s)\n", - " processing QA scores... (0.34s)\n", - " write to disk... (1.04s)\n" - ] - } - ], - "source": [ - " _store_as_modelcif(mdlcf_json, ost_ent, out_dir, mdl_name, compress)" - ] - }, - { - "cell_type": "code", - "execution_count": 8, - "id": "9f1a7a14", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "dict_keys(['max_pae', 'pae', 'plddt', 'ptm'])\n" - ] - } - ], - "source": [ - "scores = json.load(open(\"./PKG Cut/c103545_g3_i2_unrelaxed_rank_1_model_3_scores.json\"))\n", - "print(scores.keys())" - ] - }, - { - "cell_type": "code", - "execution_count": 9, - "id": "afafbf78", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "WEIRD NAME c100000_g1_i2_unrelaxed_rank_c100000_g1_i2_model_3\n", - "WEIRD NAME c100001_g1_i1_unrelaxed_rank_1_model_c100001_g1_i1\n" - ] - } - ], - "source": [ - "# check files\n", - "pdb_files = open(\"./PKG/files_PDB.txt\").readlines()\n", - "json_files = open(\"./PKG/files_JSON.txt\").readlines()\n", - "assert len(pdb_files) == len(json_files)\n", - "\n", - "mdl_titles = []\n", - "for pdb_file, json_file in zip(sorted(pdb_files), sorted(json_files)):\n", - " splitfile = os.path.split(pdb_file.strip())\n", - " assert len(splitfile) == 2\n", - " if splitfile[1]:\n", - " mdl_name, mdl_ext = os.path.splitext(splitfile[1])\n", - " assert mdl_ext == \".pdb\"\n", - " splitfile_j = os.path.split(json_file.strip())\n", - " assert len(splitfile_j) == 2\n", - " assert splitfile_j[1] == f\"{mdl_name}_scores.json\"\n", - " mdl_name_parts = mdl_name.split('_')\n", - " if len(mdl_name_parts) != 8 or mdl_name_parts[5] != '1':\n", - " print(\"WEIRD NAME\", mdl_name)\n", - " mdl_title = '_'.join(mdl_name_parts[:3])\n", - " mdl_titles.append(mdl_title)\n", - " \n", - "assert len(set(mdl_titles)) == len(mdl_titles)" - ] - }, - { - "cell_type": "code", - "execution_count": 10, - "id": "9146d967", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "PROTEINS ONLY in metadata: ['c104658_g3_i5', 'c104704_g1_i1', 'c104839_g1_i1', 'c104839_g1_i3', 'c104872_g1_i1', 'c104894_g1_i3', 'c104922_g1_i2', 'c104954_g1_i2', 'c104956_g1_i1', 'c104958_g1_i1', 'c104973_g1_i2']\n" - ] - }, - { - "data": { - "text/plain": [ - "(41932, 41943, 11)" - ] - }, - "execution_count": 10, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "# all in metadata?\n", - "only_in_metadata = set(metadata.index) - set(mdl_titles)\n", - "if only_in_metadata:\n", - " print(\"PROTEINS ONLY in metadata:\", sorted(only_in_metadata))\n", - "only_in_seqs = set(mdl_titles) - set(metadata.index)\n", - "assert len(only_in_seqs) == 0\n", - "len(mdl_titles), len(metadata), len(only_in_metadata)" - ] - }, - { - "cell_type": "code", - "execution_count": 11, - "id": "3e6e7c3b", - "metadata": {}, - "outputs": [], - "source": [ - "# check files that were converted (input is std out from run cut to only include \"translating...\")\n", - "log_lines = open(\"./FromWork/docker_out_clean.txt\").readlines()" - ] - }, - { - "cell_type": "code", - "execution_count": 12, - "id": "3e67fab0", - "metadata": {}, - "outputs": [], - "source": [ - "# plenty of assertions in here should also catch any errors...\n", - "idx = 0\n", - "timings = dict()\n", - "while idx < len(log_lines):\n", - " l = log_lines[idx].strip()\n", - " if \"already done...\" in l:\n", - " idx += 1\n", - " continue\n", - " assert l.startswith(\"translating\")\n", - " mdl_title = \"_\".join(l.split()[1].split('_')[:3])\n", - " l = log_lines[idx + 1].strip()\n", - " assert l.startswith(\"preparing data\")\n", - " assert l.endswith(\"s)\")\n", - " t_prep = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 2].strip()\n", - " assert l.startswith(\"generating ModelCIF objects\")\n", - " assert l.endswith(\"s)\")\n", - " t_cif = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 3].strip()\n", - " assert l.startswith(\"processing QA scores\")\n", - " assert l.endswith(\"s)\")\n", - " t_qa = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 4].strip()\n", - " assert l.startswith(\"write to disk\")\n", - " assert l.endswith(\"s)\")\n", - " t_write = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 5].strip()\n", - " assert l.startswith(\"... done with\")\n", - " assert l.endswith(\"s).\")\n", - " t_all = float(l.split()[-1][1:-3])\n", - " timings[mdl_title] = {\n", - " \"seq_len\": len(seq_dict[mdl_title]),\n", - " \"t_prep\": t_prep,\n", - " \"t_cif\": t_cif,\n", - " \"t_qa\": t_qa,\n", - " \"t_write\": t_write,\n", - " \"t_all\": t_all\n", - " }\n", - " idx += 6" - ] - }, - { - "cell_type": "code", - "execution_count": 13, - "id": "fa6b06ac", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "DONE 37738 models\n", - "MISSING 4194 models\n" - ] - } - ], - "source": [ - "print(f\"DONE {len(timings)} models\")\n", - "assert len(set(timings) - set(mdl_titles)) == 0\n", - "missing_ones = set(mdl_titles) - set(timings)\n", - "print(f\"MISSING {len(missing_ones)} models\")" - ] - }, - { - "cell_type": "code", - "execution_count": 14, - "id": "0025c378", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - " 2\n", - "2.106e-05 x - 4.487e-05 x + 0.05244\n", - "Average time per model (s): 2.1000026498489452\n" - ] - }, - { - "data": { - "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAEHCAYAAABBW1qbAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3deVhV5fbA8e8+h9EhcIIYLJxSkEkFh0otDTUzTC2HLDVKmqxuA2rXMutaWnmbbt1fUVp2NcEc0Mq0Mis1S0FQoVKvSclwFQcUEWXavz+QHfOZD3BYn+fpUfYZ3rWl56zzTutVVFVVEUIIIQBdYwcghBCi6ZCkIIQQQiNJQQghhEaSghBCCI0kBSGEEBpJCkIIITROtnrjmJgYPv/8c7y8vEhPTwdg0qRJHDx4EID8/Hw8PT1JS0sjMzOTwMBAevbsCcDAgQN59913DbbRsWNHAgICbHULQgjhkDIzMzl58mSdj9ksKcyYMYNZs2Yxbdo07VpiYqL29yeffBIPDw/t527dupGWlmZSGwEBASQnJ1serBBCtCARERH1PmazpDBkyBAyMzPrfExVVVavXs23335rq+aFEEKYoVHmFLZv3463tzc9evTQrh09epQ+ffowdOhQtm/f3hhhCSFEi2eznkJDVq1axZQpU7SffXx8+PPPP+nQoQMpKSncdtttZGRkcMUVV9R6bXx8PPHx8QDk5eXZLWYhhGgJ7J4USktLWbduHSkpKdo1V1dXXF1dAejXrx/dunXj0KFDdY57xcbGEhsbC9Q9LlZSUkJWVhYXL1600R0IQ9zc3PD398fZ2bmxQxFCmMjuSeGbb76hV69e+Pv7a9fy8vJo3749er2e33//ncOHD9O1a1ez3j8rK4u2bdsSEBCAoijWClsYSVVVTp06RVZWFl26dGnscIQQJrLZnMKUKVMYNGgQBw8exN/fn6VLlwKQkJBQbegI4IcffiA0NJSwsDBuv/123n33Xdq3b29WuxcvXqRDhw6SEBqJoih06NBBempCWFFSajbXLf6WLnO/4LrF35KUmm2ztmzWU1i1alWd1z/66KNa1yZMmMCECROs1rYkhMYl//5CWE9SajZPrztAUUkZANn5RTy97gAAt/Xxs3p7sqNZCCGasFe3HNQSQqWikjJe3XLQJu1JUmhGZsyYwZo1a0x6TVJSEr/88ov28/z58/nmm2+Mfn1cXBy9e/cmLi6Od999l48//hio6PHl5OSYFIsQwnQ5+UUmXbdUoyxJFdZVVlaGXq+v87GkpCTGjBlDUFAQAC+88IJJ7/3ee++Rl5enrQ6r9NFHHxEcHIyvr695QQshjOLr6U52HQnA19PdJu1JT8EGXnzxRXr27MlNN93ElClTWLJkCQA33HCDVpbj5MmTWt2mzMxMBg8eTN++fenbty8//vgjULGSZ9asWQQFBXHLLbdw4sQJrY2AgABeeOEFrr/+ej799FPef/99IiMjCQsLY8KECVy4cIEff/yRjRs3EhcXR3h4OEeOHKnW29izZw/XXnstYWFh9O/fn4KCgmr3ER0dTWFhIQMGDCAxMZEFCxawZMkS1qxZQ3JyMlOnTiU8PJyiItt8YxFCQNzInrg6Vf+odnfWEzeyp03ac+iewvOfZfBLzjmrvmeQ7xU8d2vveh9PSUkhISGB1NRUSktL6du3L/369WvwPb28vPj6669xc3Pj8OHDTJkyheTkZNavX8/Bgwc5cOAAx48fJygoiJiYGO11bm5u7NixA4BTp04xc+ZMAJ555hmWLl3KI488QnR0NGPGjOH222+v1mZxcTGTJk0iMTGRyMhIzp07h7t79W8eGzdupE2bNlpNqgULFgBw++238/bbb7NkyZIGa6gIISx3Yy8v2ro5UVJYTLkKfp7uxI3saZNJZnDwpNAYtm/fzrhx42jVqhVQ8W3bkJKSEmbNmkVaWhp6vZ5Dhw4BFUt1p0yZgl6vx9fXl2HDhlV73aRJk7S/p6en88wzz5Cfn8/58+cZOXJkg20ePHgQHx8fIiMjAercPS6EaFzl5SpPJKaRf6GExPsHERlg3lJ9Uzh0UmjoG70t1bck08nJifLycoBq6/hff/11vL292bdvH+Xl5bi5uRl8L4DWrVtrf58xYwZJSUmEhYXx0Ucf8d133zUYo6qqsnRUiCbuX9/+l62/neCFsb3tkhBA5hSsbsiQIaxfv56ioiIKCgr47LPPtMcCAgK08h5VVxGdPXsWHx8fdDod//nPfygrK9PeKyEhgbKyMnJzc9m2bVu97RYUFODj40NJSQkrV67Urrdt27bWXAFAr169yMnJYc+ePdrrS0tLjb7P+t5XCGEd3/52nDe2HmJ8Xz/uHni13dqVpGBlffv2ZdKkSYSHhzNhwgQGDx6sPfbUU0/xf//3f1x77bXVDrh46KGHWL58OQMHDuTQoUNaD2DcuHH06NGDkJAQHnzwQYYOHVpvu//4xz8YMGAAUVFR9OrVS7s+efJkXn31Vfr06cORI0e06y4uLiQmJvLII48QFhZGVFSUSbuQZ8yYwQMPPCATzULYQObJQh5LSCPwyit4aVyIXXv1iqqqqt1as7KIiIhah+z8+uuvBAYGNlJEtS1YsIA2bdrw1FNPNXYodtXUfg9CNBcXiksZ986PHC+4yGezrqdz+1ZWb6Ouz85K0lMQQogmQlVV5qw9wOETBbw1uY9NEoIhDj3R3BRULuMUQghD4n/4nc/25TB7VE+GXNOpUWKQnoIQQjQB3x/K4+XNv3FLiA8PDu3WaHFIUhBCiEaWebKQRz7ZyzXebXn1jtBGXS4uSUEIIRrR+UulzPw4GZ1O4f1pEbRyadxRfZlTEEKIRlK5Y/n3k4V8HNO/USaWa5KegpXl5+fz73//2+DzMjMz+eSTT4x6XnBwsMHXJycn8+ijj5oWrBDCrmqeoPbQJ3v56pfj/H10INd179jY4QGSFKzO2knB2NdHRETw1ltvmf1+QgjbqjxBLTu/CJWKE9Q2p/+PiKvbEXNdQGOHp2nxScHaZ5/OnTuXI0eOEB4eTlxcHKqqEhcXR3BwMCEhISQmJmrP2759O+Hh4bz++uv1ls9uqJ2qr//uu+8YM2YMULEMdvr06YwYMYKAgADWrVvH7NmzCQkJYdSoUZSUlAAVFV2HDh1Kv379GDlyJLm5uRbduxCifnWdoAYVh+U0pTpkLXpOwRZnny5evJj09HSt3PTatWtJS0tj3759nDx5ksjISIYMGcLixYtZsmQJn3/+OQAXLlyos3x2Q+1UfX3NAnhHjhxh27Zt/PLLLwwaNIi1a9fyyiuvMG7cOL744gtuueUWHnnkETZs2ECnTp1ITExk3rx5LFu2zKz7FkI0rL6T0nLPGl9exh5s1lOIiYnBy8ur2nj4ggUL8PPzIzw8nPDwcDZt2qQ9tmjRIrp3707Pnj3ZsmWLrcKqxh5nn+7YsUMrf+3t7c3QoUO1InRVlZSUMHPmTEJCQrjjjjuqHaFpjptvvhlnZ2dCQkIoKytj1KhRAISEhJCZmcnBgwdJT08nKiqK8PBwFi5cSFZWlkVtCiHqV99JabY6Qc1cNuspzJgxg1mzZjFt2rRq1x9//PFadYB++eUXEhISyMjIICcnh5tuuolDhw7Ve8Sktdjj7FNjS0s1VD7bHJXHZ+p0OpydnbXuqU6no7S0FFVV6d27N7t27bKoHSGEceJG9uTJT/dRVv7XZ4ItT1Azl816CkOGDKF9e+Pqf2/YsIHJkyfj6upKly5d6N69O7t377ZVaBpbZO6aJaWHDBlCYmIiZWVl5OXl8cMPP9C/f/9az6uvfLax7ZiqZ8+e5OXlaUmhpKSEjIwMs99PCNGw85dKKStXaePqhELFCWqLxofY7AQ1c9l9ovntt98mNDSUmJgYzpw5A0B2djadO3fWnuPv7092dt0TvvHx8URERBAREUFeXp5FscSN7Im7c/XeiKWZu0OHDlx33XUEBwcTFxfHuHHjCA0NJSwsjGHDhvHKK69w5ZVXEhoaipOTE2FhYbz++uv1ls+uT83Xm8rFxYU1a9YwZ84cwsLCCA8PNzi5LYQwz64jp1iwMYNhvbzY99wIji6+hZ1zhzW5hAA2Lp2dmZnJmDFjSE9PB+D48eN07NgRRVF49tlnyc3NZdmyZTz88MMMGjSIu+66C4B7772X0aNHM2HChAbf3xqls5NSs3l1y0Fy8ovwtfHZpy2JlM4WosKfpy4Q/c4OOrZxZf1D19LWzbmxQ2qwdLZdVx95e3trf585c6a2hNLf359jx45pj2VlZeHr62uXmG7r4ydJQAhhEwUXS7jv4z2oKnwwLaJJJARD7Dp8VHUd/Pr167WVSdHR0SQkJHDp0iWOHj3K4cOH6d+/vz1DE0IIqyorV3l0VSpH8gr599S+BHRseEi4qbBZT2HKlCl89913nDx5En9/f55//nm+++470tLSUBSFgIAA3nvvPQB69+7NxIkTCQoKwsnJiXfeecfmK4+EEMKWXvziV7YdzOPFccFNpoSFMeQ4TmET8nsQLdnKn/9g3vp0Yq7rwvxbgxo7nFrkOE4hhLCTHYdPMn9DxUqjebc0vy9GkhSEEMJK/nviPA+uTKF7pza8OTkcva7p1DQyliSFJuC+++7Tylq89NJLJr/+jTfe4MKFC9rPo0ePJj8/32rxCSEMO1NYzL3L9+DqpOOD6c1jpVFdJCk0srKyMj744AOCgirGHa2RFDZt2oSnp6fVYhRCNKy4tJwHVqSQe/Yi790d0SQOyzGXJIX9q+H1YFjgWfHn/tUWvd0rr7yinWvw+OOPM2zYMAC2bt2qbc5r06YN8+fPZ8CAAezatYsbbriB5ORk5s6dS1FREeHh4UydOhWAFStW0L9/f8LDw7n//vtrlb946623yMnJ4cYbb+TGG28EICAggJMnT5KZmUmvXr247777CA4OZurUqXzzzTdcd9119OjRQyslUlhYSExMDJGRkfTp04cNGzZY9G8gREuiqip/X3+An4+e5pUJofS7ul1jh2SRlp0U9q+Gzx6Fs8cAteLPzx61KDEMGTKE7du3AxWnoZ0/f56SkhJ27NjB4MGDgYoP4eDgYH7++Weuv/567bWLFy/G3d2dtLQ0Vq5cya+//kpiYiI7d+4kLS0NvV7PypUrq7X36KOP4uvry7Zt29i2bVuteP773//y2GOPsX//fn777Tc++eQTduzYwZIlS7ReyYsvvsiwYcPYs2cP27ZtIy4ujsLCQrP/DYRoSd7+9r+sScnibzf1cIiNsC36PAW2vgAlNSqilhRVXA+daNZb9uvXj5SUFAoKCnB1daVv374kJyezfft2rQeh1+sNlvCAit5FSkoKkZGRABQVFeHl5WVSPF26dCEkJASo2A8yfPhwFEXRSmgDfPXVV2zcuJElS5YAcPHiRf78809ZUipEPSrL42RfrqgccXU7Hhveo5Gjso6WnRTO1nN+QH3XjeDs7ExAQAAffvgh1157LaGhoWzbto0jR45oH7Jubm5Gbc5TVZXp06ezaNEis+OpLKENFWWzq5bULi0t1dpZu3YtPXs2rRK+QjRFNQ/nAkjPPsuGtByH6Cm07OEjD3/TrhtpyJAhLFmyhCFDhjB48GDeffddwsPDjTpyz9nZWTsuc/jw4axZs4YTJ04AcPr0af74449ar7G0jPbIkSP517/+pZ39kJqaavZ7CeHIklKzeXL1vlqHc10sLbfq4VyNqWUnheHzwbnG2QnO7hXXLTB48GByc3MZNGgQ3t7euLm5afMJhsTGxhIaGsrUqVMJCgpi4cKFjBgxgtDQUKKiouo8Rzk2Npabb75Zm2g21bPPPktJSQmhoaEEBwfz7LPPmvU+Qjiyyh5CWT1FIKx5OFdjkjIX+1dXzCGczaroIQyfb/Z8gviLlLkQjua6xd9qcwh18fN0Z+fcYbZp3MqfU02mdHaTFDpRkoAQwqCGEoJNj9WsXCVZuSimcpUk2OSzq2UPHwkhhJHauNb9HVqvKLY9VrOhVZI24JBJoRmPiDkE+fcXjuaJxDTOXyqtdd3dWc8/J4bZdtWRDVZJNsThkoKbmxunTp2SD6ZGoqoqp06dws3NrbFDEcIqXvgsg3Wptc+M93R3tm0PoZKNVknWx+HmFPz9/cnKyiIvL6+xQ2mx3Nzc8Pe3zf+wQthTyh9nWLYzs87HWrs62WdfwvD51ecUwCqrJOvjcEnB2dmZLl26NHYYQohm7ve889y3fE+9j9ttCWrlZLKdVkk6XFIQQghLnTx/iRkf7kFRFLzbunK84FKt5/h6utfxShux4ypJh5tTEEIISxReKuXej/ZwouAiS6dH8PToQNydq5elsekS1EYmPQUhhLispKycB1fuJT3nHO/d1Y8+V7Wjz1UVpbBf3XKQnPwifD3diRvZ0yHqHNXFZkkhJiaGzz//HC8vL9LT0wGIi4vjs88+w8XFhW7duvHhhx/i6elJZmYmgYGBWkG2gQMH8u6779oqNCGEqKW8XGXOmv38cCiPlyeEcFOQt/bYbX38HDYJ1GSz4aMZM2awefPmateioqJIT09n//79XHPNNdWqf3br1o20tDTS0tIkIQgh7O7lzb+xLjWbJ6OuYVLkVY0dTqOxWU9hyJAhWr3+SiNGjND+PnDgQNasWWOr5oUQwqCk1GwWbMwgv6iiMrGrkw7/dnacQG6CGm2iedmyZdx8883az0ePHqVPnz4MHTpUO7msLvHx8URERBARESF7EYQQZktKzSbu031aQgC4VFrO7LX7Sapjs1pL0ShJ4cUXX8TJyUk7h9jHx4c///yT1NRUXnvtNe68807OnTtX52tjY2NJTk4mOTmZTp062TNsIYQDeXXLQUrKa1c+KClTHeZsBHPYPSksX76czz//nJUrV2qHzri6utKhQweg4jjLbt26cejQIXuHJoRoQRqqemqzjWn7V8PrwbDAs+JPC86DtxW7LkndvHkzL7/8Mt9//z2tWrXSrufl5dG+fXv0ej2///47hw8fpmvXrvYMTQjRgvz3RAE6BeroKAA22phm5xLY5rJZT2HKlCkMGjSIgwcP4u/vz9KlS5k1axYFBQVERUURHh7OAw88AMAPP/xAaGgoYWFh3H777bz77ru0b9/eVqEJIVqw7Pwi7l66m9auTjjVcUKus16xzcY0O5fANpfDnbwmhBD1OXX+Ene8u4u885dYff8gDv6voNrqo3atnHnu1t622ZOwwBOo6+NWgQX51m+vAXLymhCixUpKzebVLQfJzi/CWV/RNfhk5kACfa4g0OcK+21K8/CvGDKq63oTIrWPhBAOKyk1m6fXHdAmlUvKVBQUss/YqcJpVcPnV5S8rsqGJbDNJUlBCOGwXt1ykKKSsmrXisvKG2fJaehEuPUt8OgMKBV/3vpWk5pkBhk+EkI4qKTU7HqXndrtLISa7FgC21wGewqqqrJixQpeeKFihvzPP/9k9+7dNg9MCCHMlZSazdy1++t93K5nITQzBpPCQw89xK5du1i1ahUAbdu25eGHH7Z5YEIIYaqk1GyuW/wtf0tM42JpeZ3PceSzEKzB4PDRzz//zN69e+nTpw8A7dq1o7i42OaBCSGEKSonlWvOIdS0aHxIiymDbQ6DPQVnZ2fKysq0khR5eXnodDI/LYRoWuqaVK7Jz9NdEoIBBj/dH330UcaNG8eJEyeYN28e119/PX//+9/tEZsQQhhUOWTUUC0jkGEjYxkcPpo6dSr9+vVj69atqKpKUlISgYGB9ohNCCEaZOyQkZ+DH6FpTUYtSfX29mbw4MGUlpZSVFTE3r176du3r61jE0KIBhkaMnJ31sscgokMJoVnn32Wjz76iG7dumnzCoqi8O2339o8OCGEqFRZriInvwjfy9/8G9pvYJPewf7VFQXszh4DRQ9qWcUmtOHzm/z+A2MZTAqrV6/myJEjuLi42CMeIYSopeYwUXZ+EX9LTMNZp9R5UI6fpzs75w6zbhA1S1+rl3soTbQEtrkMTjQHBweTn2/fCn5CCFFVfcNEdSUEm00o11X6Wguk6ZXANpfBnsLTTz9Nnz59CA4OxtXVVbu+ceNGmwYmhBCVDJWl8PN0rzasZJM5hLNZlj3eTBhMCtOnT2fOnDmEhITI/gQhRKPwbOXMmQsl9T5u9aGiutRX+rrq4w7AYFLo2LEjjz76qD1iEUKIWpJSs7VDcOqiV+o4Ps0Whs+vPqdQVRMsgW0ug0mhX79+PP3000RHR1cbPpIlqUIIW6ucYG7ofMgpAzrbPpDKVUclRX+tOmqpq49SU1MB+Omnn7RrsiRVCGEPxpSuWHhbiG2DqGvVkbN7kzwLwRoMJoVt27bZIw4hhKil0c49qKquVUeVq41aUlJYsWIFd911F6+99lqdjz/xxBMNvnFMTAyff/45Xl5epKenA3D69GkmTZpEZmYmAQEBrF69mnbt2gGwaNEili5dil6v56233mLkyJHm3pMQwkF0bONK3vlL9T5ul/mE+lYVOchqo5rqXU5UWFgIQEFBQa3/zp8/b/CNZ8yYwebNm6tdW7x4McOHD+fw4cMMHz6cxYsXA/DLL7+QkJBARkYGmzdv5qGHHqKsrOEuoxDC8VQWtwuY+wVd537RYEIAO80n1LeqyEFWG9VUb0/h/vvvB+Cmm27iuuuuq/bYzp07Db7xkCFDyMzMrHZtw4YNfPfdd0DFUtcbbriBl19+mQ0bNjB58mRcXV3p0qUL3bt3Z/fu3QwaNMjE2xFCNFc1dy1XPSJHAarONesVhSkDOtt+PgHqXnXkQKuNajI4p/DII4+wd+9eg9eMcfz4cXx8fADw8fHhxIkTAGRnZzNw4EDtef7+/mRnZ9f5HvHx8cTHxwMVZzsIIRxDQ5PKKjYsXbH1hYqhIA//ulcRVf5s6HkOot6ksGvXLn788Ufy8vKqzSucO3fO6kM7ah3rzZR6xgpjY2OJjY0FICIiwqpxCCHsr7LQnaHzEKw+6VxzVdHZY7AuFv78CcbUmEsNneiwSaCmeucUiouLOX/+PKWlpdXmE6644grWrFljVmPe3t7k5uYCkJubi5eXF1DRMzh27K+dgllZWfj6+prVhhCi+agcMjKUEAB8Pd2t23idtYxUSF5WkTBaqHp7CkOHDmXo0KHMmDGDq6++2iqNRUdHs3z5cubOncvy5csZO3asdv3OO+/kiSeeICcnh8OHD9O/f3+rtCmEaHqM7R1UskmRu3pXD6kOu9zUGAbnFMxNCFOmTOG7777j5MmT+Pv78/zzzzN37lwmTpzI0qVLueqqq/j0008B6N27NxMnTiQoKAgnJyfeeecd9Hq9We0KIZo2Y09LUxRQVRuemtZQLSMHXW5qDEWta0C/mYiIiCA5ObmxwxBCmMCY85TBRhPLVe1fXTGHQB0fgR6d4fF027XdyBr67JSyp0IIuzJ2wthqE8v7V8PrwbDAs+LPyvmC0IkQEUPFgtcqHHi5qTEMDh/l5eXx/vvvk5mZSWlpqXZ92bJlNg1MCOE4qh6lqVMUyowYoLDKxHJdK4yqnpI25jW4amCLWW5qDINJYezYsQwePJibbrpJxvmFECarOYdgTEKwysTy/tWw/oG/js2sVLNuUQtabmoMg0nhwoULvPzyy/aIRQjhgIypdFqVRRPL2ma0Y9TeB11FC55INsRgUhgzZgybNm1i9OjR9ohHCOFgjJ0bcHfWs2h8iPmrjGoOFdWXEMBh6xZZg8GJ5jfffJMxY8bg5uZG27Ztadu2LVdccYU9YhNCOAAfD7c6r3u6O+Pn6Y5CRe/AooQA9WxGq0MLn0g2xGBPoaCgwB5xCCEc0MWSMtq3cSHn7MVq192d9SyI7m2dvQfVhowMUPQOeziOtRhMCgAbN27khx9+AOCGG25gzJgxNg1KCNH8FVwsIfbjFNKzzzGhrx8//X6anPwifK25Ga3WkFEDHPi0NGsymBTmzp3Lnj17mDp1KlAxnLRjxw7tLAQhhKjp1PlLzPhwD7/mnuPNyeGMDbdmj6DK0lGDQ0aXJ5sd7BxlWzK4ozk0NJS0tDR0uorph7KyMvr06cP+/fvtEmBDZEezEE1H1XpGTjoFRYH37u7HsF7elr+5KT2CSpII6tXQZ6dRw0f5+fm0b98egLNnz1ovMiGEQ6i5F6G0XMVFr+NcUamBVxrJ2EnkSg5epsKWDCaFp59+mj59+nDjjTeiqio//PADixYtskdsQogmqmqvQF/PDuXisnJe3XLQOnMHxkwiV5LVRRYxmBSmTJnCDTfcwJ49e1BVlZdffpkrr7zSHrEJIZogU3YoW61+kaKvvTO5Ko/OUqbCSupNCr/99hu9evXSjt3096/Y7JGTk0NOTg59+/a1T4RCiCbFlB3KVqtf1FBCUPQyVGRF9SaF1157jfj4eJ588slajymKwrfffmvTwIQQTZMpO5StUr+osoBdffrNsKwNUU29SSE+Ph6Abdu22S0YIUTTZOpJaYB5O5RrLjstLjQ8wVzzPGVhEYNlLj799FNtV/PChQsZP348qampNg9MCNE0mHKOciU/T3fzEsJnj16eVFYr/iw6bdp7CIsZTAr/+Mc/aNu2LTt27GDLli1Mnz6dBx54wB6xCSGaAFOrnJo9bGTqslMA9/amtyMaZDApVJ6h8MUXX/Dggw8yduxYiouLbR6YEKJpMKaH4OnubHlhO1PLWeuc4WYp629tBpek+vn5cf/99/PNN98wZ84cLl26RHl5udkNHjx4kEmTJmk///7777zwwgvk5+fz/vvv06lTJwBeeuklKdctRCMxdQ6htasTac+NMK+xynmEhkpdV6pcmiq7lW3GYJmLCxcusHnzZkJCQujRowe5ubkcOHCAESPM/B+girKyMvz8/Pj555/58MMPadOmDU899ZTRr5cyF0JYX819CMZQgKOLbzG+EWMPw6nZyoJ849sQ9TK7zEV5eTn9+/cnPf2vNcA+Pj74+PhYJbCtW7fSrVs3rr76aqu8nxDCdFXPT/Zwd+bcxRLKjfmMrsKk/QimHIZTlRyMYxcNzinodDrCwsL4888/bdJ4QkICU6ZM0X5+++23CQ0NJSYmhjNnztikTSHEX6quLFKB/CLTE4LJE8vmTChL6Qq7MTh8NKopJqMAABydSURBVGzYMPbs2UP//v1p3bq1dn3jxo0WNVxcXIyvry8ZGRl4e3tz/PhxOnbsiKIoPPvss+Tm5rJs2bJar4uPj9f2UOTl5fHHH39YFIcQLdl1i781aalpTUafp1x1/4GxPQMAFCldYQMWVUl97rnnrB4QwJdffknfvn3x9q4oq1v5J8DMmTPrPcgnNjaW2NhYoOLGhBDmM6c2kae7s2mnpplT9hqk0mkjMZgUhg4dyh9//MHhw4e56aabuHDhAmVlxk9A1WfVqlXVho5yc3O1uYr169cTHBxscRtCiLolpWazYGOGSd/ZoaJnsHPuMNNeJMNFzYrBpPD+++8THx/P6dOnOXLkCNnZ2TzwwANs3brV7EYvXLjA119/zXvvvaddmz17NmlpaSiKQkBAQLXHhBDWk5SaTdyn+ygxcfLA7E1ppu4/kOWmjcpgUnjnnXfYvXs3AwYMAKBHjx6cOHHCokZbtWrFqVOnql37z3/+Y9F7CiGM8+qWgyYnBKPnDuri4V/PeQg1lqLKGcpNgsGk4OrqiouLi/ZzaWkpiqLYNCghhPVU3Yhm7I6ASq2cdfzyj5stC2D4/NpzCs7uEHYnHP5KzkFoYoyaU3jppZcoKiri66+/5t///je33nqrPWITQlio5kY0UxKCs17hpfGhxr+gZoXTyg/5yg/6uh4TTY7BJanl5eUsXbqUr776ClVVGTlyJPfdd1+T6C3IjmYhGmbuklOTh4vqWmEkw0FNlkVLUjds2MC0adOYOXOm1QMTQtiWuUtODa4wqlqmor6jMkuKKp4jSaFZMVgldePGjVxzzTXcfffdfPHFF5SWltojLiGEBZJSs7lu8bcmLzl11iksiO7d8JOqnXtAw0dlmrrySDQ6gz2FDz/8kJKSEr788ks++eQTHnroIaKiovjggw/sEZ8QwgjPJB1g1c/HKFNVkyeTKxm1KW3/alj/QMOJoCqpV9TsGEwKAM7Oztx8880oikJRUREbNmyQpCBEE/FM0gFW/PRXfTJTE4JeUfjnxDDDyeDzv1Ucj2ks2YDWLBkcPtq8eTMzZsyge/furFmzhvvuu4/c3Fx7xCaEMMInP5tfsNLdWW9cQtjwsGkJAWSSuZky2FP46KOPmDx5Mu+99x6urq72iEkIYQJTq5rqFYUyVTV+hdHWF6DMxNMWPTpLQmimDCaFhIQEe8QhhLADs2oX1bkbuQEybNSsGUwK69atY86cOZw4cQJVVVFVFUVROHfunD3iE0LUUHWHst6E/UL11i6quunMvV3FtaLT9S81rYuiB7VcNqY5AINJYfbs2Xz22WcEBgbaIx4hRANq7lAua3jvaTWLxofUHiqquems6PRfjxmbEKAiIchRmQ7B4ESzt7e3JAQhmohXtxw06ezkSn6e7nXPHZhT1rousvTUYRjsKURERDBp0iRuu+22ahPN48ePt2lgQoi/VB0yMpWzTqm/5LU1NpfpXWQOwYEYTArnzp2jVatWfPXVV9o1RVEkKQhhJ0mp2TyRmEa5Ga+td0Pa/tXw2d8wb5tbFe7t4eaXZQ7BgRi1o1kIYX9Jqdn8fd1+LpSYng7uGngVC28LqfvB/ath3f1gVpoBUCAiBsa8ZubrRVNmMClkZWXxyCOPsHPnThRF4frrr+fNN9/E31/GEIWwlaTUbB5PTDPre3wPr9bVE0LN1UUX8zErIUjV0xbB4ETzPffcQ3R0NDk5OWRnZ3Prrbdyzz332CM2IVokSxLCXQOv4usnbvjrQrXidWrF6iLVjITg0VkSQgthsKeQl5dXLQnMmDGDN954w6ZBCdFSWZIQ3pgUXnvuwNLVRV2GwvSN5r9eNDsGewodO3ZkxYoVlJWVUVZWxooVK+jQoYM9YhOixZm9Zp/ZPYQ6l5yau7pI0UPEvZIQWiCDPYVly5Yxa9YsHn/8cRRF4dprr2XZsmUWNRoQEEDbtm3R6/U4OTmRnJzM6dOnmTRpEpmZmQQEBLB69WratWtnUTtCNAfmLDetLI+t1S/S74TXp/x13GWPERXnH5uTYtzbw5yjpr9OOASDx3HaQkBAAMnJyXTs2FG7Nnv2bNq3b8/cuXNZvHgxZ86c4eWXX27wfeQ4TtGcJaVmM2/9AQqLTduMlrn4luoX9q+GpIegvMTyoHTOcNu/Ze7AwTX02Wlw+Gj69Onk5/+1ff3MmTPExMRYL7rLNmzYwPTp07U2k5KSrN6GEE1FUmo2cWv2mZwQ7hp4Ve2LX86xTkLw6CwJQRgePtq/fz+enp7az+3atSM1NdWiRhVFYcSIESiKwv33309sbCzHjx/Hx8cHAB8fH06cOGFRG0I0ZQs2ZlBSZlon/bpu7evee1C1XpGpZJmpqMFgUigvL+fMmTPa+P7p06ctPqd5586d+Pr6cuLECaKioujVq5fRr42Pjyc+Ph6oWBklRHOQlJrNgo0Z5BeZ942+2mY0bd/BsYoJYXN5dJaKpqIWg0nhySef5Nprr+X2229HURRWr17NvHnzLGrU19cXAC8vL8aNG8fu3bvx9vYmNzcXHx8fcnNz8fLyqvO1sbGxxMbGAhXjYkI0dTWPyzRFaxc9L46rUt20ZlVTUyqZQkUieDzdrFhEy2BwTmHatGmsXbsWb29vOnXqxLp167j77rvNbrCwsJCCggLt71999RXBwcFER0ezfPlyAJYvX87YsWPNbkOIpiIpNdvshHDXwKvIeGFU9aWmluw7kMNvhBEM9hQAgoKCCAoKskqDx48fZ9y4cQCUlpZy5513MmrUKCIjI5k4cSJLly7lqquu4tNPP7VKe0I0pqfX7Tf5NbV6BwCfPwEpH5neM6ik6GXuQBjFqKRgTV27dmXfvn21rnfo0IGtW7faOxwhrO6ZpAOs/OlPszeh1apb9NnfoKTQ/IBkmakwgd2TghCOypK5g1bOOl4aH1p97mDDLCi7ZFlQUtpamEiSghBWEPXadxw+Yd63+Vq9g8+fgOSllgUUca+UthZmkaQghBksOQmtKpskhC5DJSEIs0lSEMJESanZPL3ugFlnJVf16bVZRP46CxZYsPmsKpfWMOYNGSoSFpGkIISJ5q23LCH08GrN1zedgA3PQFmxdYKS4SJhJZIUhDDCM0kHWPnzn1hSPlKnwGsTL5958HqwZQlB0VUcliO7koWVSVIQwgBLJpEruegVXrk97HKJ68slKswhh94IG5OkIEQ9pr6/i51HLB/vj7syjYcL34ENliUWSQjCHiQpCFFDUmo2f0tMs/h9/Dzd+dg7kW5/JFgelMwZCDuRpCBavMrlpTn5Rbg46bhUasbB9pfpFUgYlEXkkX9VDBH9YWFwMmcg7EySgmjRai4vtSQhvNHmP9xW+iXstUJg0jMQjUSSgmjRnv8sw+L9Bs87LeNup2/QWXbMSAXZayAamSQF0WI9k3SAMxfMO/QmWreDBc4f047zoIBiaTDOreFWSQai8UlSEC2OpauKnndaxjSnbyxPBCDJQDQ5khREi2BJBVOoSAR36beiUyp2r1klIYx/X5KBaHIkKQiHZ0nPIFq3gyXO/4czKopVMgHQxgee+s1KbyaEdUlSEA7Lkt5BtG4Hrzn/Gz1YLxl07AWzfrbSmwlhG5IUhMOxdKjoS5c4einZ1ksGOhe47R0ZKhLNgiQF0axV3Xjm7qzjQonp+wyidTt4yXkZrbmoXbNKQpCNZ6IZkqQgmq2acwXmJITnnZYxTf+N9XoFcvylaOZ09m7w2LFj3HjjjQQGBtK7d2/efPNNABYsWICfnx/h4eGEh4ezadMme4cmmpFnkg5YNHm81zWWo653Wi8hKPqK1URzjkpCEM2a3XsKTk5O/POf/6Rv374UFBTQr18/oqKiAHj88cd56qmn7B2SaEbMnS+oOURktZ6Boodx70oiEA7D7knBx8cHHx8fANq2bUtgYCDZ2dn2DkM0I5aeh2z1ISKQYSLhsBp1TiEzM5PU1FQGDBjAzp07efvtt/n444+JiIjgn//8J+3atav1mvj4eOLj4wHIy8uzd8jCzszpGdyq7GCRiw0mjkEmj4XDU1TVkgMGzXf+/HmGDh3KvHnzGD9+PMePH6djx44oisKzzz5Lbm4uy5Yta/A9IiIiSE5OtlPEwp7MPdPgY+cXGazLsG6vAOSAG+FQGvrsbJSeQklJCRMmTGDq1KmMHz8eAG9vb+3xmTNnMmbMmMYITdhZ1SWlbs4VZxmUG/k1pTPHWeC0nBt1adWSgFUTgiQD0cLYPSmoqsq9995LYGAgTzzxhHY9NzdXm2tYv349wcHB9g5N2FlSajZxn+6j5HIWKDJhSekM3SbmO61AZ4v1c4oO+t0j5xmIFsnuSWHnzp385z//ISQkhPDwcABeeuklVq1aRVpaGoqiEBAQwHvvvWfv0IQdmTI8pFCODpXRup+4W/81kbpDFdetPUQkBeqEsH9SuP7666lrGmP06NH2DkU0gqTUbP6+br/RG830lHGnfiux+s/prDtpm6BkiEgIjexoFjZnzpJSNy4xS7+eu/Rb8dQVWj8oxRmes1GSEaIZk6QgbMrQktJhSgrtlPNsLu9PIe70Uw4yQ7+ZkbpkXHSWHZNZLzn/WIh6SVIQVmdsz6AD+Xyr9sNFLWGMbhf3OG0hRHfUNkFJIhDCKJIUhFUlpWbzRGIaDc0YuFBMMS64U8xsp1Xcof+eTso56wcjiUAIk0lSEBZLSs1m3voDFBbXPdzTV/kNPbBH7YWeMm7Q7WOqfiuDdQe04y2tSiaOhTCbJAVhNmOOuXTjEnvVXviRx9+c1jBZv40rlTPWD0YK0wlhFZIUhEmMqUXUlkIKaI0rxYzU7WGi/nsG6X6xTa/AuTXc+oYkAyGsRJKCaJAxm8zClMM4U06K2gMVHT2UbO7Qf88t+p+4QjGvsmmDZK5ACJuRpCBqMbYy6ZWc4hQe7FN70FXJ4W9Oa4nW7aKL7n/WD0oOvRfCLiQpCKNWDFUKVDL5XfXlEi6Uo2O6fgtj9T8SrBy1ftkJvQuMlQPvhbAnSQot2IAXv+Z4QXGDz/m7/mN+UoPZUR5CMc6cUj2YrN/GKN1u+ut+Q2/teQLZaSxEo5Kk4MCqlqX29XQnoIN7vauFonU7eNFpGTlqB7aW92VreV/2qj14qWwafuRxt/5rRut/po/yX+tPGEshOiGaDEkKDqrmBHF2flGtHcZfusRxNXnsVnuxrTyc0SWLOaZ6AdBbOcoj+vXcpN9LiE2GhtzhWRvMPQghLCJJwUFEvfYdh09ULxwXrdvBbKfV+CknUQEFUFX4Vb2K7eWhLCyZxh61J8W44Eox1+nSeUC/kWH6NHyUhvcfWGTBWdu9txDCIpIUmpn66gpF63bwoctqfJWTnFHb0F45rz12VL2Sn8qD+Lk8kJ3lvTmJJwA9lT+Zpv+awboD9Nf9hrvS8PyC2WSeQIhmQ5JCE1RzLqCgqJhzlypKSETrdpDotBpf15OUouDMX+P7igLlqsJpPPiybAA/lwfyU3kgebQDoBNnuFaXwRD9fq7XpdtmZ3GlNj7w1G+2e38hhE1IUmhCKucBqn7w51zoSEdO4+r614LRyvF9F1TOqq1IK+/O3vIe7FV7kFbejQJaA+DNaa7V/cIA3a8M1P1CF+V/1p8bqOTqAU8b3tsghGjaJCnYWVJqNk99uo/SKqfTP++0jGn6bxgLjHWtuFb54e2vnERVK34+p7qTUR5AhtqF9PIADqhdOKL6AaCjnGuUY4zR/0Rf5TARukME2DIJyK5iIRySJAUrq2vMP91lOq2VEoCKD37n2q+r+uFdqur4o9ybw6o/B1V/DpV3JkMNIFO9UnuOD6forcvkNv1O+iqHCdMdoY1y0Va3JZVHhWghJCkYKSk1mwUbM3i85D2m6b+p93ljL/+Ha/XrdX1jP6u25qh6JX+o3hxVr+RouQ+HVD+OqL4U41LxOsrprOTRW8nkDv339FaOEqzLpKMtzh+oJL0AIVqsJpcUNm/ezGOPPUZZWRn33Xcfc+fOtWv75fM96vwA1z7s9XV/wNekqnCOVmSrHclRO5KjdiBb7UCO2pFjaif+UK/kDG215yuU48speuiyGaI7QA9dFj2VLLor2bZbFVRJlogKIS5rUkmhrKyMhx9+mK+//hp/f38iIyOJjo4mKCjILu1XJoSaH/rlqkIRLpzHnbNqa86qbTintuIsrTmntuK0egV5eJCnenBS9eAkFX9erNFdcKEEH+UUfspJRul200X5HwHK/+ii/I/OygncLg8xWapyT0KdJAEIIRrQpJLC7t276d69O127dgVg8uTJbNiwwepJ4b8nzvPcxnRKy1TKVZWy8sv/lbxIGQqXcKFIdaUIF4pw5dLloZz6KJTTgQI6Kvl0Us7Slf/RUXcWLyUfPyUPX+UUvspJOlBg1RIR6uVP/5oJQAH58BdCmKVJJYXs7Gw6d+6s/ezv78/PP1cvlxwfH098fDwAeXl5Zrd1saQcvU7BSafD1UlBr1PQK2fQUY4bJbjrLuFOMe5cxF0pxo1i2lCEh1KIB4VcoVzAg0I8lEKuoBAnxZgao6ZTq+SQmj0YRUE+/IUQVtWkkoKq1v4WrdT4JIyNjSU2NhaAiIgIs9rp7tWGtQ9eW7v956Jst4SzZlv1dRhqfPNXJkixOCGE/TSppODv78+xY8e0n7OysvD19bVb+5Uf1OYkhno/5Gu6/KEv3/KFEE1Rk0oKkZGRHD58mKNHj+Ln50dCQgKffPKJ3drXvXCW8vkeJr9Om5yWD3khRDPXpJKCk5MTb7/9NiNHjqSsrIyYmBh69+5t1xh0L8gHuxCi5WpSSQFg9OjRjB49urHDEEKIFknX2AEIIYRoOiQpCCGE0EhSEEIIoZGkIIQQQiNJQQghhEaSghBCCI0kBSGEEBpFravgUDPRsWNHAgICzHptXl4enTp1sm5ATYAj3pcj3hM45n054j2B491XZmYmJ0+erPOxZp0ULBEREUFycnJjh2F1jnhfjnhP4Jj35Yj3BI57X3WR4SMhhBAaSQpCCCE0+gULFixo7CAaS79+/Ro7BJtwxPtyxHsCx7wvR7wncNz7qqnFzikIIYSoTYaPhBBCaFpkUti8eTM9e/ake/fuLF68uLHDMUlAQAAhISGEh4drx5GePn2aqKgoevToQVRUFGfOnNGev2jRIrp3707Pnj3ZsmVLY4VdS0xMDF5eXgQHB2vXzLmPlJQUQkJC6N69O48++midR7raS133tGDBAvz8/AgPDyc8PJxNmzZpjzWHezp27Bg33ngjgYGB9O7dmzfffBNo/r+r+u6ruf++rEJtYUpLS9WuXbuqR44cUS9duqSGhoaqGRkZjR2W0a6++mo1Ly+v2rW4uDh10aJFqqqq6qJFi9TZs2erqqqqGRkZamhoqHrx4kX1999/V7t27aqWlpbaPea6fP/992pKSorau3dv7Zo59xEZGan++OOPanl5uTpq1Ch106ZN9r+Zy+q6p+eee0599dVXaz23udxTTk6OmpKSoqqqqp47d07t0aOHmpGR0ex/V/XdV3P/fVlDi+sp7N69m+7du9O1a1dcXFyYPHkyGzZsaOywLLJhwwamT58OwPTp00lKStKuT548GVdXV7p06UL37t3ZvXt3Y4aqGTJkCO3bt692zdT7yM3N5dy5cwwaNAhFUZg2bZr2msZQ1z3Vp7nck4+PD3379gWgbdu2BAYGkp2d3ex/V/XdV32ay31ZQ4tLCtnZ2XTu3Fn72d/fv8H/GZoaRVEYMWIE/fr1Iz4+HoDjx4/j4+MDVPzPfuLECaD53aup95GdnY2/v3+t603N22+/TWhoKDExMdowS3O8p8zMTFJTUxkwYIBD/a6q3hc4zu/LXC0uKah1jPcpitIIkZhn586d7N27ly+//JJ33nmHH374od7nNvd7rVTffTSH+3vwwQc5cuQIaWlp+Pj48OSTTwLN757Onz/PhAkTeOONN7jiiivqfV5zvy9H+X1ZosUlBX9/f44dO6b9nJWVha+vbyNGZJrKWL28vBg3bhy7d+/G29ub3NxcAHJzc/Hy8gKa372aeh/+/v5kZWXVut6UeHt7o9fr0el0zJw5Uxu+a073VFJSwoQJE5g6dSrjx48HHON3Vd99Nfffl6VaXFKIjIzk8OHDHD16lOLiYhISEoiOjm7ssIxSWFhIQUGB9vevvvqK4OBgoqOjWb58OQDLly9n7NixAERHR5OQkMClS5c4evQohw8fpn///o0WvyGm3oePjw9t27blp59+QlVVPv74Y+01TUXlByfA+vXrtZVJzeWeVFXl3nvvJTAwkCeeeEK73tx/V/XdV3P/fVmF/ee2G98XX3yh9ujRQ+3atau6cOHCxg7HaEeOHFFDQ0PV0NBQNSgoSIv95MmT6rBhw9Tu3burw4YNU0+dOqW9ZuHChWrXrl3Va665pkmtipg8ebJ65ZVXqk5OTqqfn5/6wQcfmHUfe/bsUXv37q127dpVffjhh9Xy8vLGuB1VVeu+p7vuuksNDg5WQ0JC1FtvvVXNycnRnt8c7mn79u0qoIaEhKhhYWFqWFiY+sUXXzT731V999Xcf1/WIDuahRBCaFrc8JEQQoj6SVIQQgihkaQghBBCI0lBCCGERpKCEEIIjSQFIawoICCg3gPRzZWZmcknn3yi/fzRRx8xa9Ysq7YhRCVJCkI0cTWTghC2JElBtBiFhYXccssthIWFERwcTGJiIlBRD3/o0KH069ePkSNHartaU1JSCAsLY9CgQcTFxVU7J8EYK1asoH///oSHh3P//fdTVlYGQJs2bZg3bx5hYWEMHDiQ48ePA3DkyBEGDhxIZGQk8+fPp02bNgDMnTuX7du3Ex4ezuuvvw5ATk4Oo0aNokePHsyePdsq/z5CgCQF0YJs3rwZX19f9u3bR3p6OqNGjaKkpIRHHnmENWvWkJKSQkxMDPPmzQPgnnvu4a233mLXrl0mt/Xrr7+SmJjIzp07SUtLQ6/Xs3LlSqAiOQ0cOJB9+/YxZMgQ3n//fQAee+wxHnvsMfbs2VOtfs7ixYsZPHgwaWlpPP744wCkpaWRmJjIgQMHSExMrFaXRwhLSFIQLUZISAjffPMNc+bMYfv27Xh4eHDw4EHS09OJiooiPDychQsXkpWVxdmzZ8nPz2fo0KEA3H333Sa1tXXrVlJSUoiMjCQ8PJytW7fy+++/A+Di4sKYMWOAisPgMzMzAdi1axd33HEHAHfeeWeD7z98+HA8PDxwc3MjKCiIP/74w6T4hKiPU2MHIIS9XHPNNaSkpLBp0yaefvppRowYwbhx4+jdu3et3kB+fr5FJZBVVWX69OksWrSo1mPOzs7ae+v1ekpLS01+f1dXV+3v5r6HEHWRnoJoMXJycmjVqhV33XUXTz31FHv37qVnz57k5eVpSaGkpISMjAw8PT3x8PBgx44dANrQj7GGDx/OmjVrtMNnTp8+bfDb/MCBA1m7di0ACQkJ2vW2bdtq1XGFsDVJCqLFOHDggDbx++KLL/LMM8/g4uLCmjVrmDNnDmFhYYSHh/Pjjz8C8OGHH/Lwww8zaNAg3N3dtffJyclh9OjRDbYVFBTEwoULGTFiBKGhoURFRVUry1yXN954g9dee43+/fuTm5uLh4cHAKGhoTg5OREWFqZNNAthK1IlVQgjZGZmMmbMGNLT023WxoULF3B3d0dRFBISEli1alWzPz9cND8ypyBEE5GSksKsWbNQVRVPT0+WLVvW2CGJFkh6CkIIITQypyCEEEIjSUEIIYRGkoIQQgiNJAUhhBAaSQpCCCE0khSEEEJo/h+i4Wt13e9CSwAAAABJRU5ErkJggg==\n", - "text/plain": [ - "<Figure size 432x288 with 1 Axes>" - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], - "source": [ - "%matplotlib inline\n", - "import matplotlib.pyplot as plt\n", - "x = []\n", - "y = []\n", - "y2 = []\n", - "for v in timings.values():\n", - " x.append(v[\"seq_len\"])\n", - " y.append(v[\"t_all\"])\n", - " y2.append(v[\"t_write\"])\n", - "# fit quadratic function (for fun)\n", - "model = np.poly1d(np.polyfit(x, y, 2))\n", - "print(model)\n", - "# plot it\n", - "plt.scatter(x, y)\n", - "plt.scatter(x, y2)\n", - "polyline = np.linspace(1, max(x), 50)\n", - "plt.plot(polyline, model(polyline))\n", - "plt.xlabel(\"seq. length\")\n", - "plt.ylabel(\"conversion time\")\n", - "plt.legend([\"quadratic fit\", \"total time\", \"write time\"])\n", - "plt.gcf().patch.set_facecolor('white')\n", - "print(\"Average time per model (s):\", sum(y) / len(y))" - ] - }, - { - "cell_type": "code", - "execution_count": 16, - "id": "d5be3755", - "metadata": {}, - "outputs": [], - "source": [ - "# check results (self-contained version)\n", - "from ost import io\n", - "fasta_file = \"./PKG/Spongilla_lacustris_translated_proteome_fixed.fasta\"\n", - "out_dir = \"./modelcif\"\n", - "cifext = \"cif\"\n", - "seqs = io.LoadSequenceList(fasta_file)\n", - "seq_dict = {'_'.join(s.name.split('_')[:3]): s.string for s in seqs}\n", - "for out_fle in sorted(os.listdir(out_dir)):\n", - " if not out_fle.endswith(cifext) or \"_local_pairwise_qa\" in out_fle:\n", - " continue\n", - " mdl_name = os.path.splitext(out_fle)[0]\n", - " mdl_title = '_'.join(mdl_name.split('_')[:3])\n", - " # check if result can be read and has expected seq.\n", - " ent = io.LoadMMCIF(os.path.join(out_dir, out_fle))\n", - " assert ent.chain_count == 1, f\"Bad chain count {mdl_title}\"\n", - " ent_seq = \"\".join(res.one_letter_code for res in ent.residues)\n", - " assert ent_seq == seq_dict[mdl_title], f\"Bad seq. {mdl_title}\"\n", - " # NOTE: can use only this bit in main loop with os.path.join(out_dir, f\"{mdl_name}.{cifext}\")" - ] - }, - { - "cell_type": "code", - "execution_count": 17, - "id": "27544e00", - "metadata": {}, - "outputs": [ - { - "ename": "AssertionError", - "evalue": "c103545_g3_i2", - "output_type": "error", - "traceback": [ - "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m", - "\u001b[0;31mAssertionError\u001b[0m Traceback (most recent call last)", - "Input \u001b[0;32mIn [17]\u001b[0m, in \u001b[0;36m<cell line: 2>\u001b[0;34m()\u001b[0m\n\u001b[1;32m 4\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m line \u001b[38;5;129;01min\u001b[39;00m desc\u001b[38;5;241m.\u001b[39msplitlines():\n\u001b[1;32m 5\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m,\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;129;01min\u001b[39;00m line:\n\u001b[0;32m----> 6\u001b[0m \u001b[38;5;28;01massert\u001b[39;00m line\u001b[38;5;241m.\u001b[39mstartswith(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCoFFE orthogroups\u001b[39m\u001b[38;5;124m\"\u001b[39m) \u001b[38;5;129;01mor\u001b[39;00m line\u001b[38;5;241m.\u001b[39mstartswith(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCoFFE GO terms\u001b[39m\u001b[38;5;124m\"\u001b[39m), title\n", - "\u001b[0;31mAssertionError\u001b[0m: c103545_g3_i2" - ] - } - ], - "source": [ - "# check ,-separation in metadata\n", - "for title, row in metadata.iterrows():\n", - " desc = row.description\n", - " for line in desc.splitlines():\n", - " if \",\" in line:\n", - " assert line.startswith(\"CoFFE orthogroups\") or line.startswith(\"CoFFE GO terms\"), title" - ] - }, - { - "cell_type": "code", - "execution_count": 18, - "id": "9bb42dd2", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "'CoFFE UniProt function: FUNCTION: Involved in hearing and vision as member of the USH2 complex. Necessary for elongation and maintenance of inner and outer hair cell stereocilia in the organ of Corti in the inner ear. Involved in the maintenance of the hair bundle ankle region, which connects stereocilia in cochlear hair cells of the inner ear. In retina photoreceptors, required for the maintenance of periciliary membrane complex that seems to play a role in regulating intracellular protein transport. {ECO:0000250|UniProtKB:Q80VW5}.'" - ] - }, - "execution_count": 18, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "line" - ] - }, - { - "cell_type": "code", - "execution_count": 19, - "id": "963be9a1", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "c2495_g1_i1 CoFFE UniProt function: FUNCTION: Protein O-mannose kinase that specifically mediates phosphorylation at the 6-position of an O-mannose of the trisaccharide (N-acetylgalactosamine (GalNAc)-beta-1,3-N-acetylglucosamine (GlcNAc)-beta-1,4-mannose) to generate phosphorylated O-mannosyl trisaccharide (N-acetylgalactosamine-beta-1,3-N-acetylglucosamine-beta-1,4-(phosphate-6-)mannose). Phosphorylated O-mannosyl trisaccharide is a carbohydrate structure present in alpha-dystroglycan (DAG1), which is required for binding laminin G-like domain-containing extracellular proteins with high affinity. Only shows kinase activity when the GalNAc-beta-3-GlcNAc-beta-terminus is linked to the 4-position of O-mannose, suggesting that this disaccharide serves as the substrate recognition motif (By similarity). {ECO:0000250}.\n" - ] - } - ], - "source": [ - "# ok so we cannot blindly assume that commas are bad...\n", - "\n", - "# check longest tokens in metadata\n", - "new_desc = dict()\n", - "for title, row in metadata.iterrows():\n", - " desc = row.description\n", - " new_lines = []\n", - " for line in desc.splitlines():\n", - " is_loi = line.startswith(\"CoFFE orthogroups\") \\\n", - " or line.startswith(\"CoFFE GO terms\") \\\n", - " or line.startswith(\"Emapper orthogroups\") \\\n", - " or line.startswith(\"Emapper GO terms\") \\\n", - " or line.startswith(\"CoFFE PFAM domains\") \\\n", - " or line.startswith(\"Emapper PFAM domains\")\n", - " if \",\" in line and is_loi:\n", - " new_line = line.replace(\",\", \", \")\n", - " else:\n", - " new_line = line\n", - " token_lengths = [len(token) for token in new_line.split()]\n", - " if token_lengths and max(token_lengths) > 80:\n", - " print(title, new_line)\n", - " new_lines.append(new_line)\n", - " new_desc[title] = \"\\n\".join(new_lines)" - ] - }, - { - "cell_type": "code", - "execution_count": 20, - "id": "a62a49f5", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[[19286, 'c90048_g1_i1'],\n", - " [20561, 'c104513_g1_i1'],\n", - " [22685, 'c91485_g1_i1'],\n", - " [27674, 'c95514_g1_i1'],\n", - " [27687, 'c95514_g1_i3']]" - ] - }, - "execution_count": 20, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "# c2495_g1_i1 tested in MA and ok...let's check largest ones\n", - "sorted([len(desc), title] for title, desc in new_desc.items())[-5:]\n", - "# looks ok too..." - ] - }, - { - "cell_type": "code", - "execution_count": 35, - "id": "f9b0899e", - "metadata": { - "scrolled": false - }, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Model generated using ColabFold v1.2.0 with AlphaFold producing 5 models with 3 recycles each without model relaxation without templates ranked by pLDDT starting from an MSA from MMseqs2 (UniRef+Environmental)\n", - "Emapper preferred name [EggNOG]: -\n", - "Emapper description [EggNOG]: -\n", - "CoFFE preferred name [E\n", - "--------------------------------------------------------------------------------\n", - "Model generated using ColabFold v1.2.0 with AlphaFold producing 5 models with 3 recycles each without model relaxation without templates ranked by pLDDT starting from an MSA from MMseqs2 (UniRef+Environmental)\n", - "\n", - "Emapper preferred name [EggNOG]: -\n", - "Emapper description [EggNOG]: -\n", - "CoFFE preferred name [\n" - ] - } - ], - "source": [ - "# checking multiline details and markdown\n", - "from ost import io\n", - "import modelcif.reader\n", - "file_path = \"./modelcif/c103531_g3_i1_unrelaxed_rank_1_model_3.cif\"\n", - "ent, info = io.LoadMMCIF(file_path, info=True)\n", - "with open(file_path) as fh:\n", - " s, = modelcif.reader.read(fh)\n", - "print(info.GetStructDetails().model_details[:300])\n", - "print('-' * 80)\n", - "print(s.model_details[:300])\n", - "# NOTE: there may be a bug in OST's multiline parsing in terms of keeping line breaks intact...\n", - "# ...and lines are stripped so that we lose the trailing 2 spaces..." - ] - }, - { - "cell_type": "code", - "execution_count": 36, - "id": "84326bee", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "isoform ID: c103531_g3_i1\n", - "\n", - "And **fat** and *emphasized* markdown with lists:\n", - "\n", - "- item1\n", - "- item2\n", - "\n", - "and [links](https://github.com).\n", - "\n", - "Note that markdown ignores linebreaks\n", - "unless two spaces at end \n", - "<- as in line above\n", - "--------------------------------------------------------------------------------\n", - "<p>isoform ID: c103531_g3_i1</p>\n", - "<p>And <strong>fat</strong> and <em>emphasized</em> markdown with lists:</p>\n", - "<ul>\n", - "<li>item1</li>\n", - "<li>item2</li>\n", - "</ul>\n", - "<p>and <a href=\"https://github.com\">links</a>.</p>\n", - "<p>Note that markdown ignores linebreaks\n", - "unless two spaces at end<br />\n", - "<- as in line above</p>\n" - ] - } - ], - "source": [ - "import markdown\n", - "markdown_test = \"\"\"isoform ID: c103531_g3_i1\n", - "\n", - "And **fat** and *emphasized* markdown with lists:\n", - "\n", - "- item1\n", - "- item2\n", - "\n", - "and [links](https://github.com).\n", - "\n", - "Note that markdown ignores linebreaks\n", - "unless two spaces at end \n", - "<- as in line above\"\"\"\n", - "print(markdown_test)\n", - "print('-' * 80)\n", - "print(markdown.markdown(markdown_test))" - ] - }, - { - "cell_type": "code", - "execution_count": 2, - "id": "c4be6188", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "- none : 3.84s vs 25.59s, 27824253\n", - "- gzip : 2.70s vs 25.59s, 5417406\n", - "- gz : 0.87s vs 25.59s, 5389143\n", - "- gz(9): 2.74s vs 25.59s, 5417802\n", - "- bz : 1.61s vs 25.59s, 3802066\n", - "- bz(9): 1.56s vs 25.59s, 3802066\n", - "- lzma : 22.27s vs 25.59s, 2083062\n" - ] - } - ], - "source": [ - "# test zip file speed and size\n", - "from timeit import default_timer as timer\n", - "import os, zipfile, gzip, shutil\n", - "\n", - "def zip_test(compression, level=None):\n", - " zip_file = \"test.zip\"\n", - " files = [\"modelcif/c103531_g3_i1_unrelaxed_rank_1_model_3_local_pairwise_qa.cif\"]\n", - " files.append(\"modelcif/c103545_g3_i2_unrelaxed_rank_1_model_3_local_pairwise_qa.cif\")\n", - " pstart = timer()\n", - " if compression == \"gzip\":\n", - " file_size = 0\n", - " for file in files:\n", - " with open(file, 'rb') as f_in:\n", - " with gzip.open(zip_file, 'wb') as f_out:\n", - " shutil.copyfileobj(f_in, f_out)\n", - " file_size += os.path.getsize(zip_file)\n", - " else:\n", - " with zipfile.ZipFile(zip_file, 'w', compression, compresslevel=level) as myzip:\n", - " for file in files:\n", - " myzip.write(file)\n", - " file_size = os.path.getsize(zip_file)\n", - " # for comparison full translation time for the files (i.e. from running _main)\n", - " if len(files) == 1:\n", - " ref_time = \"1.38s\"\n", - " else:\n", - " ref_time = f\"{1.38+24.21}s\"\n", - " if compression == zipfile.ZIP_STORED:\n", - " label = \"none \"\n", - " elif compression == zipfile.ZIP_DEFLATED:\n", - " if level:\n", - " label = f\"gz({level})\"\n", - " else:\n", - " label = \"gz \"\n", - " elif compression == zipfile.ZIP_BZIP2:\n", - " if level:\n", - " label = f\"bz({level})\"\n", - " else:\n", - " label = \"bz \"\n", - " elif compression == zipfile.ZIP_LZMA:\n", - " label = \"lzma \"\n", - " else:\n", - " label = \"gzip \"\n", - " print(f\"- {label}: {timer()-pstart:.2f}s vs {ref_time}, {file_size}\")\n", - " os.remove(zip_file)\n", - "\n", - "zip_test(zipfile.ZIP_STORED)\n", - "zip_test(\"gzip\")\n", - "zip_test(zipfile.ZIP_DEFLATED)\n", - "zip_test(zipfile.ZIP_DEFLATED, 9)\n", - "zip_test(zipfile.ZIP_BZIP2)\n", - "zip_test(zipfile.ZIP_BZIP2, 9)\n", - "zip_test(zipfile.ZIP_LZMA)" - ] - }, - { - "cell_type": "markdown", - "id": "a9dc14c2", - "metadata": {}, - "source": [ - "FAZIT: lzma is too slow but bzip2 has good compromise of size vs speed" - ] - }, - { - "cell_type": "code", - "execution_count": 1, - "id": "2f604e78", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "137179 vs 184836 in 0.25s\n" - ] - } - ], - "source": [ - "# check out pdbx\n", - "import os\n", - "from timeit import default_timer as timer\n", - "from pdbx.reader.PdbxReader import PdbxReader\n", - "from pdbx.writer.PdbxWriter import PdbxWriter\n", - "test_file = \"modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif\"\n", - "# test_file = \"modelcif_MA_test/AF-P38129-F1-model_v3.cif\"\n", - "# test_file = \"modelcif_MA_test/ma-bak-cepc-0001.cif\"\n", - "# test_file = \"modelcif_MA_test/1crn.cif\"\n", - "test_file_out = \"modelcif_MA_test/test.cif\"\n", - "pstart = timer()\n", - "pdbx_data = []\n", - "with open(test_file, 'r') as f_in:\n", - " pdbxR = PdbxReader(f_in)\n", - " pdbxR.read(pdbx_data)\n", - "with open(test_file_out, 'w') as f_out:\n", - " pdbxW = PdbxWriter(f_out)\n", - " pdbxW.write(pdbx_data)\n", - "print(f\"{os.path.getsize(test_file)} vs {os.path.getsize(test_file_out)}\" \\\n", - " f\" in {timer()-pstart:.2f}s\")" - ] - }, - { - "cell_type": "markdown", - "id": "210ec7ee", - "metadata": {}, - "source": [ - "FAZIT: adds lots of spaces but doesn't remove anything \n", - "ISSUE: quotes around \"stop_...\" removed..." - ] - }, - { - "cell_type": "code", - "execution_count": 2, - "id": "ddad4236", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "137179 vs 137099 in 0.03s\n" - ] - } - ], - "source": [ - "# check out gemmi\n", - "import gemmi\n", - "pstart = timer()\n", - "doc = gemmi.cif.read(test_file)\n", - "doc.write_file(test_file_out)\n", - "print(f\"{os.path.getsize(test_file)} vs {os.path.getsize(test_file_out)}\" \\\n", - " f\" in {timer()-pstart:.2f}s\")" - ] - }, - { - "cell_type": "markdown", - "id": "9aa4244e", - "metadata": {}, - "source": [ - "FAZIT: much faster than pdbx, space handling similar to python-modelcif and also not removing anything and handling \"stop_...\" properly\n", - "\n", - "Also note that neither of the two messes up the order of tables and so files are easily comparable!\n", - "\n", - "**FAZIT**: gemmi is good!" - ] - }, - { - "cell_type": "code", - "execution_count": 14, - "id": "dde612e7", - "metadata": {}, - "outputs": [], - "source": [ - "# quick test changing data_ block name\n", - "doc = gemmi.cif.read(test_file)\n", - "doc.sole_block().name = 'test'\n", - "doc.write_file(test_file_out)" - ] - }, - { - "cell_type": "code", - "execution_count": 3, - "id": "cf4898d9", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "ma_qa_metric\n", - "['id', 'name', 'description', 'type', 'mode', 'type_other_details', 'software_group_id']\n", - "[['1', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'global', '.', '.'], ['2', 'pTM', 'Predicted accuracy according to the TM-score score in [0,1]', 'pTM', 'global', '.', '.'], ['3', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'local', '.', '.'], ['4', 'PAE', 'Predicted aligned error (in Angstroms)', 'PAE', 'local-pairwise', '.', '.']]\n" - ] - } - ], - "source": [ - "# parsing pdbx\n", - "# see https://mmcif.wwpdb.org/docs/sw-examples/python/html/\n", - "# -> all very low level\n", - "block = pdbx_data[0]\n", - "if block.exists(\"ma_qa_metric\"):\n", - " dc = block.getObj(\"ma_qa_metric\")\n", - " categoryName, attributeNameList, rowList = dc.get()\n", - " print(categoryName)\n", - " print(attributeNameList)\n", - " print(rowList)" - ] - }, - { - "cell_type": "code", - "execution_count": 4, - "id": "a43fc1fb", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "_ma_qa_metric.\n", - "['_ma_qa_metric.id', '_ma_qa_metric.name', '_ma_qa_metric.description', '_ma_qa_metric.type', '_ma_qa_metric.mode', '_ma_qa_metric.type_other_details', '_ma_qa_metric.software_group_id']\n", - "[['1', 'pLDDT', \"'Predicted accuracy according to the CA-only lDDT in [0,100]'\", 'pLDDT', 'global', '.', '.'], ['2', 'pTM', \"'Predicted accuracy according to the TM-score score in [0,1]'\", 'pTM', 'global', '.', '.'], ['3', 'pLDDT', \"'Predicted accuracy according to the CA-only lDDT in [0,100]'\", 'pLDDT', 'local', '.', '.'], ['4', 'PAE', \"'Predicted aligned error (in Angstroms)'\", 'PAE', 'local-pairwise', '.', '.']]\n" - ] - } - ], - "source": [ - "# parsing gemmi\n", - "# see https://gemmi.readthedocs.io/en/latest/cif.html#block\n", - "block = doc.sole_block()\n", - "table = block.find_mmcif_category(\"_ma_qa_metric.\")\n", - "if table:\n", - " print(table.get_prefix())\n", - " print([tag for tag in table.tags])\n", - " print([[col for col in row] for row in table])" - ] - }, - { - "cell_type": "code", - "execution_count": 15, - "id": "fdd15c7c", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "[['1', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'global', '', ''], ['2', 'pTM', 'Predicted accuracy according to the TM-score score in [0,1]', 'pTM', 'global', '', ''], ['3', 'pLDDT', 'Predicted accuracy according to the CA-only lDDT in [0,100]', 'pLDDT', 'local', '', ''], ['4', 'PAE', 'Predicted aligned error (in Angstroms)', 'PAE', 'local-pairwise', '', '']]\n", - "\"\"\n" - ] - } - ], - "source": [ - "# note: \"row.str(#) or \"gemmi.cif.as_string\" map \".\" or \"?\" to \"\" and remove quotes from strings\n", - "if table:\n", - " print([[gemmi.cif.as_string(col) for col in row] for row in table])\n", - "print(f'\"{gemmi.cif.as_string(\"?\")}\"')" - ] - }, - { - "cell_type": "code", - "execution_count": 8, - "id": "17b4fcbd", - "metadata": { - "scrolled": false - }, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "False\n", - "<gemmi.cif.Table.Row: 3 local pLDDT pLDDT None>\n", - "{'id': ['1', '2', '3', '4'], 'name': ['pLDDT', 'pTM', 'pLDDT', 'PAE'], 'description': [\"'Predicted accuracy according to the CA-only lDDT in [0,100]'\", \"'Predicted accuracy according to the TM-score score in [0,1]'\", \"'Predicted accuracy according to the CA-only lDDT in [0,100]'\", \"'Predicted aligned error (in Angstroms)'\"], 'type': ['pLDDT', 'pTM', 'pLDDT', 'PAE'], 'mode': ['global', 'global', 'local', 'local-pairwise'], 'type_other_details': ['.', '.', '.', '.'], 'software_group_id': ['.', '.', '.', '.']}\n" - ] - }, - { - "data": { - "text/plain": [ - "{'id': ['1', '2', '3', '4'],\n", - " 'name': ['pLDDT', 'pTM', 'pLDDT', 'PAE'],\n", - " 'description': ['Predicted accuracy according to the CA-only lDDT in [0,100]',\n", - " 'Predicted accuracy according to the TM-score score in [0,1]',\n", - " 'Predicted accuracy according to the CA-only lDDT in [0,100]',\n", - " 'Predicted aligned error (in Angstroms)'],\n", - " 'type': ['pLDDT', 'pTM', 'pLDDT', 'PAE'],\n", - " 'mode': ['global', 'global', 'local', 'local-pairwise'],\n", - " 'type_other_details': [False, False, False, False],\n", - " 'software_group_id': [False, False, False, False]}" - ] - }, - "execution_count": 8, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "# use find with desired columns (incl. optional ones)\n", - "table = block.find(\"_ma_qa_metric.\", [\"id\", \"mode\", \"name\", \"type\", \"?meh\"])\n", - "print(table.has_column(4))\n", - "# and look for rows according to first column\n", - "print(table.find_row(\"3\"))\n", - "# and get dictionary (as is)\n", - "print(block.get_mmcif_category(\"_ma_qa_metric.\", raw=True))\n", - "# or nicely processed (? and . becoming None)\n", - "block.get_mmcif_category(\"_ma_qa_metric.\")" - ] - }, - { - "cell_type": "code", - "execution_count": 206, - "id": "f60a0c20", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[[True, True, True, True, False],\n", - " [True, True, False, True, False],\n", - " [True, True, False, True, False]]" - ] - }, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": { - "text/plain": [ - "[['ColabFold', 'https://github.com/sokrypton/ColabFold', '1.2.0', '1', ''],\n", - " ['MMseqs2', 'https://github.com/soedinglab/mmseqs2', '', '2', ''],\n", - " ['AlphaFold', 'https://github.com/deepmind/alphafold', '', '3', '']]" - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], - "source": [ - "# some ways to deal with optional and missing (? or .) data\n", - "table = block.find(\"_software.\", [\"name\", \"?location\", \"?version\", \"?citation_id\", \"?meh\"])\n", - "display([[(row.has(idx) and bool(row.str(idx))) for idx in range(len(row))] for row in table])\n", - "display([[(row.str(idx) if row.has(idx) else '') for idx in range(len(row))] for row in table])" - ] - }, - { - "cell_type": "code", - "execution_count": 17, - "id": "f554c63c", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[]" - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], - "source": [ - "# note that the above also works for completely missing tables\n", - "table = block.find(\"_meh.\", [\"name\", \"?location\", \"?version\", \"?citation_id\", \"?meh\"])\n", - "display([[(row.has(idx) and bool(row.str(idx))) for idx in range(len(row))] for row in table])" - ] - }, - { - "cell_type": "markdown", - "id": "36fb3920", - "metadata": {}, - "source": [ - "# ModelCIF -> MA" - ] - }, - { - "cell_type": "code", - "execution_count": 50, - "id": "6424ff93", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "USAGE: python test_modelCIF_MA.py [CIF-FILE]\n" - ] - } - ], - "source": [ - "# fetch all functions from there for testing (__name__ hack to avoid executing main)\n", - "__name__ = \"test\"\n", - "execfile(\"./scripts/test_modelCIF_MA.py\")\n", - "_main()" - ] - }, - { - "cell_type": "code", - "execution_count": 51, - "id": "6dc9b31d", - "metadata": {}, - "outputs": [], - "source": [ - "# define test files for translations below\n", - "test_files = [\n", - " \"modelcif_MA_test/c103531_g3_i1_unrelaxed_rank_1_model_3.cif\",\n", - " \"modelcif_MA_test/AF-P38129-F1-model_v3.cif\",\n", - " \"modelcif_MA_test/ma-bak-cepc-0001.cif\",\n", - " \"modelcif_MA_test/1crn.cif\",\n", - " \"modelcif_MA_test/Tara_A0A1B0GTU1-O75152_unrelaxed_rank_1_model_1.cif\",\n", - " \"modelcif_MA_test/Var3D_I6XD65_1046.cif\",\n", - " \"modelcif_MA_test/Var3D_L7N665_1046.cif\",\n", - " \"modelcif_MA_test/Var3D_P9WIE5_3767.cif\",\n", - " \"modelcif_MA_test/ORNL_F0JBU9_9DELT.cif\",\n", - "]\n", - "\n", - "# open one for quick testing\n", - "doc = gemmi.cif.read(test_files[-4])\n", - "block = doc.sole_block()" - ] - }, - { - "cell_type": "code", - "execution_count": 53, - "id": "f8258452", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "ModelCIF->MA for modelcif_MA_test/AF-P38129-F1-model_v3.cif\n", - "--------------------------------------------------------------------------------\n", - "TITLE: NO TITLE\n", - "--------------------------------------------------------------------------------\n", - "OVERVIEW:\n", - "--------------------------------------------------------------------------------\n", - "NO ABSTRACT\n", - "\n", - "This model is part of the dataset \"TOFILL\"\n", - "\n", - "\n", - "--------------------------------------------------------------------------------\n", - "MATERIAL:\n", - "--------------------------------------------------------------------------------\n", - "The following molecular entities are in the model:\n", - "- Transcription initiation factor TFIID subunit 5 (chains: A)\n", - "UniProt: [P38129](https://www.uniprot.org/uniprot/P38129) 1-798; Saccharomyces cerevisiae (strain ATCC 204508 / S288c)\n", - "\n", - "The following software was used:\n", - "- AlphaFold (v2.0)\n", - "- dssp (4)\n", - "\n", - "The following templates were used:\n", - "- PDB: [6TBM](http://dx.doi.org/10.2210/pdb6TBM/pdb); chains (auth_asym_id): G\n", - "- PDB: [6TB4](http://dx.doi.org/10.2210/pdb6TB4/pdb); chains (auth_asym_id): G\n", - "- PDB: [6F3T](http://dx.doi.org/10.2210/pdb6F3T/pdb); chains (auth_asym_id): A\n", - "- PDB: [6MZC](http://dx.doi.org/10.2210/pdb6MZC/pdb); chains (auth_asym_id): G\n", - "\n", - "\n", - "--------------------------------------------------------------------------------\n", - "PROCEDURE:\n", - "--------------------------------------------------------------------------------\n", - "Step 1 - coevolution MSA\n", - "Step 2 - template search\n", - "Step 3 - modeling\n", - "\n", - "The model has a global model confidence score (pLDDT) of 73.91.\n", - "\n", - "Local per-residue model confidence scores (pLDDT) are available in the model mmCIF file.\n", - "\n", - "Full details are available in [ModelCIF format](https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/)in the model mmCIF file.\n", - "\n", - "\n", - "--------------------------------------------------------------------------------\n" - ] - } - ], - "source": [ - "_process_file(test_files[1])" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "id": "e4368fa1", - "metadata": {}, - "outputs": [], - "source": [] - } - ], - "metadata": { - "kernelspec": { - "display_name": "Python 3 (ipykernel)", - "language": "python", - "name": "python3" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.8.10" - } - }, - "nbformat": 4, - "nbformat_minor": 5 -} diff --git a/projects/CoFFE-sponge-proteins/tests/test_modelCIF_MA.py b/projects/CoFFE-sponge-proteins/tests/test_modelCIF_MA.py deleted file mode 100644 index 5fdd23c63bcc52b6de6aeba5421c7064bbe49c76..0000000000000000000000000000000000000000 --- a/projects/CoFFE-sponge-proteins/tests/test_modelCIF_MA.py +++ /dev/null @@ -1,470 +0,0 @@ -# USAGE: python test_modelCIF_MA.py [CIF-FILE] -# OUTPUT: preview of MA entry - -import gemmi, sys - -################################################################################ -# define converters for printing or for html (here markdown used for display) -def _make_url(link_text, link_url): - return f"[{link_text}]({link_url})" -def _make_list(list_top, list_items): - list_texts = [f"- {item}" for item in list_items] - list_text = '\n'.join(list_texts) - if list_texts: - return(f"{list_top}\n{list_text}") -def _make_multiline_text(lines): - return '\n'.join(lines) -def _make_paragraph(text): - return f"{text}\n\n" -################################################################################ - -################################################################################ -# HELPERS -################################################################################ -def _get_chain_entity(block): - # NOTE: adapted from ParseCIF (asym_ids as list and handle optional fields) - chain_entity = {} - - ma_target_entity = block.find( - "_ma_target_entity_instance.", ["asym_id", "entity_id"] - ) - if ma_target_entity: - for row in ma_target_entity: - if row["entity_id"] in chain_entity: - chain_entity[row["entity_id"]]["asym_ids"].append( - gemmi.cif.as_string(row["asym_id"]) - ) - else: - chain_entity[row["entity_id"]] = { - "asym_ids": [row["asym_id"]], - "ma_target_ref_db_details": [], - } - - for row in block.find("_entity.", ["id", "pdbx_description"]): - chain_entity[row["id"]].update( - {"pdbx_description": gemmi.cif.as_string(row["pdbx_description"])} - ) - - cols = [ - "target_entity_id", - "db_accession", - "db_name", - "?db_name_other_details", - "?organism_scientific", - "?seq_db_align_begin", - "?seq_db_align_end", - ] - # NOTE: row[col] doesn't work with '?' in find! Bad crashed happen if you try... - for row in block.find("_ma_target_ref_db_details.", cols): - json_obj = {} - target_entity_id = row[0] # make sure this stays at idx 0 in cols! - for idx, cq in enumerate(cols): - if cq.startswith('?'): - col = cq[1:] - if not row.has(idx): - json_obj[col] = None - continue - else: - col = cq - if col != "target_entity_id": - if col.find("seq_db_align") > -1: - json_obj[col] = gemmi.cif.as_int(row[idx]) - else: - json_obj[col] = gemmi.cif.as_string(row[idx]) - chain_entity[target_entity_id][ - "ma_target_ref_db_details" - ].append(json_obj) - - for row in block.find( - "_entity_poly.", - ["entity_id", "pdbx_strand_id", "pdbx_seq_one_letter_code"], - ): - chain_entity[row["entity_id"]]["olc"] = gemmi.cif.as_string( - row["pdbx_seq_one_letter_code"] - ).replace("\n", "") - - return chain_entity - -def _fetch_qa_data(block): - """Get 3 lists of QA scores and extract global scores.""" - # fetch main info - table = block.find("_ma_qa_metric.", ["id", "name", "mode", "type"]) - qa_dict = dict() # for easy access: keyed on "id" and rest as dict - for row in table: - d = {key: row.str(idx + 1) for idx, key in enumerate(["name", "mode", "type"])} - qa_dict[row.str(0)] = d - # fetch global scores - qa_global = [] - table = block.find("_ma_qa_metric_global.", ["metric_id", "metric_value"]) - for row in table: - metric_id = row.str(0) - metric_value = gemmi.cif.as_number(row.get(1)) - if metric_id in qa_dict: - assert qa_dict[metric_id]["mode"] == "global" - qa_dict[metric_id]["value"] = metric_value - qa_global.append(qa_dict[metric_id]) - # fetch local scores - qa_local = [d for d in qa_dict.values() if d["mode"] == "local"] - qa_local_pairwise = [d for d in qa_dict.values() if d["mode"] == "local-pairwise"] - return qa_global, qa_local, qa_local_pairwise -################################################################################ - -################################################################################ -# TEXT GETTERS -# -> each function turns gemmi-block into a text -# -> bits that could be reused elsewhere are given by helpers above -################################################################################ -def _get_title_text(block): - title = block.find_value("_struct.title") - if title: - title = gemmi.cif.as_string(title) - if title: - return title - else: - return "NO TITLE" - -def _get_overview_text(block): - abstract = block.find_value("_struct.pdbx_model_details") - if abstract: - abstract = gemmi.cif.as_string(abstract) - if abstract: - text = _make_paragraph(abstract) - else: - text = _make_paragraph("NO ABSTRACT") - # TODO: "TOFILL" below to be filled by MA using info from model set - text += _make_paragraph('This model is part of the dataset "TOFILL"') - return text - -def _get_entity_text(block): - # NOTE: reuse (updated!) code from ParseCIF - chain_entity = _get_chain_entity(block) - # do it - item_strings = [] - for ent in chain_entity: - item_title = f"{chain_entity[ent]['pdbx_description']} " \ - f"(chains: {', '.join(chain_entity[ent]['asym_ids'])})" - db_links = [item_title] - for i, ref in enumerate(chain_entity[ent]["ma_target_ref_db_details"]): - if ref["db_name"] == "UNP": - link_text = ref['db_accession'] - link_url = f"https://www.uniprot.org/uniprot/{ref['db_accession']}" - db_link = f"UniProt: {_make_url(link_text, link_url)}" - elif ref["db_name"] == "OrthoDB": - link_text = ref['db_accession'] - link_url = f"https://www.orthodb.org/?query={ref['db_accession']}" - db_link = f"OrthoDB: {_make_url(link_text, link_url)}" - elif ref["db_name"] == "Other" and ref["db_name_other_details"]: - db_link = f"{ref['db_name_other_details']}: {ref['db_accession']}" - else: - db_link = f"{ref['db_name']}: {ref['db_accession']}" - if ref['seq_db_align_begin'] and ref['seq_db_align_end']: - db_link += f" {ref['seq_db_align_begin']}-{ref['seq_db_align_end']}" - if ref['organism_scientific']: - db_link += f"; {ref['organism_scientific']}" - db_links.append(db_link) - item_strings.append(_make_multiline_text(db_links)) - # and into a paragraph... - if item_strings: - list_top = f"The following molecular entities are in the model:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_sw_text(block): - # get author names for each citation - tmp = dict() - for row in block.find("_citation_author.", ["citation_id", "name"]): - cid = row.str(0) - name = row.str(1) - if cid not in tmp: - tmp[cid] = {"name": name.split()[0].split(",")[0], "etal": ""} - else: - tmp[cid]["etal"] = " et al." - cit_names = {cid: (d["name"] + d["etal"]) for cid, d in tmp.items()} - # add year if available - table = block.find("_citation.", ["id", "?year"]) - if table.has_column(1): - for row in table: - cid = row.str(0) - year = row.str(1) - if cid in cit_names and year: - cit_names[cid] += " " + year - # add URL if available - cit_urls = {} - table = block.find("_citation.", ["id", "?pdbx_database_id_DOI", "?pdbx_database_id_PubMed"]) - formatters = ["https://doi.org/%s", - "https://www.ncbi.nlm.nih.gov/pubmed/%s"] - for row in table: - cid = row.str(0) - # add whichever URL we find first - for i in range(1, table.width()): - if row.has(i) and row.str(i): - cit_urls[cid] = formatters[i - 1] % row.str(i) - break - # now map this to software - item_strings = [] - table = block.find("_software.", ["name", "?location", "?version", "?citation_id"]) - for row in table: - sw_name = row.str(0) - if row.has(1) and row.str(1): - item = _make_url(sw_name, row.str(1)) - else: - item = sw_name - if row.has(2) and row.str(2): - item += f" ({row.str(2)})" - if row.has(3) and row.str(3) in cit_names: - cid = row.str(3) - if cid in cit_urls: - item += f" ({_make_url(cit_names[cid], cit_urls[cid])})" - else: - item += f" ({cit_names[cid]})" - item_strings.append(item) - # and into a paragraph... - if item_strings: - list_top = f"The following software was used:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_ref_db_text(block): - # look for DBs with version or release date - item_strings = [] - table = block.find("_ma_data_ref_db.", ["name", "?version", "?release_date"]) - for row in table: - item = f"{row.str(0)}" - # add whichever version we find first - for i in range(1, 3): - if row.has(i) and row.str(i): - item += f" ({row.str(i)})" - break - item_strings.append(item) - # and into a paragraph... - if item_strings: - list_top = f"The following reference databases were used:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_tpl_text(block): - # collect info per tpl-id - tpl_dict = {} # keyed on template_id - # fetch main info - cols = ["template_id", "target_asym_id", "template_auth_asym_id", - "?template_label_asym_id"] - for row in block.find("_ma_template_details.", cols): - tid = row.str(0) - tpl_dict[tid] = { - "trg_asym_id": row.str(1), - "tpl_auth_asym_id": row.str(2) - } - if row.has(3) and row.str(3): - tpl_dict[tid]["tpl_label_asym_id"] = row.str(3) - # add ref DBs - cols = ["template_id", "db_accession_code", "db_name", - "?db_name_other_details"] - for row in block.find("_ma_template_ref_db_details.", cols): - tid = row.str(0) - if tid in tpl_dict: - tpl_dict[tid]["db_acc"] = row.str(1) - if row.str(2) == "Other" and row.has(3) and row.str(3): - tpl_dict[tid]["db_name"] = row.str(3) - else: - tpl_dict[tid]["db_name"] = row.str(2) - # add info for small molecules - cols = ["template_id", "?comp_id", "?details"] - for row in block.find("_ma_template_non_poly.", cols): - tid = row.str(0) - if tid in tpl_dict: - if row.has(1) and row.str(1): - tpl_dict[tid]["non_poly_comp_id"] = row.str(1) - if row.has(2) and row.str(2): - tpl_dict[tid]["non_poly_details"] = row.str(2) - # aggregate per template for diplaying - tpl_td = dict() - for tpl in tpl_dict.values(): - did = f"{tpl['db_name']}-{tpl['db_acc']}" - if did not in tpl_td: - if tpl['db_name'] == "PDB": - link_url = f"http://dx.doi.org/10.2210/pdb{tpl['db_acc']}/pdb" - elif tpl['db_name'] == "PubChem": - link_url = f"https://pubchem.ncbi.nlm.nih.gov/compound/{tpl['db_acc']}" - else: - link_url = None - print(f"URLs for {tpl['db_name']} NOT SUPPORTED YET") - if link_url: - tpl_text = f"{tpl['db_name']}: {_make_url(tpl['db_acc'], link_url)}" - else: - tpl_text = f"{tpl['db_name']}: {tpl['db_acc']}" - tpl_td[did] = { - "tpl_text": tpl_text, - "tpl_chains_label": [], - "tpl_chains_auth": [], - "tpl_chains_all_label": True, - "tpl_non_poly_ids": [] - } - # collect chain names - if "tpl_label_asym_id" in tpl: - # if here it is guaranteed to be non-empty - tpl_td[did]["tpl_chains_label"].append(tpl["tpl_label_asym_id"]) - else: - # if any missing, we set all to False and fall back to auth - tpl_td[did]["tpl_chains_all_label"] = False - if tpl["tpl_auth_asym_id"]: - # only add non empty ones - tpl_td[did]["tpl_chains_auth"].append(tpl["tpl_auth_asym_id"]) - # collect info on non poly if available (prefer short comp. ID) - if "non_poly_comp_id" in tpl: - tpl_td[did]["tpl_non_poly_ids"].append(tpl["non_poly_comp_id"]) - elif "non_poly_details" in tpl: - tpl_td[did]["tpl_non_poly_ids"].append(tpl["non_poly_details"]) - # turn into text - item_strings = [] - for tpl in tpl_td.values(): - item = tpl["tpl_text"] - if tpl["tpl_chains_all_label"] and tpl["tpl_chains_label"]: - chain_ids = sorted(set(tpl['tpl_chains_label'])) - item += f"; chains (label_asym_id): {', '.join(chain_ids)}" - elif tpl["tpl_chains_auth"]: - chain_ids = sorted(set(tpl['tpl_chains_auth'])) - item += f"; chains (auth_asym_id): {', '.join(chain_ids)}" - if tpl["tpl_non_poly_ids"]: - np_ids = sorted(set(tpl['tpl_non_poly_ids'])) - item += f"; non-polymers: {', '.join(np_ids)}" - item_strings.append(item) - # and into a paragraph... - if item_strings: - list_top = f"The following templates were used:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_protocol_steps_text(block): - # do it - item_strings = [] - table = block.find("_ma_protocol_step.", ["step_id", "method_type", "?details"]) - for row in table: - item = f"Step {row.str(0)} - {row.str(1)}" - if row.has(2) and row.str(2): - item += f" : {row.str(2)}" - item_strings.append(item) - # and into a paragraph... - if item_strings: - return _make_paragraph(_make_multiline_text(item_strings)) - else: - return "" - -def _get_qa_acc_text(block): - # get QA part (can reuse if already used elsewhere) - qa_global, qa_local, qa_local_pairwise = _fetch_qa_data(block) - # parse accompanying data - file_contents = block.find_values("_ma_entry_associated_files.file_content") - has_single_zip_file = len(file_contents) == 1 and \ - file_contents.str(0) == "archive with multiple files" - if has_single_zip_file: - # override with data from other block - file_contents = block.find_values("_ma_associated_archive_file_details.file_content") - has_loc_pw_in_acc = any(True for v in file_contents \ - if gemmi.cif.as_string(v) == "local pairwise QA scores") - # put together text - text = "" - # text for QA - item = "" - if len(qa_global) > 1: - score_strings = [f"{v['name']} of {v['value']}" for v in qa_global] - item = f"The model has the following global model confidence scores:" \ - f" {', '.join(score_strings)}." - elif len(qa_global) == 1: - item = f"The model has a global model confidence score " \ - f"({qa_global[0]['name']}) of {qa_global[0]['value']}." - if item: - text += _make_paragraph(item) - # lots of options for local QA string - item = "" - qa_local_names = ", ".join([v["name"] for v in qa_local]) - qa_loc_pw_names = ", ".join([v["name"] for v in qa_local_pairwise]) - if qa_local_names and qa_loc_pw_names and has_loc_pw_in_acc: - item = f"Local per-residue model confidence scores ({qa_local_names}) " \ - f"are available in the model mmCIF file " \ - f"and local per-residue-pair scores ({qa_loc_pw_names}) " \ - f"in the accompanying data download." - elif qa_local_names and qa_loc_pw_names and not has_loc_pw_in_acc: - item = f"Local per-residue model confidence scores ({qa_local_names}) " \ - f"and local per-residue-pair scores ({qa_loc_pw_names}) " \ - f"are available in the model mmCIF file." - elif qa_local_names and not qa_loc_pw_names: - item = f"Local per-residue model confidence scores ({qa_local_names}) " \ - f"are available in the model mmCIF file." - elif not qa_local_names and qa_loc_pw_names and has_loc_pw_in_acc: - item = f"Local per-residue-pair model confidence scores ({qa_loc_pw_names}) " \ - f"are available in the accompanying data download." - elif not qa_local_names and qa_loc_pw_names and not has_loc_pw_in_acc: - item = f"Local per-residue-pair model confidence scores ({qa_loc_pw_names}) " \ - f"are available in the model mmCIF file." - if item: - text += _make_paragraph(item) - # list files in accompanying data (if any) - if has_single_zip_file: - table = block.find("_ma_associated_archive_file_details.", - ["file_path", "?file_content", "?description"]) - else: - # NOTE: aimed to work legacy-style for Baker-models but should be obsoleted - # -> can replace below with "table = None" in future - table = block.find("_ma_entry_associated_files.", - ["file_url", "?file_content", "?details"]) - if table: - list_top = "Files in accompanying data:" - list_items = [] - for row in table: - item = f"{row.str(0)}" - if row.has(1) and row.str(1): - item += f" ({row.str(1)})" - if row.has(2) and row.str(2): - item += f": {row.str(2)}" - list_items.append(item) - text += _make_paragraph(_make_list(list_top, list_items)) - # conclude with standard pointer to ModelCIF file - model_cif_link = _make_url( - "ModelCIF format", - "https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/" - ) - text += _make_paragraph( - f"Full details are available in {model_cif_link}" \ - f"in the model mmCIF file." - ) - return text -################################################################################ - -# full parsing of file -def _process_file(file_path): - print(f"ModelCIF->MA for {file_path}") - doc = gemmi.cif.read(file_path) - block = doc.sole_block() - print('-'*80) - print(f"TITLE: {_get_title_text(block)}") - print('-'*80) - print(f"OVERVIEW:\n{'-'*80}") - print(_get_overview_text(block)) - print('-'*80) - print(f"MATERIAL:\n{'-'*80}") - material_text = _get_entity_text(block) \ - + _get_sw_text(block) \ - + _get_ref_db_text(block) \ - + _get_tpl_text(block) - print(material_text) - print('-'*80) - print(f"PROCEDURE:\n{'-'*80}") - procedure_text = _get_protocol_steps_text(block) \ - + _get_qa_acc_text(block) - print(procedure_text) - print('-'*80) - -def _main(): - # get file to process - if len(sys.argv) == 2: - file_path = sys.argv[1] - _process_file(file_path) - else: - print("USAGE: python test_modelCIF_MA.py [CIF-FILE]") - -if __name__ == "__main__": - _main() diff --git a/projects/USDA-ASFVG/README.md b/projects/USDA-ASFVG/README.md index 60f8e4900521c6a69193ef1f014440a8ebe6719b..6afb9aabd405a576d51cdf9a4a5c74d08d21e233 100644 --- a/projects/USDA-ASFVG/README.md +++ b/projects/USDA-ASFVG/README.md @@ -1,8 +1,6 @@ # Modelling of African Swine Fever proteome from USDA -Main links: -- [Link Project in MA](https://modelarchive.org/doi/10.5452/ma-asfv-asfvg) (incl. background on project itself) -- [Jira-story](https://jira.biozentrum.unibas.ch/browse/SCHWED-5651) +[Link to project in ModelArchive](https://modelarchive.org/doi/10.5452/ma-asfv-asfvg) (incl. background on project itself) Setup: - Using AlphaFold for monomer predictions with default CASP14 setup (no PAE, no pTM, templates used and relaxation enabled) @@ -21,6 +19,3 @@ Special features here: Content: - translate2modelcif.py : script to do conversion based on CoFFE-sponge-proteins project (identical Docker setup used) -- tests folder with - - test_modelCIF_MA.py to convert ModelCIF to content displayed in ModelArchive (needs gemmi library) - - test.ipynb and .html for tests performed during development diff --git a/projects/USDA-ASFVG/tests/test-220823.html b/projects/USDA-ASFVG/tests/test-220823.html deleted file mode 100644 index 993e6ad6274cfc4b323d320f33cd7354710816ae..0000000000000000000000000000000000000000 --- a/projects/USDA-ASFVG/tests/test-220823.html +++ /dev/null @@ -1,16332 +0,0 @@ -<!DOCTYPE html> -<html> -<head><meta charset="utf-8" /> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>test</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script> - - - - -<style type="text/css"> - pre { line-height: 125%; } -td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } -span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } -td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } -span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } -.highlight .hll { background-color: var(--jp-cell-editor-active-background) } -.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) } -.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */ -.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */ -.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */ -.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */ -.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */ -.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */ -.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */ -.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */ -.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */ -.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */ -.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */ -.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */ -.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */ -.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */ -.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */ -.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */ -.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */ -.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */ -.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */ -.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */ -.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */ -.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */ -.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */ -.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */ -.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */ -.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */ -.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */ -.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */ -.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */ -.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */ -.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */ -.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */ -.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */ -.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */ -.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */ -.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */ -.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */ -.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */ -.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */ -.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */ - </style> - - - -<style type="text/css"> -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* - * Mozilla scrollbar styling - */ - -/* use standard opaque scrollbars for most nodes */ -[data-jp-theme-scrollbars='true'] { - scrollbar-color: rgb(var(--jp-scrollbar-thumb-color)) - var(--jp-scrollbar-background-color); -} - -/* for code nodes, use a transparent style of scrollbar. These selectors - * will match lower in the tree, and so will override the above */ -[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar, -[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar { - scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; -} - -/* tiny scrollbar */ - -.jp-scrollbar-tiny { - scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; - scrollbar-width: thin; -} - -/* - * Webkit scrollbar styling - */ - -/* use standard opaque scrollbars for most nodes */ - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-corner { - background: var(--jp-scrollbar-background-color); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-thumb { - background: rgb(var(--jp-scrollbar-thumb-color)); - border: var(--jp-scrollbar-thumb-margin) solid transparent; - background-clip: content-box; - border-radius: var(--jp-scrollbar-thumb-radius); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:horizontal { - border-left: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); - border-right: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:vertical { - border-top: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); - border-bottom: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); -} - -/* for code nodes, use a transparent style of scrollbar */ - -[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-corner, -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-corner { - background-color: transparent; -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-thumb, -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-thumb { - background: rgba(var(--jp-scrollbar-thumb-color), 0.5); - border: var(--jp-scrollbar-thumb-margin) solid transparent; - background-clip: content-box; - border-radius: var(--jp-scrollbar-thumb-radius); -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-track:horizontal { - border-left: var(--jp-scrollbar-endpad) solid transparent; - border-right: var(--jp-scrollbar-endpad) solid transparent; -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-track:vertical { - border-top: var(--jp-scrollbar-endpad) solid transparent; - border-bottom: var(--jp-scrollbar-endpad) solid transparent; -} - -/* tiny scrollbar */ - -.jp-scrollbar-tiny::-webkit-scrollbar, -.jp-scrollbar-tiny::-webkit-scrollbar-corner { - background-color: transparent; - height: 4px; - width: 4px; -} - -.jp-scrollbar-tiny::-webkit-scrollbar-thumb { - background: rgba(var(--jp-scrollbar-thumb-color), 0.5); -} - -.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal { - border-left: 0px solid transparent; - border-right: 0px solid transparent; -} - -.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical { - border-top: 0px solid transparent; - border-bottom: 0px solid transparent; -} - -/* - * Phosphor - */ - -.lm-ScrollBar[data-orientation='horizontal'] { - min-height: 16px; - max-height: 16px; - min-width: 45px; - border-top: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='vertical'] { - min-width: 16px; - max-width: 16px; - min-height: 45px; - border-left: 1px solid #a0a0a0; -} - -.lm-ScrollBar-button { - background-color: #f0f0f0; - background-position: center center; - min-height: 15px; - max-height: 15px; - min-width: 15px; - max-width: 15px; -} - -.lm-ScrollBar-button:hover { - background-color: #dadada; -} - -.lm-ScrollBar-button.lm-mod-active { - background-color: #cdcdcd; -} - -.lm-ScrollBar-track { - background: #f0f0f0; -} - -.lm-ScrollBar-thumb { - background: #cdcdcd; -} - -.lm-ScrollBar-thumb:hover { - background: #bababa; -} - -.lm-ScrollBar-thumb.lm-mod-active { - background: #a0a0a0; -} - -.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb { - height: 100%; - min-width: 15px; - border-left: 1px solid #a0a0a0; - border-right: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb { - width: 100%; - min-height: 15px; - border-top: 1px solid #a0a0a0; - border-bottom: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='horizontal'] - .lm-ScrollBar-button[data-action='decrement'] { - background-image: var(--jp-icon-caret-left); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='horizontal'] - .lm-ScrollBar-button[data-action='increment'] { - background-image: var(--jp-icon-caret-right); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='vertical'] - .lm-ScrollBar-button[data-action='decrement'] { - background-image: var(--jp-icon-caret-up); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='vertical'] - .lm-ScrollBar-button[data-action='increment'] { - background-image: var(--jp-icon-caret-down); - background-size: 17px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-Widget, /* </DEPRECATED> */ -.lm-Widget { - box-sizing: border-box; - position: relative; - overflow: hidden; - cursor: default; -} - - -/* <DEPRECATED> */ .p-Widget.p-mod-hidden, /* </DEPRECATED> */ -.lm-Widget.lm-mod-hidden { - display: none !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-CommandPalette, /* </DEPRECATED> */ -.lm-CommandPalette { - display: flex; - flex-direction: column; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-CommandPalette-search, /* </DEPRECATED> */ -.lm-CommandPalette-search { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-content, /* </DEPRECATED> */ -.lm-CommandPalette-content { - flex: 1 1 auto; - margin: 0; - padding: 0; - min-height: 0; - overflow: auto; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p-CommandPalette-header, /* </DEPRECATED> */ -.lm-CommandPalette-header { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - - -/* <DEPRECATED> */ .p-CommandPalette-item, /* </DEPRECATED> */ -.lm-CommandPalette-item { - display: flex; - flex-direction: row; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemIcon, /* </DEPRECATED> */ -.lm-CommandPalette-itemIcon { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemContent, /* </DEPRECATED> */ -.lm-CommandPalette-itemContent { - flex: 1 1 auto; - overflow: hidden; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemShortcut, /* </DEPRECATED> */ -.lm-CommandPalette-itemShortcut { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemLabel, /* </DEPRECATED> */ -.lm-CommandPalette-itemLabel { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.lm-close-icon { - border:1px solid transparent; - background-color: transparent; - position: absolute; - z-index:1; - right:3%; - top: 0; - bottom: 0; - margin: auto; - padding: 7px 0; - display: none; - vertical-align: middle; - outline: 0; - cursor: pointer; -} -.lm-close-icon:after { - content: "X"; - display: block; - width: 15px; - height: 15px; - text-align: center; - color:#000; - font-weight: normal; - font-size: 12px; - cursor: pointer; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-DockPanel, /* </DEPRECATED> */ -.lm-DockPanel { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-DockPanel-widget, /* </DEPRECATED> */ -.lm-DockPanel-widget { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-DockPanel-tabBar, /* </DEPRECATED> */ -.lm-DockPanel-tabBar { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle, /* </DEPRECATED> */ -.lm-DockPanel-handle { - z-index: 2; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle.p-mod-hidden, /* </DEPRECATED> */ -.lm-DockPanel-handle.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle:after, /* </DEPRECATED> */ -.lm-DockPanel-handle:after { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='horizontal'], -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='horizontal'] { - cursor: ew-resize; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='vertical'], -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='vertical'] { - cursor: ns-resize; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='horizontal']:after, -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='horizontal']:after { - left: 50%; - min-width: 8px; - transform: translateX(-50%); -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='vertical']:after, -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='vertical']:after { - top: 50%; - min-height: 8px; - transform: translateY(-50%); -} - - -/* <DEPRECATED> */ .p-DockPanel-overlay, /* </DEPRECATED> */ -.lm-DockPanel-overlay { - z-index: 3; - box-sizing: border-box; - pointer-events: none; -} - - -/* <DEPRECATED> */ .p-DockPanel-overlay.p-mod-hidden, /* </DEPRECATED> */ -.lm-DockPanel-overlay.lm-mod-hidden { - display: none !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-Menu, /* </DEPRECATED> */ -.lm-Menu { - z-index: 10000; - position: absolute; - white-space: nowrap; - overflow-x: hidden; - overflow-y: auto; - outline: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-Menu-content, /* </DEPRECATED> */ -.lm-Menu-content { - margin: 0; - padding: 0; - display: table; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p-Menu-item, /* </DEPRECATED> */ -.lm-Menu-item { - display: table-row; -} - - -/* <DEPRECATED> */ -.p-Menu-item.p-mod-hidden, -.p-Menu-item.p-mod-collapsed, -/* </DEPRECATED> */ -.lm-Menu-item.lm-mod-hidden, -.lm-Menu-item.lm-mod-collapsed { - display: none !important; -} - - -/* <DEPRECATED> */ -.p-Menu-itemIcon, -.p-Menu-itemSubmenuIcon, -/* </DEPRECATED> */ -.lm-Menu-itemIcon, -.lm-Menu-itemSubmenuIcon { - display: table-cell; - text-align: center; -} - - -/* <DEPRECATED> */ .p-Menu-itemLabel, /* </DEPRECATED> */ -.lm-Menu-itemLabel { - display: table-cell; - text-align: left; -} - - -/* <DEPRECATED> */ .p-Menu-itemShortcut, /* </DEPRECATED> */ -.lm-Menu-itemShortcut { - display: table-cell; - text-align: right; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-MenuBar, /* </DEPRECATED> */ -.lm-MenuBar { - outline: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-MenuBar-content, /* </DEPRECATED> */ -.lm-MenuBar-content { - margin: 0; - padding: 0; - display: flex; - flex-direction: row; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p--MenuBar-item, /* </DEPRECATED> */ -.lm-MenuBar-item { - box-sizing: border-box; -} - - -/* <DEPRECATED> */ -.p-MenuBar-itemIcon, -.p-MenuBar-itemLabel, -/* </DEPRECATED> */ -.lm-MenuBar-itemIcon, -.lm-MenuBar-itemLabel { - display: inline-block; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-ScrollBar, /* </DEPRECATED> */ -.lm-ScrollBar { - display: flex; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ -.p-ScrollBar[data-orientation='horizontal'], -/* </DEPRECATED> */ -.lm-ScrollBar[data-orientation='horizontal'] { - flex-direction: row; -} - - -/* <DEPRECATED> */ -.p-ScrollBar[data-orientation='vertical'], -/* </DEPRECATED> */ -.lm-ScrollBar[data-orientation='vertical'] { - flex-direction: column; -} - - -/* <DEPRECATED> */ .p-ScrollBar-button, /* </DEPRECATED> */ -.lm-ScrollBar-button { - box-sizing: border-box; - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-ScrollBar-track, /* </DEPRECATED> */ -.lm-ScrollBar-track { - box-sizing: border-box; - position: relative; - overflow: hidden; - flex: 1 1 auto; -} - - -/* <DEPRECATED> */ .p-ScrollBar-thumb, /* </DEPRECATED> */ -.lm-ScrollBar-thumb { - box-sizing: border-box; - position: absolute; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-SplitPanel-child, /* </DEPRECATED> */ -.lm-SplitPanel-child { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle, /* </DEPRECATED> */ -.lm-SplitPanel-handle { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle.p-mod-hidden, /* </DEPRECATED> */ -.lm-SplitPanel-handle.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle:after, /* </DEPRECATED> */ -.lm-SplitPanel-handle:after { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle { - cursor: ew-resize; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle { - cursor: ns-resize; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle:after, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after { - left: 50%; - min-width: 8px; - transform: translateX(-50%); -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle:after, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after { - top: 50%; - min-height: 8px; - transform: translateY(-50%); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-TabBar, /* </DEPRECATED> */ -.lm-TabBar { - display: flex; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-TabBar[data-orientation='horizontal'], /* </DEPRECATED> */ -.lm-TabBar[data-orientation='horizontal'] { - flex-direction: row; - align-items: flex-end; -} - - -/* <DEPRECATED> */ .p-TabBar[data-orientation='vertical'], /* </DEPRECATED> */ -.lm-TabBar[data-orientation='vertical'] { - flex-direction: column; - align-items: flex-end; -} - - -/* <DEPRECATED> */ .p-TabBar-content, /* </DEPRECATED> */ -.lm-TabBar-content { - margin: 0; - padding: 0; - display: flex; - flex: 1 1 auto; - list-style-type: none; -} - - -/* <DEPRECATED> */ -.p-TabBar[data-orientation='horizontal'] > .p-TabBar-content, -/* </DEPRECATED> */ -.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content { - flex-direction: row; -} - - -/* <DEPRECATED> */ -.p-TabBar[data-orientation='vertical'] > .p-TabBar-content, -/* </DEPRECATED> */ -.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content { - flex-direction: column; -} - - -/* <DEPRECATED> */ .p-TabBar-tab, /* </DEPRECATED> */ -.lm-TabBar-tab { - display: flex; - flex-direction: row; - box-sizing: border-box; - overflow: hidden; -} - - -/* <DEPRECATED> */ -.p-TabBar-tabIcon, -.p-TabBar-tabCloseIcon, -/* </DEPRECATED> */ -.lm-TabBar-tabIcon, -.lm-TabBar-tabCloseIcon { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-TabBar-tabLabel, /* </DEPRECATED> */ -.lm-TabBar-tabLabel { - flex: 1 1 auto; - overflow: hidden; - white-space: nowrap; -} - - -.lm-TabBar-tabInput { - user-select: all; - width: 100%; - box-sizing : border-box; -} - - -/* <DEPRECATED> */ .p-TabBar-tab.p-mod-hidden, /* </DEPRECATED> */ -.lm-TabBar-tab.lm-mod-hidden { - display: none !important; -} - - -.lm-TabBar-addButton.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-TabBar.p-mod-dragging .p-TabBar-tab, /* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging .lm-TabBar-tab { - position: relative; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab { - left: 0; - transition: left 150ms ease; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab { - top: 0; - transition: top 150ms ease; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging { - transition: none; -} - -.lm-TabBar-tabLabel .lm-TabBar-tabInput { - user-select: all; - width: 100%; - box-sizing : border-box; - background: inherit; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-TabPanel-tabBar, /* </DEPRECATED> */ -.lm-TabPanel-tabBar { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-TabPanel-stackedPanel, /* </DEPRECATED> */ -.lm-TabPanel-stackedPanel { - z-index: 0; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - -@charset "UTF-8"; -html{ - -webkit-box-sizing:border-box; - box-sizing:border-box; } - -*, -*::before, -*::after{ - -webkit-box-sizing:inherit; - box-sizing:inherit; } - -body{ - font-size:14px; - font-weight:400; - letter-spacing:0; - line-height:1.28581; - text-transform:none; - color:#182026; - font-family:-apple-system, "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", "Icons16", sans-serif; } - -p{ - margin-bottom:10px; - margin-top:0; } - -small{ - font-size:12px; } - -strong{ - font-weight:600; } - -::-moz-selection{ - background:rgba(125, 188, 255, 0.6); } - -::selection{ - background:rgba(125, 188, 255, 0.6); } -.bp3-heading{ - color:#182026; - font-weight:600; - margin:0 0 10px; - padding:0; } - .bp3-dark .bp3-heading{ - color:#f5f8fa; } - -h1.bp3-heading, .bp3-running-text h1{ - font-size:36px; - line-height:40px; } - -h2.bp3-heading, .bp3-running-text h2{ - font-size:28px; - line-height:32px; } - -h3.bp3-heading, .bp3-running-text h3{ - font-size:22px; - line-height:25px; } - -h4.bp3-heading, .bp3-running-text h4{ - font-size:18px; - line-height:21px; } - -h5.bp3-heading, .bp3-running-text h5{ - font-size:16px; - line-height:19px; } - -h6.bp3-heading, .bp3-running-text h6{ - font-size:14px; - line-height:16px; } -.bp3-ui-text{ - font-size:14px; - font-weight:400; - letter-spacing:0; - line-height:1.28581; - text-transform:none; } - -.bp3-monospace-text{ - font-family:monospace; - text-transform:none; } - -.bp3-text-muted{ - color:#5c7080; } - .bp3-dark .bp3-text-muted{ - color:#a7b6c2; } - -.bp3-text-disabled{ - color:rgba(92, 112, 128, 0.6); } - .bp3-dark .bp3-text-disabled{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-text-overflow-ellipsis{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; } -.bp3-running-text{ - font-size:14px; - line-height:1.5; } - .bp3-running-text h1{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h1{ - color:#f5f8fa; } - .bp3-running-text h2{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h2{ - color:#f5f8fa; } - .bp3-running-text h3{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h3{ - color:#f5f8fa; } - .bp3-running-text h4{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h4{ - color:#f5f8fa; } - .bp3-running-text h5{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h5{ - color:#f5f8fa; } - .bp3-running-text h6{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h6{ - color:#f5f8fa; } - .bp3-running-text hr{ - border:none; - border-bottom:1px solid rgba(16, 22, 26, 0.15); - margin:20px 0; } - .bp3-dark .bp3-running-text hr{ - border-color:rgba(255, 255, 255, 0.15); } - .bp3-running-text p{ - margin:0 0 10px; - padding:0; } - -.bp3-text-large{ - font-size:16px; } - -.bp3-text-small{ - font-size:12px; } -a{ - color:#106ba3; - text-decoration:none; } - a:hover{ - color:#106ba3; - cursor:pointer; - text-decoration:underline; } - a .bp3-icon, a .bp3-icon-standard, a .bp3-icon-large{ - color:inherit; } - a code, - .bp3-dark a code{ - color:inherit; } - .bp3-dark a, - .bp3-dark a:hover{ - color:#48aff0; } - .bp3-dark a .bp3-icon, .bp3-dark a .bp3-icon-standard, .bp3-dark a .bp3-icon-large, - .bp3-dark a:hover .bp3-icon, - .bp3-dark a:hover .bp3-icon-standard, - .bp3-dark a:hover .bp3-icon-large{ - color:inherit; } -.bp3-running-text code, .bp3-code{ - font-family:monospace; - text-transform:none; - background:rgba(255, 255, 255, 0.7); - border-radius:3px; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2); - color:#5c7080; - font-size:smaller; - padding:2px 5px; } - .bp3-dark .bp3-running-text code, .bp3-running-text .bp3-dark code, .bp3-dark .bp3-code{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - color:#a7b6c2; } - .bp3-running-text a > code, a > .bp3-code{ - color:#137cbd; } - .bp3-dark .bp3-running-text a > code, .bp3-running-text .bp3-dark a > code, .bp3-dark a > .bp3-code{ - color:inherit; } - -.bp3-running-text pre, .bp3-code-block{ - font-family:monospace; - text-transform:none; - background:rgba(255, 255, 255, 0.7); - border-radius:3px; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - color:#182026; - display:block; - font-size:13px; - line-height:1.4; - margin:10px 0; - padding:13px 15px 12px; - word-break:break-all; - word-wrap:break-word; } - .bp3-dark .bp3-running-text pre, .bp3-running-text .bp3-dark pre, .bp3-dark .bp3-code-block{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-running-text pre > code, .bp3-code-block > code{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; - font-size:inherit; - padding:0; } - -.bp3-running-text kbd, .bp3-key{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - color:#5c7080; - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - font-family:inherit; - font-size:12px; - height:24px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - line-height:24px; - min-width:24px; - padding:3px 6px; - vertical-align:middle; } - .bp3-running-text kbd .bp3-icon, .bp3-key .bp3-icon, .bp3-running-text kbd .bp3-icon-standard, .bp3-key .bp3-icon-standard, .bp3-running-text kbd .bp3-icon-large, .bp3-key .bp3-icon-large{ - margin-right:5px; } - .bp3-dark .bp3-running-text kbd, .bp3-running-text .bp3-dark kbd, .bp3-dark .bp3-key{ - background:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - color:#a7b6c2; } -.bp3-running-text blockquote, .bp3-blockquote{ - border-left:solid 4px rgba(167, 182, 194, 0.5); - margin:0 0 10px; - padding:0 20px; } - .bp3-dark .bp3-running-text blockquote, .bp3-running-text .bp3-dark blockquote, .bp3-dark .bp3-blockquote{ - border-color:rgba(115, 134, 148, 0.5); } -.bp3-running-text ul, -.bp3-running-text ol, .bp3-list{ - margin:10px 0; - padding-left:30px; } - .bp3-running-text ul li:not(:last-child), .bp3-running-text ol li:not(:last-child), .bp3-list li:not(:last-child){ - margin-bottom:5px; } - .bp3-running-text ul ol, .bp3-running-text ol ol, .bp3-list ol, - .bp3-running-text ul ul, - .bp3-running-text ol ul, - .bp3-list ul{ - margin-top:5px; } - -.bp3-list-unstyled{ - list-style:none; - margin:0; - padding:0; } - .bp3-list-unstyled li{ - padding:0; } -.bp3-rtl{ - text-align:right; } - -.bp3-dark{ - color:#f5f8fa; } - -:focus{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:2px; - -moz-outline-radius:6px; } - -.bp3-focus-disabled :focus{ - outline:none !important; } - .bp3-focus-disabled :focus ~ .bp3-control-indicator{ - outline:none !important; } - -.bp3-alert{ - max-width:400px; - padding:20px; } - -.bp3-alert-body{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-alert-body .bp3-icon{ - font-size:40px; - margin-right:20px; - margin-top:0; } - -.bp3-alert-contents{ - word-break:break-word; } - -.bp3-alert-footer{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:reverse; - -ms-flex-direction:row-reverse; - flex-direction:row-reverse; - margin-top:10px; } - .bp3-alert-footer .bp3-button{ - margin-left:10px; } -.bp3-breadcrumbs{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - cursor:default; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-wrap:wrap; - flex-wrap:wrap; - height:30px; - list-style:none; - margin:0; - padding:0; } - .bp3-breadcrumbs > li{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-breadcrumbs > li::after{ - background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.71 7.29l-4-4a1.003 1.003 0 00-1.42 1.42L8.59 8 5.3 11.29c-.19.18-.3.43-.3.71a1.003 1.003 0 001.71.71l4-4c.18-.18.29-.43.29-.71 0-.28-.11-.53-.29-.71z' fill='%235C7080'/%3e%3c/svg%3e"); - content:""; - display:block; - height:16px; - margin:0 5px; - width:16px; } - .bp3-breadcrumbs > li:last-of-type::after{ - display:none; } - -.bp3-breadcrumb, -.bp3-breadcrumb-current, -.bp3-breadcrumbs-collapsed{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - font-size:16px; } - -.bp3-breadcrumb, -.bp3-breadcrumbs-collapsed{ - color:#5c7080; } - -.bp3-breadcrumb:hover{ - text-decoration:none; } - -.bp3-breadcrumb.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-breadcrumb .bp3-icon{ - margin-right:5px; } - -.bp3-breadcrumb-current{ - color:inherit; - font-weight:600; } - .bp3-breadcrumb-current .bp3-input{ - font-size:inherit; - font-weight:inherit; - vertical-align:baseline; } - -.bp3-breadcrumbs-collapsed{ - background:#ced9e0; - border:none; - border-radius:3px; - cursor:pointer; - margin-right:2px; - padding:1px 5px; - vertical-align:text-bottom; } - .bp3-breadcrumbs-collapsed::before{ - background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cg fill='%235C7080'%3e%3ccircle cx='2' cy='8.03' r='2'/%3e%3ccircle cx='14' cy='8.03' r='2'/%3e%3ccircle cx='8' cy='8.03' r='2'/%3e%3c/g%3e%3c/svg%3e") center no-repeat; - content:""; - display:block; - height:16px; - width:16px; } - .bp3-breadcrumbs-collapsed:hover{ - background:#bfccd6; - color:#182026; - text-decoration:none; } - -.bp3-dark .bp3-breadcrumb, -.bp3-dark .bp3-breadcrumbs-collapsed{ - color:#a7b6c2; } - -.bp3-dark .bp3-breadcrumbs > li::after{ - color:#a7b6c2; } - -.bp3-dark .bp3-breadcrumb.bp3-disabled{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-dark .bp3-breadcrumb-current{ - color:#f5f8fa; } - -.bp3-dark .bp3-breadcrumbs-collapsed{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-breadcrumbs-collapsed:hover{ - background:rgba(16, 22, 26, 0.6); - color:#f5f8fa; } -.bp3-button{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border:none; - border-radius:3px; - cursor:pointer; - font-size:14px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - padding:5px 10px; - text-align:left; - vertical-align:middle; - min-height:30px; - min-width:30px; } - .bp3-button > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-button > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-button::before, - .bp3-button > *{ - margin-right:7px; } - .bp3-button:empty::before, - .bp3-button > :last-child{ - margin-right:0; } - .bp3-button:empty{ - padding:0 !important; } - .bp3-button:disabled, .bp3-button.bp3-disabled{ - cursor:not-allowed; } - .bp3-button.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-button.bp3-align-right, - .bp3-align-right .bp3-button{ - text-align:right; } - .bp3-button.bp3-align-left, - .bp3-align-left .bp3-button{ - text-align:left; } - .bp3-button:not([class*="bp3-intent-"]){ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; } - .bp3-button:not([class*="bp3-intent-"]):hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-button:not([class*="bp3-intent-"]):active, .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active:hover, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-button.bp3-intent-primary{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-primary:hover, .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-primary:hover{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{ - background-color:#0e5a8a; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-primary:disabled, .bp3-button.bp3-intent-primary.bp3-disabled{ - background-color:rgba(19, 124, 189, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-success{ - background-color:#0f9960; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-success:hover, .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-success:hover{ - background-color:#0d8050; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{ - background-color:#0a6640; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-success:disabled, .bp3-button.bp3-intent-success.bp3-disabled{ - background-color:rgba(15, 153, 96, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-warning{ - background-color:#d9822b; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-warning:hover, .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-warning:hover{ - background-color:#bf7326; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{ - background-color:#a66321; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-warning:disabled, .bp3-button.bp3-intent-warning.bp3-disabled{ - background-color:rgba(217, 130, 43, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-danger{ - background-color:#db3737; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-danger:hover, .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-danger:hover{ - background-color:#c23030; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{ - background-color:#a82a2a; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-danger:disabled, .bp3-button.bp3-intent-danger.bp3-disabled{ - background-color:rgba(219, 55, 55, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{ - stroke:#ffffff; } - .bp3-button.bp3-large, - .bp3-large .bp3-button{ - min-height:40px; - min-width:40px; - font-size:16px; - padding:5px 15px; } - .bp3-button.bp3-large::before, - .bp3-button.bp3-large > *, - .bp3-large .bp3-button::before, - .bp3-large .bp3-button > *{ - margin-right:10px; } - .bp3-button.bp3-large:empty::before, - .bp3-button.bp3-large > :last-child, - .bp3-large .bp3-button:empty::before, - .bp3-large .bp3-button > :last-child{ - margin-right:0; } - .bp3-button.bp3-small, - .bp3-small .bp3-button{ - min-height:24px; - min-width:24px; - padding:0 7px; } - .bp3-button.bp3-loading{ - position:relative; } - .bp3-button.bp3-loading[class*="bp3-icon-"]::before{ - visibility:hidden; } - .bp3-button.bp3-loading .bp3-button-spinner{ - margin:0; - position:absolute; } - .bp3-button.bp3-loading > :not(.bp3-button-spinner){ - visibility:hidden; } - .bp3-button[class*="bp3-icon-"]::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - color:#5c7080; } - .bp3-button .bp3-icon, .bp3-button .bp3-icon-standard, .bp3-button .bp3-icon-large{ - color:#5c7080; } - .bp3-button .bp3-icon.bp3-align-right, .bp3-button .bp3-icon-standard.bp3-align-right, .bp3-button .bp3-icon-large.bp3-align-right{ - margin-left:7px; } - .bp3-button .bp3-icon:first-child:last-child, - .bp3-button .bp3-spinner + .bp3-icon:last-child{ - margin:0 -7px; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]){ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover, .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"])[class*="bp3-icon-"]::before{ - color:#a7b6c2; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-large{ - color:#a7b6c2; } - .bp3-dark .bp3-button[class*="bp3-intent-"]{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:active, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:disabled, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-disabled{ - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.3); } - .bp3-dark .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{ - stroke:#8a9ba8; } - .bp3-button:disabled::before, - .bp3-button:disabled .bp3-icon, .bp3-button:disabled .bp3-icon-standard, .bp3-button:disabled .bp3-icon-large, .bp3-button.bp3-disabled::before, - .bp3-button.bp3-disabled .bp3-icon, .bp3-button.bp3-disabled .bp3-icon-standard, .bp3-button.bp3-disabled .bp3-icon-large, .bp3-button[class*="bp3-intent-"]::before, - .bp3-button[class*="bp3-intent-"] .bp3-icon, .bp3-button[class*="bp3-intent-"] .bp3-icon-standard, .bp3-button[class*="bp3-intent-"] .bp3-icon-large{ - color:inherit !important; } - .bp3-button.bp3-minimal{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-button.bp3-minimal:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button.bp3-minimal:active, .bp3-button.bp3-minimal.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button.bp3-minimal:disabled, .bp3-button.bp3-minimal:disabled:hover, .bp3-button.bp3-minimal.bp3-disabled, .bp3-button.bp3-minimal.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button.bp3-minimal{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button.bp3-minimal:hover, .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button.bp3-minimal:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button.bp3-minimal:disabled, .bp3-dark .bp3-button.bp3-minimal:disabled:hover, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-primary{ - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:hover, .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-success{ - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:hover, .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-warning{ - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:hover, .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-danger{ - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:hover, .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - border:1px solid rgba(24, 32, 38, 0.2); - -webkit-box-sizing:border-box; - box-sizing:border-box; } - .bp3-button.bp3-outlined:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button.bp3-outlined:active, .bp3-button.bp3-outlined.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button.bp3-outlined{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button.bp3-outlined:hover, .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button.bp3-outlined:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-primary{ - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:hover, .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-success{ - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:hover, .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-warning{ - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:hover, .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-danger{ - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:hover, .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled:hover{ - border-color:rgba(92, 112, 128, 0.1); } - .bp3-dark .bp3-button.bp3-outlined{ - border-color:rgba(255, 255, 255, 0.4); } - .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{ - border-color:rgba(255, 255, 255, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-primary{ - border-color:rgba(16, 107, 163, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - border-color:rgba(16, 107, 163, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{ - border-color:rgba(72, 175, 240, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - border-color:rgba(72, 175, 240, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-success{ - border-color:rgba(13, 128, 80, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - border-color:rgba(13, 128, 80, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{ - border-color:rgba(61, 204, 145, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - border-color:rgba(61, 204, 145, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-warning{ - border-color:rgba(191, 115, 38, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - border-color:rgba(191, 115, 38, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{ - border-color:rgba(255, 179, 102, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - border-color:rgba(255, 179, 102, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-danger{ - border-color:rgba(194, 48, 48, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - border-color:rgba(194, 48, 48, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{ - border-color:rgba(255, 115, 115, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - border-color:rgba(255, 115, 115, 0.2); } - -a.bp3-button{ - text-align:center; - text-decoration:none; - -webkit-transition:none; - transition:none; } - a.bp3-button, a.bp3-button:hover, a.bp3-button:active{ - color:#182026; } - a.bp3-button.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); } - -.bp3-button-text{ - -webkit-box-flex:0; - -ms-flex:0 1 auto; - flex:0 1 auto; } - -.bp3-button.bp3-align-left .bp3-button-text, .bp3-button.bp3-align-right .bp3-button-text, -.bp3-button-group.bp3-align-left .bp3-button-text, -.bp3-button-group.bp3-align-right .bp3-button-text{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } -.bp3-button-group{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; } - .bp3-button-group .bp3-button{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - position:relative; - z-index:4; } - .bp3-button-group .bp3-button:focus{ - z-index:5; } - .bp3-button-group .bp3-button:hover{ - z-index:6; } - .bp3-button-group .bp3-button:active, .bp3-button-group .bp3-button.bp3-active{ - z-index:7; } - .bp3-button-group .bp3-button:disabled, .bp3-button-group .bp3-button.bp3-disabled{ - z-index:3; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]{ - z-index:9; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:focus{ - z-index:10; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:hover{ - z-index:11; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:active, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-active{ - z-index:12; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:disabled, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-disabled{ - z-index:8; } - .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:first-child) .bp3-button, - .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:first-child){ - border-bottom-left-radius:0; - border-top-left-radius:0; } - .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){ - border-bottom-right-radius:0; - border-top-right-radius:0; - margin-right:-1px; } - .bp3-button-group.bp3-minimal .bp3-button{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-button-group.bp3-minimal .bp3-button:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{ - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{ - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{ - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{ - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button-group .bp3-popover-wrapper, - .bp3-button-group .bp3-popover-target{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-button-group.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-button-group .bp3-button.bp3-fill, - .bp3-button-group.bp3-fill .bp3-button:not(.bp3-fixed){ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-button-group.bp3-vertical{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - vertical-align:top; } - .bp3-button-group.bp3-vertical.bp3-fill{ - height:100%; - width:unset; } - .bp3-button-group.bp3-vertical .bp3-button{ - margin-right:0 !important; - width:100%; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:first-child .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:first-child{ - border-radius:3px 3px 0 0; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:last-child .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:last-child{ - border-radius:0 0 3px 3px; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:not(:last-child){ - margin-bottom:-1px; } - .bp3-button-group.bp3-align-left .bp3-button{ - text-align:left; } - .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){ - margin-right:1px; } - .bp3-dark .bp3-button-group.bp3-vertical > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-dark .bp3-button-group.bp3-vertical > .bp3-button:not(:last-child){ - margin-bottom:1px; } -.bp3-callout{ - font-size:14px; - line-height:1.5; - background-color:rgba(138, 155, 168, 0.15); - border-radius:3px; - padding:10px 12px 9px; - position:relative; - width:100%; } - .bp3-callout[class*="bp3-icon-"]{ - padding-left:40px; } - .bp3-callout[class*="bp3-icon-"]::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - color:#5c7080; - left:10px; - position:absolute; - top:10px; } - .bp3-callout.bp3-callout-icon{ - padding-left:40px; } - .bp3-callout.bp3-callout-icon > .bp3-icon:first-child{ - color:#5c7080; - left:10px; - position:absolute; - top:10px; } - .bp3-callout .bp3-heading{ - line-height:20px; - margin-bottom:5px; - margin-top:0; } - .bp3-callout .bp3-heading:last-child{ - margin-bottom:0; } - .bp3-dark .bp3-callout{ - background-color:rgba(138, 155, 168, 0.2); } - .bp3-dark .bp3-callout[class*="bp3-icon-"]::before{ - color:#a7b6c2; } - .bp3-callout.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.15); } - .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-primary > .bp3-icon:first-child, - .bp3-callout.bp3-intent-primary .bp3-heading{ - color:#106ba3; } - .bp3-dark .bp3-callout.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-primary > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-primary .bp3-heading{ - color:#48aff0; } - .bp3-callout.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.15); } - .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-success > .bp3-icon:first-child, - .bp3-callout.bp3-intent-success .bp3-heading{ - color:#0d8050; } - .bp3-dark .bp3-callout.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-success > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-success .bp3-heading{ - color:#3dcc91; } - .bp3-callout.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.15); } - .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-warning > .bp3-icon:first-child, - .bp3-callout.bp3-intent-warning .bp3-heading{ - color:#bf7326; } - .bp3-dark .bp3-callout.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-warning > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-warning .bp3-heading{ - color:#ffb366; } - .bp3-callout.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.15); } - .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-danger > .bp3-icon:first-child, - .bp3-callout.bp3-intent-danger .bp3-heading{ - color:#c23030; } - .bp3-dark .bp3-callout.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-danger > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-danger .bp3-heading{ - color:#ff7373; } - .bp3-running-text .bp3-callout{ - margin:20px 0; } -.bp3-card{ - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - padding:20px; - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-card.bp3-dark, - .bp3-dark .bp3-card{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - -.bp3-elevation-0{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - .bp3-elevation-0.bp3-dark, - .bp3-dark .bp3-elevation-0{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - -.bp3-elevation-1{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-elevation-1.bp3-dark, - .bp3-dark .bp3-elevation-1{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-2{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); } - .bp3-elevation-2.bp3-dark, - .bp3-dark .bp3-elevation-2{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-3{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); } - .bp3-elevation-3.bp3-dark, - .bp3-dark .bp3-elevation-3{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-4{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); } - .bp3-elevation-4.bp3-dark, - .bp3-dark .bp3-elevation-4{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); } - -.bp3-card.bp3-interactive:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - cursor:pointer; } - .bp3-card.bp3-interactive:hover.bp3-dark, - .bp3-dark .bp3-card.bp3-interactive:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - -.bp3-card.bp3-interactive:active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - opacity:0.9; - -webkit-transition-duration:0; - transition-duration:0; } - .bp3-card.bp3-interactive:active.bp3-dark, - .bp3-dark .bp3-card.bp3-interactive:active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-collapse{ - height:0; - overflow-y:hidden; - -webkit-transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-collapse .bp3-collapse-body{ - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-collapse .bp3-collapse-body[aria-hidden="true"]{ - display:none; } - -.bp3-context-menu .bp3-popover-target{ - display:block; } - -.bp3-context-menu-popover-target{ - position:fixed; } - -.bp3-divider{ - border-bottom:1px solid rgba(16, 22, 26, 0.15); - border-right:1px solid rgba(16, 22, 26, 0.15); - margin:5px; } - .bp3-dark .bp3-divider{ - border-color:rgba(16, 22, 26, 0.4); } -.bp3-dialog-container{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - min-height:100%; - pointer-events:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - width:100%; } - .bp3-dialog-container.bp3-overlay-enter > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear > .bp3-dialog{ - opacity:0; - -webkit-transform:scale(0.5); - transform:scale(0.5); } - .bp3-dialog-container.bp3-overlay-enter-active > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear-active > .bp3-dialog{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:opacity, transform; - transition-property:opacity, transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-dialog-container.bp3-overlay-exit > .bp3-dialog{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-dialog-container.bp3-overlay-exit-active > .bp3-dialog{ - opacity:0; - -webkit-transform:scale(0.5); - transform:scale(0.5); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:opacity, transform; - transition-property:opacity, transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - -.bp3-dialog{ - background:#ebf1f5; - border-radius:6px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:30px 0; - padding-bottom:20px; - pointer-events:all; - -webkit-user-select:text; - -moz-user-select:text; - -ms-user-select:text; - user-select:text; - width:500px; } - .bp3-dialog:focus{ - outline:0; } - .bp3-dialog.bp3-dark, - .bp3-dark .bp3-dialog{ - background:#293742; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - -.bp3-dialog-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background:#ffffff; - border-radius:6px 6px 0 0; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - min-height:40px; - padding-left:20px; - padding-right:5px; - z-index:30; } - .bp3-dialog-header .bp3-icon-large, - .bp3-dialog-header .bp3-icon{ - color:#5c7080; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin-right:10px; } - .bp3-dialog-header .bp3-heading{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:inherit; - margin:0; } - .bp3-dialog-header .bp3-heading:last-child{ - margin-right:20px; } - .bp3-dark .bp3-dialog-header{ - background:#30404d; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-dialog-header .bp3-icon-large, - .bp3-dark .bp3-dialog-header .bp3-icon{ - color:#a7b6c2; } - -.bp3-dialog-body{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:18px; - margin:20px; } - -.bp3-dialog-footer{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin:0 20px; } - -.bp3-dialog-footer-actions{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:end; - -ms-flex-pack:end; - justify-content:flex-end; } - .bp3-dialog-footer-actions .bp3-button{ - margin-left:10px; } -.bp3-multistep-dialog-panels{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - -.bp3-multistep-dialog-left-panel{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-dark .bp3-multistep-dialog-left-panel{ - background:#202b33; } - -.bp3-multistep-dialog-right-panel{ - background-color:#f5f8fa; - border-left:1px solid rgba(16, 22, 26, 0.15); - border-radius:0 0 6px 0; - -webkit-box-flex:3; - -ms-flex:3; - flex:3; - min-width:0; } - .bp3-dark .bp3-multistep-dialog-right-panel{ - background-color:#293742; - border-left:1px solid rgba(16, 22, 26, 0.4); } - -.bp3-multistep-dialog-footer{ - background-color:#ffffff; - border-radius:0 0 6px 0; - border-top:1px solid rgba(16, 22, 26, 0.15); - padding:10px; } - .bp3-dark .bp3-multistep-dialog-footer{ - background:#30404d; - border-top:1px solid rgba(16, 22, 26, 0.4); } - -.bp3-dialog-step-container{ - background-color:#f5f8fa; - border-bottom:1px solid rgba(16, 22, 26, 0.15); } - .bp3-dark .bp3-dialog-step-container{ - background:#293742; - border-bottom:1px solid rgba(16, 22, 26, 0.4); } - .bp3-dialog-step-container.bp3-dialog-step-viewed{ - background-color:#ffffff; } - .bp3-dark .bp3-dialog-step-container.bp3-dialog-step-viewed{ - background:#30404d; } - -.bp3-dialog-step{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:#f5f8fa; - border-radius:6px; - cursor:not-allowed; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin:4px; - padding:6px 14px; } - .bp3-dark .bp3-dialog-step{ - background:#293742; } - .bp3-dialog-step-viewed .bp3-dialog-step{ - background-color:#ffffff; - cursor:pointer; } - .bp3-dark .bp3-dialog-step-viewed .bp3-dialog-step{ - background:#30404d; } - .bp3-dialog-step:hover{ - background-color:#f5f8fa; } - .bp3-dark .bp3-dialog-step:hover{ - background:#293742; } - -.bp3-dialog-step-icon{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:rgba(92, 112, 128, 0.6); - border-radius:50%; - color:#ffffff; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:25px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - width:25px; } - .bp3-dark .bp3-dialog-step-icon{ - background-color:rgba(167, 182, 194, 0.6); } - .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-icon{ - background-color:#2b95d6; } - .bp3-dialog-step-viewed .bp3-dialog-step-icon{ - background-color:#8a9ba8; } - -.bp3-dialog-step-title{ - color:rgba(92, 112, 128, 0.6); - -webkit-box-flex:1; - -ms-flex:1; - flex:1; - padding-left:10px; } - .bp3-dark .bp3-dialog-step-title{ - color:rgba(167, 182, 194, 0.6); } - .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-title{ - color:#2b95d6; } - .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{ - color:#182026; } - .bp3-dark .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{ - color:#f5f8fa; } -.bp3-drawer{ - background:#ffffff; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:0; - padding:0; } - .bp3-drawer:focus{ - outline:0; } - .bp3-drawer.bp3-position-top{ - height:50%; - left:0; - right:0; - top:0; } - .bp3-drawer.bp3-position-top.bp3-overlay-enter, .bp3-drawer.bp3-position-top.bp3-overlay-appear{ - -webkit-transform:translateY(-100%); - transform:translateY(-100%); } - .bp3-drawer.bp3-position-top.bp3-overlay-enter-active, .bp3-drawer.bp3-position-top.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-top.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer.bp3-position-top.bp3-overlay-exit-active{ - -webkit-transform:translateY(-100%); - transform:translateY(-100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-bottom{ - bottom:0; - height:50%; - left:0; - right:0; } - .bp3-drawer.bp3-position-bottom.bp3-overlay-enter, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear{ - -webkit-transform:translateY(100%); - transform:translateY(100%); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-enter-active, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-exit-active{ - -webkit-transform:translateY(100%); - transform:translateY(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-left{ - bottom:0; - left:0; - top:0; - width:50%; } - .bp3-drawer.bp3-position-left.bp3-overlay-enter, .bp3-drawer.bp3-position-left.bp3-overlay-appear{ - -webkit-transform:translateX(-100%); - transform:translateX(-100%); } - .bp3-drawer.bp3-position-left.bp3-overlay-enter-active, .bp3-drawer.bp3-position-left.bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-left.bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer.bp3-position-left.bp3-overlay-exit-active{ - -webkit-transform:translateX(-100%); - transform:translateX(-100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-right{ - bottom:0; - right:0; - top:0; - width:50%; } - .bp3-drawer.bp3-position-right.bp3-overlay-enter, .bp3-drawer.bp3-position-right.bp3-overlay-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); } - .bp3-drawer.bp3-position-right.bp3-overlay-enter-active, .bp3-drawer.bp3-position-right.bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-right.bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer.bp3-position-right.bp3-overlay-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical){ - bottom:0; - right:0; - top:0; - width:50%; } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical{ - bottom:0; - height:50%; - left:0; - right:0; } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-appear{ - -webkit-transform:translateY(100%); - transform:translateY(100%); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-exit-active{ - -webkit-transform:translateY(100%); - transform:translateY(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-dark, - .bp3-dark .bp3-drawer{ - background:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - -.bp3-drawer-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border-radius:0; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - min-height:40px; - padding:5px; - padding-left:20px; - position:relative; } - .bp3-drawer-header .bp3-icon-large, - .bp3-drawer-header .bp3-icon{ - color:#5c7080; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin-right:10px; } - .bp3-drawer-header .bp3-heading{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:inherit; - margin:0; } - .bp3-drawer-header .bp3-heading:last-child{ - margin-right:20px; } - .bp3-dark .bp3-drawer-header{ - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-drawer-header .bp3-icon-large, - .bp3-dark .bp3-drawer-header .bp3-icon{ - color:#a7b6c2; } - -.bp3-drawer-body{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:18px; - overflow:auto; } - -.bp3-drawer-footer{ - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - padding:10px 20px; - position:relative; } - .bp3-dark .bp3-drawer-footer{ - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); } -.bp3-editable-text{ - cursor:text; - display:inline-block; - max-width:100%; - position:relative; - vertical-align:top; - white-space:nowrap; } - .bp3-editable-text::before{ - bottom:-3px; - left:-3px; - position:absolute; - right:-3px; - top:-3px; - border-radius:3px; - content:""; - -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-editable-text:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-editable-text.bp3-editable-text-editing::before{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-disabled::before{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-editable-text.bp3-intent-primary .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{ - color:#137cbd; } - .bp3-editable-text.bp3-intent-primary:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); } - .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-success .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{ - color:#0f9960; } - .bp3-editable-text.bp3-intent-success:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); } - .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-warning .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{ - color:#d9822b; } - .bp3-editable-text.bp3-intent-warning:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); } - .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-danger .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{ - color:#db3737; } - .bp3-editable-text.bp3-intent-danger:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); } - .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-editable-text:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); } - .bp3-dark .bp3-editable-text.bp3-editable-text-editing::before{ - background-color:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-disabled::before{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{ - color:#48aff0; } - .bp3-dark .bp3-editable-text.bp3-intent-primary:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); - box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{ - color:#3dcc91; } - .bp3-dark .bp3-editable-text.bp3-intent-success:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); - box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{ - color:#ffb366; } - .bp3-dark .bp3-editable-text.bp3-intent-warning:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); - box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{ - color:#ff7373; } - .bp3-dark .bp3-editable-text.bp3-intent-danger:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); - box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-editable-text-input, -.bp3-editable-text-content{ - color:inherit; - display:inherit; - font:inherit; - letter-spacing:inherit; - max-width:inherit; - min-width:inherit; - position:relative; - resize:none; - text-transform:inherit; - vertical-align:top; } - -.bp3-editable-text-input{ - background:none; - border:none; - -webkit-box-shadow:none; - box-shadow:none; - padding:0; - white-space:pre-wrap; - width:100%; } - .bp3-editable-text-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input:focus{ - outline:none; } - .bp3-editable-text-input::-ms-clear{ - display:none; } - -.bp3-editable-text-content{ - overflow:hidden; - padding-right:2px; - text-overflow:ellipsis; - white-space:pre; } - .bp3-editable-text-editing > .bp3-editable-text-content{ - left:0; - position:absolute; - visibility:hidden; } - .bp3-editable-text-placeholder > .bp3-editable-text-content{ - color:rgba(92, 112, 128, 0.6); } - .bp3-dark .bp3-editable-text-placeholder > .bp3-editable-text-content{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-editable-text.bp3-multiline{ - display:block; } - .bp3-editable-text.bp3-multiline .bp3-editable-text-content{ - overflow:auto; - white-space:pre-wrap; - word-wrap:break-word; } -.bp3-divider{ - border-bottom:1px solid rgba(16, 22, 26, 0.15); - border-right:1px solid rgba(16, 22, 26, 0.15); - margin:5px; } - .bp3-dark .bp3-divider{ - border-color:rgba(16, 22, 26, 0.4); } -.bp3-control-group{ - -webkit-transform:translateZ(0); - transform:translateZ(0); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; } - .bp3-control-group > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-control-group > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-control-group .bp3-button, - .bp3-control-group .bp3-html-select, - .bp3-control-group .bp3-input, - .bp3-control-group .bp3-select{ - position:relative; } - .bp3-control-group .bp3-input{ - border-radius:inherit; - z-index:2; } - .bp3-control-group .bp3-input:focus{ - border-radius:3px; - z-index:14; } - .bp3-control-group .bp3-input[class*="bp3-intent"]{ - z-index:13; } - .bp3-control-group .bp3-input[class*="bp3-intent"]:focus{ - z-index:15; } - .bp3-control-group .bp3-input[readonly], .bp3-control-group .bp3-input:disabled, .bp3-control-group .bp3-input.bp3-disabled{ - z-index:1; } - .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input{ - z-index:13; } - .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input:focus{ - z-index:15; } - .bp3-control-group .bp3-button, - .bp3-control-group .bp3-html-select select, - .bp3-control-group .bp3-select select{ - -webkit-transform:translateZ(0); - transform:translateZ(0); - border-radius:inherit; - z-index:4; } - .bp3-control-group .bp3-button:focus, - .bp3-control-group .bp3-html-select select:focus, - .bp3-control-group .bp3-select select:focus{ - z-index:5; } - .bp3-control-group .bp3-button:hover, - .bp3-control-group .bp3-html-select select:hover, - .bp3-control-group .bp3-select select:hover{ - z-index:6; } - .bp3-control-group .bp3-button:active, - .bp3-control-group .bp3-html-select select:active, - .bp3-control-group .bp3-select select:active{ - z-index:7; } - .bp3-control-group .bp3-button[readonly], .bp3-control-group .bp3-button:disabled, .bp3-control-group .bp3-button.bp3-disabled, - .bp3-control-group .bp3-html-select select[readonly], - .bp3-control-group .bp3-html-select select:disabled, - .bp3-control-group .bp3-html-select select.bp3-disabled, - .bp3-control-group .bp3-select select[readonly], - .bp3-control-group .bp3-select select:disabled, - .bp3-control-group .bp3-select select.bp3-disabled{ - z-index:3; } - .bp3-control-group .bp3-button[class*="bp3-intent"], - .bp3-control-group .bp3-html-select select[class*="bp3-intent"], - .bp3-control-group .bp3-select select[class*="bp3-intent"]{ - z-index:9; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:focus, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:focus, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:focus{ - z-index:10; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:hover, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:hover, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:hover{ - z-index:11; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:active, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:active, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:active{ - z-index:12; } - .bp3-control-group .bp3-button[class*="bp3-intent"][readonly], .bp3-control-group .bp3-button[class*="bp3-intent"]:disabled, .bp3-control-group .bp3-button[class*="bp3-intent"].bp3-disabled, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"][readonly], - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:disabled, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"].bp3-disabled, - .bp3-control-group .bp3-select select[class*="bp3-intent"][readonly], - .bp3-control-group .bp3-select select[class*="bp3-intent"]:disabled, - .bp3-control-group .bp3-select select[class*="bp3-intent"].bp3-disabled{ - z-index:8; } - .bp3-control-group .bp3-input-group > .bp3-icon, - .bp3-control-group .bp3-input-group > .bp3-button, - .bp3-control-group .bp3-input-group > .bp3-input-left-container, - .bp3-control-group .bp3-input-group > .bp3-input-action{ - z-index:16; } - .bp3-control-group .bp3-select::after, - .bp3-control-group .bp3-html-select::after, - .bp3-control-group .bp3-select > .bp3-icon, - .bp3-control-group .bp3-html-select > .bp3-icon{ - z-index:17; } - .bp3-control-group .bp3-select:focus-within{ - z-index:5; } - .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){ - margin-right:-1px; } - .bp3-control-group:not(.bp3-vertical) > .bp3-divider:not(:first-child){ - margin-left:6px; } - .bp3-dark .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){ - margin-right:0; } - .bp3-dark .bp3-control-group:not(.bp3-vertical) > .bp3-button + .bp3-button{ - margin-left:1px; } - .bp3-control-group .bp3-popover-wrapper, - .bp3-control-group .bp3-popover-target{ - border-radius:inherit; } - .bp3-control-group > :first-child{ - border-radius:3px 0 0 3px; } - .bp3-control-group > :last-child{ - border-radius:0 3px 3px 0; - margin-right:0; } - .bp3-control-group > :only-child{ - border-radius:3px; - margin-right:0; } - .bp3-control-group .bp3-input-group .bp3-button{ - border-radius:3px; } - .bp3-control-group .bp3-numeric-input:not(:first-child) .bp3-input-group{ - border-bottom-left-radius:0; - border-top-left-radius:0; } - .bp3-control-group.bp3-fill{ - width:100%; } - .bp3-control-group > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-control-group.bp3-fill > *:not(.bp3-fixed){ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-control-group.bp3-vertical{ - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-control-group.bp3-vertical > *{ - margin-top:-1px; } - .bp3-control-group.bp3-vertical > :first-child{ - border-radius:3px 3px 0 0; - margin-top:0; } - .bp3-control-group.bp3-vertical > :last-child{ - border-radius:0 0 3px 3px; } -.bp3-control{ - cursor:pointer; - display:block; - margin-bottom:10px; - position:relative; - text-transform:none; } - .bp3-control input:checked ~ .bp3-control-indicator{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-control:hover input:checked ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{ - background:#0e5a8a; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control input:disabled:checked ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-control input:checked ~ .bp3-control-indicator{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control:hover input:checked ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{ - background-color:#0e5a8a; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control input:disabled:checked ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-control:not(.bp3-align-right){ - padding-left:26px; } - .bp3-control:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-26px; } - .bp3-control.bp3-align-right{ - padding-right:26px; } - .bp3-control.bp3-align-right .bp3-control-indicator{ - margin-right:-26px; } - .bp3-control.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-control.bp3-inline{ - display:inline-block; - margin-right:20px; } - .bp3-control input{ - left:0; - opacity:0; - position:absolute; - top:0; - z-index:-1; } - .bp3-control .bp3-control-indicator{ - background-clip:padding-box; - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - border:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - cursor:pointer; - display:inline-block; - font-size:16px; - height:1em; - margin-right:10px; - margin-top:-3px; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - vertical-align:middle; - width:1em; } - .bp3-control .bp3-control-indicator::before{ - content:""; - display:block; - height:1em; - width:1em; } - .bp3-control:hover .bp3-control-indicator{ - background-color:#ebf1f5; } - .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{ - background:#d8e1e8; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control input:disabled ~ .bp3-control-indicator{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - cursor:not-allowed; } - .bp3-control input:focus ~ .bp3-control-indicator{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:2px; - -moz-outline-radius:6px; } - .bp3-control.bp3-align-right .bp3-control-indicator{ - float:right; - margin-left:10px; - margin-top:1px; } - .bp3-control.bp3-large{ - font-size:16px; } - .bp3-control.bp3-large:not(.bp3-align-right){ - padding-left:30px; } - .bp3-control.bp3-large:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-30px; } - .bp3-control.bp3-large.bp3-align-right{ - padding-right:30px; } - .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-right:-30px; } - .bp3-control.bp3-large .bp3-control-indicator{ - font-size:20px; } - .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-top:0; } - .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{ - background:#0e5a8a; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{ - background-color:#0e5a8a; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-control.bp3-checkbox .bp3-control-indicator{ - border-radius:3px; } - .bp3-control.bp3-checkbox input:checked ~ .bp3-control-indicator::before{ - background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M12 5c-.28 0-.53.11-.71.29L7 9.59l-2.29-2.3a1.003 1.003 0 00-1.42 1.42l3 3c.18.18.43.29.71.29s.53-.11.71-.29l5-5A1.003 1.003 0 0012 5z' fill='white'/%3e%3c/svg%3e"); } - .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator::before{ - background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M11 7H5c-.55 0-1 .45-1 1s.45 1 1 1h6c.55 0 1-.45 1-1s-.45-1-1-1z' fill='white'/%3e%3c/svg%3e"); } - .bp3-control.bp3-radio .bp3-control-indicator{ - border-radius:50%; } - .bp3-control.bp3-radio input:checked ~ .bp3-control-indicator::before{ - background-image:radial-gradient(#ffffff, #ffffff 28%, transparent 32%); } - .bp3-control.bp3-radio input:checked:disabled ~ .bp3-control-indicator::before{ - opacity:0.5; } - .bp3-control.bp3-radio input:focus ~ .bp3-control-indicator{ - -moz-outline-radius:16px; } - .bp3-control.bp3-switch input ~ .bp3-control-indicator{ - background:rgba(167, 182, 194, 0.5); } - .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{ - background:rgba(115, 134, 148, 0.5); } - .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{ - background:rgba(92, 112, 128, 0.5); } - .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{ - background:rgba(206, 217, 224, 0.5); } - .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{ - background:rgba(255, 255, 255, 0.8); } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{ - background:#137cbd; } - .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{ - background:#106ba3; } - .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{ - background:#0e5a8a; } - .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); } - .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{ - background:rgba(255, 255, 255, 0.8); } - .bp3-control.bp3-switch:not(.bp3-align-right){ - padding-left:38px; } - .bp3-control.bp3-switch:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-38px; } - .bp3-control.bp3-switch.bp3-align-right{ - padding-right:38px; } - .bp3-control.bp3-switch.bp3-align-right .bp3-control-indicator{ - margin-right:-38px; } - .bp3-control.bp3-switch .bp3-control-indicator{ - border:none; - border-radius:1.75em; - -webkit-box-shadow:none !important; - box-shadow:none !important; - min-width:1.75em; - -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:auto; } - .bp3-control.bp3-switch .bp3-control-indicator::before{ - background:#ffffff; - border-radius:50%; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - height:calc(1em - 4px); - left:0; - margin:2px; - position:absolute; - -webkit-transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:calc(1em - 4px); } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{ - left:calc(100% - 1em); } - .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right){ - padding-left:45px; } - .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-45px; } - .bp3-control.bp3-switch.bp3-large.bp3-align-right{ - padding-right:45px; } - .bp3-control.bp3-switch.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-right:-45px; } - .bp3-dark .bp3-control.bp3-switch input ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.5); } - .bp3-dark .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.7); } - .bp3-dark .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.9); } - .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{ - background:rgba(57, 75, 89, 0.5); } - .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{ - background:#137cbd; } - .bp3-dark .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{ - background:#106ba3; } - .bp3-dark .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{ - background:#0e5a8a; } - .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); } - .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch .bp3-control-indicator::before{ - background:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-control.bp3-switch .bp3-switch-inner-text{ - font-size:0.7em; - text-align:center; } - .bp3-control.bp3-switch .bp3-control-indicator-child:first-child{ - line-height:0; - margin-left:0.5em; - margin-right:1.2em; - visibility:hidden; } - .bp3-control.bp3-switch .bp3-control-indicator-child:last-child{ - line-height:1em; - margin-left:1.2em; - margin-right:0.5em; - visibility:visible; } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:first-child{ - line-height:1em; - visibility:visible; } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:last-child{ - line-height:0; - visibility:hidden; } - .bp3-dark .bp3-control{ - color:#f5f8fa; } - .bp3-dark .bp3-control.bp3-disabled{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-control .bp3-control-indicator{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control:hover .bp3-control-indicator{ - background-color:#30404d; } - .bp3-dark .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{ - background:#202b33; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control input:disabled ~ .bp3-control-indicator{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - cursor:not-allowed; } - .bp3-dark .bp3-control.bp3-checkbox input:disabled:checked ~ .bp3-control-indicator, .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - color:rgba(167, 182, 194, 0.6); } -.bp3-file-input{ - cursor:pointer; - display:inline-block; - height:30px; - position:relative; } - .bp3-file-input input{ - margin:0; - min-width:200px; - opacity:0; } - .bp3-file-input input:disabled + .bp3-file-upload-input, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-file-input input:disabled + .bp3-file-upload-input::after, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active:hover, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{ - color:#182026; } - .bp3-dark .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{ - color:#f5f8fa; } - .bp3-file-input.bp3-fill{ - width:100%; } - .bp3-file-input.bp3-large, - .bp3-large .bp3-file-input{ - height:40px; } - .bp3-file-input .bp3-file-upload-input-custom-text::after{ - content:attr(bp3-button-text); } - -.bp3-file-upload-input{ - -webkit-appearance:none; - -moz-appearance:none; - appearance:none; - background:#ffffff; - border:none; - border-radius:3px; - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - color:#182026; - font-size:14px; - font-weight:400; - height:30px; - line-height:30px; - outline:none; - padding:0 10px; - -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - vertical-align:middle; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - color:rgba(92, 112, 128, 0.6); - left:0; - padding-right:80px; - position:absolute; - right:0; - top:0; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-file-upload-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input:focus, .bp3-file-upload-input.bp3-active{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-file-upload-input[type="search"], .bp3-file-upload-input.bp3-round{ - border-radius:30px; - -webkit-box-sizing:border-box; - box-sizing:border-box; - padding-left:10px; } - .bp3-file-upload-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-file-upload-input:disabled, .bp3-file-upload-input.bp3-disabled{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-file-upload-input::after{ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - min-height:24px; - min-width:24px; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - border-radius:3px; - content:"Browse"; - line-height:24px; - margin:3px; - position:absolute; - right:0; - text-align:center; - top:0; - width:70px; } - .bp3-file-upload-input::after:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-file-upload-input::after:active, .bp3-file-upload-input::after.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-file-upload-input::after:disabled, .bp3-file-upload-input::after.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-file-upload-input::after:disabled.bp3-active, .bp3-file-upload-input::after:disabled.bp3-active:hover, .bp3-file-upload-input::after.bp3-disabled.bp3-active, .bp3-file-upload-input::after.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-file-upload-input:hover::after{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-file-upload-input:active::after{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-large .bp3-file-upload-input{ - font-size:16px; - height:40px; - line-height:40px; - padding-right:95px; } - .bp3-large .bp3-file-upload-input[type="search"], .bp3-large .bp3-file-upload-input.bp3-round{ - padding:0 15px; } - .bp3-large .bp3-file-upload-input::after{ - min-height:30px; - min-width:30px; - line-height:30px; - margin:5px; - width:85px; } - .bp3-dark .bp3-file-upload-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input:disabled, .bp3-dark .bp3-file-upload-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::after{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-file-upload-input::after:hover, .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-file-upload-input::after:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-file-upload-input::after:disabled, .bp3-dark .bp3-file-upload-input::after.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::after:disabled.bp3-active, .bp3-dark .bp3-file-upload-input::after.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-file-upload-input::after .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-file-upload-input:hover::after{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input:active::after{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } -.bp3-file-upload-input::after{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } -.bp3-form-group{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:0 0 15px; } - .bp3-form-group label.bp3-label{ - margin-bottom:5px; } - .bp3-form-group .bp3-control{ - margin-top:7px; } - .bp3-form-group .bp3-form-helper-text{ - color:#5c7080; - font-size:12px; - margin-top:5px; } - .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{ - color:#106ba3; } - .bp3-form-group.bp3-intent-success .bp3-form-helper-text{ - color:#0d8050; } - .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{ - color:#bf7326; } - .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{ - color:#c23030; } - .bp3-form-group.bp3-inline{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; } - .bp3-form-group.bp3-inline.bp3-large label.bp3-label{ - line-height:40px; - margin:0 10px 0 0; } - .bp3-form-group.bp3-inline label.bp3-label{ - line-height:30px; - margin:0 10px 0 0; } - .bp3-form-group.bp3-disabled .bp3-label, - .bp3-form-group.bp3-disabled .bp3-text-muted, - .bp3-form-group.bp3-disabled .bp3-form-helper-text{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-dark .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{ - color:#48aff0; } - .bp3-dark .bp3-form-group.bp3-intent-success .bp3-form-helper-text{ - color:#3dcc91; } - .bp3-dark .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{ - color:#ffb366; } - .bp3-dark .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{ - color:#ff7373; } - .bp3-dark .bp3-form-group .bp3-form-helper-text{ - color:#a7b6c2; } - .bp3-dark .bp3-form-group.bp3-disabled .bp3-label, - .bp3-dark .bp3-form-group.bp3-disabled .bp3-text-muted, - .bp3-dark .bp3-form-group.bp3-disabled .bp3-form-helper-text{ - color:rgba(167, 182, 194, 0.6) !important; } -.bp3-input-group{ - display:block; - position:relative; } - .bp3-input-group .bp3-input{ - position:relative; - width:100%; } - .bp3-input-group .bp3-input:not(:first-child){ - padding-left:30px; } - .bp3-input-group .bp3-input:not(:last-child){ - padding-right:30px; } - .bp3-input-group .bp3-input-action, - .bp3-input-group > .bp3-input-left-container, - .bp3-input-group > .bp3-button, - .bp3-input-group > .bp3-icon{ - position:absolute; - top:0; } - .bp3-input-group .bp3-input-action:first-child, - .bp3-input-group > .bp3-input-left-container:first-child, - .bp3-input-group > .bp3-button:first-child, - .bp3-input-group > .bp3-icon:first-child{ - left:0; } - .bp3-input-group .bp3-input-action:last-child, - .bp3-input-group > .bp3-input-left-container:last-child, - .bp3-input-group > .bp3-button:last-child, - .bp3-input-group > .bp3-icon:last-child{ - right:0; } - .bp3-input-group .bp3-button{ - min-height:24px; - min-width:24px; - margin:3px; - padding:0 7px; } - .bp3-input-group .bp3-button:empty{ - padding:0; } - .bp3-input-group > .bp3-input-left-container, - .bp3-input-group > .bp3-icon{ - z-index:1; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon, - .bp3-input-group > .bp3-icon{ - color:#5c7080; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon:empty, - .bp3-input-group > .bp3-icon:empty{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon, - .bp3-input-group > .bp3-icon, - .bp3-input-group .bp3-input-action > .bp3-spinner{ - margin:7px; } - .bp3-input-group .bp3-tag{ - margin:5px; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){ - color:#5c7080; } - .bp3-dark .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), .bp3-dark - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){ - color:#a7b6c2; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large{ - color:#5c7080; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-large, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-standard, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-large{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-input-group.bp3-disabled{ - cursor:not-allowed; } - .bp3-input-group.bp3-disabled .bp3-icon{ - color:rgba(92, 112, 128, 0.6); } - .bp3-input-group.bp3-large .bp3-button{ - min-height:30px; - min-width:30px; - margin:5px; } - .bp3-input-group.bp3-large > .bp3-input-left-container > .bp3-icon, - .bp3-input-group.bp3-large > .bp3-icon, - .bp3-input-group.bp3-large .bp3-input-action > .bp3-spinner{ - margin:12px; } - .bp3-input-group.bp3-large .bp3-input{ - font-size:16px; - height:40px; - line-height:40px; } - .bp3-input-group.bp3-large .bp3-input[type="search"], .bp3-input-group.bp3-large .bp3-input.bp3-round{ - padding:0 15px; } - .bp3-input-group.bp3-large .bp3-input:not(:first-child){ - padding-left:40px; } - .bp3-input-group.bp3-large .bp3-input:not(:last-child){ - padding-right:40px; } - .bp3-input-group.bp3-small .bp3-button{ - min-height:20px; - min-width:20px; - margin:2px; } - .bp3-input-group.bp3-small .bp3-tag{ - min-height:20px; - min-width:20px; - margin:2px; } - .bp3-input-group.bp3-small > .bp3-input-left-container > .bp3-icon, - .bp3-input-group.bp3-small > .bp3-icon, - .bp3-input-group.bp3-small .bp3-input-action > .bp3-spinner{ - margin:4px; } - .bp3-input-group.bp3-small .bp3-input{ - font-size:12px; - height:24px; - line-height:24px; - padding-left:8px; - padding-right:8px; } - .bp3-input-group.bp3-small .bp3-input[type="search"], .bp3-input-group.bp3-small .bp3-input.bp3-round{ - padding:0 12px; } - .bp3-input-group.bp3-small .bp3-input:not(:first-child){ - padding-left:24px; } - .bp3-input-group.bp3-small .bp3-input:not(:last-child){ - padding-right:24px; } - .bp3-input-group.bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - width:100%; } - .bp3-input-group.bp3-round .bp3-button, - .bp3-input-group.bp3-round .bp3-input, - .bp3-input-group.bp3-round .bp3-tag{ - border-radius:30px; } - .bp3-dark .bp3-input-group .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-input-group.bp3-disabled .bp3-icon{ - color:rgba(167, 182, 194, 0.6); } - .bp3-input-group.bp3-intent-primary .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-primary .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-primary .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-input-group.bp3-intent-primary .bp3-input:disabled, .bp3-input-group.bp3-intent-primary .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-primary > .bp3-icon{ - color:#106ba3; } - .bp3-dark .bp3-input-group.bp3-intent-primary > .bp3-icon{ - color:#48aff0; } - .bp3-input-group.bp3-intent-success .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-success .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-success .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-input-group.bp3-intent-success .bp3-input:disabled, .bp3-input-group.bp3-intent-success .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-success > .bp3-icon{ - color:#0d8050; } - .bp3-dark .bp3-input-group.bp3-intent-success > .bp3-icon{ - color:#3dcc91; } - .bp3-input-group.bp3-intent-warning .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-warning .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-warning .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-input-group.bp3-intent-warning .bp3-input:disabled, .bp3-input-group.bp3-intent-warning .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-warning > .bp3-icon{ - color:#bf7326; } - .bp3-dark .bp3-input-group.bp3-intent-warning > .bp3-icon{ - color:#ffb366; } - .bp3-input-group.bp3-intent-danger .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-danger .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-danger .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-input-group.bp3-intent-danger .bp3-input:disabled, .bp3-input-group.bp3-intent-danger .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-danger > .bp3-icon{ - color:#c23030; } - .bp3-dark .bp3-input-group.bp3-intent-danger > .bp3-icon{ - color:#ff7373; } -.bp3-input{ - -webkit-appearance:none; - -moz-appearance:none; - appearance:none; - background:#ffffff; - border:none; - border-radius:3px; - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - color:#182026; - font-size:14px; - font-weight:400; - height:30px; - line-height:30px; - outline:none; - padding:0 10px; - -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - vertical-align:middle; } - .bp3-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input:focus, .bp3-input.bp3-active{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input[type="search"], .bp3-input.bp3-round{ - border-radius:30px; - -webkit-box-sizing:border-box; - box-sizing:border-box; - padding-left:10px; } - .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-input:disabled, .bp3-input.bp3-disabled{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-input.bp3-large{ - font-size:16px; - height:40px; - line-height:40px; } - .bp3-input.bp3-large[type="search"], .bp3-input.bp3-large.bp3-round{ - padding:0 15px; } - .bp3-input.bp3-small{ - font-size:12px; - height:24px; - line-height:24px; - padding-left:8px; - padding-right:8px; } - .bp3-input.bp3-small[type="search"], .bp3-input.bp3-small.bp3-round{ - padding:0 12px; } - .bp3-input.bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - width:100%; } - .bp3-dark .bp3-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input:disabled, .bp3-dark .bp3-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-input.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-primary:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-primary[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-input.bp3-intent-primary:disabled, .bp3-input.bp3-intent-primary.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-primary:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-primary[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-dark .bp3-input.bp3-intent-primary:disabled, .bp3-dark .bp3-input.bp3-intent-primary.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-success{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-success:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-success[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-input.bp3-intent-success:disabled, .bp3-input.bp3-intent-success.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-success{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-success:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-success[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-dark .bp3-input.bp3-intent-success:disabled, .bp3-dark .bp3-input.bp3-intent-success.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-warning:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-warning[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-input.bp3-intent-warning:disabled, .bp3-input.bp3-intent-warning.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-warning:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-warning[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-dark .bp3-input.bp3-intent-warning:disabled, .bp3-dark .bp3-input.bp3-intent-warning.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-danger:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-danger[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-input.bp3-intent-danger:disabled, .bp3-input.bp3-intent-danger.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-danger:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-danger[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-dark .bp3-input.bp3-intent-danger:disabled, .bp3-dark .bp3-input.bp3-intent-danger.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input::-ms-clear{ - display:none; } -textarea.bp3-input{ - max-width:100%; - padding:10px; } - textarea.bp3-input, textarea.bp3-input.bp3-large, textarea.bp3-input.bp3-small{ - height:auto; - line-height:inherit; } - textarea.bp3-input.bp3-small{ - padding:8px; } - .bp3-dark textarea.bp3-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark textarea.bp3-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark textarea.bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark textarea.bp3-input:disabled, .bp3-dark textarea.bp3-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } -label.bp3-label{ - display:block; - margin-bottom:15px; - margin-top:0; } - label.bp3-label .bp3-html-select, - label.bp3-label .bp3-input, - label.bp3-label .bp3-select, - label.bp3-label .bp3-slider, - label.bp3-label .bp3-popover-wrapper{ - display:block; - margin-top:5px; - text-transform:none; } - label.bp3-label .bp3-button-group{ - margin-top:5px; } - label.bp3-label .bp3-select select, - label.bp3-label .bp3-html-select select{ - font-weight:400; - vertical-align:top; - width:100%; } - label.bp3-label.bp3-disabled, - label.bp3-label.bp3-disabled .bp3-text-muted{ - color:rgba(92, 112, 128, 0.6); } - label.bp3-label.bp3-inline{ - line-height:30px; } - label.bp3-label.bp3-inline .bp3-html-select, - label.bp3-label.bp3-inline .bp3-input, - label.bp3-label.bp3-inline .bp3-input-group, - label.bp3-label.bp3-inline .bp3-select, - label.bp3-label.bp3-inline .bp3-popover-wrapper{ - display:inline-block; - margin:0 0 0 5px; - vertical-align:top; } - label.bp3-label.bp3-inline .bp3-button-group{ - margin:0 0 0 5px; } - label.bp3-label.bp3-inline .bp3-input-group .bp3-input{ - margin-left:0; } - label.bp3-label.bp3-inline.bp3-large{ - line-height:40px; } - label.bp3-label:not(.bp3-inline) .bp3-popover-target{ - display:block; } - .bp3-dark label.bp3-label{ - color:#f5f8fa; } - .bp3-dark label.bp3-label.bp3-disabled, - .bp3-dark label.bp3-label.bp3-disabled .bp3-text-muted{ - color:rgba(167, 182, 194, 0.6); } -.bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button{ - -webkit-box-flex:1; - -ms-flex:1 1 14px; - flex:1 1 14px; - min-height:0; - padding:0; - width:30px; } - .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:first-child{ - border-radius:0 3px 0 0; } - .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:last-child{ - border-radius:0 0 3px 0; } - -.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:first-child{ - border-radius:3px 0 0 0; } - -.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:last-child{ - border-radius:0 0 0 3px; } - -.bp3-numeric-input.bp3-large .bp3-button-group.bp3-vertical > .bp3-button{ - width:40px; } - -form{ - display:block; } -.bp3-html-select select, -.bp3-select select{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border:none; - border-radius:3px; - cursor:pointer; - font-size:14px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - padding:5px 10px; - text-align:left; - vertical-align:middle; - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - -moz-appearance:none; - -webkit-appearance:none; - border-radius:3px; - height:30px; - padding:0 25px 0 10px; - width:100%; } - .bp3-html-select select > *, .bp3-select select > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-html-select select > .bp3-fill, .bp3-select select > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-html-select select::before, - .bp3-select select::before, .bp3-html-select select > *, .bp3-select select > *{ - margin-right:7px; } - .bp3-html-select select:empty::before, - .bp3-select select:empty::before, - .bp3-html-select select > :last-child, - .bp3-select select > :last-child{ - margin-right:0; } - .bp3-html-select select:hover, - .bp3-select select:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-html-select select:active, - .bp3-select select:active, .bp3-html-select select.bp3-active, - .bp3-select select.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-html-select select:disabled, - .bp3-select select:disabled, .bp3-html-select select.bp3-disabled, - .bp3-select select.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-html-select select:disabled.bp3-active, - .bp3-select select:disabled.bp3-active, .bp3-html-select select:disabled.bp3-active:hover, - .bp3-select select:disabled.bp3-active:hover, .bp3-html-select select.bp3-disabled.bp3-active, - .bp3-select select.bp3-disabled.bp3-active, .bp3-html-select select.bp3-disabled.bp3-active:hover, - .bp3-select select.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - -.bp3-html-select.bp3-minimal select, -.bp3-select.bp3-minimal select{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-html-select.bp3-minimal select:hover, - .bp3-select.bp3-minimal select:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-html-select.bp3-minimal select:active, - .bp3-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal select.bp3-active, - .bp3-select.bp3-minimal select.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-html-select.bp3-minimal select:disabled, - .bp3-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal select:disabled:hover, - .bp3-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal select.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal select.bp3-disabled:hover, - .bp3-select.bp3-minimal select.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-html-select.bp3-minimal select:disabled.bp3-active, - .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, - .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, - .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-html-select.bp3-minimal select, .bp3-html-select.bp3-minimal .bp3-dark select, - .bp3-dark .bp3-select.bp3-minimal select, .bp3-select.bp3-minimal .bp3-dark select{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover, - .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover, .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active, - .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover, - .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active, - .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-html-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal .bp3-dark select:disabled, - .bp3-dark .bp3-select.bp3-minimal select:disabled, .bp3-select.bp3-minimal .bp3-dark select:disabled, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover, - .bp3-dark .bp3-select.bp3-minimal select:disabled:hover, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-html-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary, - .bp3-select.bp3-minimal select.bp3-intent-primary{ - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, - .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, - .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, - .bp3-select.bp3-minimal select.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, - .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, - .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-success, - .bp3-select.bp3-minimal select.bp3-intent-success{ - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, - .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal select.bp3-intent-success:active, - .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, - .bp3-select.bp3-minimal select.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:active, - .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, - .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning, - .bp3-select.bp3-minimal select.bp3-intent-warning{ - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, - .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, - .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, - .bp3-select.bp3-minimal select.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, - .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, - .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger, - .bp3-select.bp3-minimal select.bp3-intent-danger{ - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, - .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, - .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, - .bp3-select.bp3-minimal select.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, - .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, - .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - -.bp3-html-select.bp3-large select, -.bp3-select.bp3-large select{ - font-size:16px; - height:40px; - padding-right:35px; } - -.bp3-dark .bp3-html-select select, .bp3-dark .bp3-select select{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover, .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-html-select select:disabled, .bp3-dark .bp3-select select:disabled, .bp3-dark .bp3-html-select select.bp3-disabled, .bp3-dark .bp3-select select.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-html-select select:disabled.bp3-active, .bp3-dark .bp3-select select:disabled.bp3-active, .bp3-dark .bp3-html-select select.bp3-disabled.bp3-active, .bp3-dark .bp3-select select.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-html-select select .bp3-button-spinner .bp3-spinner-head, .bp3-dark .bp3-select select .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - -.bp3-html-select select:disabled, -.bp3-select select:disabled{ - background-color:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-html-select .bp3-icon, -.bp3-select .bp3-icon, .bp3-select::after{ - color:#5c7080; - pointer-events:none; - position:absolute; - right:7px; - top:7px; } - .bp3-html-select .bp3-disabled.bp3-icon, - .bp3-select .bp3-disabled.bp3-icon, .bp3-disabled.bp3-select::after{ - color:rgba(92, 112, 128, 0.6); } -.bp3-html-select, -.bp3-select{ - display:inline-block; - letter-spacing:normal; - position:relative; - vertical-align:middle; } - .bp3-html-select select::-ms-expand, - .bp3-select select::-ms-expand{ - display:none; } - .bp3-html-select .bp3-icon, - .bp3-select .bp3-icon{ - color:#5c7080; } - .bp3-html-select .bp3-icon:hover, - .bp3-select .bp3-icon:hover{ - color:#182026; } - .bp3-dark .bp3-html-select .bp3-icon, .bp3-dark - .bp3-select .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-html-select .bp3-icon:hover, .bp3-dark - .bp3-select .bp3-icon:hover{ - color:#f5f8fa; } - .bp3-html-select.bp3-large::after, - .bp3-html-select.bp3-large .bp3-icon, - .bp3-select.bp3-large::after, - .bp3-select.bp3-large .bp3-icon{ - right:12px; - top:12px; } - .bp3-html-select.bp3-fill, - .bp3-html-select.bp3-fill select, - .bp3-select.bp3-fill, - .bp3-select.bp3-fill select{ - width:100%; } - .bp3-dark .bp3-html-select option, .bp3-dark - .bp3-select option{ - background-color:#30404d; - color:#f5f8fa; } - .bp3-dark .bp3-html-select option:disabled, .bp3-dark - .bp3-select option:disabled{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-html-select::after, .bp3-dark - .bp3-select::after{ - color:#a7b6c2; } - -.bp3-select::after{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - content:""; } -.bp3-running-text table, table.bp3-html-table{ - border-spacing:0; - font-size:14px; } - .bp3-running-text table th, table.bp3-html-table th, - .bp3-running-text table td, - table.bp3-html-table td{ - padding:11px; - text-align:left; - vertical-align:top; } - .bp3-running-text table th, table.bp3-html-table th{ - color:#182026; - font-weight:600; } - - .bp3-running-text table td, - table.bp3-html-table td{ - color:#182026; } - .bp3-running-text table tbody tr:first-child th, table.bp3-html-table tbody tr:first-child th, - .bp3-running-text table tbody tr:first-child td, - table.bp3-html-table tbody tr:first-child td, - .bp3-running-text table tfoot tr:first-child th, - table.bp3-html-table tfoot tr:first-child th, - .bp3-running-text table tfoot tr:first-child td, - table.bp3-html-table tfoot tr:first-child td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); } - .bp3-dark .bp3-running-text table th, .bp3-running-text .bp3-dark table th, .bp3-dark table.bp3-html-table th{ - color:#f5f8fa; } - .bp3-dark .bp3-running-text table td, .bp3-running-text .bp3-dark table td, .bp3-dark table.bp3-html-table td{ - color:#f5f8fa; } - .bp3-dark .bp3-running-text table tbody tr:first-child th, .bp3-running-text .bp3-dark table tbody tr:first-child th, .bp3-dark table.bp3-html-table tbody tr:first-child th, - .bp3-dark .bp3-running-text table tbody tr:first-child td, - .bp3-running-text .bp3-dark table tbody tr:first-child td, - .bp3-dark table.bp3-html-table tbody tr:first-child td, - .bp3-dark .bp3-running-text table tfoot tr:first-child th, - .bp3-running-text .bp3-dark table tfoot tr:first-child th, - .bp3-dark table.bp3-html-table tfoot tr:first-child th, - .bp3-dark .bp3-running-text table tfoot tr:first-child td, - .bp3-running-text .bp3-dark table tfoot tr:first-child td, - .bp3-dark table.bp3-html-table tfoot tr:first-child td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); } - -table.bp3-html-table.bp3-html-table-condensed th, -table.bp3-html-table.bp3-html-table-condensed td, table.bp3-html-table.bp3-small th, -table.bp3-html-table.bp3-small td{ - padding-bottom:6px; - padding-top:6px; } - -table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{ - background:rgba(191, 204, 214, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered tbody tr td, -table.bp3-html-table.bp3-html-table-bordered tfoot tr td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); } - table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child), - table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){ - -webkit-box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{ - -webkit-box-shadow:none; - box-shadow:none; } - table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-interactive tbody tr:hover td{ - background-color:rgba(191, 204, 214, 0.3); - cursor:pointer; } - -table.bp3-html-table.bp3-interactive tbody tr:active td{ - background-color:rgba(191, 204, 214, 0.4); } - -.bp3-dark table.bp3-html-table{ } - .bp3-dark table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{ - background:rgba(92, 112, 128, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td, - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child), - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){ - -webkit-box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{ - -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:first-child{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:hover td{ - background-color:rgba(92, 112, 128, 0.3); - cursor:pointer; } - .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:active td{ - background-color:rgba(92, 112, 128, 0.4); } - -.bp3-key-combo{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; } - .bp3-key-combo > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-key-combo > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-key-combo::before, - .bp3-key-combo > *{ - margin-right:5px; } - .bp3-key-combo:empty::before, - .bp3-key-combo > :last-child{ - margin-right:0; } - -.bp3-hotkey-dialog{ - padding-bottom:0; - top:40px; } - .bp3-hotkey-dialog .bp3-dialog-body{ - margin:0; - padding:0; } - .bp3-hotkey-dialog .bp3-hotkey-label{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; } - -.bp3-hotkey-column{ - margin:auto; - max-height:80vh; - overflow-y:auto; - padding:30px; } - .bp3-hotkey-column .bp3-heading{ - margin-bottom:20px; } - .bp3-hotkey-column .bp3-heading:not(:first-child){ - margin-top:40px; } - -.bp3-hotkey{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:justify; - -ms-flex-pack:justify; - justify-content:space-between; - margin-left:0; - margin-right:0; } - .bp3-hotkey:not(:last-child){ - margin-bottom:10px; } -.bp3-icon{ - display:inline-block; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - vertical-align:text-bottom; } - .bp3-icon:not(:empty)::before{ - content:"" !important; - content:unset !important; } - .bp3-icon > svg{ - display:block; } - .bp3-icon > svg:not([fill]){ - fill:currentColor; } - -.bp3-icon.bp3-intent-primary, .bp3-icon-standard.bp3-intent-primary, .bp3-icon-large.bp3-intent-primary{ - color:#106ba3; } - .bp3-dark .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-icon-large.bp3-intent-primary{ - color:#48aff0; } - -.bp3-icon.bp3-intent-success, .bp3-icon-standard.bp3-intent-success, .bp3-icon-large.bp3-intent-success{ - color:#0d8050; } - .bp3-dark .bp3-icon.bp3-intent-success, .bp3-dark .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-icon-large.bp3-intent-success{ - color:#3dcc91; } - -.bp3-icon.bp3-intent-warning, .bp3-icon-standard.bp3-intent-warning, .bp3-icon-large.bp3-intent-warning{ - color:#bf7326; } - .bp3-dark .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-icon-large.bp3-intent-warning{ - color:#ffb366; } - -.bp3-icon.bp3-intent-danger, .bp3-icon-standard.bp3-intent-danger, .bp3-icon-large.bp3-intent-danger{ - color:#c23030; } - .bp3-dark .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-icon-large.bp3-intent-danger{ - color:#ff7373; } - -span.bp3-icon-standard{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - display:inline-block; } - -span.bp3-icon-large{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - display:inline-block; } - -span.bp3-icon:empty{ - font-family:"Icons20"; - font-size:inherit; - font-style:normal; - font-weight:400; - line-height:1; } - span.bp3-icon:empty::before{ - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; } - -.bp3-icon-add::before{ - content:""; } - -.bp3-icon-add-column-left::before{ - content:""; } - -.bp3-icon-add-column-right::before{ - content:""; } - -.bp3-icon-add-row-bottom::before{ - content:""; } - -.bp3-icon-add-row-top::before{ - content:""; } - -.bp3-icon-add-to-artifact::before{ - content:""; } - -.bp3-icon-add-to-folder::before{ - content:""; } - -.bp3-icon-airplane::before{ - content:""; } - -.bp3-icon-align-center::before{ - content:""; } - -.bp3-icon-align-justify::before{ - content:""; } - -.bp3-icon-align-left::before{ - content:""; } - -.bp3-icon-align-right::before{ - content:""; } - -.bp3-icon-alignment-bottom::before{ - content:""; } - -.bp3-icon-alignment-horizontal-center::before{ - content:""; } - -.bp3-icon-alignment-left::before{ - content:""; } - -.bp3-icon-alignment-right::before{ - content:""; } - -.bp3-icon-alignment-top::before{ - content:""; } - -.bp3-icon-alignment-vertical-center::before{ - content:""; } - -.bp3-icon-annotation::before{ - content:""; } - -.bp3-icon-application::before{ - content:""; } - -.bp3-icon-applications::before{ - content:""; } - -.bp3-icon-archive::before{ - content:""; } - -.bp3-icon-arrow-bottom-left::before{ - content:"↙"; } - -.bp3-icon-arrow-bottom-right::before{ - content:"↘"; } - -.bp3-icon-arrow-down::before{ - content:"↓"; } - -.bp3-icon-arrow-left::before{ - content:"←"; } - -.bp3-icon-arrow-right::before{ - content:"→"; } - -.bp3-icon-arrow-top-left::before{ - content:"↖"; } - -.bp3-icon-arrow-top-right::before{ - content:"↗"; } - -.bp3-icon-arrow-up::before{ - content:"↑"; } - -.bp3-icon-arrows-horizontal::before{ - content:"↔"; } - -.bp3-icon-arrows-vertical::before{ - content:"↕"; } - -.bp3-icon-asterisk::before{ - content:"*"; } - -.bp3-icon-automatic-updates::before{ - content:""; } - -.bp3-icon-badge::before{ - content:""; } - -.bp3-icon-ban-circle::before{ - content:""; } - -.bp3-icon-bank-account::before{ - content:""; } - -.bp3-icon-barcode::before{ - content:""; } - -.bp3-icon-blank::before{ - content:""; } - -.bp3-icon-blocked-person::before{ - content:""; } - -.bp3-icon-bold::before{ - content:""; } - -.bp3-icon-book::before{ - content:""; } - -.bp3-icon-bookmark::before{ - content:""; } - -.bp3-icon-box::before{ - content:""; } - -.bp3-icon-briefcase::before{ - content:""; } - -.bp3-icon-bring-data::before{ - content:""; } - -.bp3-icon-build::before{ - content:""; } - -.bp3-icon-calculator::before{ - content:""; } - -.bp3-icon-calendar::before{ - content:""; } - -.bp3-icon-camera::before{ - content:""; } - -.bp3-icon-caret-down::before{ - content:"⌄"; } - -.bp3-icon-caret-left::before{ - content:"〈"; } - -.bp3-icon-caret-right::before{ - content:"〉"; } - -.bp3-icon-caret-up::before{ - content:"⌃"; } - -.bp3-icon-cell-tower::before{ - content:""; } - -.bp3-icon-changes::before{ - content:""; } - -.bp3-icon-chart::before{ - content:""; } - -.bp3-icon-chat::before{ - content:""; } - -.bp3-icon-chevron-backward::before{ - content:""; } - -.bp3-icon-chevron-down::before{ - content:""; } - -.bp3-icon-chevron-forward::before{ - content:""; } - -.bp3-icon-chevron-left::before{ - content:""; } - -.bp3-icon-chevron-right::before{ - content:""; } - -.bp3-icon-chevron-up::before{ - content:""; } - -.bp3-icon-circle::before{ - content:""; } - -.bp3-icon-circle-arrow-down::before{ - content:""; } - -.bp3-icon-circle-arrow-left::before{ - content:""; } - -.bp3-icon-circle-arrow-right::before{ - content:""; } - -.bp3-icon-circle-arrow-up::before{ - content:""; } - -.bp3-icon-citation::before{ - content:""; } - -.bp3-icon-clean::before{ - content:""; } - -.bp3-icon-clipboard::before{ - content:""; } - -.bp3-icon-cloud::before{ - content:"☁"; } - -.bp3-icon-cloud-download::before{ - content:""; } - -.bp3-icon-cloud-upload::before{ - content:""; } - -.bp3-icon-code::before{ - content:""; } - -.bp3-icon-code-block::before{ - content:""; } - -.bp3-icon-cog::before{ - content:""; } - -.bp3-icon-collapse-all::before{ - content:""; } - -.bp3-icon-column-layout::before{ - content:""; } - -.bp3-icon-comment::before{ - content:""; } - -.bp3-icon-comparison::before{ - content:""; } - -.bp3-icon-compass::before{ - content:""; } - -.bp3-icon-compressed::before{ - content:""; } - -.bp3-icon-confirm::before{ - content:""; } - -.bp3-icon-console::before{ - content:""; } - -.bp3-icon-contrast::before{ - content:""; } - -.bp3-icon-control::before{ - content:""; } - -.bp3-icon-credit-card::before{ - content:""; } - -.bp3-icon-cross::before{ - content:"✗"; } - -.bp3-icon-crown::before{ - content:""; } - -.bp3-icon-cube::before{ - content:""; } - -.bp3-icon-cube-add::before{ - content:""; } - -.bp3-icon-cube-remove::before{ - content:""; } - -.bp3-icon-curved-range-chart::before{ - content:""; } - -.bp3-icon-cut::before{ - content:""; } - -.bp3-icon-dashboard::before{ - content:""; } - -.bp3-icon-data-lineage::before{ - content:""; } - -.bp3-icon-database::before{ - content:""; } - -.bp3-icon-delete::before{ - content:""; } - -.bp3-icon-delta::before{ - content:"Δ"; } - -.bp3-icon-derive-column::before{ - content:""; } - -.bp3-icon-desktop::before{ - content:""; } - -.bp3-icon-diagnosis::before{ - content:""; } - -.bp3-icon-diagram-tree::before{ - content:""; } - -.bp3-icon-direction-left::before{ - content:""; } - -.bp3-icon-direction-right::before{ - content:""; } - -.bp3-icon-disable::before{ - content:""; } - -.bp3-icon-document::before{ - content:""; } - -.bp3-icon-document-open::before{ - content:""; } - -.bp3-icon-document-share::before{ - content:""; } - -.bp3-icon-dollar::before{ - content:"$"; } - -.bp3-icon-dot::before{ - content:"•"; } - -.bp3-icon-double-caret-horizontal::before{ - content:""; } - -.bp3-icon-double-caret-vertical::before{ - content:""; } - -.bp3-icon-double-chevron-down::before{ - content:""; } - -.bp3-icon-double-chevron-left::before{ - content:""; } - -.bp3-icon-double-chevron-right::before{ - content:""; } - -.bp3-icon-double-chevron-up::before{ - content:""; } - -.bp3-icon-doughnut-chart::before{ - content:""; } - -.bp3-icon-download::before{ - content:""; } - -.bp3-icon-drag-handle-horizontal::before{ - content:""; } - -.bp3-icon-drag-handle-vertical::before{ - content:""; } - -.bp3-icon-draw::before{ - content:""; } - -.bp3-icon-drive-time::before{ - content:""; } - -.bp3-icon-duplicate::before{ - content:""; } - -.bp3-icon-edit::before{ - content:"✎"; } - -.bp3-icon-eject::before{ - content:"⏏"; } - -.bp3-icon-endorsed::before{ - content:""; } - -.bp3-icon-envelope::before{ - content:"✉"; } - -.bp3-icon-equals::before{ - content:""; } - -.bp3-icon-eraser::before{ - content:""; } - -.bp3-icon-error::before{ - content:""; } - -.bp3-icon-euro::before{ - content:"€"; } - -.bp3-icon-exchange::before{ - content:""; } - -.bp3-icon-exclude-row::before{ - content:""; } - -.bp3-icon-expand-all::before{ - content:""; } - -.bp3-icon-export::before{ - content:""; } - -.bp3-icon-eye-off::before{ - content:""; } - -.bp3-icon-eye-on::before{ - content:""; } - -.bp3-icon-eye-open::before{ - content:""; } - -.bp3-icon-fast-backward::before{ - content:""; } - -.bp3-icon-fast-forward::before{ - content:""; } - -.bp3-icon-feed::before{ - content:""; } - -.bp3-icon-feed-subscribed::before{ - content:""; } - -.bp3-icon-film::before{ - content:""; } - -.bp3-icon-filter::before{ - content:""; } - -.bp3-icon-filter-keep::before{ - content:""; } - -.bp3-icon-filter-list::before{ - content:""; } - -.bp3-icon-filter-open::before{ - content:""; } - -.bp3-icon-filter-remove::before{ - content:""; } - -.bp3-icon-flag::before{ - content:"⚑"; } - -.bp3-icon-flame::before{ - content:""; } - -.bp3-icon-flash::before{ - content:""; } - -.bp3-icon-floppy-disk::before{ - content:""; } - -.bp3-icon-flow-branch::before{ - content:""; } - -.bp3-icon-flow-end::before{ - content:""; } - -.bp3-icon-flow-linear::before{ - content:""; } - -.bp3-icon-flow-review::before{ - content:""; } - -.bp3-icon-flow-review-branch::before{ - content:""; } - -.bp3-icon-flows::before{ - content:""; } - -.bp3-icon-folder-close::before{ - content:""; } - -.bp3-icon-folder-new::before{ - content:""; } - -.bp3-icon-folder-open::before{ - content:""; } - -.bp3-icon-folder-shared::before{ - content:""; } - -.bp3-icon-folder-shared-open::before{ - content:""; } - -.bp3-icon-follower::before{ - content:""; } - -.bp3-icon-following::before{ - content:""; } - -.bp3-icon-font::before{ - content:""; } - -.bp3-icon-fork::before{ - content:""; } - -.bp3-icon-form::before{ - content:""; } - -.bp3-icon-full-circle::before{ - content:""; } - -.bp3-icon-full-stacked-chart::before{ - content:""; } - -.bp3-icon-fullscreen::before{ - content:""; } - -.bp3-icon-function::before{ - content:""; } - -.bp3-icon-gantt-chart::before{ - content:""; } - -.bp3-icon-geolocation::before{ - content:""; } - -.bp3-icon-geosearch::before{ - content:""; } - -.bp3-icon-git-branch::before{ - content:""; } - -.bp3-icon-git-commit::before{ - content:""; } - -.bp3-icon-git-merge::before{ - content:""; } - -.bp3-icon-git-new-branch::before{ - content:""; } - -.bp3-icon-git-pull::before{ - content:""; } - -.bp3-icon-git-push::before{ - content:""; } - -.bp3-icon-git-repo::before{ - content:""; } - -.bp3-icon-glass::before{ - content:""; } - -.bp3-icon-globe::before{ - content:""; } - -.bp3-icon-globe-network::before{ - content:""; } - -.bp3-icon-graph::before{ - content:""; } - -.bp3-icon-graph-remove::before{ - content:""; } - -.bp3-icon-greater-than::before{ - content:""; } - -.bp3-icon-greater-than-or-equal-to::before{ - content:""; } - -.bp3-icon-grid::before{ - content:""; } - -.bp3-icon-grid-view::before{ - content:""; } - -.bp3-icon-group-objects::before{ - content:""; } - -.bp3-icon-grouped-bar-chart::before{ - content:""; } - -.bp3-icon-hand::before{ - content:""; } - -.bp3-icon-hand-down::before{ - content:""; } - -.bp3-icon-hand-left::before{ - content:""; } - -.bp3-icon-hand-right::before{ - content:""; } - -.bp3-icon-hand-up::before{ - content:""; } - -.bp3-icon-header::before{ - content:""; } - -.bp3-icon-header-one::before{ - content:""; } - -.bp3-icon-header-two::before{ - content:""; } - -.bp3-icon-headset::before{ - content:""; } - -.bp3-icon-heart::before{ - content:"♥"; } - -.bp3-icon-heart-broken::before{ - content:""; } - -.bp3-icon-heat-grid::before{ - content:""; } - -.bp3-icon-heatmap::before{ - content:""; } - -.bp3-icon-help::before{ - content:"?"; } - -.bp3-icon-helper-management::before{ - content:""; } - -.bp3-icon-highlight::before{ - content:""; } - -.bp3-icon-history::before{ - content:""; } - -.bp3-icon-home::before{ - content:"⌂"; } - -.bp3-icon-horizontal-bar-chart::before{ - content:""; } - -.bp3-icon-horizontal-bar-chart-asc::before{ - content:""; } - -.bp3-icon-horizontal-bar-chart-desc::before{ - content:""; } - -.bp3-icon-horizontal-distribution::before{ - content:""; } - -.bp3-icon-id-number::before{ - content:""; } - -.bp3-icon-image-rotate-left::before{ - content:""; } - -.bp3-icon-image-rotate-right::before{ - content:""; } - -.bp3-icon-import::before{ - content:""; } - -.bp3-icon-inbox::before{ - content:""; } - -.bp3-icon-inbox-filtered::before{ - content:""; } - -.bp3-icon-inbox-geo::before{ - content:""; } - -.bp3-icon-inbox-search::before{ - content:""; } - -.bp3-icon-inbox-update::before{ - content:""; } - -.bp3-icon-info-sign::before{ - content:"ℹ"; } - -.bp3-icon-inheritance::before{ - content:""; } - -.bp3-icon-inner-join::before{ - content:""; } - -.bp3-icon-insert::before{ - content:""; } - -.bp3-icon-intersection::before{ - content:""; } - -.bp3-icon-ip-address::before{ - content:""; } - -.bp3-icon-issue::before{ - content:""; } - -.bp3-icon-issue-closed::before{ - content:""; } - -.bp3-icon-issue-new::before{ - content:""; } - -.bp3-icon-italic::before{ - content:""; } - -.bp3-icon-join-table::before{ - content:""; } - -.bp3-icon-key::before{ - content:""; } - -.bp3-icon-key-backspace::before{ - content:""; } - -.bp3-icon-key-command::before{ - content:""; } - -.bp3-icon-key-control::before{ - content:""; } - -.bp3-icon-key-delete::before{ - content:""; } - -.bp3-icon-key-enter::before{ - content:""; } - -.bp3-icon-key-escape::before{ - content:""; } - -.bp3-icon-key-option::before{ - content:""; } - -.bp3-icon-key-shift::before{ - content:""; } - -.bp3-icon-key-tab::before{ - content:""; } - -.bp3-icon-known-vehicle::before{ - content:""; } - -.bp3-icon-lab-test::before{ - content:""; } - -.bp3-icon-label::before{ - content:""; } - -.bp3-icon-layer::before{ - content:""; } - -.bp3-icon-layers::before{ - content:""; } - -.bp3-icon-layout::before{ - content:""; } - -.bp3-icon-layout-auto::before{ - content:""; } - -.bp3-icon-layout-balloon::before{ - content:""; } - -.bp3-icon-layout-circle::before{ - content:""; } - -.bp3-icon-layout-grid::before{ - content:""; } - -.bp3-icon-layout-group-by::before{ - content:""; } - -.bp3-icon-layout-hierarchy::before{ - content:""; } - -.bp3-icon-layout-linear::before{ - content:""; } - -.bp3-icon-layout-skew-grid::before{ - content:""; } - -.bp3-icon-layout-sorted-clusters::before{ - content:""; } - -.bp3-icon-learning::before{ - content:""; } - -.bp3-icon-left-join::before{ - content:""; } - -.bp3-icon-less-than::before{ - content:""; } - -.bp3-icon-less-than-or-equal-to::before{ - content:""; } - -.bp3-icon-lifesaver::before{ - content:""; } - -.bp3-icon-lightbulb::before{ - content:""; } - -.bp3-icon-link::before{ - content:""; } - -.bp3-icon-list::before{ - content:"☰"; } - -.bp3-icon-list-columns::before{ - content:""; } - -.bp3-icon-list-detail-view::before{ - content:""; } - -.bp3-icon-locate::before{ - content:""; } - -.bp3-icon-lock::before{ - content:""; } - -.bp3-icon-log-in::before{ - content:""; } - -.bp3-icon-log-out::before{ - content:""; } - -.bp3-icon-manual::before{ - content:""; } - -.bp3-icon-manually-entered-data::before{ - content:""; } - -.bp3-icon-map::before{ - content:""; } - -.bp3-icon-map-create::before{ - content:""; } - -.bp3-icon-map-marker::before{ - content:""; } - -.bp3-icon-maximize::before{ - content:""; } - -.bp3-icon-media::before{ - content:""; } - -.bp3-icon-menu::before{ - content:""; } - -.bp3-icon-menu-closed::before{ - content:""; } - -.bp3-icon-menu-open::before{ - content:""; } - -.bp3-icon-merge-columns::before{ - content:""; } - -.bp3-icon-merge-links::before{ - content:""; } - -.bp3-icon-minimize::before{ - content:""; } - -.bp3-icon-minus::before{ - content:"−"; } - -.bp3-icon-mobile-phone::before{ - content:""; } - -.bp3-icon-mobile-video::before{ - content:""; } - -.bp3-icon-moon::before{ - content:""; } - -.bp3-icon-more::before{ - content:""; } - -.bp3-icon-mountain::before{ - content:""; } - -.bp3-icon-move::before{ - content:""; } - -.bp3-icon-mugshot::before{ - content:""; } - -.bp3-icon-multi-select::before{ - content:""; } - -.bp3-icon-music::before{ - content:""; } - -.bp3-icon-new-drawing::before{ - content:""; } - -.bp3-icon-new-grid-item::before{ - content:""; } - -.bp3-icon-new-layer::before{ - content:""; } - -.bp3-icon-new-layers::before{ - content:""; } - -.bp3-icon-new-link::before{ - content:""; } - -.bp3-icon-new-object::before{ - content:""; } - -.bp3-icon-new-person::before{ - content:""; } - -.bp3-icon-new-prescription::before{ - content:""; } - -.bp3-icon-new-text-box::before{ - content:""; } - -.bp3-icon-ninja::before{ - content:""; } - -.bp3-icon-not-equal-to::before{ - content:""; } - -.bp3-icon-notifications::before{ - content:""; } - -.bp3-icon-notifications-updated::before{ - content:""; } - -.bp3-icon-numbered-list::before{ - content:""; } - -.bp3-icon-numerical::before{ - content:""; } - -.bp3-icon-office::before{ - content:""; } - -.bp3-icon-offline::before{ - content:""; } - -.bp3-icon-oil-field::before{ - content:""; } - -.bp3-icon-one-column::before{ - content:""; } - -.bp3-icon-outdated::before{ - content:""; } - -.bp3-icon-page-layout::before{ - content:""; } - -.bp3-icon-panel-stats::before{ - content:""; } - -.bp3-icon-panel-table::before{ - content:""; } - -.bp3-icon-paperclip::before{ - content:""; } - -.bp3-icon-paragraph::before{ - content:""; } - -.bp3-icon-path::before{ - content:""; } - -.bp3-icon-path-search::before{ - content:""; } - -.bp3-icon-pause::before{ - content:""; } - -.bp3-icon-people::before{ - content:""; } - -.bp3-icon-percentage::before{ - content:""; } - -.bp3-icon-person::before{ - content:""; } - -.bp3-icon-phone::before{ - content:"☎"; } - -.bp3-icon-pie-chart::before{ - content:""; } - -.bp3-icon-pin::before{ - content:""; } - -.bp3-icon-pivot::before{ - content:""; } - -.bp3-icon-pivot-table::before{ - content:""; } - -.bp3-icon-play::before{ - content:""; } - -.bp3-icon-plus::before{ - content:"+"; } - -.bp3-icon-polygon-filter::before{ - content:""; } - -.bp3-icon-power::before{ - content:""; } - -.bp3-icon-predictive-analysis::before{ - content:""; } - -.bp3-icon-prescription::before{ - content:""; } - -.bp3-icon-presentation::before{ - content:""; } - -.bp3-icon-print::before{ - content:"⎙"; } - -.bp3-icon-projects::before{ - content:""; } - -.bp3-icon-properties::before{ - content:""; } - -.bp3-icon-property::before{ - content:""; } - -.bp3-icon-publish-function::before{ - content:""; } - -.bp3-icon-pulse::before{ - content:""; } - -.bp3-icon-random::before{ - content:""; } - -.bp3-icon-record::before{ - content:""; } - -.bp3-icon-redo::before{ - content:""; } - -.bp3-icon-refresh::before{ - content:""; } - -.bp3-icon-regression-chart::before{ - content:""; } - -.bp3-icon-remove::before{ - content:""; } - -.bp3-icon-remove-column::before{ - content:""; } - -.bp3-icon-remove-column-left::before{ - content:""; } - -.bp3-icon-remove-column-right::before{ - content:""; } - -.bp3-icon-remove-row-bottom::before{ - content:""; } - -.bp3-icon-remove-row-top::before{ - content:""; } - -.bp3-icon-repeat::before{ - content:""; } - -.bp3-icon-reset::before{ - content:""; } - -.bp3-icon-resolve::before{ - content:""; } - -.bp3-icon-rig::before{ - content:""; } - -.bp3-icon-right-join::before{ - content:""; } - -.bp3-icon-ring::before{ - content:""; } - -.bp3-icon-rotate-document::before{ - content:""; } - -.bp3-icon-rotate-page::before{ - content:""; } - -.bp3-icon-satellite::before{ - content:""; } - -.bp3-icon-saved::before{ - content:""; } - -.bp3-icon-scatter-plot::before{ - content:""; } - -.bp3-icon-search::before{ - content:""; } - -.bp3-icon-search-around::before{ - content:""; } - -.bp3-icon-search-template::before{ - content:""; } - -.bp3-icon-search-text::before{ - content:""; } - -.bp3-icon-segmented-control::before{ - content:""; } - -.bp3-icon-select::before{ - content:""; } - -.bp3-icon-selection::before{ - content:"⦿"; } - -.bp3-icon-send-to::before{ - content:""; } - -.bp3-icon-send-to-graph::before{ - content:""; } - -.bp3-icon-send-to-map::before{ - content:""; } - -.bp3-icon-series-add::before{ - content:""; } - -.bp3-icon-series-configuration::before{ - content:""; } - -.bp3-icon-series-derived::before{ - content:""; } - -.bp3-icon-series-filtered::before{ - content:""; } - -.bp3-icon-series-search::before{ - content:""; } - -.bp3-icon-settings::before{ - content:""; } - -.bp3-icon-share::before{ - content:""; } - -.bp3-icon-shield::before{ - content:""; } - -.bp3-icon-shop::before{ - content:""; } - -.bp3-icon-shopping-cart::before{ - content:""; } - -.bp3-icon-signal-search::before{ - content:""; } - -.bp3-icon-sim-card::before{ - content:""; } - -.bp3-icon-slash::before{ - content:""; } - -.bp3-icon-small-cross::before{ - content:""; } - -.bp3-icon-small-minus::before{ - content:""; } - -.bp3-icon-small-plus::before{ - content:""; } - -.bp3-icon-small-tick::before{ - content:""; } - -.bp3-icon-snowflake::before{ - content:""; } - -.bp3-icon-social-media::before{ - content:""; } - -.bp3-icon-sort::before{ - content:""; } - -.bp3-icon-sort-alphabetical::before{ - content:""; } - -.bp3-icon-sort-alphabetical-desc::before{ - content:""; } - -.bp3-icon-sort-asc::before{ - content:""; } - -.bp3-icon-sort-desc::before{ - content:""; } - -.bp3-icon-sort-numerical::before{ - content:""; } - -.bp3-icon-sort-numerical-desc::before{ - content:""; } - -.bp3-icon-split-columns::before{ - content:""; } - -.bp3-icon-square::before{ - content:""; } - -.bp3-icon-stacked-chart::before{ - content:""; } - -.bp3-icon-star::before{ - content:"★"; } - -.bp3-icon-star-empty::before{ - content:"☆"; } - -.bp3-icon-step-backward::before{ - content:""; } - -.bp3-icon-step-chart::before{ - content:""; } - -.bp3-icon-step-forward::before{ - content:""; } - -.bp3-icon-stop::before{ - content:""; } - -.bp3-icon-stopwatch::before{ - content:""; } - -.bp3-icon-strikethrough::before{ - content:""; } - -.bp3-icon-style::before{ - content:""; } - -.bp3-icon-swap-horizontal::before{ - content:""; } - -.bp3-icon-swap-vertical::before{ - content:""; } - -.bp3-icon-symbol-circle::before{ - content:""; } - -.bp3-icon-symbol-cross::before{ - content:""; } - -.bp3-icon-symbol-diamond::before{ - content:""; } - -.bp3-icon-symbol-square::before{ - content:""; } - -.bp3-icon-symbol-triangle-down::before{ - content:""; } - -.bp3-icon-symbol-triangle-up::before{ - content:""; } - -.bp3-icon-tag::before{ - content:""; } - -.bp3-icon-take-action::before{ - content:""; } - -.bp3-icon-taxi::before{ - content:""; } - -.bp3-icon-text-highlight::before{ - content:""; } - -.bp3-icon-th::before{ - content:""; } - -.bp3-icon-th-derived::before{ - content:""; } - -.bp3-icon-th-disconnect::before{ - content:""; } - -.bp3-icon-th-filtered::before{ - content:""; } - -.bp3-icon-th-list::before{ - content:""; } - -.bp3-icon-thumbs-down::before{ - content:""; } - -.bp3-icon-thumbs-up::before{ - content:""; } - -.bp3-icon-tick::before{ - content:"✓"; } - -.bp3-icon-tick-circle::before{ - content:""; } - -.bp3-icon-time::before{ - content:"⏲"; } - -.bp3-icon-timeline-area-chart::before{ - content:""; } - -.bp3-icon-timeline-bar-chart::before{ - content:""; } - -.bp3-icon-timeline-events::before{ - content:""; } - -.bp3-icon-timeline-line-chart::before{ - content:""; } - -.bp3-icon-tint::before{ - content:""; } - -.bp3-icon-torch::before{ - content:""; } - -.bp3-icon-tractor::before{ - content:""; } - -.bp3-icon-train::before{ - content:""; } - -.bp3-icon-translate::before{ - content:""; } - -.bp3-icon-trash::before{ - content:""; } - -.bp3-icon-tree::before{ - content:""; } - -.bp3-icon-trending-down::before{ - content:""; } - -.bp3-icon-trending-up::before{ - content:""; } - -.bp3-icon-truck::before{ - content:""; } - -.bp3-icon-two-columns::before{ - content:""; } - -.bp3-icon-unarchive::before{ - content:""; } - -.bp3-icon-underline::before{ - content:"⎁"; } - -.bp3-icon-undo::before{ - content:"⎌"; } - -.bp3-icon-ungroup-objects::before{ - content:""; } - -.bp3-icon-unknown-vehicle::before{ - content:""; } - -.bp3-icon-unlock::before{ - content:""; } - -.bp3-icon-unpin::before{ - content:""; } - -.bp3-icon-unresolve::before{ - content:""; } - -.bp3-icon-updated::before{ - content:""; } - -.bp3-icon-upload::before{ - content:""; } - -.bp3-icon-user::before{ - content:""; } - -.bp3-icon-variable::before{ - content:""; } - -.bp3-icon-vertical-bar-chart-asc::before{ - content:""; } - -.bp3-icon-vertical-bar-chart-desc::before{ - content:""; } - -.bp3-icon-vertical-distribution::before{ - content:""; } - -.bp3-icon-video::before{ - content:""; } - -.bp3-icon-volume-down::before{ - content:""; } - -.bp3-icon-volume-off::before{ - content:""; } - -.bp3-icon-volume-up::before{ - content:""; } - -.bp3-icon-walk::before{ - content:""; } - -.bp3-icon-warning-sign::before{ - content:""; } - -.bp3-icon-waterfall-chart::before{ - content:""; } - -.bp3-icon-widget::before{ - content:""; } - -.bp3-icon-widget-button::before{ - content:""; } - -.bp3-icon-widget-footer::before{ - content:""; } - -.bp3-icon-widget-header::before{ - content:""; } - -.bp3-icon-wrench::before{ - content:""; } - -.bp3-icon-zoom-in::before{ - content:""; } - -.bp3-icon-zoom-out::before{ - content:""; } - -.bp3-icon-zoom-to-fit::before{ - content:""; } -.bp3-submenu > .bp3-popover-wrapper{ - display:block; } - -.bp3-submenu .bp3-popover-target{ - display:block; } - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ } - -.bp3-submenu.bp3-popover{ - -webkit-box-shadow:none; - box-shadow:none; - padding:0 5px; } - .bp3-submenu.bp3-popover > .bp3-popover-content{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-submenu.bp3-popover, .bp3-submenu.bp3-popover.bp3-dark{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-submenu.bp3-popover > .bp3-popover-content, .bp3-submenu.bp3-popover.bp3-dark > .bp3-popover-content{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } -.bp3-menu{ - background:#ffffff; - border-radius:3px; - color:#182026; - list-style:none; - margin:0; - min-width:180px; - padding:5px; - text-align:left; } - -.bp3-menu-divider{ - border-top:1px solid rgba(16, 22, 26, 0.15); - display:block; - margin:5px; } - .bp3-dark .bp3-menu-divider{ - border-top-color:rgba(255, 255, 255, 0.15); } - -.bp3-menu-item{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - border-radius:2px; - color:inherit; - line-height:20px; - padding:5px 7px; - text-decoration:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-menu-item > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-menu-item > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-menu-item::before, - .bp3-menu-item > *{ - margin-right:7px; } - .bp3-menu-item:empty::before, - .bp3-menu-item > :last-child{ - margin-right:0; } - .bp3-menu-item > .bp3-fill{ - word-break:break-word; } - .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - background-color:rgba(167, 182, 194, 0.3); - cursor:pointer; - text-decoration:none; } - .bp3-menu-item.bp3-disabled{ - background-color:inherit; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-menu-item{ - color:inherit; } - .bp3-dark .bp3-menu-item:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - background-color:rgba(138, 155, 168, 0.15); - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-disabled{ - background-color:inherit; - color:rgba(167, 182, 194, 0.6); } - .bp3-menu-item.bp3-intent-primary{ - color:#106ba3; } - .bp3-menu-item.bp3-intent-primary .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-primary::before, .bp3-menu-item.bp3-intent-primary::after, - .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{ - color:#106ba3; } - .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary.bp3-active{ - background-color:#137cbd; } - .bp3-menu-item.bp3-intent-primary:active{ - background-color:#106ba3; } - .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary:active, .bp3-menu-item.bp3-intent-primary:active::before, .bp3-menu-item.bp3-intent-primary:active::after, - .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-menu-item.bp3-intent-primary.bp3-active::after, - .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-success{ - color:#0d8050; } - .bp3-menu-item.bp3-intent-success .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-success::before, .bp3-menu-item.bp3-intent-success::after, - .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{ - color:#0d8050; } - .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success.bp3-active{ - background-color:#0f9960; } - .bp3-menu-item.bp3-intent-success:active{ - background-color:#0d8050; } - .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-menu-item.bp3-intent-success:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success:active, .bp3-menu-item.bp3-intent-success:active::before, .bp3-menu-item.bp3-intent-success:active::after, - .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-menu-item.bp3-intent-success.bp3-active::after, - .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-warning{ - color:#bf7326; } - .bp3-menu-item.bp3-intent-warning .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-warning::before, .bp3-menu-item.bp3-intent-warning::after, - .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{ - color:#bf7326; } - .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning.bp3-active{ - background-color:#d9822b; } - .bp3-menu-item.bp3-intent-warning:active{ - background-color:#bf7326; } - .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning:active, .bp3-menu-item.bp3-intent-warning:active::before, .bp3-menu-item.bp3-intent-warning:active::after, - .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-menu-item.bp3-intent-warning.bp3-active::after, - .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-danger{ - color:#c23030; } - .bp3-menu-item.bp3-intent-danger .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-danger::before, .bp3-menu-item.bp3-intent-danger::after, - .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{ - color:#c23030; } - .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger.bp3-active{ - background-color:#db3737; } - .bp3-menu-item.bp3-intent-danger:active{ - background-color:#c23030; } - .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger:active, .bp3-menu-item.bp3-intent-danger:active::before, .bp3-menu-item.bp3-intent-danger:active::after, - .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-menu-item.bp3-intent-danger.bp3-active::after, - .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - margin-right:7px; } - .bp3-menu-item::before, - .bp3-menu-item > .bp3-icon{ - color:#5c7080; - margin-top:2px; } - .bp3-menu-item .bp3-menu-item-label{ - color:#5c7080; } - .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - color:inherit; } - .bp3-menu-item.bp3-active, .bp3-menu-item:active{ - background-color:rgba(115, 134, 148, 0.3); } - .bp3-menu-item.bp3-disabled{ - background-color:inherit !important; - color:rgba(92, 112, 128, 0.6) !important; - cursor:not-allowed !important; - outline:none !important; } - .bp3-menu-item.bp3-disabled::before, - .bp3-menu-item.bp3-disabled > .bp3-icon, - .bp3-menu-item.bp3-disabled .bp3-menu-item-label{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-large .bp3-menu-item{ - font-size:16px; - line-height:22px; - padding:9px 7px; } - .bp3-large .bp3-menu-item .bp3-icon{ - margin-top:3px; } - .bp3-large .bp3-menu-item::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - margin-right:10px; - margin-top:1px; } - -button.bp3-menu-item{ - background:none; - border:none; - text-align:left; - width:100%; } -.bp3-menu-header{ - border-top:1px solid rgba(16, 22, 26, 0.15); - display:block; - margin:5px; - cursor:default; - padding-left:2px; } - .bp3-dark .bp3-menu-header{ - border-top-color:rgba(255, 255, 255, 0.15); } - .bp3-menu-header:first-of-type{ - border-top:none; } - .bp3-menu-header > h6{ - color:#182026; - font-weight:600; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - line-height:17px; - margin:0; - padding:10px 7px 0 1px; } - .bp3-dark .bp3-menu-header > h6{ - color:#f5f8fa; } - .bp3-menu-header:first-of-type > h6{ - padding-top:0; } - .bp3-large .bp3-menu-header > h6{ - font-size:18px; - padding-bottom:5px; - padding-top:15px; } - .bp3-large .bp3-menu-header:first-of-type > h6{ - padding-top:0; } - -.bp3-dark .bp3-menu{ - background:#30404d; - color:#f5f8fa; } - -.bp3-dark .bp3-menu-item{ } - .bp3-dark .bp3-menu-item.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-primary::before, .bp3-dark .bp3-menu-item.bp3-intent-primary::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{ - color:#48aff0; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active{ - background-color:#137cbd; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:active{ - background-color:#106ba3; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary:active, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-success::before, .bp3-dark .bp3-menu-item.bp3-intent-success::after, - .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{ - color:#3dcc91; } - .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active{ - background-color:#0f9960; } - .bp3-dark .bp3-menu-item.bp3-intent-success:active{ - background-color:#0d8050; } - .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success:active, .bp3-dark .bp3-menu-item.bp3-intent-success:active::before, .bp3-dark .bp3-menu-item.bp3-intent-success:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-warning::before, .bp3-dark .bp3-menu-item.bp3-intent-warning::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{ - color:#ffb366; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active{ - background-color:#d9822b; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:active{ - background-color:#bf7326; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning:active, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-danger::before, .bp3-dark .bp3-menu-item.bp3-intent-danger::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{ - color:#ff7373; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active{ - background-color:#db3737; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:active{ - background-color:#c23030; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger:active, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item::before, - .bp3-dark .bp3-menu-item > .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-menu-item .bp3-menu-item-label{ - color:#a7b6c2; } - .bp3-dark .bp3-menu-item.bp3-active, .bp3-dark .bp3-menu-item:active{ - background-color:rgba(138, 155, 168, 0.3); } - .bp3-dark .bp3-menu-item.bp3-disabled{ - color:rgba(167, 182, 194, 0.6) !important; } - .bp3-dark .bp3-menu-item.bp3-disabled::before, - .bp3-dark .bp3-menu-item.bp3-disabled > .bp3-icon, - .bp3-dark .bp3-menu-item.bp3-disabled .bp3-menu-item-label{ - color:rgba(167, 182, 194, 0.6) !important; } - -.bp3-dark .bp3-menu-divider, -.bp3-dark .bp3-menu-header{ - border-color:rgba(255, 255, 255, 0.15); } - -.bp3-dark .bp3-menu-header > h6{ - color:#f5f8fa; } - -.bp3-label .bp3-menu{ - margin-top:5px; } -.bp3-navbar{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - height:50px; - padding:0 15px; - position:relative; - width:100%; - z-index:10; } - .bp3-navbar.bp3-dark, - .bp3-dark .bp3-navbar{ - background-color:#394b59; } - .bp3-navbar.bp3-dark{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-navbar{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-navbar.bp3-fixed-top{ - left:0; - position:fixed; - right:0; - top:0; } - -.bp3-navbar-heading{ - font-size:16px; - margin-right:15px; } - -.bp3-navbar-group{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:50px; } - .bp3-navbar-group.bp3-align-left{ - float:left; } - .bp3-navbar-group.bp3-align-right{ - float:right; } - -.bp3-navbar-divider{ - border-left:1px solid rgba(16, 22, 26, 0.15); - height:20px; - margin:0 10px; } - .bp3-dark .bp3-navbar-divider{ - border-left-color:rgba(255, 255, 255, 0.15); } -.bp3-non-ideal-state{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - height:100%; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - text-align:center; - width:100%; } - .bp3-non-ideal-state > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-non-ideal-state > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-non-ideal-state::before, - .bp3-non-ideal-state > *{ - margin-bottom:20px; } - .bp3-non-ideal-state:empty::before, - .bp3-non-ideal-state > :last-child{ - margin-bottom:0; } - .bp3-non-ideal-state > *{ - max-width:400px; } - -.bp3-non-ideal-state-visual{ - color:rgba(92, 112, 128, 0.6); - font-size:60px; } - .bp3-dark .bp3-non-ideal-state-visual{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-overflow-list{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-wrap:nowrap; - flex-wrap:nowrap; - min-width:0; } - -.bp3-overflow-list-spacer{ - -ms-flex-negative:1; - flex-shrink:1; - width:1px; } - -body.bp3-overlay-open{ - overflow:hidden; } - -.bp3-overlay{ - bottom:0; - left:0; - position:static; - right:0; - top:0; - z-index:20; } - .bp3-overlay:not(.bp3-overlay-open){ - pointer-events:none; } - .bp3-overlay.bp3-overlay-container{ - overflow:hidden; - position:fixed; } - .bp3-overlay.bp3-overlay-container.bp3-overlay-inline{ - position:absolute; } - .bp3-overlay.bp3-overlay-scroll-container{ - overflow:auto; - position:fixed; } - .bp3-overlay.bp3-overlay-scroll-container.bp3-overlay-inline{ - position:absolute; } - .bp3-overlay.bp3-overlay-inline{ - display:inline; - overflow:visible; } - -.bp3-overlay-content{ - position:fixed; - z-index:20; } - .bp3-overlay-inline .bp3-overlay-content, - .bp3-overlay-scroll-container .bp3-overlay-content{ - position:absolute; } - -.bp3-overlay-backdrop{ - bottom:0; - left:0; - position:fixed; - right:0; - top:0; - opacity:1; - background-color:rgba(16, 22, 26, 0.7); - overflow:auto; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - z-index:20; } - .bp3-overlay-backdrop.bp3-overlay-enter, .bp3-overlay-backdrop.bp3-overlay-appear{ - opacity:0; } - .bp3-overlay-backdrop.bp3-overlay-enter-active, .bp3-overlay-backdrop.bp3-overlay-appear-active{ - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-overlay-backdrop.bp3-overlay-exit{ - opacity:1; } - .bp3-overlay-backdrop.bp3-overlay-exit-active{ - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-overlay-backdrop:focus{ - outline:none; } - .bp3-overlay-inline .bp3-overlay-backdrop{ - position:absolute; } -.bp3-panel-stack{ - overflow:hidden; - position:relative; } - -.bp3-panel-stack-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 1px rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-negative:0; - flex-shrink:0; - height:30px; - z-index:1; } - .bp3-dark .bp3-panel-stack-header{ - -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 1px rgba(255, 255, 255, 0.15); } - .bp3-panel-stack-header > span{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; } - .bp3-panel-stack-header .bp3-heading{ - margin:0 5px; } - -.bp3-button.bp3-panel-stack-header-back{ - margin-left:5px; - padding-left:0; - white-space:nowrap; } - .bp3-button.bp3-panel-stack-header-back .bp3-icon{ - margin:0 2px; } - -.bp3-panel-stack-view{ - bottom:0; - left:0; - position:absolute; - right:0; - top:0; - background-color:#ffffff; - border-right:1px solid rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin-right:-1px; - overflow-y:auto; - z-index:1; } - .bp3-dark .bp3-panel-stack-view{ - background-color:#30404d; } - .bp3-panel-stack-view:nth-last-child(n + 4){ - display:none; } - -.bp3-panel-stack-push .bp3-panel-stack-enter, .bp3-panel-stack-push .bp3-panel-stack-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; } - -.bp3-panel-stack-push .bp3-panel-stack-enter-active, .bp3-panel-stack-push .bp3-panel-stack-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-push .bp3-panel-stack-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack-push .bp3-panel-stack-exit-active{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-pop .bp3-panel-stack-enter, .bp3-panel-stack-pop .bp3-panel-stack-appear{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; } - -.bp3-panel-stack-pop .bp3-panel-stack-enter-active, .bp3-panel-stack-pop .bp3-panel-stack-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-pop .bp3-panel-stack-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack-pop .bp3-panel-stack-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } -.bp3-panel-stack2{ - overflow:hidden; - position:relative; } - -.bp3-panel-stack2-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 1px rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-negative:0; - flex-shrink:0; - height:30px; - z-index:1; } - .bp3-dark .bp3-panel-stack2-header{ - -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 1px rgba(255, 255, 255, 0.15); } - .bp3-panel-stack2-header > span{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; } - .bp3-panel-stack2-header .bp3-heading{ - margin:0 5px; } - -.bp3-button.bp3-panel-stack2-header-back{ - margin-left:5px; - padding-left:0; - white-space:nowrap; } - .bp3-button.bp3-panel-stack2-header-back .bp3-icon{ - margin:0 2px; } - -.bp3-panel-stack2-view{ - bottom:0; - left:0; - position:absolute; - right:0; - top:0; - background-color:#ffffff; - border-right:1px solid rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin-right:-1px; - overflow-y:auto; - z-index:1; } - .bp3-dark .bp3-panel-stack2-view{ - background-color:#30404d; } - .bp3-panel-stack2-view:nth-last-child(n + 4){ - display:none; } - -.bp3-panel-stack2-push .bp3-panel-stack2-enter, .bp3-panel-stack2-push .bp3-panel-stack2-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; } - -.bp3-panel-stack2-push .bp3-panel-stack2-enter-active, .bp3-panel-stack2-push .bp3-panel-stack2-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-push .bp3-panel-stack2-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack2-push .bp3-panel-stack2-exit-active{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-enter, .bp3-panel-stack2-pop .bp3-panel-stack2-appear{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-enter-active, .bp3-panel-stack2-pop .bp3-panel-stack2-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } -.bp3-popover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - -webkit-transform:scale(1); - transform:scale(1); - border-radius:3px; - display:inline-block; - z-index:20; } - .bp3-popover .bp3-popover-arrow{ - height:30px; - position:absolute; - width:30px; } - .bp3-popover .bp3-popover-arrow::before{ - height:20px; - margin:5px; - width:20px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover{ - margin-bottom:17px; - margin-top:-17px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{ - bottom:-11px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(-90deg); - transform:rotate(-90deg); } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover{ - margin-left:17px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{ - left:-11px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(0); - transform:rotate(0); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover{ - margin-top:17px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{ - top:-11px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover{ - margin-left:-17px; - margin-right:17px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{ - right:-11px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(180deg); - transform:rotate(180deg); } - .bp3-tether-element-attached-middle > .bp3-popover > .bp3-popover-arrow{ - top:50%; - -webkit-transform:translateY(-50%); - transform:translateY(-50%); } - .bp3-tether-element-attached-center > .bp3-popover > .bp3-popover-arrow{ - right:50%; - -webkit-transform:translateX(50%); - transform:translateX(50%); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{ - top:-0.3934px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{ - right:-0.3934px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{ - left:-0.3934px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{ - bottom:-0.3934px; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:top left; - transform-origin:top left; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:top center; - transform-origin:top center; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:top right; - transform-origin:top right; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:center left; - transform-origin:center left; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:center center; - transform-origin:center center; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:center right; - transform-origin:center right; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:bottom left; - transform-origin:bottom left; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:bottom center; - transform-origin:bottom center; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:bottom right; - transform-origin:bottom right; } - .bp3-popover .bp3-popover-content{ - background:#ffffff; - color:inherit; } - .bp3-popover .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); } - .bp3-popover .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.1; } - .bp3-popover .bp3-popover-arrow-fill{ - fill:#ffffff; } - .bp3-popover-enter > .bp3-popover, .bp3-popover-appear > .bp3-popover{ - -webkit-transform:scale(0.3); - transform:scale(0.3); } - .bp3-popover-enter-active > .bp3-popover, .bp3-popover-appear-active > .bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-popover-exit > .bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-popover{ - -webkit-transform:scale(0.3); - transform:scale(0.3); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-popover .bp3-popover-content{ - border-radius:3px; - position:relative; } - .bp3-popover.bp3-popover-content-sizing .bp3-popover-content{ - max-width:350px; - padding:20px; } - .bp3-popover-target + .bp3-overlay .bp3-popover.bp3-popover-content-sizing{ - width:350px; } - .bp3-popover.bp3-minimal{ - margin:0 !important; } - .bp3-popover.bp3-minimal .bp3-popover-arrow{ - display:none; } - .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-enter > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-enter-active > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear-active > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover-exit > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover.bp3-dark, - .bp3-dark .bp3-popover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-popover.bp3-dark .bp3-popover-content, - .bp3-dark .bp3-popover .bp3-popover-content{ - background:#30404d; - color:inherit; } - .bp3-popover.bp3-dark .bp3-popover-arrow::before, - .bp3-dark .bp3-popover .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); } - .bp3-popover.bp3-dark .bp3-popover-arrow-border, - .bp3-dark .bp3-popover .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.2; } - .bp3-popover.bp3-dark .bp3-popover-arrow-fill, - .bp3-dark .bp3-popover .bp3-popover-arrow-fill{ - fill:#30404d; } - -.bp3-popover-arrow::before{ - border-radius:2px; - content:""; - display:block; - position:absolute; - -webkit-transform:rotate(45deg); - transform:rotate(45deg); } - -.bp3-tether-pinned .bp3-popover-arrow{ - display:none; } - -.bp3-popover-backdrop{ - background:rgba(255, 255, 255, 0); } - -.bp3-transition-container{ - opacity:1; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - z-index:20; } - .bp3-transition-container.bp3-popover-enter, .bp3-transition-container.bp3-popover-appear{ - opacity:0; } - .bp3-transition-container.bp3-popover-enter-active, .bp3-transition-container.bp3-popover-appear-active{ - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-transition-container.bp3-popover-exit{ - opacity:1; } - .bp3-transition-container.bp3-popover-exit-active{ - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-transition-container:focus{ - outline:none; } - .bp3-transition-container.bp3-popover-leave .bp3-popover-content{ - pointer-events:none; } - .bp3-transition-container[data-x-out-of-boundaries]{ - display:none; } - -span.bp3-popover-target{ - display:inline-block; } - -.bp3-popover-wrapper.bp3-fill{ - width:100%; } - -.bp3-portal{ - left:0; - position:absolute; - right:0; - top:0; } -@-webkit-keyframes linear-progress-bar-stripes{ - from{ - background-position:0 0; } - to{ - background-position:30px 0; } } -@keyframes linear-progress-bar-stripes{ - from{ - background-position:0 0; } - to{ - background-position:30px 0; } } - -.bp3-progress-bar{ - background:rgba(92, 112, 128, 0.2); - border-radius:40px; - display:block; - height:8px; - overflow:hidden; - position:relative; - width:100%; } - .bp3-progress-bar .bp3-progress-meter{ - background:linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, transparent 75%); - background-color:rgba(92, 112, 128, 0.8); - background-size:30px 30px; - border-radius:40px; - height:100%; - position:absolute; - -webkit-transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:100%; } - .bp3-progress-bar:not(.bp3-no-animation):not(.bp3-no-stripes) .bp3-progress-meter{ - animation:linear-progress-bar-stripes 300ms linear infinite reverse; } - .bp3-progress-bar.bp3-no-stripes .bp3-progress-meter{ - background-image:none; } - -.bp3-dark .bp3-progress-bar{ - background:rgba(16, 22, 26, 0.5); } - .bp3-dark .bp3-progress-bar .bp3-progress-meter{ - background-color:#8a9ba8; } - -.bp3-progress-bar.bp3-intent-primary .bp3-progress-meter{ - background-color:#137cbd; } - -.bp3-progress-bar.bp3-intent-success .bp3-progress-meter{ - background-color:#0f9960; } - -.bp3-progress-bar.bp3-intent-warning .bp3-progress-meter{ - background-color:#d9822b; } - -.bp3-progress-bar.bp3-intent-danger .bp3-progress-meter{ - background-color:#db3737; } -@-webkit-keyframes skeleton-glow{ - from{ - background:rgba(206, 217, 224, 0.2); - border-color:rgba(206, 217, 224, 0.2); } - to{ - background:rgba(92, 112, 128, 0.2); - border-color:rgba(92, 112, 128, 0.2); } } -@keyframes skeleton-glow{ - from{ - background:rgba(206, 217, 224, 0.2); - border-color:rgba(206, 217, 224, 0.2); } - to{ - background:rgba(92, 112, 128, 0.2); - border-color:rgba(92, 112, 128, 0.2); } } -.bp3-skeleton{ - -webkit-animation:1000ms linear infinite alternate skeleton-glow; - animation:1000ms linear infinite alternate skeleton-glow; - background:rgba(206, 217, 224, 0.2); - background-clip:padding-box !important; - border-color:rgba(206, 217, 224, 0.2) !important; - border-radius:2px; - -webkit-box-shadow:none !important; - box-shadow:none !important; - color:transparent !important; - cursor:default; - pointer-events:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-skeleton::before, .bp3-skeleton::after, - .bp3-skeleton *{ - visibility:hidden !important; } -.bp3-slider{ - height:40px; - min-width:150px; - width:100%; - cursor:default; - outline:none; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-slider:hover{ - cursor:pointer; } - .bp3-slider:active{ - cursor:-webkit-grabbing; - cursor:grabbing; } - .bp3-slider.bp3-disabled{ - cursor:not-allowed; - opacity:0.5; } - .bp3-slider.bp3-slider-unlabeled{ - height:16px; } - -.bp3-slider-track, -.bp3-slider-progress{ - height:6px; - left:0; - right:0; - top:5px; - position:absolute; } - -.bp3-slider-track{ - border-radius:3px; - overflow:hidden; } - -.bp3-slider-progress{ - background:rgba(92, 112, 128, 0.2); } - .bp3-dark .bp3-slider-progress{ - background:rgba(16, 22, 26, 0.5); } - .bp3-slider-progress.bp3-intent-primary{ - background-color:#137cbd; } - .bp3-slider-progress.bp3-intent-success{ - background-color:#0f9960; } - .bp3-slider-progress.bp3-intent-warning{ - background-color:#d9822b; } - .bp3-slider-progress.bp3-intent-danger{ - background-color:#db3737; } - -.bp3-slider-handle{ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - cursor:pointer; - height:16px; - left:0; - position:absolute; - top:0; - width:16px; } - .bp3-slider-handle:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-slider-handle:active, .bp3-slider-handle.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-slider-handle:disabled, .bp3-slider-handle.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-slider-handle:disabled.bp3-active, .bp3-slider-handle:disabled.bp3-active:hover, .bp3-slider-handle.bp3-disabled.bp3-active, .bp3-slider-handle.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-slider-handle:focus{ - z-index:1; } - .bp3-slider-handle:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - cursor:-webkit-grab; - cursor:grab; - z-index:2; } - .bp3-slider-handle.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1); - cursor:-webkit-grabbing; - cursor:grabbing; } - .bp3-disabled .bp3-slider-handle{ - background:#bfccd6; - -webkit-box-shadow:none; - box-shadow:none; - pointer-events:none; } - .bp3-dark .bp3-slider-handle{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-slider-handle:hover, .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-slider-handle:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-slider-handle:disabled, .bp3-dark .bp3-slider-handle.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-slider-handle:disabled.bp3-active, .bp3-dark .bp3-slider-handle.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-slider-handle .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-slider-handle, .bp3-dark .bp3-slider-handle:hover{ - background-color:#394b59; } - .bp3-dark .bp3-slider-handle.bp3-active{ - background-color:#293742; } - .bp3-dark .bp3-disabled .bp3-slider-handle{ - background:#5c7080; - border-color:#5c7080; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-slider-handle .bp3-slider-label{ - background:#394b59; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - color:#f5f8fa; - margin-left:8px; } - .bp3-dark .bp3-slider-handle .bp3-slider-label{ - background:#e1e8ed; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - color:#394b59; } - .bp3-disabled .bp3-slider-handle .bp3-slider-label{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-slider-handle.bp3-start, .bp3-slider-handle.bp3-end{ - width:8px; } - .bp3-slider-handle.bp3-start{ - border-bottom-right-radius:0; - border-top-right-radius:0; } - .bp3-slider-handle.bp3-end{ - border-bottom-left-radius:0; - border-top-left-radius:0; - margin-left:8px; } - .bp3-slider-handle.bp3-end .bp3-slider-label{ - margin-left:0; } - -.bp3-slider-label{ - -webkit-transform:translate(-50%, 20px); - transform:translate(-50%, 20px); - display:inline-block; - font-size:12px; - line-height:1; - padding:2px 5px; - position:absolute; - vertical-align:top; } - -.bp3-slider.bp3-vertical{ - height:150px; - min-width:40px; - width:40px; } - .bp3-slider.bp3-vertical .bp3-slider-track, - .bp3-slider.bp3-vertical .bp3-slider-progress{ - bottom:0; - height:auto; - left:5px; - top:0; - width:6px; } - .bp3-slider.bp3-vertical .bp3-slider-progress{ - top:auto; } - .bp3-slider.bp3-vertical .bp3-slider-label{ - -webkit-transform:translate(20px, 50%); - transform:translate(20px, 50%); } - .bp3-slider.bp3-vertical .bp3-slider-handle{ - top:auto; } - .bp3-slider.bp3-vertical .bp3-slider-handle .bp3-slider-label{ - margin-left:0; - margin-top:-8px; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end, .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{ - height:8px; - margin-left:0; - width:16px; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{ - border-bottom-right-radius:3px; - border-top-left-radius:0; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start .bp3-slider-label{ - -webkit-transform:translate(20px); - transform:translate(20px); } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end{ - border-bottom-left-radius:0; - border-bottom-right-radius:0; - border-top-left-radius:3px; - margin-bottom:8px; } - -@-webkit-keyframes pt-spinner-animation{ - from{ - -webkit-transform:rotate(0deg); - transform:rotate(0deg); } - to{ - -webkit-transform:rotate(360deg); - transform:rotate(360deg); } } - -@keyframes pt-spinner-animation{ - from{ - -webkit-transform:rotate(0deg); - transform:rotate(0deg); } - to{ - -webkit-transform:rotate(360deg); - transform:rotate(360deg); } } - -.bp3-spinner{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - overflow:visible; - vertical-align:middle; } - .bp3-spinner svg{ - display:block; } - .bp3-spinner path{ - fill-opacity:0; } - .bp3-spinner .bp3-spinner-head{ - stroke:rgba(92, 112, 128, 0.8); - stroke-linecap:round; - -webkit-transform-origin:center; - transform-origin:center; - -webkit-transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-spinner .bp3-spinner-track{ - stroke:rgba(92, 112, 128, 0.2); } - -.bp3-spinner-animation{ - -webkit-animation:pt-spinner-animation 500ms linear infinite; - animation:pt-spinner-animation 500ms linear infinite; } - .bp3-no-spin > .bp3-spinner-animation{ - -webkit-animation:none; - animation:none; } - -.bp3-dark .bp3-spinner .bp3-spinner-head{ - stroke:#8a9ba8; } - -.bp3-dark .bp3-spinner .bp3-spinner-track{ - stroke:rgba(16, 22, 26, 0.5); } - -.bp3-spinner.bp3-intent-primary .bp3-spinner-head{ - stroke:#137cbd; } - -.bp3-spinner.bp3-intent-success .bp3-spinner-head{ - stroke:#0f9960; } - -.bp3-spinner.bp3-intent-warning .bp3-spinner-head{ - stroke:#d9822b; } - -.bp3-spinner.bp3-intent-danger .bp3-spinner-head{ - stroke:#db3737; } -.bp3-tabs.bp3-vertical{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-tabs.bp3-vertical > .bp3-tab-list{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab{ - border-radius:3px; - padding:0 10px; - width:100%; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab[aria-selected="true"]{ - background-color:rgba(19, 124, 189, 0.2); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab-indicator-wrapper .bp3-tab-indicator{ - background-color:rgba(19, 124, 189, 0.2); - border-radius:3px; - bottom:0; - height:auto; - left:0; - right:0; - top:0; } - .bp3-tabs.bp3-vertical > .bp3-tab-panel{ - margin-top:0; - padding-left:20px; } - -.bp3-tab-list{ - -webkit-box-align:end; - -ms-flex-align:end; - align-items:flex-end; - border:none; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - list-style:none; - margin:0; - padding:0; - position:relative; } - .bp3-tab-list > *:not(:last-child){ - margin-right:20px; } - -.bp3-tab{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - color:#182026; - cursor:pointer; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - font-size:14px; - line-height:30px; - max-width:100%; - position:relative; - vertical-align:top; } - .bp3-tab a{ - color:inherit; - display:block; - text-decoration:none; } - .bp3-tab-indicator-wrapper ~ .bp3-tab{ - background-color:transparent !important; - -webkit-box-shadow:none !important; - box-shadow:none !important; } - .bp3-tab[aria-disabled="true"]{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-tab[aria-selected="true"]{ - border-radius:0; - -webkit-box-shadow:inset 0 -3px 0 #106ba3; - box-shadow:inset 0 -3px 0 #106ba3; } - .bp3-tab[aria-selected="true"], .bp3-tab:not([aria-disabled="true"]):hover{ - color:#106ba3; } - .bp3-tab:focus{ - -moz-outline-radius:0; } - .bp3-large > .bp3-tab{ - font-size:16px; - line-height:40px; } - -.bp3-tab-panel{ - margin-top:20px; } - .bp3-tab-panel[aria-hidden="true"]{ - display:none; } - -.bp3-tab-indicator-wrapper{ - left:0; - pointer-events:none; - position:absolute; - top:0; - -webkit-transform:translateX(0), translateY(0); - transform:translateX(0), translateY(0); - -webkit-transition:height, width, -webkit-transform; - transition:height, width, -webkit-transform; - transition:height, transform, width; - transition:height, transform, width, -webkit-transform; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tab-indicator-wrapper .bp3-tab-indicator{ - background-color:#106ba3; - bottom:0; - height:3px; - left:0; - position:absolute; - right:0; } - .bp3-tab-indicator-wrapper.bp3-no-animation{ - -webkit-transition:none; - transition:none; } - -.bp3-dark .bp3-tab{ - color:#f5f8fa; } - .bp3-dark .bp3-tab[aria-disabled="true"]{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tab[aria-selected="true"]{ - -webkit-box-shadow:inset 0 -3px 0 #48aff0; - box-shadow:inset 0 -3px 0 #48aff0; } - .bp3-dark .bp3-tab[aria-selected="true"], .bp3-dark .bp3-tab:not([aria-disabled="true"]):hover{ - color:#48aff0; } - -.bp3-dark .bp3-tab-indicator{ - background-color:#48aff0; } - -.bp3-flex-expander{ - -webkit-box-flex:1; - -ms-flex:1 1; - flex:1 1; } -.bp3-tag{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:#5c7080; - border:none; - border-radius:3px; - -webkit-box-shadow:none; - box-shadow:none; - color:#f5f8fa; - font-size:12px; - line-height:16px; - max-width:100%; - min-height:20px; - min-width:20px; - padding:2px 6px; - position:relative; } - .bp3-tag.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-interactive:hover{ - background-color:rgba(92, 112, 128, 0.85); } - .bp3-tag.bp3-interactive.bp3-active, .bp3-tag.bp3-interactive:active{ - background-color:rgba(92, 112, 128, 0.7); } - .bp3-tag > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag::before, - .bp3-tag > *{ - margin-right:4px; } - .bp3-tag:empty::before, - .bp3-tag > :last-child{ - margin-right:0; } - .bp3-tag:focus{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:0; - -moz-outline-radius:6px; } - .bp3-tag.bp3-round{ - border-radius:30px; - padding-left:8px; - padding-right:8px; } - .bp3-dark .bp3-tag{ - background-color:#bfccd6; - color:#182026; } - .bp3-dark .bp3-tag.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-interactive:hover{ - background-color:rgba(191, 204, 214, 0.85); } - .bp3-dark .bp3-tag.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-interactive:active{ - background-color:rgba(191, 204, 214, 0.7); } - .bp3-dark .bp3-tag > .bp3-icon, .bp3-dark .bp3-tag .bp3-icon-standard, .bp3-dark .bp3-tag .bp3-icon-large{ - fill:currentColor; } - .bp3-tag > .bp3-icon, .bp3-tag .bp3-icon-standard, .bp3-tag .bp3-icon-large{ - fill:#ffffff; } - .bp3-tag.bp3-large, - .bp3-large .bp3-tag{ - font-size:14px; - line-height:20px; - min-height:30px; - min-width:30px; - padding:5px 10px; } - .bp3-tag.bp3-large::before, - .bp3-tag.bp3-large > *, - .bp3-large .bp3-tag::before, - .bp3-large .bp3-tag > *{ - margin-right:7px; } - .bp3-tag.bp3-large:empty::before, - .bp3-tag.bp3-large > :last-child, - .bp3-large .bp3-tag:empty::before, - .bp3-large .bp3-tag > :last-child{ - margin-right:0; } - .bp3-tag.bp3-large.bp3-round, - .bp3-large .bp3-tag.bp3-round{ - padding-left:12px; - padding-right:12px; } - .bp3-tag.bp3-intent-primary{ - background:#137cbd; - color:#ffffff; } - .bp3-tag.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.85); } - .bp3-tag.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.7); } - .bp3-tag.bp3-intent-success{ - background:#0f9960; - color:#ffffff; } - .bp3-tag.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.85); } - .bp3-tag.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.7); } - .bp3-tag.bp3-intent-warning{ - background:#d9822b; - color:#ffffff; } - .bp3-tag.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.85); } - .bp3-tag.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.7); } - .bp3-tag.bp3-intent-danger{ - background:#db3737; - color:#ffffff; } - .bp3-tag.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.85); } - .bp3-tag.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.7); } - .bp3-tag.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-tag.bp3-minimal > .bp3-icon, .bp3-tag.bp3-minimal .bp3-icon-standard, .bp3-tag.bp3-minimal .bp3-icon-large{ - fill:#5c7080; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){ - background-color:rgba(138, 155, 168, 0.2); - color:#182026; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{ - background-color:rgba(92, 112, 128, 0.3); } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{ - background-color:rgba(92, 112, 128, 0.4); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){ - color:#f5f8fa; } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{ - background-color:rgba(191, 204, 214, 0.3); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{ - background-color:rgba(191, 204, 214, 0.4); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) > .bp3-icon, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-large{ - fill:#a7b6c2; } - .bp3-tag.bp3-minimal.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-primary > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-large{ - fill:#137cbd; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.25); - color:#48aff0; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-success > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-large{ - fill:#0f9960; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.25); - color:#3dcc91; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-warning > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-large{ - fill:#d9822b; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.25); - color:#ffb366; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-danger > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-large{ - fill:#db3737; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.25); - color:#ff7373; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.45); } - -.bp3-tag-remove{ - background:none; - border:none; - color:inherit; - cursor:pointer; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin-bottom:-2px; - margin-right:-6px !important; - margin-top:-2px; - opacity:0.5; - padding:2px; - padding-left:0; } - .bp3-tag-remove:hover{ - background:none; - opacity:0.8; - text-decoration:none; } - .bp3-tag-remove:active{ - opacity:1; } - .bp3-tag-remove:empty::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - content:""; } - .bp3-large .bp3-tag-remove{ - margin-right:-10px !important; - padding:0 5px 0 0; } - .bp3-large .bp3-tag-remove:empty::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; } -.bp3-tag-input{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - cursor:text; - height:auto; - line-height:inherit; - min-height:30px; - padding-left:5px; - padding-right:0; } - .bp3-tag-input > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag-input > .bp3-tag-input-values{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag-input .bp3-tag-input-icon{ - color:#5c7080; - margin-left:2px; - margin-right:7px; - margin-top:7px; } - .bp3-tag-input .bp3-tag-input-values{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -ms-flex-item-align:stretch; - align-self:stretch; - -ms-flex-wrap:wrap; - flex-wrap:wrap; - margin-right:7px; - margin-top:5px; - min-width:0; } - .bp3-tag-input .bp3-tag-input-values > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag-input .bp3-tag-input-values > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag-input .bp3-tag-input-values::before, - .bp3-tag-input .bp3-tag-input-values > *{ - margin-right:5px; } - .bp3-tag-input .bp3-tag-input-values:empty::before, - .bp3-tag-input .bp3-tag-input-values > :last-child{ - margin-right:0; } - .bp3-tag-input .bp3-tag-input-values:first-child .bp3-input-ghost:first-child{ - padding-left:5px; } - .bp3-tag-input .bp3-tag-input-values > *{ - margin-bottom:5px; } - .bp3-tag-input .bp3-tag{ - overflow-wrap:break-word; } - .bp3-tag-input .bp3-tag.bp3-active{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:0; - -moz-outline-radius:6px; } - .bp3-tag-input .bp3-input-ghost{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:20px; - width:80px; } - .bp3-tag-input .bp3-input-ghost:disabled, .bp3-tag-input .bp3-input-ghost.bp3-disabled{ - cursor:not-allowed; } - .bp3-tag-input .bp3-button, - .bp3-tag-input .bp3-spinner{ - margin:3px; - margin-left:0; } - .bp3-tag-input .bp3-button{ - min-height:24px; - min-width:24px; - padding:0 7px; } - .bp3-tag-input.bp3-large{ - height:auto; - min-height:40px; } - .bp3-tag-input.bp3-large::before, - .bp3-tag-input.bp3-large > *{ - margin-right:10px; } - .bp3-tag-input.bp3-large:empty::before, - .bp3-tag-input.bp3-large > :last-child{ - margin-right:0; } - .bp3-tag-input.bp3-large .bp3-tag-input-icon{ - margin-left:5px; - margin-top:10px; } - .bp3-tag-input.bp3-large .bp3-input-ghost{ - line-height:30px; } - .bp3-tag-input.bp3-large .bp3-button{ - min-height:30px; - min-width:30px; - padding:5px 10px; - margin:5px; - margin-left:0; } - .bp3-tag-input.bp3-large .bp3-spinner{ - margin:8px; - margin-left:0; } - .bp3-tag-input.bp3-active{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-success{ - -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-tag-input .bp3-tag-input-icon, .bp3-tag-input.bp3-dark .bp3-tag-input-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-tag-input .bp3-input-ghost, .bp3-tag-input.bp3-dark .bp3-input-ghost{ - color:#f5f8fa; } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-webkit-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-moz-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost:-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input.bp3-active, .bp3-tag-input.bp3-dark.bp3-active{ - background-color:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-primary, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-success, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-success{ - -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-warning, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-danger, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-input-ghost{ - background:none; - border:none; - -webkit-box-shadow:none; - box-shadow:none; - padding:0; } - .bp3-input-ghost::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost:focus{ - outline:none !important; } -.bp3-toast{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin:20px 0 0; - max-width:500px; - min-width:300px; - pointer-events:all; - position:relative !important; } - .bp3-toast.bp3-toast-enter, .bp3-toast.bp3-toast-appear{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); } - .bp3-toast.bp3-toast-enter-active, .bp3-toast.bp3-toast-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-toast.bp3-toast-enter ~ .bp3-toast, .bp3-toast.bp3-toast-appear ~ .bp3-toast{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); } - .bp3-toast.bp3-toast-enter-active ~ .bp3-toast, .bp3-toast.bp3-toast-appear-active ~ .bp3-toast{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-toast.bp3-toast-exit{ - opacity:1; - -webkit-filter:blur(0); - filter:blur(0); } - .bp3-toast.bp3-toast-exit-active{ - opacity:0; - -webkit-filter:blur(10px); - filter:blur(10px); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:opacity, filter; - transition-property:opacity, filter, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-toast.bp3-toast-exit ~ .bp3-toast{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-toast.bp3-toast-exit-active ~ .bp3-toast{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); - -webkit-transition-delay:50ms; - transition-delay:50ms; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-toast .bp3-button-group{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - padding:5px; - padding-left:0; } - .bp3-toast > .bp3-icon{ - color:#5c7080; - margin:12px; - margin-right:0; } - .bp3-toast.bp3-dark, - .bp3-dark .bp3-toast{ - background-color:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-toast.bp3-dark > .bp3-icon, - .bp3-dark .bp3-toast > .bp3-icon{ - color:#a7b6c2; } - .bp3-toast[class*="bp3-intent-"] a{ - color:rgba(255, 255, 255, 0.7); } - .bp3-toast[class*="bp3-intent-"] a:hover{ - color:#ffffff; } - .bp3-toast[class*="bp3-intent-"] > .bp3-icon{ - color:#ffffff; } - .bp3-toast[class*="bp3-intent-"] .bp3-button, .bp3-toast[class*="bp3-intent-"] .bp3-button::before, - .bp3-toast[class*="bp3-intent-"] .bp3-button .bp3-icon, .bp3-toast[class*="bp3-intent-"] .bp3-button:active{ - color:rgba(255, 255, 255, 0.7) !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button:focus{ - outline-color:rgba(255, 255, 255, 0.5); } - .bp3-toast[class*="bp3-intent-"] .bp3-button:hover{ - background-color:rgba(255, 255, 255, 0.15) !important; - color:#ffffff !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button:active{ - background-color:rgba(255, 255, 255, 0.3) !important; - color:#ffffff !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button::after{ - background:rgba(255, 255, 255, 0.3) !important; } - .bp3-toast.bp3-intent-primary{ - background-color:#137cbd; - color:#ffffff; } - .bp3-toast.bp3-intent-success{ - background-color:#0f9960; - color:#ffffff; } - .bp3-toast.bp3-intent-warning{ - background-color:#d9822b; - color:#ffffff; } - .bp3-toast.bp3-intent-danger{ - background-color:#db3737; - color:#ffffff; } - -.bp3-toast-message{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - padding:11px; - word-break:break-word; } - -.bp3-toast-container{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box !important; - display:-ms-flexbox !important; - display:flex !important; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - left:0; - overflow:hidden; - padding:0 20px 20px; - pointer-events:none; - right:0; - z-index:40; } - .bp3-toast-container.bp3-toast-container-in-portal{ - position:fixed; } - .bp3-toast-container.bp3-toast-container-inline{ - position:absolute; } - .bp3-toast-container.bp3-toast-container-top{ - top:0; } - .bp3-toast-container.bp3-toast-container-bottom{ - bottom:0; - -webkit-box-orient:vertical; - -webkit-box-direction:reverse; - -ms-flex-direction:column-reverse; - flex-direction:column-reverse; - top:auto; } - .bp3-toast-container.bp3-toast-container-left{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; } - .bp3-toast-container.bp3-toast-container-right{ - -webkit-box-align:end; - -ms-flex-align:end; - align-items:flex-end; } - -.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active), -.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active) ~ .bp3-toast, .bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active), -.bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active) ~ .bp3-toast, -.bp3-toast-container-bottom .bp3-toast.bp3-toast-exit-active ~ .bp3-toast, -.bp3-toast-container-bottom .bp3-toast.bp3-toast-leave-active ~ .bp3-toast{ - -webkit-transform:translateY(60px); - transform:translateY(60px); } -.bp3-tooltip{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-tooltip .bp3-popover-arrow{ - height:22px; - position:absolute; - width:22px; } - .bp3-tooltip .bp3-popover-arrow::before{ - height:14px; - margin:4px; - width:14px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip{ - margin-bottom:11px; - margin-top:-11px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{ - bottom:-8px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(-90deg); - transform:rotate(-90deg); } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip{ - margin-left:11px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{ - left:-8px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(0); - transform:rotate(0); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip{ - margin-top:11px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{ - top:-8px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip{ - margin-left:-11px; - margin-right:11px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{ - right:-8px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(180deg); - transform:rotate(180deg); } - .bp3-tether-element-attached-middle > .bp3-tooltip > .bp3-popover-arrow{ - top:50%; - -webkit-transform:translateY(-50%); - transform:translateY(-50%); } - .bp3-tether-element-attached-center > .bp3-tooltip > .bp3-popover-arrow{ - right:50%; - -webkit-transform:translateX(50%); - transform:translateX(50%); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{ - top:-0.22183px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{ - right:-0.22183px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{ - left:-0.22183px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{ - bottom:-0.22183px; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:top left; - transform-origin:top left; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:top center; - transform-origin:top center; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:top right; - transform-origin:top right; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:center left; - transform-origin:center left; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:center center; - transform-origin:center center; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:center right; - transform-origin:center right; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:bottom left; - transform-origin:bottom left; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:bottom center; - transform-origin:bottom center; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:bottom right; - transform-origin:bottom right; } - .bp3-tooltip .bp3-popover-content{ - background:#394b59; - color:#f5f8fa; } - .bp3-tooltip .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); } - .bp3-tooltip .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.1; } - .bp3-tooltip .bp3-popover-arrow-fill{ - fill:#394b59; } - .bp3-popover-enter > .bp3-tooltip, .bp3-popover-appear > .bp3-tooltip{ - -webkit-transform:scale(0.8); - transform:scale(0.8); } - .bp3-popover-enter-active > .bp3-tooltip, .bp3-popover-appear-active > .bp3-tooltip{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover-exit > .bp3-tooltip{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-tooltip{ - -webkit-transform:scale(0.8); - transform:scale(0.8); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tooltip .bp3-popover-content{ - padding:10px 12px; } - .bp3-tooltip.bp3-dark, - .bp3-dark .bp3-tooltip{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-tooltip.bp3-dark .bp3-popover-content, - .bp3-dark .bp3-tooltip .bp3-popover-content{ - background:#e1e8ed; - color:#394b59; } - .bp3-tooltip.bp3-dark .bp3-popover-arrow::before, - .bp3-dark .bp3-tooltip .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); } - .bp3-tooltip.bp3-dark .bp3-popover-arrow-border, - .bp3-dark .bp3-tooltip .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.2; } - .bp3-tooltip.bp3-dark .bp3-popover-arrow-fill, - .bp3-dark .bp3-tooltip .bp3-popover-arrow-fill{ - fill:#e1e8ed; } - .bp3-tooltip.bp3-intent-primary .bp3-popover-content{ - background:#137cbd; - color:#ffffff; } - .bp3-tooltip.bp3-intent-primary .bp3-popover-arrow-fill{ - fill:#137cbd; } - .bp3-tooltip.bp3-intent-success .bp3-popover-content{ - background:#0f9960; - color:#ffffff; } - .bp3-tooltip.bp3-intent-success .bp3-popover-arrow-fill{ - fill:#0f9960; } - .bp3-tooltip.bp3-intent-warning .bp3-popover-content{ - background:#d9822b; - color:#ffffff; } - .bp3-tooltip.bp3-intent-warning .bp3-popover-arrow-fill{ - fill:#d9822b; } - .bp3-tooltip.bp3-intent-danger .bp3-popover-content{ - background:#db3737; - color:#ffffff; } - .bp3-tooltip.bp3-intent-danger .bp3-popover-arrow-fill{ - fill:#db3737; } - -.bp3-tooltip-indicator{ - border-bottom:dotted 1px; - cursor:help; } -.bp3-tree .bp3-icon, .bp3-tree .bp3-icon-standard, .bp3-tree .bp3-icon-large{ - color:#5c7080; } - .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-tree .bp3-icon-large.bp3-intent-primary{ - color:#137cbd; } - .bp3-tree .bp3-icon.bp3-intent-success, .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-tree .bp3-icon-large.bp3-intent-success{ - color:#0f9960; } - .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-tree .bp3-icon-large.bp3-intent-warning{ - color:#d9822b; } - .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-tree .bp3-icon-large.bp3-intent-danger{ - color:#db3737; } - -.bp3-tree-node-list{ - list-style:none; - margin:0; - padding-left:0; } - -.bp3-tree-root{ - background-color:transparent; - cursor:default; - padding-left:0; - position:relative; } - -.bp3-tree-node-content-0{ - padding-left:0px; } - -.bp3-tree-node-content-1{ - padding-left:23px; } - -.bp3-tree-node-content-2{ - padding-left:46px; } - -.bp3-tree-node-content-3{ - padding-left:69px; } - -.bp3-tree-node-content-4{ - padding-left:92px; } - -.bp3-tree-node-content-5{ - padding-left:115px; } - -.bp3-tree-node-content-6{ - padding-left:138px; } - -.bp3-tree-node-content-7{ - padding-left:161px; } - -.bp3-tree-node-content-8{ - padding-left:184px; } - -.bp3-tree-node-content-9{ - padding-left:207px; } - -.bp3-tree-node-content-10{ - padding-left:230px; } - -.bp3-tree-node-content-11{ - padding-left:253px; } - -.bp3-tree-node-content-12{ - padding-left:276px; } - -.bp3-tree-node-content-13{ - padding-left:299px; } - -.bp3-tree-node-content-14{ - padding-left:322px; } - -.bp3-tree-node-content-15{ - padding-left:345px; } - -.bp3-tree-node-content-16{ - padding-left:368px; } - -.bp3-tree-node-content-17{ - padding-left:391px; } - -.bp3-tree-node-content-18{ - padding-left:414px; } - -.bp3-tree-node-content-19{ - padding-left:437px; } - -.bp3-tree-node-content-20{ - padding-left:460px; } - -.bp3-tree-node-content{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:30px; - padding-right:5px; - width:100%; } - .bp3-tree-node-content:hover{ - background-color:rgba(191, 204, 214, 0.4); } - -.bp3-tree-node-caret, -.bp3-tree-node-caret-none{ - min-width:30px; } - -.bp3-tree-node-caret{ - color:#5c7080; - cursor:pointer; - padding:7px; - -webkit-transform:rotate(0deg); - transform:rotate(0deg); - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tree-node-caret:hover{ - color:#182026; } - .bp3-dark .bp3-tree-node-caret{ - color:#a7b6c2; } - .bp3-dark .bp3-tree-node-caret:hover{ - color:#f5f8fa; } - .bp3-tree-node-caret.bp3-tree-node-caret-open{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tree-node-caret.bp3-icon-standard::before{ - content:""; } - -.bp3-tree-node-icon{ - margin-right:7px; - position:relative; } - -.bp3-tree-node-label{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-tree-node-label span{ - display:inline; } - -.bp3-tree-node-secondary-label{ - padding:0 5px; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-tree-node-secondary-label .bp3-popover-wrapper, - .bp3-tree-node-secondary-label .bp3-popover-target{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - -.bp3-tree-node.bp3-disabled .bp3-tree-node-content{ - background-color:inherit; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-tree-node.bp3-disabled .bp3-tree-node-caret, -.bp3-tree-node.bp3-disabled .bp3-tree-node-icon{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{ - background-color:#137cbd; } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content, - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-standard, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-large{ - color:#ffffff; } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret::before{ - color:rgba(255, 255, 255, 0.7); } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret:hover::before{ - color:#ffffff; } - -.bp3-dark .bp3-tree-node-content:hover{ - background-color:rgba(92, 112, 128, 0.3); } - -.bp3-dark .bp3-tree .bp3-icon, .bp3-dark .bp3-tree .bp3-icon-standard, .bp3-dark .bp3-tree .bp3-icon-large{ - color:#a7b6c2; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-primary{ - color:#137cbd; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-success{ - color:#0f9960; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-warning{ - color:#d9822b; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-danger{ - color:#db3737; } - -.bp3-dark .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{ - background-color:#137cbd; } -.bp3-omnibar{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - left:calc(50% - 250px); - top:20vh; - width:500px; - z-index:21; } - .bp3-omnibar.bp3-overlay-enter, .bp3-omnibar.bp3-overlay-appear{ - -webkit-filter:blur(20px); - filter:blur(20px); - opacity:0.2; } - .bp3-omnibar.bp3-overlay-enter-active, .bp3-omnibar.bp3-overlay-appear-active{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:filter, opacity; - transition-property:filter, opacity, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-omnibar.bp3-overlay-exit{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; } - .bp3-omnibar.bp3-overlay-exit-active{ - -webkit-filter:blur(20px); - filter:blur(20px); - opacity:0.2; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:filter, opacity; - transition-property:filter, opacity, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-omnibar .bp3-input{ - background-color:transparent; - border-radius:0; } - .bp3-omnibar .bp3-input, .bp3-omnibar .bp3-input:focus{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-omnibar .bp3-menu{ - background-color:transparent; - border-radius:0; - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - max-height:calc(60vh - 40px); - overflow:auto; } - .bp3-omnibar .bp3-menu:empty{ - display:none; } - .bp3-dark .bp3-omnibar, .bp3-omnibar.bp3-dark{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); } - -.bp3-omnibar-overlay .bp3-overlay-backdrop{ - background-color:rgba(16, 22, 26, 0.2); } - -.bp3-select-popover .bp3-popover-content{ - padding:5px; } - -.bp3-select-popover .bp3-input-group{ - margin-bottom:0; } - -.bp3-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; - padding:0; } - .bp3-select-popover .bp3-menu:not(:first-child){ - padding-top:5px; } - -.bp3-multi-select{ - min-width:150px; } - -.bp3-multi-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; } - -.bp3-select-popover .bp3-popover-content{ - padding:5px; } - -.bp3-select-popover .bp3-input-group{ - margin-bottom:0; } - -.bp3-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; - padding:0; } - .bp3-select-popover .bp3-menu:not(:first-child){ - padding-top:5px; } -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */ - -/** - * (DEPRECATED) Support for consuming icons as CSS background images - */ - -/* Icons urls */ - -:root { - --jp-icon-add: url(); - --jp-icon-bug: url(); - --jp-icon-build: url(); - --jp-icon-caret-down-empty-thin: url(); - --jp-icon-caret-down-empty: url(); - --jp-icon-caret-down: url(); - --jp-icon-caret-left: url(); - --jp-icon-caret-right: url(); - --jp-icon-caret-up-empty-thin: url(); - --jp-icon-caret-up: url(); - --jp-icon-case-sensitive: url(); - --jp-icon-check: url(); - --jp-icon-circle-empty: url(); - --jp-icon-circle: url(); - --jp-icon-clear: url(); - --jp-icon-close: url(); - --jp-icon-code: url(); - --jp-icon-console: url(); - --jp-icon-copy: url(); - --jp-icon-copyright: url(); - --jp-icon-cut: url(); - --jp-icon-download: url(); - --jp-icon-edit: url(); - --jp-icon-ellipses: url(); - --jp-icon-extension: url(); - --jp-icon-fast-forward: url(); - --jp-icon-file-upload: url(); - --jp-icon-file: url(); - --jp-icon-filter-list: url(); - --jp-icon-folder: url(); - --jp-icon-html5: url(); - --jp-icon-image: url(); - --jp-icon-inspector: url(); - --jp-icon-json: url(); - --jp-icon-julia: url(); - --jp-icon-jupyter-favicon: url(); - --jp-icon-jupyter: url(); - --jp-icon-jupyterlab-wordmark: url(); - --jp-icon-kernel: url(); - --jp-icon-keyboard: url(); - --jp-icon-launcher: url(); - --jp-icon-line-form: url(); - --jp-icon-link: url(); - --jp-icon-list: url(); - --jp-icon-listings-info: url(); - --jp-icon-markdown: url(); - --jp-icon-new-folder: url(); - --jp-icon-not-trusted: url(); - --jp-icon-notebook: url(); - --jp-icon-numbering: url(); - --jp-icon-offline-bolt: url(); - --jp-icon-palette: url(); - --jp-icon-paste: url(); - --jp-icon-pdf: url(); - --jp-icon-python: url(); - --jp-icon-r-kernel: url(); - --jp-icon-react: url(); - --jp-icon-redo: url(); - --jp-icon-refresh: url(); - --jp-icon-regex: url(); - --jp-icon-run: url(); - --jp-icon-running: url(); - --jp-icon-save: url(); - --jp-icon-search: url(); - --jp-icon-settings: url(); - --jp-icon-spreadsheet: url(); - --jp-icon-stop: url(); - --jp-icon-tab: url(); - --jp-icon-table-rows: url(); - --jp-icon-tag: url(); - --jp-icon-terminal: url(); - --jp-icon-text-editor: url(); - --jp-icon-toc: url(); - --jp-icon-tree-view: url(); - --jp-icon-trusted: url(); - --jp-icon-undo: url(); - --jp-icon-vega: url(); - --jp-icon-yaml: url(); -} - -/* Icon CSS class declarations */ - -.jp-AddIcon { - background-image: var(--jp-icon-add); -} -.jp-BugIcon { - background-image: var(--jp-icon-bug); -} -.jp-BuildIcon { - background-image: var(--jp-icon-build); -} -.jp-CaretDownEmptyIcon { - background-image: var(--jp-icon-caret-down-empty); -} -.jp-CaretDownEmptyThinIcon { - background-image: var(--jp-icon-caret-down-empty-thin); -} -.jp-CaretDownIcon { - background-image: var(--jp-icon-caret-down); -} -.jp-CaretLeftIcon { - background-image: var(--jp-icon-caret-left); -} -.jp-CaretRightIcon { - background-image: var(--jp-icon-caret-right); -} -.jp-CaretUpEmptyThinIcon { - background-image: var(--jp-icon-caret-up-empty-thin); -} -.jp-CaretUpIcon { - background-image: var(--jp-icon-caret-up); -} -.jp-CaseSensitiveIcon { - background-image: var(--jp-icon-case-sensitive); -} -.jp-CheckIcon { - background-image: var(--jp-icon-check); -} -.jp-CircleEmptyIcon { - background-image: var(--jp-icon-circle-empty); -} -.jp-CircleIcon { - background-image: var(--jp-icon-circle); -} -.jp-ClearIcon { - background-image: var(--jp-icon-clear); -} -.jp-CloseIcon { - background-image: var(--jp-icon-close); -} -.jp-CodeIcon { - background-image: var(--jp-icon-code); -} -.jp-ConsoleIcon { - background-image: var(--jp-icon-console); -} -.jp-CopyIcon { - background-image: var(--jp-icon-copy); -} -.jp-CopyrightIcon { - background-image: var(--jp-icon-copyright); -} -.jp-CutIcon { - background-image: var(--jp-icon-cut); -} -.jp-DownloadIcon { - background-image: var(--jp-icon-download); -} -.jp-EditIcon { - background-image: var(--jp-icon-edit); -} -.jp-EllipsesIcon { - background-image: var(--jp-icon-ellipses); -} -.jp-ExtensionIcon { - background-image: var(--jp-icon-extension); -} -.jp-FastForwardIcon { - background-image: var(--jp-icon-fast-forward); -} -.jp-FileIcon { - background-image: var(--jp-icon-file); -} -.jp-FileUploadIcon { - background-image: var(--jp-icon-file-upload); -} -.jp-FilterListIcon { - background-image: var(--jp-icon-filter-list); -} -.jp-FolderIcon { - background-image: var(--jp-icon-folder); -} -.jp-Html5Icon { - background-image: var(--jp-icon-html5); -} -.jp-ImageIcon { - background-image: var(--jp-icon-image); -} -.jp-InspectorIcon { - background-image: var(--jp-icon-inspector); -} -.jp-JsonIcon { - background-image: var(--jp-icon-json); -} -.jp-JuliaIcon { - background-image: var(--jp-icon-julia); -} -.jp-JupyterFaviconIcon { - background-image: var(--jp-icon-jupyter-favicon); -} -.jp-JupyterIcon { - background-image: var(--jp-icon-jupyter); -} -.jp-JupyterlabWordmarkIcon { - background-image: var(--jp-icon-jupyterlab-wordmark); -} -.jp-KernelIcon { - background-image: var(--jp-icon-kernel); -} -.jp-KeyboardIcon { - background-image: var(--jp-icon-keyboard); -} -.jp-LauncherIcon { - background-image: var(--jp-icon-launcher); -} -.jp-LineFormIcon { - background-image: var(--jp-icon-line-form); -} -.jp-LinkIcon { - background-image: var(--jp-icon-link); -} -.jp-ListIcon { - background-image: var(--jp-icon-list); -} -.jp-ListingsInfoIcon { - background-image: var(--jp-icon-listings-info); -} -.jp-MarkdownIcon { - background-image: var(--jp-icon-markdown); -} -.jp-NewFolderIcon { - background-image: var(--jp-icon-new-folder); -} -.jp-NotTrustedIcon { - background-image: var(--jp-icon-not-trusted); -} -.jp-NotebookIcon { - background-image: var(--jp-icon-notebook); -} -.jp-NumberingIcon { - background-image: var(--jp-icon-numbering); -} -.jp-OfflineBoltIcon { - background-image: var(--jp-icon-offline-bolt); -} -.jp-PaletteIcon { - background-image: var(--jp-icon-palette); -} -.jp-PasteIcon { - background-image: var(--jp-icon-paste); -} -.jp-PdfIcon { - background-image: var(--jp-icon-pdf); -} -.jp-PythonIcon { - background-image: var(--jp-icon-python); -} -.jp-RKernelIcon { - background-image: var(--jp-icon-r-kernel); -} -.jp-ReactIcon { - background-image: var(--jp-icon-react); -} -.jp-RedoIcon { - background-image: var(--jp-icon-redo); -} -.jp-RefreshIcon { - background-image: var(--jp-icon-refresh); -} -.jp-RegexIcon { - background-image: var(--jp-icon-regex); -} -.jp-RunIcon { - background-image: var(--jp-icon-run); -} -.jp-RunningIcon { - background-image: var(--jp-icon-running); -} -.jp-SaveIcon { - background-image: var(--jp-icon-save); -} -.jp-SearchIcon { - background-image: var(--jp-icon-search); -} -.jp-SettingsIcon { - background-image: var(--jp-icon-settings); -} -.jp-SpreadsheetIcon { - background-image: var(--jp-icon-spreadsheet); -} -.jp-StopIcon { - background-image: var(--jp-icon-stop); -} -.jp-TabIcon { - background-image: var(--jp-icon-tab); -} -.jp-TableRowsIcon { - background-image: var(--jp-icon-table-rows); -} -.jp-TagIcon { - background-image: var(--jp-icon-tag); -} -.jp-TerminalIcon { - background-image: var(--jp-icon-terminal); -} -.jp-TextEditorIcon { - background-image: var(--jp-icon-text-editor); -} -.jp-TocIcon { - background-image: var(--jp-icon-toc); -} -.jp-TreeViewIcon { - background-image: var(--jp-icon-tree-view); -} -.jp-TrustedIcon { - background-image: var(--jp-icon-trusted); -} -.jp-UndoIcon { - background-image: var(--jp-icon-undo); -} -.jp-VegaIcon { - background-image: var(--jp-icon-vega); -} -.jp-YamlIcon { - background-image: var(--jp-icon-yaml); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * (DEPRECATED) Support for consuming icons as CSS background images - */ - -.jp-Icon, -.jp-MaterialIcon { - background-position: center; - background-repeat: no-repeat; - background-size: 16px; - min-width: 16px; - min-height: 16px; -} - -.jp-Icon-cover { - background-position: center; - background-repeat: no-repeat; - background-size: cover; -} - -/** - * (DEPRECATED) Support for specific CSS icon sizes - */ - -.jp-Icon-16 { - background-size: 16px; - min-width: 16px; - min-height: 16px; -} - -.jp-Icon-18 { - background-size: 18px; - min-width: 18px; - min-height: 18px; -} - -.jp-Icon-20 { - background-size: 20px; - min-width: 20px; - min-height: 20px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * Support for icons as inline SVG HTMLElements - */ - -/* recolor the primary elements of an icon */ -.jp-icon0[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon1[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon2[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon3[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon4[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon0[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon1[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon2[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon3[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon4[stroke] { - stroke: var(--jp-inverse-layout-color4); -} -/* recolor the accent elements of an icon */ -.jp-icon-accent0[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-accent1[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-accent2[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-accent3[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-accent4[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-accent0[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-accent1[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-accent2[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-accent3[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-accent4[stroke] { - stroke: var(--jp-layout-color4); -} -/* set the color of an icon to transparent */ -.jp-icon-none[fill] { - fill: none; -} - -.jp-icon-none[stroke] { - stroke: none; -} -/* brand icon colors. Same for light and dark */ -.jp-icon-brand0[fill] { - fill: var(--jp-brand-color0); -} -.jp-icon-brand1[fill] { - fill: var(--jp-brand-color1); -} -.jp-icon-brand2[fill] { - fill: var(--jp-brand-color2); -} -.jp-icon-brand3[fill] { - fill: var(--jp-brand-color3); -} -.jp-icon-brand4[fill] { - fill: var(--jp-brand-color4); -} - -.jp-icon-brand0[stroke] { - stroke: var(--jp-brand-color0); -} -.jp-icon-brand1[stroke] { - stroke: var(--jp-brand-color1); -} -.jp-icon-brand2[stroke] { - stroke: var(--jp-brand-color2); -} -.jp-icon-brand3[stroke] { - stroke: var(--jp-brand-color3); -} -.jp-icon-brand4[stroke] { - stroke: var(--jp-brand-color4); -} -/* warn icon colors. Same for light and dark */ -.jp-icon-warn0[fill] { - fill: var(--jp-warn-color0); -} -.jp-icon-warn1[fill] { - fill: var(--jp-warn-color1); -} -.jp-icon-warn2[fill] { - fill: var(--jp-warn-color2); -} -.jp-icon-warn3[fill] { - fill: var(--jp-warn-color3); -} - -.jp-icon-warn0[stroke] { - stroke: var(--jp-warn-color0); -} -.jp-icon-warn1[stroke] { - stroke: var(--jp-warn-color1); -} -.jp-icon-warn2[stroke] { - stroke: var(--jp-warn-color2); -} -.jp-icon-warn3[stroke] { - stroke: var(--jp-warn-color3); -} -/* icon colors that contrast well with each other and most backgrounds */ -.jp-icon-contrast0[fill] { - fill: var(--jp-icon-contrast-color0); -} -.jp-icon-contrast1[fill] { - fill: var(--jp-icon-contrast-color1); -} -.jp-icon-contrast2[fill] { - fill: var(--jp-icon-contrast-color2); -} -.jp-icon-contrast3[fill] { - fill: var(--jp-icon-contrast-color3); -} - -.jp-icon-contrast0[stroke] { - stroke: var(--jp-icon-contrast-color0); -} -.jp-icon-contrast1[stroke] { - stroke: var(--jp-icon-contrast-color1); -} -.jp-icon-contrast2[stroke] { - stroke: var(--jp-icon-contrast-color2); -} -.jp-icon-contrast3[stroke] { - stroke: var(--jp-icon-contrast-color3); -} - -/* CSS for icons in selected items in the settings editor */ -#setting-editor .jp-PluginList .jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} -#setting-editor - .jp-PluginList - .jp-mod-selected - .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} - -/* CSS for icons in selected filebrowser listing items */ -.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} -.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} - -/* CSS for icons in selected tabs in the sidebar tab manager */ -#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable[fill] { - fill: #fff; -} - -#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} -#tab-manager - .lm-TabBar-tab.jp-mod-active - .jp-icon-hover - :hover - .jp-icon-selectable[fill] { - fill: var(--jp-brand-color1); -} - -#tab-manager - .lm-TabBar-tab.jp-mod-active - .jp-icon-hover - :hover - .jp-icon-selectable-inverse[fill] { - fill: #fff; -} - -/** - * TODO: come up with non css-hack solution for showing the busy icon on top - * of the close icon - * CSS for complex behavior of close icon of tabs in the sidebar tab manager - */ -#tab-manager - .lm-TabBar-tab.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon3[fill] { - fill: none; -} -#tab-manager - .lm-TabBar-tab.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: var(--jp-inverse-layout-color3); -} - -#tab-manager - .lm-TabBar-tab.jp-mod-dirty.jp-mod-active - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: #fff; -} - -/** -* TODO: come up with non css-hack solution for showing the busy icon on top -* of the close icon -* CSS for complex behavior of close icon of tabs in the main area tabbar -*/ -.lm-DockPanel-tabBar - .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon3[fill] { - fill: none; -} -.lm-DockPanel-tabBar - .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: var(--jp-inverse-layout-color3); -} - -/* CSS for icons in status bar */ -#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} - -#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} -/* special handling for splash icon CSS. While the theme CSS reloads during - splash, the splash icon can loose theming. To prevent that, we set a - default for its color variable */ -:root { - --jp-warn-color0: var(--md-orange-700); -} - -/* not sure what to do with this one, used in filebrowser listing */ -.jp-DragIcon { - margin-right: 4px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * Support for alt colors for icons as inline SVG HTMLElements - */ - -/* alt recolor the primary elements of an icon */ -.jp-icon-alt .jp-icon0[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-alt .jp-icon1[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-alt .jp-icon2[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-alt .jp-icon3[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-alt .jp-icon4[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-alt .jp-icon0[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-alt .jp-icon1[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-alt .jp-icon2[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-alt .jp-icon3[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-alt .jp-icon4[stroke] { - stroke: var(--jp-layout-color4); -} - -/* alt recolor the accent elements of an icon */ -.jp-icon-alt .jp-icon-accent0[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-alt .jp-icon-accent1[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-alt .jp-icon-accent2[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-alt .jp-icon-accent3[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-alt .jp-icon-accent4[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-alt .jp-icon-accent0[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-alt .jp-icon-accent1[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-alt .jp-icon-accent2[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-alt .jp-icon-accent3[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-alt .jp-icon-accent4[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-icon-hoverShow:not(:hover) svg { - display: none !important; -} - -/** - * Support for hover colors for icons as inline SVG HTMLElements - */ - -/** - * regular colors - */ - -/* recolor the primary elements of an icon */ -.jp-icon-hover :hover .jp-icon0-hover[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-hover :hover .jp-icon1-hover[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-hover :hover .jp-icon2-hover[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-hover :hover .jp-icon3-hover[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-hover :hover .jp-icon4-hover[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-hover :hover .jp-icon0-hover[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-hover :hover .jp-icon1-hover[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-hover :hover .jp-icon2-hover[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-hover :hover .jp-icon3-hover[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-hover :hover .jp-icon4-hover[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/* recolor the accent elements of an icon */ -.jp-icon-hover :hover .jp-icon-accent0-hover[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-hover :hover .jp-icon-accent1-hover[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-hover :hover .jp-icon-accent2-hover[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-hover :hover .jp-icon-accent3-hover[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-hover :hover .jp-icon-accent4-hover[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] { - stroke: var(--jp-layout-color4); -} - -/* set the color of an icon to transparent */ -.jp-icon-hover :hover .jp-icon-none-hover[fill] { - fill: none; -} - -.jp-icon-hover :hover .jp-icon-none-hover[stroke] { - stroke: none; -} - -/** - * inverse colors - */ - -/* inverse recolor the primary elements of an icon */ -.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] { - stroke: var(--jp-layout-color4); -} - -/* inverse recolor the accent elements of an icon */ -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-switch { - display: flex; - align-items: center; - padding-left: 4px; - padding-right: 4px; - font-size: var(--jp-ui-font-size1); - background-color: transparent; - color: var(--jp-ui-font-color1); - border: none; - height: 20px; -} - -.jp-switch:hover { - background-color: var(--jp-layout-color2); -} - -.jp-switch-label { - margin-right: 5px; -} - -.jp-switch-track { - cursor: pointer; - background-color: var(--jp-border-color1); - -webkit-transition: 0.4s; - transition: 0.4s; - border-radius: 34px; - height: 16px; - width: 35px; - position: relative; -} - -.jp-switch-track::before { - content: ''; - position: absolute; - height: 10px; - width: 10px; - margin: 3px; - left: 0px; - background-color: var(--jp-ui-inverse-font-color1); - -webkit-transition: 0.4s; - transition: 0.4s; - border-radius: 50%; -} - -.jp-switch[aria-checked='true'] .jp-switch-track { - background-color: var(--jp-warn-color0); -} - -.jp-switch[aria-checked='true'] .jp-switch-track::before { - /* track width (35) - margins (3 + 3) - thumb width (10) */ - left: 19px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* Sibling imports */ - -/* Override Blueprint's _reset.scss styles */ -html { - box-sizing: unset; -} - -*, -*::before, -*::after { - box-sizing: unset; -} - -body { - color: unset; - font-family: var(--jp-ui-font-family); -} - -p { - margin-top: unset; - margin-bottom: unset; -} - -small { - font-size: unset; -} - -strong { - font-weight: unset; -} - -/* Override Blueprint's _typography.scss styles */ -a { - text-decoration: unset; - color: unset; -} -a:hover { - text-decoration: unset; - color: unset; -} - -/* Override Blueprint's _accessibility.scss styles */ -:focus { - outline: unset; - outline-offset: unset; - -moz-outline-radius: unset; -} - -/* Styles for ui-components */ -.jp-Button { - border-radius: var(--jp-border-radius); - padding: 0px 12px; - font-size: var(--jp-ui-font-size1); -} - -/* Use our own theme for hover styles */ -button.jp-Button.bp3-button.bp3-minimal:hover { - background-color: var(--jp-layout-color2); -} -.jp-Button.minimal { - color: unset !important; -} - -.jp-Button.jp-ToolbarButtonComponent { - text-transform: none; -} - -.jp-InputGroup input { - box-sizing: border-box; - border-radius: 0; - background-color: transparent; - color: var(--jp-ui-font-color0); - box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); -} - -.jp-InputGroup input:focus { - box-shadow: inset 0 0 0 var(--jp-border-width) - var(--jp-input-active-box-shadow-color), - inset 0 0 0 3px var(--jp-input-active-box-shadow-color); -} - -.jp-InputGroup input::placeholder, -input::placeholder { - color: var(--jp-ui-font-color3); -} - -.jp-BPIcon { - display: inline-block; - vertical-align: middle; - margin: auto; -} - -/* Stop blueprint futzing with our icon fills */ -.bp3-icon.jp-BPIcon > svg:not([fill]) { - fill: var(--jp-inverse-layout-color3); -} - -.jp-InputGroupAction { - padding: 6px; -} - -.jp-HTMLSelect.jp-DefaultStyle select { - background-color: initial; - border: none; - border-radius: 0; - box-shadow: none; - color: var(--jp-ui-font-color0); - display: block; - font-size: var(--jp-ui-font-size1); - height: 24px; - line-height: 14px; - padding: 0 25px 0 10px; - text-align: left; - -moz-appearance: none; - -webkit-appearance: none; -} - -/* Use our own theme for hover and option styles */ -.jp-HTMLSelect.jp-DefaultStyle select:hover, -.jp-HTMLSelect.jp-DefaultStyle select > option { - background-color: var(--jp-layout-color2); - color: var(--jp-ui-font-color0); -} -select { - box-sizing: border-box; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Collapse { - display: flex; - flex-direction: column; - align-items: stretch; - border-top: 1px solid var(--jp-border-color2); - border-bottom: 1px solid var(--jp-border-color2); -} - -.jp-Collapse-header { - padding: 1px 12px; - color: var(--jp-ui-font-color1); - background-color: var(--jp-layout-color1); - font-size: var(--jp-ui-font-size2); -} - -.jp-Collapse-header:hover { - background-color: var(--jp-layout-color2); -} - -.jp-Collapse-contents { - padding: 0px 12px 0px 12px; - background-color: var(--jp-layout-color1); - color: var(--jp-ui-font-color1); - overflow: auto; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-commandpalette-search-height: 28px; -} - -/*----------------------------------------------------------------------------- -| Overall styles -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette { - padding-bottom: 0px; - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); -} - -/*----------------------------------------------------------------------------- -| Modal variant -|----------------------------------------------------------------------------*/ - -.jp-ModalCommandPalette { - position: absolute; - z-index: 10000; - top: 38px; - left: 30%; - margin: 0; - padding: 4px; - width: 40%; - box-shadow: var(--jp-elevation-z4); - border-radius: 4px; - background: var(--jp-layout-color0); -} - -.jp-ModalCommandPalette .lm-CommandPalette { - max-height: 40vh; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after { - display: none; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header { - display: none; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item { - margin-left: 4px; - margin-right: 4px; -} - -.jp-ModalCommandPalette - .lm-CommandPalette - .lm-CommandPalette-item.lm-mod-disabled { - display: none; -} - -/*----------------------------------------------------------------------------- -| Search -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette-search { - padding: 4px; - background-color: var(--jp-layout-color1); - z-index: 2; -} - -.lm-CommandPalette-wrapper { - overflow: overlay; - padding: 0px 9px; - background-color: var(--jp-input-active-background); - height: 30px; - box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); -} - -.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper { - box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color), - inset 0 0 0 3px var(--jp-input-active-box-shadow-color); -} - -.jp-SearchIconGroup { - color: white; - background-color: var(--jp-brand-color1); - position: absolute; - top: 4px; - right: 4px; - padding: 5px 5px 1px 5px; -} - -.jp-SearchIconGroup svg { - height: 20px; - width: 20px; -} - -.jp-SearchIconGroup .jp-icon3[fill] { - fill: var(--jp-layout-color0); -} - -.lm-CommandPalette-input { - background: transparent; - width: calc(100% - 18px); - float: left; - border: none; - outline: none; - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - line-height: var(--jp-private-commandpalette-search-height); -} - -.lm-CommandPalette-input::-webkit-input-placeholder, -.lm-CommandPalette-input::-moz-placeholder, -.lm-CommandPalette-input:-ms-input-placeholder { - color: var(--jp-ui-font-color2); - font-size: var(--jp-ui-font-size1); -} - -/*----------------------------------------------------------------------------- -| Results -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette-header:first-child { - margin-top: 0px; -} - -.lm-CommandPalette-header { - border-bottom: solid var(--jp-border-width) var(--jp-border-color2); - color: var(--jp-ui-font-color1); - cursor: pointer; - display: flex; - font-size: var(--jp-ui-font-size0); - font-weight: 600; - letter-spacing: 1px; - margin-top: 8px; - padding: 8px 0 8px 12px; - text-transform: uppercase; -} - -.lm-CommandPalette-header.lm-mod-active { - background: var(--jp-layout-color2); -} - -.lm-CommandPalette-header > mark { - background-color: transparent; - font-weight: bold; - color: var(--jp-ui-font-color1); -} - -.lm-CommandPalette-item { - padding: 4px 12px 4px 4px; - color: var(--jp-ui-font-color1); - font-size: var(--jp-ui-font-size1); - font-weight: 400; - display: flex; -} - -.lm-CommandPalette-item.lm-mod-disabled { - color: var(--jp-ui-font-color2); -} - -.lm-CommandPalette-item.lm-mod-active { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-inverse-font-color0); -} - -.lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] { - fill: var(--jp-layout-color0); -} - -.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-inverse-font-color0); -} - -.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) { - background: var(--jp-layout-color2); -} - -.lm-CommandPalette-itemContent { - overflow: hidden; -} - -.lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-font-color0); - background-color: transparent; - font-weight: bold; -} - -.lm-CommandPalette-item.lm-mod-disabled mark { - color: var(--jp-ui-font-color2); -} - -.lm-CommandPalette-item .lm-CommandPalette-itemIcon { - margin: 0 4px 0 0; - position: relative; - width: 16px; - top: 2px; - flex: 0 0 auto; -} - -.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon { - opacity: 0.6; -} - -.lm-CommandPalette-item .lm-CommandPalette-itemShortcut { - flex: 0 0 auto; -} - -.lm-CommandPalette-itemCaption { - display: none; -} - -.lm-CommandPalette-content { - background-color: var(--jp-layout-color1); -} - -.lm-CommandPalette-content:empty:after { - content: 'No results'; - margin: auto; - margin-top: 20px; - width: 100px; - display: block; - font-size: var(--jp-ui-font-size2); - font-family: var(--jp-ui-font-family); - font-weight: lighter; -} - -.lm-CommandPalette-emptyMessage { - text-align: center; - margin-top: 24px; - line-height: 1.32; - padding: 0px 8px; - color: var(--jp-content-font-color3); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Dialog { - position: absolute; - z-index: 10000; - display: flex; - flex-direction: column; - align-items: center; - justify-content: center; - top: 0px; - left: 0px; - margin: 0; - padding: 0; - width: 100%; - height: 100%; - background: var(--jp-dialog-background); -} - -.jp-Dialog-content { - display: flex; - flex-direction: column; - margin-left: auto; - margin-right: auto; - background: var(--jp-layout-color1); - padding: 24px; - padding-bottom: 12px; - min-width: 300px; - min-height: 150px; - max-width: 1000px; - max-height: 500px; - box-sizing: border-box; - box-shadow: var(--jp-elevation-z20); - word-wrap: break-word; - border-radius: var(--jp-border-radius); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color1); - resize: both; -} - -.jp-Dialog-button { - overflow: visible; -} - -button.jp-Dialog-button:focus { - outline: 1px solid var(--jp-brand-color1); - outline-offset: 4px; - -moz-outline-radius: 0px; -} - -button.jp-Dialog-button:focus::-moz-focus-inner { - border: 0; -} - -button.jp-Dialog-close-button { - padding: 0; - height: 100%; - min-width: unset; - min-height: unset; -} - -.jp-Dialog-header { - display: flex; - justify-content: space-between; - flex: 0 0 auto; - padding-bottom: 12px; - font-size: var(--jp-ui-font-size3); - font-weight: 400; - color: var(--jp-ui-font-color0); -} - -.jp-Dialog-body { - display: flex; - flex-direction: column; - flex: 1 1 auto; - font-size: var(--jp-ui-font-size1); - background: var(--jp-layout-color1); - overflow: auto; -} - -.jp-Dialog-footer { - display: flex; - flex-direction: row; - justify-content: flex-end; - flex: 0 0 auto; - margin-left: -12px; - margin-right: -12px; - padding: 12px; -} - -.jp-Dialog-title { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.jp-Dialog-body > .jp-select-wrapper { - width: 100%; -} - -.jp-Dialog-body > button { - padding: 0px 16px; -} - -.jp-Dialog-body > label { - line-height: 1.4; - color: var(--jp-ui-font-color0); -} - -.jp-Dialog-button.jp-mod-styled:not(:last-child) { - margin-right: 12px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-HoverBox { - position: fixed; -} - -.jp-HoverBox.jp-mod-outofview { - display: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-IFrame { - width: 100%; - height: 100%; -} - -.jp-IFrame > iframe { - border: none; -} - -/* -When drag events occur, `p-mod-override-cursor` is added to the body. -Because iframes steal all cursor events, the following two rules are necessary -to suppress pointer events while resize drags are occurring. There may be a -better solution to this problem. -*/ -body.lm-mod-override-cursor .jp-IFrame { - position: relative; -} - -body.lm-mod-override-cursor .jp-IFrame:before { - content: ''; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; -} - -.jp-Input-Boolean-Dialog { - flex-direction: row-reverse; - align-items: end; - width: 100%; -} - -.jp-Input-Boolean-Dialog > label { - flex: 1 1 auto; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-MainAreaWidget > :focus { - outline: none; -} - -/** - * google-material-color v1.2.6 - * https://github.com/danlevan/google-material-color - */ -:root { - --md-red-50: #ffebee; - --md-red-100: #ffcdd2; - --md-red-200: #ef9a9a; - --md-red-300: #e57373; - --md-red-400: #ef5350; - --md-red-500: #f44336; - --md-red-600: #e53935; - --md-red-700: #d32f2f; - --md-red-800: #c62828; - --md-red-900: #b71c1c; - --md-red-A100: #ff8a80; - --md-red-A200: #ff5252; - --md-red-A400: #ff1744; - --md-red-A700: #d50000; - - --md-pink-50: #fce4ec; - --md-pink-100: #f8bbd0; - --md-pink-200: #f48fb1; - --md-pink-300: #f06292; - --md-pink-400: #ec407a; - --md-pink-500: #e91e63; - --md-pink-600: #d81b60; - --md-pink-700: #c2185b; - --md-pink-800: #ad1457; - --md-pink-900: #880e4f; - --md-pink-A100: #ff80ab; - --md-pink-A200: #ff4081; - --md-pink-A400: #f50057; - --md-pink-A700: #c51162; - - --md-purple-50: #f3e5f5; - --md-purple-100: #e1bee7; - --md-purple-200: #ce93d8; - --md-purple-300: #ba68c8; - --md-purple-400: #ab47bc; - --md-purple-500: #9c27b0; - --md-purple-600: #8e24aa; - --md-purple-700: #7b1fa2; - --md-purple-800: #6a1b9a; - --md-purple-900: #4a148c; - --md-purple-A100: #ea80fc; - --md-purple-A200: #e040fb; - --md-purple-A400: #d500f9; - --md-purple-A700: #aa00ff; - - --md-deep-purple-50: #ede7f6; - --md-deep-purple-100: #d1c4e9; - --md-deep-purple-200: #b39ddb; - --md-deep-purple-300: #9575cd; - --md-deep-purple-400: #7e57c2; - --md-deep-purple-500: #673ab7; - --md-deep-purple-600: #5e35b1; - --md-deep-purple-700: #512da8; - --md-deep-purple-800: #4527a0; - --md-deep-purple-900: #311b92; - --md-deep-purple-A100: #b388ff; - --md-deep-purple-A200: #7c4dff; - --md-deep-purple-A400: #651fff; - --md-deep-purple-A700: #6200ea; - - --md-indigo-50: #e8eaf6; - --md-indigo-100: #c5cae9; - --md-indigo-200: #9fa8da; - --md-indigo-300: #7986cb; - --md-indigo-400: #5c6bc0; - --md-indigo-500: #3f51b5; - --md-indigo-600: #3949ab; - --md-indigo-700: #303f9f; - --md-indigo-800: #283593; - --md-indigo-900: #1a237e; - --md-indigo-A100: #8c9eff; - --md-indigo-A200: #536dfe; - --md-indigo-A400: #3d5afe; - --md-indigo-A700: #304ffe; - - --md-blue-50: #e3f2fd; - --md-blue-100: #bbdefb; - --md-blue-200: #90caf9; - --md-blue-300: #64b5f6; - --md-blue-400: #42a5f5; - --md-blue-500: #2196f3; - --md-blue-600: #1e88e5; - --md-blue-700: #1976d2; - --md-blue-800: #1565c0; - --md-blue-900: #0d47a1; - --md-blue-A100: #82b1ff; - --md-blue-A200: #448aff; - --md-blue-A400: #2979ff; - --md-blue-A700: #2962ff; - - --md-light-blue-50: #e1f5fe; - --md-light-blue-100: #b3e5fc; - --md-light-blue-200: #81d4fa; - --md-light-blue-300: #4fc3f7; - --md-light-blue-400: #29b6f6; - --md-light-blue-500: #03a9f4; - --md-light-blue-600: #039be5; - --md-light-blue-700: #0288d1; - --md-light-blue-800: #0277bd; - --md-light-blue-900: #01579b; - --md-light-blue-A100: #80d8ff; - --md-light-blue-A200: #40c4ff; - --md-light-blue-A400: #00b0ff; - --md-light-blue-A700: #0091ea; - - --md-cyan-50: #e0f7fa; - --md-cyan-100: #b2ebf2; - --md-cyan-200: #80deea; - --md-cyan-300: #4dd0e1; - --md-cyan-400: #26c6da; - --md-cyan-500: #00bcd4; - --md-cyan-600: #00acc1; - --md-cyan-700: #0097a7; - --md-cyan-800: #00838f; - --md-cyan-900: #006064; - --md-cyan-A100: #84ffff; - --md-cyan-A200: #18ffff; - --md-cyan-A400: #00e5ff; - --md-cyan-A700: #00b8d4; - - --md-teal-50: #e0f2f1; - --md-teal-100: #b2dfdb; - --md-teal-200: #80cbc4; - --md-teal-300: #4db6ac; - --md-teal-400: #26a69a; - --md-teal-500: #009688; - --md-teal-600: #00897b; - --md-teal-700: #00796b; - --md-teal-800: #00695c; - --md-teal-900: #004d40; - --md-teal-A100: #a7ffeb; - --md-teal-A200: #64ffda; - --md-teal-A400: #1de9b6; - --md-teal-A700: #00bfa5; - - --md-green-50: #e8f5e9; - --md-green-100: #c8e6c9; - --md-green-200: #a5d6a7; - --md-green-300: #81c784; - --md-green-400: #66bb6a; - --md-green-500: #4caf50; - --md-green-600: #43a047; - --md-green-700: #388e3c; - --md-green-800: #2e7d32; - --md-green-900: #1b5e20; - --md-green-A100: #b9f6ca; - --md-green-A200: #69f0ae; - --md-green-A400: #00e676; - --md-green-A700: #00c853; - - --md-light-green-50: #f1f8e9; - --md-light-green-100: #dcedc8; - --md-light-green-200: #c5e1a5; - --md-light-green-300: #aed581; - --md-light-green-400: #9ccc65; - --md-light-green-500: #8bc34a; - --md-light-green-600: #7cb342; - --md-light-green-700: #689f38; - --md-light-green-800: #558b2f; - --md-light-green-900: #33691e; - --md-light-green-A100: #ccff90; - --md-light-green-A200: #b2ff59; - --md-light-green-A400: #76ff03; - --md-light-green-A700: #64dd17; - - --md-lime-50: #f9fbe7; - --md-lime-100: #f0f4c3; - --md-lime-200: #e6ee9c; - --md-lime-300: #dce775; - --md-lime-400: #d4e157; - --md-lime-500: #cddc39; - --md-lime-600: #c0ca33; - --md-lime-700: #afb42b; - --md-lime-800: #9e9d24; - --md-lime-900: #827717; - --md-lime-A100: #f4ff81; - --md-lime-A200: #eeff41; - --md-lime-A400: #c6ff00; - --md-lime-A700: #aeea00; - - --md-yellow-50: #fffde7; - --md-yellow-100: #fff9c4; - --md-yellow-200: #fff59d; - --md-yellow-300: #fff176; - --md-yellow-400: #ffee58; - --md-yellow-500: #ffeb3b; - --md-yellow-600: #fdd835; - --md-yellow-700: #fbc02d; - --md-yellow-800: #f9a825; - --md-yellow-900: #f57f17; - --md-yellow-A100: #ffff8d; - --md-yellow-A200: #ffff00; - --md-yellow-A400: #ffea00; - --md-yellow-A700: #ffd600; - - --md-amber-50: #fff8e1; - --md-amber-100: #ffecb3; - --md-amber-200: #ffe082; - --md-amber-300: #ffd54f; - --md-amber-400: #ffca28; - --md-amber-500: #ffc107; - --md-amber-600: #ffb300; - --md-amber-700: #ffa000; - --md-amber-800: #ff8f00; - --md-amber-900: #ff6f00; - --md-amber-A100: #ffe57f; - --md-amber-A200: #ffd740; - --md-amber-A400: #ffc400; - --md-amber-A700: #ffab00; - - --md-orange-50: #fff3e0; - --md-orange-100: #ffe0b2; - --md-orange-200: #ffcc80; - --md-orange-300: #ffb74d; - --md-orange-400: #ffa726; - --md-orange-500: #ff9800; - --md-orange-600: #fb8c00; - --md-orange-700: #f57c00; - --md-orange-800: #ef6c00; - --md-orange-900: #e65100; - --md-orange-A100: #ffd180; - --md-orange-A200: #ffab40; - --md-orange-A400: #ff9100; - --md-orange-A700: #ff6d00; - - --md-deep-orange-50: #fbe9e7; - --md-deep-orange-100: #ffccbc; - --md-deep-orange-200: #ffab91; - --md-deep-orange-300: #ff8a65; - --md-deep-orange-400: #ff7043; - --md-deep-orange-500: #ff5722; - --md-deep-orange-600: #f4511e; - --md-deep-orange-700: #e64a19; - --md-deep-orange-800: #d84315; - --md-deep-orange-900: #bf360c; - --md-deep-orange-A100: #ff9e80; - --md-deep-orange-A200: #ff6e40; - --md-deep-orange-A400: #ff3d00; - --md-deep-orange-A700: #dd2c00; - - --md-brown-50: #efebe9; - --md-brown-100: #d7ccc8; - --md-brown-200: #bcaaa4; - --md-brown-300: #a1887f; - --md-brown-400: #8d6e63; - --md-brown-500: #795548; - --md-brown-600: #6d4c41; - --md-brown-700: #5d4037; - --md-brown-800: #4e342e; - --md-brown-900: #3e2723; - - --md-grey-50: #fafafa; - --md-grey-100: #f5f5f5; - --md-grey-200: #eeeeee; - --md-grey-300: #e0e0e0; - --md-grey-400: #bdbdbd; - --md-grey-500: #9e9e9e; - --md-grey-600: #757575; - --md-grey-700: #616161; - --md-grey-800: #424242; - --md-grey-900: #212121; - - --md-blue-grey-50: #eceff1; - --md-blue-grey-100: #cfd8dc; - --md-blue-grey-200: #b0bec5; - --md-blue-grey-300: #90a4ae; - --md-blue-grey-400: #78909c; - --md-blue-grey-500: #607d8b; - --md-blue-grey-600: #546e7a; - --md-blue-grey-700: #455a64; - --md-blue-grey-800: #37474f; - --md-blue-grey-900: #263238; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Spinner { - position: absolute; - display: flex; - justify-content: center; - align-items: center; - z-index: 10; - left: 0; - top: 0; - width: 100%; - height: 100%; - background: var(--jp-layout-color0); - outline: none; -} - -.jp-SpinnerContent { - font-size: 10px; - margin: 50px auto; - text-indent: -9999em; - width: 3em; - height: 3em; - border-radius: 50%; - background: var(--jp-brand-color3); - background: linear-gradient( - to right, - #f37626 10%, - rgba(255, 255, 255, 0) 42% - ); - position: relative; - animation: load3 1s infinite linear, fadeIn 1s; -} - -.jp-SpinnerContent:before { - width: 50%; - height: 50%; - background: #f37626; - border-radius: 100% 0 0 0; - position: absolute; - top: 0; - left: 0; - content: ''; -} - -.jp-SpinnerContent:after { - background: var(--jp-layout-color0); - width: 75%; - height: 75%; - border-radius: 50%; - content: ''; - margin: auto; - position: absolute; - top: 0; - left: 0; - bottom: 0; - right: 0; -} - -@keyframes fadeIn { - 0% { - opacity: 0; - } - 100% { - opacity: 1; - } -} - -@keyframes load3 { - 0% { - transform: rotate(0deg); - } - 100% { - transform: rotate(360deg); - } -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -button.jp-mod-styled { - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - border: none; - box-sizing: border-box; - text-align: center; - line-height: 32px; - height: 32px; - padding: 0px 12px; - letter-spacing: 0.8px; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -input.jp-mod-styled { - background: var(--jp-input-background); - height: 28px; - box-sizing: border-box; - border: var(--jp-border-width) solid var(--jp-border-color1); - padding-left: 7px; - padding-right: 7px; - font-size: var(--jp-ui-font-size2); - color: var(--jp-ui-font-color0); - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -input[type='checkbox'].jp-mod-styled { - appearance: checkbox; - -webkit-appearance: checkbox; - -moz-appearance: checkbox; - height: auto; -} - -input.jp-mod-styled:focus { - border: var(--jp-border-width) solid var(--md-blue-500); - box-shadow: inset 0 0 4px var(--md-blue-300); -} - -.jp-FileDialog-Checkbox { - margin-top: 35px; - display: flex; - flex-direction: row; - align-items: end; - width: 100%; -} - -.jp-FileDialog-Checkbox > label { - flex: 1 1 auto; -} - -.jp-select-wrapper { - display: flex; - position: relative; - flex-direction: column; - padding: 1px; - background-color: var(--jp-layout-color1); - height: 28px; - box-sizing: border-box; - margin-bottom: 12px; -} - -.jp-select-wrapper.jp-mod-focused select.jp-mod-styled { - border: var(--jp-border-width) solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); - background-color: var(--jp-input-active-background); -} - -select.jp-mod-styled:hover { - background-color: var(--jp-layout-color1); - cursor: pointer; - color: var(--jp-ui-font-color0); - background-color: var(--jp-input-hover-background); - box-shadow: inset 0 0px 1px rgba(0, 0, 0, 0.5); -} - -select.jp-mod-styled { - flex: 1 1 auto; - height: 32px; - width: 100%; - font-size: var(--jp-ui-font-size2); - background: var(--jp-input-background); - color: var(--jp-ui-font-color0); - padding: 0 25px 0 8px; - border: var(--jp-border-width) solid var(--jp-input-border-color); - border-radius: 0px; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-toolbar-height: calc( - 28px + var(--jp-border-width) - ); /* leave 28px for content */ -} - -.jp-Toolbar { - color: var(--jp-ui-font-color1); - flex: 0 0 auto; - display: flex; - flex-direction: row; - border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); - box-shadow: var(--jp-toolbar-box-shadow); - background: var(--jp-toolbar-background); - min-height: var(--jp-toolbar-micro-height); - padding: 2px; - z-index: 1; - overflow-x: auto; -} - -/* Toolbar items */ - -.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer { - flex-grow: 1; - flex-shrink: 1; -} - -.jp-Toolbar-item.jp-Toolbar-kernelStatus { - display: inline-block; - width: 32px; - background-repeat: no-repeat; - background-position: center; - background-size: 16px; -} - -.jp-Toolbar > .jp-Toolbar-item { - flex: 0 0 auto; - display: flex; - padding-left: 1px; - padding-right: 1px; - font-size: var(--jp-ui-font-size1); - line-height: var(--jp-private-toolbar-height); - height: 100%; -} - -/* Toolbar buttons */ - -/* This is the div we use to wrap the react component into a Widget */ -div.jp-ToolbarButton { - color: transparent; - border: none; - box-sizing: border-box; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; - padding: 0px; - margin: 0px; -} - -button.jp-ToolbarButtonComponent { - background: var(--jp-layout-color1); - border: none; - box-sizing: border-box; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; - padding: 0px 6px; - margin: 0px; - height: 24px; - border-radius: var(--jp-border-radius); - display: flex; - align-items: center; - text-align: center; - font-size: 14px; - min-width: unset; - min-height: unset; -} - -button.jp-ToolbarButtonComponent:disabled { - opacity: 0.4; -} - -button.jp-ToolbarButtonComponent span { - padding: 0px; - flex: 0 0 auto; -} - -button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label { - font-size: var(--jp-ui-font-size1); - line-height: 100%; - padding-left: 2px; - color: var(--jp-ui-font-color1); -} - -#jp-main-dock-panel[data-mode='single-document'] - .jp-MainAreaWidget - > .jp-Toolbar.jp-Toolbar-micro { - padding: 0; - min-height: 0; -} - -#jp-main-dock-panel[data-mode='single-document'] - .jp-MainAreaWidget - > .jp-Toolbar { - border: none; - box-shadow: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ body.p-mod-override-cursor *, /* </DEPRECATED> */ -body.lm-mod-override-cursor * { - cursor: inherit !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-JSONEditor { - display: flex; - flex-direction: column; - width: 100%; -} - -.jp-JSONEditor-host { - flex: 1 1 auto; - border: var(--jp-border-width) solid var(--jp-input-border-color); - border-radius: 0px; - background: var(--jp-layout-color0); - min-height: 50px; - padding: 1px; -} - -.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host { - border-color: red; - outline-color: red; -} - -.jp-JSONEditor-header { - display: flex; - flex: 1 0 auto; - padding: 0 0 0 12px; -} - -.jp-JSONEditor-header label { - flex: 0 0 auto; -} - -.jp-JSONEditor-commitButton { - height: 16px; - width: 16px; - background-size: 18px; - background-repeat: no-repeat; - background-position: center; -} - -.jp-JSONEditor-host.jp-mod-focused { - background-color: var(--jp-input-active-background); - border: 1px solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); -} - -.jp-Editor.jp-mod-dropTarget { - border: var(--jp-border-width) solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); -} - -/* BASICS */ - -.CodeMirror { - /* Set height, width, borders, and global font properties here */ - font-family: monospace; - height: 300px; - color: black; - direction: ltr; -} - -/* PADDING */ - -.CodeMirror-lines { - padding: 4px 0; /* Vertical padding around content */ -} -.CodeMirror pre.CodeMirror-line, -.CodeMirror pre.CodeMirror-line-like { - padding: 0 4px; /* Horizontal padding of content */ -} - -.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { - background-color: white; /* The little square between H and V scrollbars */ -} - -/* GUTTER */ - -.CodeMirror-gutters { - border-right: 1px solid #ddd; - background-color: #f7f7f7; - white-space: nowrap; -} -.CodeMirror-linenumbers {} -.CodeMirror-linenumber { - padding: 0 3px 0 5px; - min-width: 20px; - text-align: right; - color: #999; - white-space: nowrap; -} - -.CodeMirror-guttermarker { color: black; } -.CodeMirror-guttermarker-subtle { color: #999; } - -/* CURSOR */ - -.CodeMirror-cursor { - border-left: 1px solid black; - border-right: none; - width: 0; -} -/* Shown when moving in bi-directional text */ -.CodeMirror div.CodeMirror-secondarycursor { - border-left: 1px solid silver; -} -.cm-fat-cursor .CodeMirror-cursor { - width: auto; - border: 0 !important; - background: #7e7; -} -.cm-fat-cursor div.CodeMirror-cursors { - z-index: 1; -} -.cm-fat-cursor-mark { - background-color: rgba(20, 255, 20, 0.5); - -webkit-animation: blink 1.06s steps(1) infinite; - -moz-animation: blink 1.06s steps(1) infinite; - animation: blink 1.06s steps(1) infinite; -} -.cm-animate-fat-cursor { - width: auto; - border: 0; - -webkit-animation: blink 1.06s steps(1) infinite; - -moz-animation: blink 1.06s steps(1) infinite; - animation: blink 1.06s steps(1) infinite; - background-color: #7e7; -} -@-moz-keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} -@-webkit-keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} -@keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} - -/* Can style cursor different in overwrite (non-insert) mode */ -.CodeMirror-overwrite .CodeMirror-cursor {} - -.cm-tab { display: inline-block; text-decoration: inherit; } - -.CodeMirror-rulers { - position: absolute; - left: 0; right: 0; top: -50px; bottom: 0; - overflow: hidden; -} -.CodeMirror-ruler { - border-left: 1px solid #ccc; - top: 0; bottom: 0; - position: absolute; -} - -/* DEFAULT THEME */ - -.cm-s-default .cm-header {color: blue;} -.cm-s-default .cm-quote {color: #090;} -.cm-negative {color: #d44;} -.cm-positive {color: #292;} -.cm-header, .cm-strong {font-weight: bold;} -.cm-em {font-style: italic;} -.cm-link {text-decoration: underline;} -.cm-strikethrough {text-decoration: line-through;} - -.cm-s-default .cm-keyword {color: #708;} -.cm-s-default .cm-atom {color: #219;} -.cm-s-default .cm-number {color: #164;} -.cm-s-default .cm-def {color: #00f;} -.cm-s-default .cm-variable, -.cm-s-default .cm-punctuation, -.cm-s-default .cm-property, -.cm-s-default .cm-operator {} -.cm-s-default .cm-variable-2 {color: #05a;} -.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;} -.cm-s-default .cm-comment {color: #a50;} -.cm-s-default .cm-string {color: #a11;} -.cm-s-default .cm-string-2 {color: #f50;} -.cm-s-default .cm-meta {color: #555;} -.cm-s-default .cm-qualifier {color: #555;} -.cm-s-default .cm-builtin {color: #30a;} -.cm-s-default .cm-bracket {color: #997;} -.cm-s-default .cm-tag {color: #170;} -.cm-s-default .cm-attribute {color: #00c;} -.cm-s-default .cm-hr {color: #999;} -.cm-s-default .cm-link {color: #00c;} - -.cm-s-default .cm-error {color: #f00;} -.cm-invalidchar {color: #f00;} - -.CodeMirror-composing { border-bottom: 2px solid; } - -/* Default styles for common addons */ - -div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;} -div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;} -.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); } -.CodeMirror-activeline-background {background: #e8f2ff;} - -/* STOP */ - -/* The rest of this file contains styles related to the mechanics of - the editor. You probably shouldn't touch them. */ - -.CodeMirror { - position: relative; - overflow: hidden; - background: white; -} - -.CodeMirror-scroll { - overflow: scroll !important; /* Things will break if this is overridden */ - /* 50px is the magic margin used to hide the element's real scrollbars */ - /* See overflow: hidden in .CodeMirror */ - margin-bottom: -50px; margin-right: -50px; - padding-bottom: 50px; - height: 100%; - outline: none; /* Prevent dragging from highlighting the element */ - position: relative; -} -.CodeMirror-sizer { - position: relative; - border-right: 50px solid transparent; -} - -/* The fake, visible scrollbars. Used to force redraw during scrolling - before actual scrolling happens, thus preventing shaking and - flickering artifacts. */ -.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { - position: absolute; - z-index: 6; - display: none; - outline: none; -} -.CodeMirror-vscrollbar { - right: 0; top: 0; - overflow-x: hidden; - overflow-y: scroll; -} -.CodeMirror-hscrollbar { - bottom: 0; left: 0; - overflow-y: hidden; - overflow-x: scroll; -} -.CodeMirror-scrollbar-filler { - right: 0; bottom: 0; -} -.CodeMirror-gutter-filler { - left: 0; bottom: 0; -} - -.CodeMirror-gutters { - position: absolute; left: 0; top: 0; - min-height: 100%; - z-index: 3; -} -.CodeMirror-gutter { - white-space: normal; - height: 100%; - display: inline-block; - vertical-align: top; - margin-bottom: -50px; -} -.CodeMirror-gutter-wrapper { - position: absolute; - z-index: 4; - background: none !important; - border: none !important; -} -.CodeMirror-gutter-background { - position: absolute; - top: 0; bottom: 0; - z-index: 4; -} -.CodeMirror-gutter-elt { - position: absolute; - cursor: default; - z-index: 4; -} -.CodeMirror-gutter-wrapper ::selection { background-color: transparent } -.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent } - -.CodeMirror-lines { - cursor: text; - min-height: 1px; /* prevents collapsing before first draw */ -} -.CodeMirror pre.CodeMirror-line, -.CodeMirror pre.CodeMirror-line-like { - /* Reset some styles that the rest of the page might have set */ - -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; - border-width: 0; - background: transparent; - font-family: inherit; - font-size: inherit; - margin: 0; - white-space: pre; - word-wrap: normal; - line-height: inherit; - color: inherit; - z-index: 2; - position: relative; - overflow: visible; - -webkit-tap-highlight-color: transparent; - -webkit-font-variant-ligatures: contextual; - font-variant-ligatures: contextual; -} -.CodeMirror-wrap pre.CodeMirror-line, -.CodeMirror-wrap pre.CodeMirror-line-like { - word-wrap: break-word; - white-space: pre-wrap; - word-break: normal; -} - -.CodeMirror-linebackground { - position: absolute; - left: 0; right: 0; top: 0; bottom: 0; - z-index: 0; -} - -.CodeMirror-linewidget { - position: relative; - z-index: 2; - padding: 0.1px; /* Force widget margins to stay inside of the container */ -} - -.CodeMirror-widget {} - -.CodeMirror-rtl pre { direction: rtl; } - -.CodeMirror-code { - outline: none; -} - -/* Force content-box sizing for the elements where we expect it */ -.CodeMirror-scroll, -.CodeMirror-sizer, -.CodeMirror-gutter, -.CodeMirror-gutters, -.CodeMirror-linenumber { - -moz-box-sizing: content-box; - box-sizing: content-box; -} - -.CodeMirror-measure { - position: absolute; - width: 100%; - height: 0; - overflow: hidden; - visibility: hidden; -} - -.CodeMirror-cursor { - position: absolute; - pointer-events: none; -} -.CodeMirror-measure pre { position: static; } - -div.CodeMirror-cursors { - visibility: hidden; - position: relative; - z-index: 3; -} -div.CodeMirror-dragcursors { - visibility: visible; -} - -.CodeMirror-focused div.CodeMirror-cursors { - visibility: visible; -} - -.CodeMirror-selected { background: #d9d9d9; } -.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; } -.CodeMirror-crosshair { cursor: crosshair; } -.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; } -.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; } - -.cm-searching { - background-color: #ffa; - background-color: rgba(255, 255, 0, .4); -} - -/* Used to force a border model for a node */ -.cm-force-border { padding-right: .1px; } - -@media print { - /* Hide the cursor when printing */ - .CodeMirror div.CodeMirror-cursors { - visibility: hidden; - } -} - -/* See issue #2901 */ -.cm-tab-wrap-hack:after { content: ''; } - -/* Help users use markselection to safely style text background */ -span.CodeMirror-selectedtext { background: none; } - -.CodeMirror-dialog { - position: absolute; - left: 0; right: 0; - background: inherit; - z-index: 15; - padding: .1em .8em; - overflow: hidden; - color: inherit; -} - -.CodeMirror-dialog-top { - border-bottom: 1px solid #eee; - top: 0; -} - -.CodeMirror-dialog-bottom { - border-top: 1px solid #eee; - bottom: 0; -} - -.CodeMirror-dialog input { - border: none; - outline: none; - background: transparent; - width: 20em; - color: inherit; - font-family: monospace; -} - -.CodeMirror-dialog button { - font-size: 70%; -} - -.CodeMirror-foldmarker { - color: blue; - text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px; - font-family: arial; - line-height: .3; - cursor: pointer; -} -.CodeMirror-foldgutter { - width: .7em; -} -.CodeMirror-foldgutter-open, -.CodeMirror-foldgutter-folded { - cursor: pointer; -} -.CodeMirror-foldgutter-open:after { - content: "\25BE"; -} -.CodeMirror-foldgutter-folded:after { - content: "\25B8"; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.CodeMirror { - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - font-family: var(--jp-code-font-family); - border: 0; - border-radius: 0; - height: auto; - /* Changed to auto to autogrow */ -} - -.CodeMirror pre { - padding: 0 var(--jp-code-padding); -} - -.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-dialog { - background-color: var(--jp-layout-color0); - color: var(--jp-content-font-color1); -} - -/* This causes https://github.com/jupyter/jupyterlab/issues/522 */ -/* May not cause it not because we changed it! */ -.CodeMirror-lines { - padding: var(--jp-code-padding) 0; -} - -.CodeMirror-linenumber { - padding: 0 8px; -} - -.jp-CodeMirrorEditor { - cursor: text; -} - -.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color); -} - -/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */ -@media screen and (min-width: 2138px) and (max-width: 4319px) { - .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width1) solid - var(--jp-editor-cursor-color); - } -} - -/* When zoomed out less than 33% */ -@media screen and (min-width: 4320px) { - .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width2) solid - var(--jp-editor-cursor-color); - } -} - -.CodeMirror.jp-mod-readOnly .CodeMirror-cursor { - display: none; -} - -.CodeMirror-gutters { - border-right: 1px solid var(--jp-border-color2); - background-color: var(--jp-layout-color0); -} - -.jp-CollaboratorCursor { - border-left: 5px solid transparent; - border-right: 5px solid transparent; - border-top: none; - border-bottom: 3px solid; - background-clip: content-box; - margin-left: -5px; - margin-right: -5px; -} - -.CodeMirror-selectedtext.cm-searching { - background-color: var(--jp-search-selected-match-background-color) !important; - color: var(--jp-search-selected-match-color) !important; -} - -.cm-searching { - background-color: var( - --jp-search-unselected-match-background-color - ) !important; - color: var(--jp-search-unselected-match-color) !important; -} - -.CodeMirror-focused .CodeMirror-selected { - background-color: var(--jp-editor-selected-focused-background); -} - -.CodeMirror-selected { - background-color: var(--jp-editor-selected-background); -} - -.jp-CollaboratorCursor-hover { - position: absolute; - z-index: 1; - transform: translateX(-50%); - color: white; - border-radius: 3px; - padding-left: 4px; - padding-right: 4px; - padding-top: 1px; - padding-bottom: 1px; - text-align: center; - font-size: var(--jp-ui-font-size1); - white-space: nowrap; -} - -.jp-CodeMirror-ruler { - border-left: 1px dashed var(--jp-border-color2); -} - -/** - * Here is our jupyter theme for CodeMirror syntax highlighting - * This is used in our marked.js syntax highlighting and CodeMirror itself - * The string "jupyter" is set in ../codemirror/widget.DEFAULT_CODEMIRROR_THEME - * This came from the classic notebook, which came form highlight.js/GitHub - */ - -/** - * CodeMirror themes are handling the background/color in this way. This works - * fine for CodeMirror editors outside the notebook, but the notebook styles - * these things differently. - */ -.CodeMirror.cm-s-jupyter { - background: var(--jp-layout-color0); - color: var(--jp-content-font-color1); -} - -/* In the notebook, we want this styling to be handled by its container */ -.jp-CodeConsole .CodeMirror.cm-s-jupyter, -.jp-Notebook .CodeMirror.cm-s-jupyter { - background: transparent; -} - -.cm-s-jupyter .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color); -} -.cm-s-jupyter span.cm-keyword { - color: var(--jp-mirror-editor-keyword-color); - font-weight: bold; -} -.cm-s-jupyter span.cm-atom { - color: var(--jp-mirror-editor-atom-color); -} -.cm-s-jupyter span.cm-number { - color: var(--jp-mirror-editor-number-color); -} -.cm-s-jupyter span.cm-def { - color: var(--jp-mirror-editor-def-color); -} -.cm-s-jupyter span.cm-variable { - color: var(--jp-mirror-editor-variable-color); -} -.cm-s-jupyter span.cm-variable-2 { - color: var(--jp-mirror-editor-variable-2-color); -} -.cm-s-jupyter span.cm-variable-3 { - color: var(--jp-mirror-editor-variable-3-color); -} -.cm-s-jupyter span.cm-punctuation { - color: var(--jp-mirror-editor-punctuation-color); -} -.cm-s-jupyter span.cm-property { - color: var(--jp-mirror-editor-property-color); -} -.cm-s-jupyter span.cm-operator { - color: var(--jp-mirror-editor-operator-color); - font-weight: bold; -} -.cm-s-jupyter span.cm-comment { - color: var(--jp-mirror-editor-comment-color); - font-style: italic; -} -.cm-s-jupyter span.cm-string { - color: var(--jp-mirror-editor-string-color); -} -.cm-s-jupyter span.cm-string-2 { - color: var(--jp-mirror-editor-string-2-color); -} -.cm-s-jupyter span.cm-meta { - color: var(--jp-mirror-editor-meta-color); -} -.cm-s-jupyter span.cm-qualifier { - color: var(--jp-mirror-editor-qualifier-color); -} -.cm-s-jupyter span.cm-builtin { - color: var(--jp-mirror-editor-builtin-color); -} -.cm-s-jupyter span.cm-bracket { - color: var(--jp-mirror-editor-bracket-color); -} -.cm-s-jupyter span.cm-tag { - color: var(--jp-mirror-editor-tag-color); -} -.cm-s-jupyter span.cm-attribute { - color: var(--jp-mirror-editor-attribute-color); -} -.cm-s-jupyter span.cm-header { - color: var(--jp-mirror-editor-header-color); -} -.cm-s-jupyter span.cm-quote { - color: var(--jp-mirror-editor-quote-color); -} -.cm-s-jupyter span.cm-link { - color: var(--jp-mirror-editor-link-color); -} -.cm-s-jupyter span.cm-error { - color: var(--jp-mirror-editor-error-color); -} -.cm-s-jupyter span.cm-hr { - color: #999; -} - -.cm-s-jupyter span.cm-tab { - background: url(); - background-position: right; - background-repeat: no-repeat; -} - -.cm-s-jupyter .CodeMirror-activeline-background, -.cm-s-jupyter .CodeMirror-gutter { - background-color: var(--jp-layout-color2); -} - -/* Styles for shared cursors (remote cursor locations and selected ranges) */ -.jp-CodeMirrorEditor .remote-caret { - position: relative; - border-left: 2px solid black; - margin-left: -1px; - margin-right: -1px; - box-sizing: border-box; -} - -.jp-CodeMirrorEditor .remote-caret > div { - white-space: nowrap; - position: absolute; - top: -1.15em; - padding-bottom: 0.05em; - left: -2px; - font-size: 0.95em; - background-color: rgb(250, 129, 0); - font-family: var(--jp-ui-font-family); - font-weight: bold; - line-height: normal; - user-select: none; - color: white; - padding-left: 2px; - padding-right: 2px; - z-index: 3; - transition: opacity 0.3s ease-in-out; -} - -.jp-CodeMirrorEditor .remote-caret.hide-name > div { - transition-delay: 0.7s; - opacity: 0; -} - -.jp-CodeMirrorEditor .remote-caret:hover > div { - opacity: 1; - transition-delay: 0s; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| RenderedText -|----------------------------------------------------------------------------*/ - -:root { - /* This is the padding value to fill the gaps between lines containing spans with background color. */ - --jp-private-code-span-padding: calc( - (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2 - ); -} - -.jp-RenderedText { - text-align: left; - padding-left: var(--jp-code-padding); - line-height: var(--jp-code-line-height); - font-family: var(--jp-code-font-family); -} - -.jp-RenderedText pre, -.jp-RenderedJavaScript pre, -.jp-RenderedHTMLCommon pre { - color: var(--jp-content-font-color1); - font-size: var(--jp-code-font-size); - border: none; - margin: 0px; - padding: 0px; -} - -.jp-RenderedText pre a:link { - text-decoration: none; - color: var(--jp-content-link-color); -} -.jp-RenderedText pre a:hover { - text-decoration: underline; - color: var(--jp-content-link-color); -} -.jp-RenderedText pre a:visited { - text-decoration: none; - color: var(--jp-content-link-color); -} - -/* console foregrounds and backgrounds */ -.jp-RenderedText pre .ansi-black-fg { - color: #3e424d; -} -.jp-RenderedText pre .ansi-red-fg { - color: #e75c58; -} -.jp-RenderedText pre .ansi-green-fg { - color: #00a250; -} -.jp-RenderedText pre .ansi-yellow-fg { - color: #ddb62b; -} -.jp-RenderedText pre .ansi-blue-fg { - color: #208ffb; -} -.jp-RenderedText pre .ansi-magenta-fg { - color: #d160c4; -} -.jp-RenderedText pre .ansi-cyan-fg { - color: #60c6c8; -} -.jp-RenderedText pre .ansi-white-fg { - color: #c5c1b4; -} - -.jp-RenderedText pre .ansi-black-bg { - background-color: #3e424d; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-red-bg { - background-color: #e75c58; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-green-bg { - background-color: #00a250; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-yellow-bg { - background-color: #ddb62b; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-blue-bg { - background-color: #208ffb; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-magenta-bg { - background-color: #d160c4; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-cyan-bg { - background-color: #60c6c8; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-white-bg { - background-color: #c5c1b4; - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-black-intense-fg { - color: #282c36; -} -.jp-RenderedText pre .ansi-red-intense-fg { - color: #b22b31; -} -.jp-RenderedText pre .ansi-green-intense-fg { - color: #007427; -} -.jp-RenderedText pre .ansi-yellow-intense-fg { - color: #b27d12; -} -.jp-RenderedText pre .ansi-blue-intense-fg { - color: #0065ca; -} -.jp-RenderedText pre .ansi-magenta-intense-fg { - color: #a03196; -} -.jp-RenderedText pre .ansi-cyan-intense-fg { - color: #258f8f; -} -.jp-RenderedText pre .ansi-white-intense-fg { - color: #a1a6b2; -} - -.jp-RenderedText pre .ansi-black-intense-bg { - background-color: #282c36; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-red-intense-bg { - background-color: #b22b31; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-green-intense-bg { - background-color: #007427; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-yellow-intense-bg { - background-color: #b27d12; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-blue-intense-bg { - background-color: #0065ca; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-magenta-intense-bg { - background-color: #a03196; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-cyan-intense-bg { - background-color: #258f8f; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-white-intense-bg { - background-color: #a1a6b2; - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-default-inverse-fg { - color: var(--jp-ui-inverse-font-color0); -} -.jp-RenderedText pre .ansi-default-inverse-bg { - background-color: var(--jp-inverse-layout-color0); - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-bold { - font-weight: bold; -} -.jp-RenderedText pre .ansi-underline { - text-decoration: underline; -} - -.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] { - background: var(--jp-rendermime-error-background); - padding-top: var(--jp-code-padding); -} - -/*----------------------------------------------------------------------------- -| RenderedLatex -|----------------------------------------------------------------------------*/ - -.jp-RenderedLatex { - color: var(--jp-content-font-color1); - font-size: var(--jp-content-font-size1); - line-height: var(--jp-content-line-height); -} - -/* Left-justify outputs.*/ -.jp-OutputArea-output.jp-RenderedLatex { - padding: var(--jp-code-padding); - text-align: left; -} - -/*----------------------------------------------------------------------------- -| RenderedHTML -|----------------------------------------------------------------------------*/ - -.jp-RenderedHTMLCommon { - color: var(--jp-content-font-color1); - font-family: var(--jp-content-font-family); - font-size: var(--jp-content-font-size1); - line-height: var(--jp-content-line-height); - /* Give a bit more R padding on Markdown text to keep line lengths reasonable */ - padding-right: 20px; -} - -.jp-RenderedHTMLCommon em { - font-style: italic; -} - -.jp-RenderedHTMLCommon strong { - font-weight: bold; -} - -.jp-RenderedHTMLCommon u { - text-decoration: underline; -} - -.jp-RenderedHTMLCommon a:link { - text-decoration: none; - color: var(--jp-content-link-color); -} - -.jp-RenderedHTMLCommon a:hover { - text-decoration: underline; - color: var(--jp-content-link-color); -} - -.jp-RenderedHTMLCommon a:visited { - text-decoration: none; - color: var(--jp-content-link-color); -} - -/* Headings */ - -.jp-RenderedHTMLCommon h1, -.jp-RenderedHTMLCommon h2, -.jp-RenderedHTMLCommon h3, -.jp-RenderedHTMLCommon h4, -.jp-RenderedHTMLCommon h5, -.jp-RenderedHTMLCommon h6 { - line-height: var(--jp-content-heading-line-height); - font-weight: var(--jp-content-heading-font-weight); - font-style: normal; - margin: var(--jp-content-heading-margin-top) 0 - var(--jp-content-heading-margin-bottom) 0; -} - -.jp-RenderedHTMLCommon h1:first-child, -.jp-RenderedHTMLCommon h2:first-child, -.jp-RenderedHTMLCommon h3:first-child, -.jp-RenderedHTMLCommon h4:first-child, -.jp-RenderedHTMLCommon h5:first-child, -.jp-RenderedHTMLCommon h6:first-child { - margin-top: calc(0.5 * var(--jp-content-heading-margin-top)); -} - -.jp-RenderedHTMLCommon h1:last-child, -.jp-RenderedHTMLCommon h2:last-child, -.jp-RenderedHTMLCommon h3:last-child, -.jp-RenderedHTMLCommon h4:last-child, -.jp-RenderedHTMLCommon h5:last-child, -.jp-RenderedHTMLCommon h6:last-child { - margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom)); -} - -.jp-RenderedHTMLCommon h1 { - font-size: var(--jp-content-font-size5); -} - -.jp-RenderedHTMLCommon h2 { - font-size: var(--jp-content-font-size4); -} - -.jp-RenderedHTMLCommon h3 { - font-size: var(--jp-content-font-size3); -} - -.jp-RenderedHTMLCommon h4 { - font-size: var(--jp-content-font-size2); -} - -.jp-RenderedHTMLCommon h5 { - font-size: var(--jp-content-font-size1); -} - -.jp-RenderedHTMLCommon h6 { - font-size: var(--jp-content-font-size0); -} - -/* Lists */ - -.jp-RenderedHTMLCommon ul:not(.list-inline), -.jp-RenderedHTMLCommon ol:not(.list-inline) { - padding-left: 2em; -} - -.jp-RenderedHTMLCommon ul { - list-style: disc; -} - -.jp-RenderedHTMLCommon ul ul { - list-style: square; -} - -.jp-RenderedHTMLCommon ul ul ul { - list-style: circle; -} - -.jp-RenderedHTMLCommon ol { - list-style: decimal; -} - -.jp-RenderedHTMLCommon ol ol { - list-style: upper-alpha; -} - -.jp-RenderedHTMLCommon ol ol ol { - list-style: lower-alpha; -} - -.jp-RenderedHTMLCommon ol ol ol ol { - list-style: lower-roman; -} - -.jp-RenderedHTMLCommon ol ol ol ol ol { - list-style: decimal; -} - -.jp-RenderedHTMLCommon ol, -.jp-RenderedHTMLCommon ul { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon ul ul, -.jp-RenderedHTMLCommon ul ol, -.jp-RenderedHTMLCommon ol ul, -.jp-RenderedHTMLCommon ol ol { - margin-bottom: 0em; -} - -.jp-RenderedHTMLCommon hr { - color: var(--jp-border-color2); - background-color: var(--jp-border-color1); - margin-top: 1em; - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon > pre { - margin: 1.5em 2em; -} - -.jp-RenderedHTMLCommon pre, -.jp-RenderedHTMLCommon code { - border: 0; - background-color: var(--jp-layout-color0); - color: var(--jp-content-font-color1); - font-family: var(--jp-code-font-family); - font-size: inherit; - line-height: var(--jp-code-line-height); - padding: 0; - white-space: pre-wrap; -} - -.jp-RenderedHTMLCommon :not(pre) > code { - background-color: var(--jp-layout-color2); - padding: 1px 5px; -} - -/* Tables */ - -.jp-RenderedHTMLCommon table { - border-collapse: collapse; - border-spacing: 0; - border: none; - color: var(--jp-ui-font-color1); - font-size: 12px; - table-layout: fixed; - margin-left: auto; - margin-right: auto; -} - -.jp-RenderedHTMLCommon thead { - border-bottom: var(--jp-border-width) solid var(--jp-border-color1); - vertical-align: bottom; -} - -.jp-RenderedHTMLCommon td, -.jp-RenderedHTMLCommon th, -.jp-RenderedHTMLCommon tr { - vertical-align: middle; - padding: 0.5em 0.5em; - line-height: normal; - white-space: normal; - max-width: none; - border: none; -} - -.jp-RenderedMarkdown.jp-RenderedHTMLCommon td, -.jp-RenderedMarkdown.jp-RenderedHTMLCommon th { - max-width: none; -} - -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td, -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th, -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr { - text-align: right; -} - -.jp-RenderedHTMLCommon th { - font-weight: bold; -} - -.jp-RenderedHTMLCommon tbody tr:nth-child(odd) { - background: var(--jp-layout-color0); -} - -.jp-RenderedHTMLCommon tbody tr:nth-child(even) { - background: var(--jp-rendermime-table-row-background); -} - -.jp-RenderedHTMLCommon tbody tr:hover { - background: var(--jp-rendermime-table-row-hover-background); -} - -.jp-RenderedHTMLCommon table { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon p { - text-align: left; - margin: 0px; -} - -.jp-RenderedHTMLCommon p { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon img { - -moz-force-broken-image-icon: 1; -} - -/* Restrict to direct children as other images could be nested in other content. */ -.jp-RenderedHTMLCommon > img { - display: block; - margin-left: 0; - margin-right: 0; - margin-bottom: 1em; -} - -/* Change color behind transparent images if they need it... */ -[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background { - background-color: var(--jp-inverse-layout-color1); -} -[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background { - background-color: var(--jp-inverse-layout-color1); -} -/* ...or leave it untouched if they don't */ -[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-dark-background { -} -[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-light-background { -} - -.jp-RenderedHTMLCommon img, -.jp-RenderedImage img, -.jp-RenderedHTMLCommon svg, -.jp-RenderedSVG svg { - max-width: 100%; - height: auto; -} - -.jp-RenderedHTMLCommon img.jp-mod-unconfined, -.jp-RenderedImage img.jp-mod-unconfined, -.jp-RenderedHTMLCommon svg.jp-mod-unconfined, -.jp-RenderedSVG svg.jp-mod-unconfined { - max-width: none; -} - -.jp-RenderedHTMLCommon .alert { - padding: var(--jp-notebook-padding); - border: var(--jp-border-width) solid transparent; - border-radius: var(--jp-border-radius); - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon .alert-info { - color: var(--jp-info-color0); - background-color: var(--jp-info-color3); - border-color: var(--jp-info-color2); -} -.jp-RenderedHTMLCommon .alert-info hr { - border-color: var(--jp-info-color3); -} -.jp-RenderedHTMLCommon .alert-info > p:last-child, -.jp-RenderedHTMLCommon .alert-info > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-warning { - color: var(--jp-warn-color0); - background-color: var(--jp-warn-color3); - border-color: var(--jp-warn-color2); -} -.jp-RenderedHTMLCommon .alert-warning hr { - border-color: var(--jp-warn-color3); -} -.jp-RenderedHTMLCommon .alert-warning > p:last-child, -.jp-RenderedHTMLCommon .alert-warning > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-success { - color: var(--jp-success-color0); - background-color: var(--jp-success-color3); - border-color: var(--jp-success-color2); -} -.jp-RenderedHTMLCommon .alert-success hr { - border-color: var(--jp-success-color3); -} -.jp-RenderedHTMLCommon .alert-success > p:last-child, -.jp-RenderedHTMLCommon .alert-success > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-danger { - color: var(--jp-error-color0); - background-color: var(--jp-error-color3); - border-color: var(--jp-error-color2); -} -.jp-RenderedHTMLCommon .alert-danger hr { - border-color: var(--jp-error-color3); -} -.jp-RenderedHTMLCommon .alert-danger > p:last-child, -.jp-RenderedHTMLCommon .alert-danger > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon blockquote { - margin: 1em 2em; - padding: 0 1em; - border-left: 5px solid var(--jp-border-color2); -} - -a.jp-InternalAnchorLink { - visibility: hidden; - margin-left: 8px; - color: var(--md-blue-800); -} - -h1:hover .jp-InternalAnchorLink, -h2:hover .jp-InternalAnchorLink, -h3:hover .jp-InternalAnchorLink, -h4:hover .jp-InternalAnchorLink, -h5:hover .jp-InternalAnchorLink, -h6:hover .jp-InternalAnchorLink { - visibility: visible; -} - -.jp-RenderedHTMLCommon kbd { - background-color: var(--jp-rendermime-table-row-background); - border: 1px solid var(--jp-border-color0); - border-bottom-color: var(--jp-border-color2); - border-radius: 3px; - box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25); - display: inline-block; - font-size: 0.8em; - line-height: 1em; - padding: 0.2em 0.5em; -} - -/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0. - * At the bottom of cells this is a bit too much as there is also spacing - * between cells. Going all the way to 0 gets too tight between markdown and - * code cells. - */ -.jp-RenderedHTMLCommon > *:last-child { - margin-bottom: 0.5em; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-MimeDocument { - outline: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-filebrowser-button-height: 28px; - --jp-private-filebrowser-button-width: 48px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-FileBrowser { - display: flex; - flex-direction: column; - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); -} - -.jp-FileBrowser-toolbar.jp-Toolbar { - border-bottom: none; - height: auto; - margin: var(--jp-toolbar-header-margin); - box-shadow: none; -} - -.jp-BreadCrumbs { - flex: 0 0 auto; - margin: 8px 12px 8px 12px; -} - -.jp-BreadCrumbs-item { - margin: 0px 2px; - padding: 0px 2px; - border-radius: var(--jp-border-radius); - cursor: pointer; -} - -.jp-BreadCrumbs-item:hover { - background-color: var(--jp-layout-color2); -} - -.jp-BreadCrumbs-item:first-child { - margin-left: 0px; -} - -.jp-BreadCrumbs-item.jp-mod-dropTarget { - background-color: var(--jp-brand-color2); - opacity: 0.7; -} - -/*----------------------------------------------------------------------------- -| Buttons -|----------------------------------------------------------------------------*/ - -.jp-FileBrowser-toolbar.jp-Toolbar { - padding: 0px; - margin: 8px 12px 0px 12px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar { - justify-content: flex-start; -} - -.jp-FileBrowser-toolbar.jp-Toolbar .jp-Toolbar-item { - flex: 0 0 auto; - padding-left: 0px; - padding-right: 2px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar .jp-ToolbarButtonComponent { - width: 40px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent { - width: 72px; - background: var(--jp-brand-color1); -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent:focus-visible { - background-color: var(--jp-brand-color0); -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent - .jp-icon3 { - fill: white; -} - -/*----------------------------------------------------------------------------- -| Other styles -|----------------------------------------------------------------------------*/ - -.jp-FileDialog.jp-mod-conflict input { - color: var(--jp-error-color1); -} - -.jp-FileDialog .jp-new-name-title { - margin-top: 12px; -} - -.jp-LastModified-hidden { - display: none; -} - -.jp-FileBrowser-filterBox { - padding: 0px; - flex: 0 0 auto; - margin: 8px 12px 0px 12px; -} - -/*----------------------------------------------------------------------------- -| DirListing -|----------------------------------------------------------------------------*/ - -.jp-DirListing { - flex: 1 1 auto; - display: flex; - flex-direction: column; - outline: 0; -} - -.jp-DirListing:focus-visible { - border: 1px solid var(--jp-brand-color1); -} - -.jp-DirListing-header { - flex: 0 0 auto; - display: flex; - flex-direction: row; - overflow: hidden; - border-top: var(--jp-border-width) solid var(--jp-border-color2); - border-bottom: var(--jp-border-width) solid var(--jp-border-color1); - box-shadow: var(--jp-toolbar-box-shadow); - z-index: 2; -} - -.jp-DirListing-headerItem { - padding: 4px 12px 2px 12px; - font-weight: 500; -} - -.jp-DirListing-headerItem:hover { - background: var(--jp-layout-color2); -} - -.jp-DirListing-headerItem.jp-id-name { - flex: 1 0 84px; -} - -.jp-DirListing-headerItem.jp-id-modified { - flex: 0 0 112px; - border-left: var(--jp-border-width) solid var(--jp-border-color2); - text-align: right; -} - -.jp-id-narrow { - display: none; - flex: 0 0 5px; - padding: 4px 4px; - border-left: var(--jp-border-width) solid var(--jp-border-color2); - text-align: right; - color: var(--jp-border-color2); -} - -.jp-DirListing-narrow .jp-id-narrow { - display: block; -} - -.jp-DirListing-narrow .jp-id-modified, -.jp-DirListing-narrow .jp-DirListing-itemModified { - display: none; -} - -.jp-DirListing-headerItem.jp-mod-selected { - font-weight: 600; -} - -/* increase specificity to override bundled default */ -.jp-DirListing-content { - flex: 1 1 auto; - margin: 0; - padding: 0; - list-style-type: none; - overflow: auto; - background-color: var(--jp-layout-color1); -} - -.jp-DirListing-content mark { - color: var(--jp-ui-font-color0); - background-color: transparent; - font-weight: bold; -} - -.jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark { - color: var(--jp-ui-inverse-font-color0); -} - -/* Style the directory listing content when a user drops a file to upload */ -.jp-DirListing.jp-mod-native-drop .jp-DirListing-content { - outline: 5px dashed rgba(128, 128, 128, 0.5); - outline-offset: -10px; - cursor: copy; -} - -.jp-DirListing-item { - display: flex; - flex-direction: row; - padding: 4px 12px; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -.jp-DirListing-item[data-is-dot] { - opacity: 75%; -} - -.jp-DirListing-item.jp-mod-selected { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.jp-DirListing-item.jp-mod-dropTarget { - background: var(--jp-brand-color3); -} - -.jp-DirListing-item:hover:not(.jp-mod-selected) { - background: var(--jp-layout-color2); -} - -.jp-DirListing-itemIcon { - flex: 0 0 20px; - margin-right: 4px; -} - -.jp-DirListing-itemText { - flex: 1 0 64px; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - user-select: none; -} - -.jp-DirListing-itemModified { - flex: 0 0 125px; - text-align: right; -} - -.jp-DirListing-editor { - flex: 1 0 64px; - outline: none; - border: none; -} - -.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon:before { - color: var(--jp-success-color1); - content: '\25CF'; - font-size: 8px; - position: absolute; - left: -8px; -} - -.jp-DirListing-item.jp-mod-running.jp-mod-selected - .jp-DirListing-itemIcon:before { - color: var(--jp-ui-inverse-font-color1); -} - -.jp-DirListing-item.lm-mod-drag-image, -.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image { - font-size: var(--jp-ui-font-size1); - padding-left: 4px; - margin-left: 4px; - width: 160px; - background-color: var(--jp-ui-inverse-font-color2); - box-shadow: var(--jp-elevation-z2); - border-radius: 0px; - color: var(--jp-ui-font-color1); - transform: translateX(-40%) translateY(-58%); -} - -.jp-DirListing-deadSpace { - flex: 1 1 auto; - margin: 0; - padding: 0; - list-style-type: none; - overflow: auto; - background-color: var(--jp-layout-color1); -} - -.jp-Document { - min-width: 120px; - min-height: 120px; - outline: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { -} - -/*----------------------------------------------------------------------------- -| Main OutputArea -| OutputArea has a list of Outputs -|----------------------------------------------------------------------------*/ - -.jp-OutputArea { - overflow-y: auto; -} - -.jp-OutputArea-child { - display: flex; - flex-direction: row; -} - -body[data-format='mobile'] .jp-OutputArea-child { - flex-direction: column; -} - -.jp-OutputPrompt { - flex: 0 0 var(--jp-cell-prompt-width); - color: var(--jp-cell-outprompt-font-color); - font-family: var(--jp-cell-prompt-font-family); - padding: var(--jp-code-padding); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; - opacity: var(--jp-cell-prompt-opacity); - /* Right align prompt text, don't wrap to handle large prompt numbers */ - text-align: right; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - /* Disable text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -body[data-format='mobile'] .jp-OutputPrompt { - flex: 0 0 auto; - text-align: left; -} - -.jp-OutputArea-output { - height: auto; - overflow: auto; - user-select: text; - -moz-user-select: text; - -webkit-user-select: text; - -ms-user-select: text; -} - -.jp-OutputArea-child .jp-OutputArea-output { - flex-grow: 1; - flex-shrink: 1; -} - -body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output { - margin-left: var(--jp-notebook-padding); -} - -/** - * Isolated output. - */ -.jp-OutputArea-output.jp-mod-isolated { - width: 100%; - display: block; -} - -/* -When drag events occur, `p-mod-override-cursor` is added to the body. -Because iframes steal all cursor events, the following two rules are necessary -to suppress pointer events while resize drags are occurring. There may be a -better solution to this problem. -*/ -body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated { - position: relative; -} - -body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated:before { - content: ''; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; -} - -/* pre */ - -.jp-OutputArea-output pre { - border: none; - margin: 0px; - padding: 0px; - overflow-x: auto; - overflow-y: auto; - word-break: break-all; - word-wrap: break-word; - white-space: pre-wrap; -} - -/* tables */ - -.jp-OutputArea-output.jp-RenderedHTMLCommon table { - margin-left: 0; - margin-right: 0; -} - -/* description lists */ - -.jp-OutputArea-output dl, -.jp-OutputArea-output dt, -.jp-OutputArea-output dd { - display: block; -} - -.jp-OutputArea-output dl { - width: 100%; - overflow: hidden; - padding: 0; - margin: 0; -} - -.jp-OutputArea-output dt { - font-weight: bold; - float: left; - width: 20%; - padding: 0; - margin: 0; -} - -.jp-OutputArea-output dd { - float: left; - width: 80%; - padding: 0; - margin: 0; -} - -/* Hide the gutter in case of - * - nested output areas (e.g. in the case of output widgets) - * - mirrored output areas - */ -.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt { - display: none; -} - -/*----------------------------------------------------------------------------- -| executeResult is added to any Output-result for the display of the object -| returned by a cell -|----------------------------------------------------------------------------*/ - -.jp-OutputArea-output.jp-OutputArea-executeResult { - margin-left: 0px; - flex: 1 1 auto; -} - -/* Text output with the Out[] prompt needs a top padding to match the - * alignment of the Out[] prompt itself. - */ -.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output { - padding-top: var(--jp-code-padding); - border-top: var(--jp-border-width) solid transparent; -} - -/*----------------------------------------------------------------------------- -| The Stdin output -|----------------------------------------------------------------------------*/ - -.jp-OutputArea-stdin { - line-height: var(--jp-code-line-height); - padding-top: var(--jp-code-padding); - display: flex; -} - -.jp-Stdin-prompt { - color: var(--jp-content-font-color0); - padding-right: var(--jp-code-padding); - vertical-align: baseline; - flex: 0 0 auto; -} - -.jp-Stdin-input { - font-family: var(--jp-code-font-family); - font-size: inherit; - color: inherit; - background-color: inherit; - width: 42%; - min-width: 200px; - /* make sure input baseline aligns with prompt */ - vertical-align: baseline; - /* padding + margin = 0.5em between prompt and cursor */ - padding: 0em 0.25em; - margin: 0em 0.25em; - flex: 0 0 70%; -} - -.jp-Stdin-input:focus { - box-shadow: none; -} - -/*----------------------------------------------------------------------------- -| Output Area View -|----------------------------------------------------------------------------*/ - -.jp-LinkedOutputView .jp-OutputArea { - height: 100%; - display: block; -} - -.jp-LinkedOutputView .jp-OutputArea-output:only-child { - height: 100%; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Collapser { - flex: 0 0 var(--jp-cell-collapser-width); - padding: 0px; - margin: 0px; - border: none; - outline: none; - background: transparent; - border-radius: var(--jp-border-radius); - opacity: 1; -} - -.jp-Collapser-child { - display: block; - width: 100%; - box-sizing: border-box; - /* height: 100% doesn't work because the height of its parent is computed from content */ - position: absolute; - top: 0px; - bottom: 0px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Header/Footer -|----------------------------------------------------------------------------*/ - -/* Hidden by zero height by default */ -.jp-CellHeader, -.jp-CellFooter { - height: 0px; - width: 100%; - padding: 0px; - margin: 0px; - border: none; - outline: none; - background: transparent; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Input -|----------------------------------------------------------------------------*/ - -/* All input areas */ -.jp-InputArea { - display: flex; - flex-direction: row; - overflow: hidden; -} - -body[data-format='mobile'] .jp-InputArea { - flex-direction: column; -} - -.jp-InputArea-editor { - flex: 1 1 auto; - overflow: hidden; -} - -.jp-InputArea-editor { - /* This is the non-active, default styling */ - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - border-radius: 0px; - background: var(--jp-cell-editor-background); -} - -body[data-format='mobile'] .jp-InputArea-editor { - margin-left: var(--jp-notebook-padding); -} - -.jp-InputPrompt { - flex: 0 0 var(--jp-cell-prompt-width); - color: var(--jp-cell-inprompt-font-color); - font-family: var(--jp-cell-prompt-font-family); - padding: var(--jp-code-padding); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - opacity: var(--jp-cell-prompt-opacity); - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; - opacity: var(--jp-cell-prompt-opacity); - /* Right align prompt text, don't wrap to handle large prompt numbers */ - text-align: right; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - /* Disable text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -body[data-format='mobile'] .jp-InputPrompt { - flex: 0 0 auto; - text-align: left; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Placeholder -|----------------------------------------------------------------------------*/ - -.jp-Placeholder { - display: flex; - flex-direction: row; - flex: 1 1 auto; -} - -.jp-Placeholder-prompt { - box-sizing: border-box; -} - -.jp-Placeholder-content { - flex: 1 1 auto; - border: none; - background: transparent; - height: 20px; - box-sizing: border-box; -} - -.jp-Placeholder-content .jp-MoreHorizIcon { - width: 32px; - height: 16px; - border: 1px solid transparent; - border-radius: var(--jp-border-radius); -} - -.jp-Placeholder-content .jp-MoreHorizIcon:hover { - border: 1px solid var(--jp-border-color1); - box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.25); - background-color: var(--jp-layout-color0); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-cell-scrolling-output-offset: 5px; -} - -/*----------------------------------------------------------------------------- -| Cell -|----------------------------------------------------------------------------*/ - -.jp-Cell { - padding: var(--jp-cell-padding); - margin: 0px; - border: none; - outline: none; - background: transparent; -} - -/*----------------------------------------------------------------------------- -| Common input/output -|----------------------------------------------------------------------------*/ - -.jp-Cell-inputWrapper, -.jp-Cell-outputWrapper { - display: flex; - flex-direction: row; - padding: 0px; - margin: 0px; - /* Added to reveal the box-shadow on the input and output collapsers. */ - overflow: visible; -} - -/* Only input/output areas inside cells */ -.jp-Cell-inputArea, -.jp-Cell-outputArea { - flex: 1 1 auto; -} - -/*----------------------------------------------------------------------------- -| Collapser -|----------------------------------------------------------------------------*/ - -/* Make the output collapser disappear when there is not output, but do so - * in a manner that leaves it in the layout and preserves its width. - */ -.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser { - border: none !important; - background: transparent !important; -} - -.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser { - min-height: var(--jp-cell-collapser-min-height); -} - -/*----------------------------------------------------------------------------- -| Output -|----------------------------------------------------------------------------*/ - -/* Put a space between input and output when there IS output */ -.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper { - margin-top: 5px; -} - -.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea { - overflow-y: auto; - max-height: 200px; - box-shadow: inset 0 0 6px 2px rgba(0, 0, 0, 0.3); - margin-left: var(--jp-private-cell-scrolling-output-offset); -} - -.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { - flex: 0 0 - calc( - var(--jp-cell-prompt-width) - - var(--jp-private-cell-scrolling-output-offset) - ); -} - -/*----------------------------------------------------------------------------- -| CodeCell -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| MarkdownCell -|----------------------------------------------------------------------------*/ - -.jp-MarkdownOutput { - flex: 1 1 auto; - margin-top: 0; - margin-bottom: 0; - padding-left: var(--jp-code-padding); -} - -.jp-MarkdownOutput.jp-RenderedHTMLCommon { - overflow: auto; -} - -.jp-showHiddenCellsButton { - margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding)); - margin-top: var(--jp-code-padding); - border: 1px solid var(--jp-border-color2); - background-color: var(--jp-border-color3) !important; - color: var(--jp-content-font-color0) !important; -} - -.jp-showHiddenCellsButton:hover { - background-color: var(--jp-border-color2) !important; -} - -.jp-collapseHeadingButton { - display: none; -} - -.jp-MarkdownCell:hover .jp-collapseHeadingButton { - display: flex; - min-height: var(--jp-cell-collapser-min-height); - position: absolute; - right: 0; - top: 0; - bottom: 0; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- - -/*----------------------------------------------------------------------------- -| Styles -|----------------------------------------------------------------------------*/ - -.jp-NotebookPanel-toolbar { - padding: 2px; -} - -.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused { - border: none; - box-shadow: none; -} - -.jp-Notebook-toolbarCellTypeDropdown select { - height: 24px; - font-size: var(--jp-ui-font-size1); - line-height: 14px; - border-radius: 0; - display: block; -} - -.jp-Notebook-toolbarCellTypeDropdown span { - top: 5px !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-notebook-dragImage-width: 304px; - --jp-private-notebook-dragImage-height: 36px; - --jp-private-notebook-selected-color: var(--md-blue-400); - --jp-private-notebook-active-color: var(--md-green-400); -} - -/*----------------------------------------------------------------------------- -| Imports -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Notebook -|----------------------------------------------------------------------------*/ - -.jp-NotebookPanel { - display: block; - height: 100%; -} - -.jp-NotebookPanel.jp-Document { - min-width: 240px; - min-height: 120px; -} - -.jp-Notebook { - padding: var(--jp-notebook-padding); - outline: none; - overflow: auto; - background: var(--jp-layout-color0); -} - -.jp-Notebook.jp-mod-scrollPastEnd::after { - display: block; - content: ''; - min-height: var(--jp-notebook-scroll-padding); -} - -.jp-MainAreaWidget-ContainStrict .jp-Notebook * { - contain: strict; -} - -.jp-Notebook-render * { - contain: none !important; -} - -.jp-Notebook .jp-Cell { - overflow: visible; -} - -.jp-Notebook .jp-Cell .jp-InputPrompt { - cursor: move; - float: left; -} - -/*----------------------------------------------------------------------------- -| Notebook state related styling -| -| The notebook and cells each have states, here are the possibilities: -| -| - Notebook -| - Command -| - Edit -| - Cell -| - None -| - Active (only one can be active) -| - Selected (the cells actions are applied to) -| - Multiselected (when multiple selected, the cursor) -| - No outputs -|----------------------------------------------------------------------------*/ - -/* Command or edit modes */ - -.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt { - opacity: var(--jp-cell-prompt-not-active-opacity); - color: var(--jp-cell-prompt-not-active-font-color); -} - -.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt { - opacity: var(--jp-cell-prompt-not-active-opacity); - color: var(--jp-cell-prompt-not-active-font-color); -} - -/* cell is active */ -.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser { - background: var(--jp-brand-color1); -} - -/* cell is dirty */ -.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt { - color: var(--jp-warn-color1); -} -.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt:before { - color: var(--jp-warn-color1); - content: '•'; -} - -.jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser { - background: var(--jp-warn-color1); -} - -/* collapser is hovered */ -.jp-Notebook .jp-Cell .jp-Collapser:hover { - box-shadow: var(--jp-elevation-z2); - background: var(--jp-brand-color1); - opacity: var(--jp-cell-collapser-not-active-hover-opacity); -} - -/* cell is active and collapser is hovered */ -.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover { - background: var(--jp-brand-color0); - opacity: 1; -} - -/* Command mode */ - -.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected { - background: var(--jp-notebook-multiselected-color); -} - -.jp-Notebook.jp-mod-commandMode - .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) { - background: transparent; -} - -/* Edit mode */ - -.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor { - border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color); - box-shadow: var(--jp-input-box-shadow); - background-color: var(--jp-cell-editor-active-background); -} - -/*----------------------------------------------------------------------------- -| Notebook drag and drop -|----------------------------------------------------------------------------*/ - -.jp-Notebook-cell.jp-mod-dropSource { - opacity: 0.5; -} - -.jp-Notebook-cell.jp-mod-dropTarget, -.jp-Notebook.jp-mod-commandMode - .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget { - border-top-color: var(--jp-private-notebook-selected-color); - border-top-style: solid; - border-top-width: 2px; -} - -.jp-dragImage { - display: block; - flex-direction: row; - width: var(--jp-private-notebook-dragImage-width); - height: var(--jp-private-notebook-dragImage-height); - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - background: var(--jp-cell-editor-background); - overflow: visible; -} - -.jp-dragImage-singlePrompt { - box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); -} - -.jp-dragImage .jp-dragImage-content { - flex: 1 1 auto; - z-index: 2; - font-size: var(--jp-code-font-size); - font-family: var(--jp-code-font-family); - line-height: var(--jp-code-line-height); - padding: var(--jp-code-padding); - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - background: var(--jp-cell-editor-background-color); - color: var(--jp-content-font-color3); - text-align: left; - margin: 4px 4px 4px 0px; -} - -.jp-dragImage .jp-dragImage-prompt { - flex: 0 0 auto; - min-width: 36px; - color: var(--jp-cell-inprompt-font-color); - padding: var(--jp-code-padding); - padding-left: 12px; - font-family: var(--jp-cell-prompt-font-family); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - line-height: 1.9; - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; -} - -.jp-dragImage-multipleBack { - z-index: -1; - position: absolute; - height: 32px; - width: 300px; - top: 8px; - left: 8px; - background: var(--jp-layout-color2); - border: var(--jp-border-width) solid var(--jp-input-border-color); - box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); -} - -/*----------------------------------------------------------------------------- -| Cell toolbar -|----------------------------------------------------------------------------*/ - -.jp-NotebookTools { - display: block; - min-width: var(--jp-sidebar-min-width); - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); - overflow: auto; -} - -.jp-NotebookTools-tool { - padding: 0px 12px 0 12px; -} - -.jp-ActiveCellTool { - padding: 12px; - background-color: var(--jp-layout-color1); - border-top: none !important; -} - -.jp-ActiveCellTool .jp-InputArea-prompt { - flex: 0 0 auto; - padding-left: 0px; -} - -.jp-ActiveCellTool .jp-InputArea-editor { - flex: 1 1 auto; - background: var(--jp-cell-editor-background); - border-color: var(--jp-cell-editor-border-color); -} - -.jp-ActiveCellTool .jp-InputArea-editor .CodeMirror { - background: transparent; -} - -.jp-MetadataEditorTool { - flex-direction: column; - padding: 12px 0px 12px 0px; -} - -.jp-RankedPanel > :not(:first-child) { - margin-top: 12px; -} - -.jp-KeySelector select.jp-mod-styled { - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - border: var(--jp-border-width) solid var(--jp-border-color1); -} - -.jp-KeySelector label, -.jp-MetadataEditorTool label { - line-height: 1.4; -} - -.jp-NotebookTools .jp-select-wrapper { - margin-top: 4px; - margin-bottom: 0px; -} - -.jp-NotebookTools .jp-Collapse { - margin-top: 16px; -} - -/*----------------------------------------------------------------------------- -| Presentation Mode (.jp-mod-presentationMode) -|----------------------------------------------------------------------------*/ - -.jp-mod-presentationMode .jp-Notebook { - --jp-content-font-size1: var(--jp-content-presentation-font-size1); - --jp-code-font-size: var(--jp-code-presentation-font-size); -} - -.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt, -.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt { - flex: 0 0 110px; -} - -/*----------------------------------------------------------------------------- -| Placeholder -|----------------------------------------------------------------------------*/ - -.jp-Cell-Placeholder { - padding-left: 55px; -} - -.jp-Cell-Placeholder-wrapper { - background: #fff; - border: 1px solid; - border-color: #e5e6e9 #dfe0e4 #d0d1d5; - border-radius: 4px; - -webkit-border-radius: 4px; - margin: 10px 15px; -} - -.jp-Cell-Placeholder-wrapper-inner { - padding: 15px; - position: relative; -} - -.jp-Cell-Placeholder-wrapper-body { - background-repeat: repeat; - background-size: 50% auto; -} - -.jp-Cell-Placeholder-wrapper-body div { - background: #f6f7f8; - background-image: -webkit-linear-gradient( - left, - #f6f7f8 0%, - #edeef1 20%, - #f6f7f8 40%, - #f6f7f8 100% - ); - background-repeat: no-repeat; - background-size: 800px 104px; - height: 104px; - position: relative; -} - -.jp-Cell-Placeholder-wrapper-body div { - position: absolute; - right: 15px; - left: 15px; - top: 15px; -} - -div.jp-Cell-Placeholder-h1 { - top: 20px; - height: 20px; - left: 15px; - width: 150px; -} - -div.jp-Cell-Placeholder-h2 { - left: 15px; - top: 50px; - height: 10px; - width: 100px; -} - -div.jp-Cell-Placeholder-content-1, -div.jp-Cell-Placeholder-content-2, -div.jp-Cell-Placeholder-content-3 { - left: 15px; - right: 15px; - height: 10px; -} - -div.jp-Cell-Placeholder-content-1 { - top: 100px; -} - -div.jp-Cell-Placeholder-content-2 { - top: 120px; -} - -div.jp-Cell-Placeholder-content-3 { - top: 140px; -} - -</style> - - <style type="text/css"> -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* -The following CSS variables define the main, public API for styling JupyterLab. -These variables should be used by all plugins wherever possible. In other -words, plugins should not define custom colors, sizes, etc unless absolutely -necessary. This enables users to change the visual theme of JupyterLab -by changing these variables. - -Many variables appear in an ordered sequence (0,1,2,3). These sequences -are designed to work well together, so for example, `--jp-border-color1` should -be used with `--jp-layout-color1`. The numbers have the following meanings: - -* 0: super-primary, reserved for special emphasis -* 1: primary, most important under normal situations -* 2: secondary, next most important under normal situations -* 3: tertiary, next most important under normal situations - -Throughout JupyterLab, we are mostly following principles from Google's -Material Design when selecting colors. We are not, however, following -all of MD as it is not optimized for dense, information rich UIs. -*/ - -:root { - /* Elevation - * - * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here: - * - * https://github.com/material-components/material-components-web - * https://material-components-web.appspot.com/elevation.html - */ - - --jp-shadow-base-lightness: 0; - --jp-shadow-umbra-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.2 - ); - --jp-shadow-penumbra-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.14 - ); - --jp-shadow-ambient-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.12 - ); - --jp-elevation-z0: none; - --jp-elevation-z1: 0px 2px 1px -1px var(--jp-shadow-umbra-color), - 0px 1px 1px 0px var(--jp-shadow-penumbra-color), - 0px 1px 3px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z2: 0px 3px 1px -2px var(--jp-shadow-umbra-color), - 0px 2px 2px 0px var(--jp-shadow-penumbra-color), - 0px 1px 5px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z4: 0px 2px 4px -1px var(--jp-shadow-umbra-color), - 0px 4px 5px 0px var(--jp-shadow-penumbra-color), - 0px 1px 10px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z6: 0px 3px 5px -1px var(--jp-shadow-umbra-color), - 0px 6px 10px 0px var(--jp-shadow-penumbra-color), - 0px 1px 18px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z8: 0px 5px 5px -3px var(--jp-shadow-umbra-color), - 0px 8px 10px 1px var(--jp-shadow-penumbra-color), - 0px 3px 14px 2px var(--jp-shadow-ambient-color); - --jp-elevation-z12: 0px 7px 8px -4px var(--jp-shadow-umbra-color), - 0px 12px 17px 2px var(--jp-shadow-penumbra-color), - 0px 5px 22px 4px var(--jp-shadow-ambient-color); - --jp-elevation-z16: 0px 8px 10px -5px var(--jp-shadow-umbra-color), - 0px 16px 24px 2px var(--jp-shadow-penumbra-color), - 0px 6px 30px 5px var(--jp-shadow-ambient-color); - --jp-elevation-z20: 0px 10px 13px -6px var(--jp-shadow-umbra-color), - 0px 20px 31px 3px var(--jp-shadow-penumbra-color), - 0px 8px 38px 7px var(--jp-shadow-ambient-color); - --jp-elevation-z24: 0px 11px 15px -7px var(--jp-shadow-umbra-color), - 0px 24px 38px 3px var(--jp-shadow-penumbra-color), - 0px 9px 46px 8px var(--jp-shadow-ambient-color); - - /* Borders - * - * The following variables, specify the visual styling of borders in JupyterLab. - */ - - --jp-border-width: 1px; - --jp-border-color0: var(--md-grey-400); - --jp-border-color1: var(--md-grey-400); - --jp-border-color2: var(--md-grey-300); - --jp-border-color3: var(--md-grey-200); - --jp-border-radius: 2px; - - /* UI Fonts - * - * The UI font CSS variables are used for the typography all of the JupyterLab - * user interface elements that are not directly user generated content. - * - * The font sizing here is done assuming that the body font size of --jp-ui-font-size1 - * is applied to a parent element. When children elements, such as headings, are sized - * in em all things will be computed relative to that body size. - */ - - --jp-ui-font-scale-factor: 1.2; - --jp-ui-font-size0: 0.83333em; - --jp-ui-font-size1: 13px; /* Base font size */ - --jp-ui-font-size2: 1.2em; - --jp-ui-font-size3: 1.44em; - - --jp-ui-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, - Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; - - /* - * Use these font colors against the corresponding main layout colors. - * In a light theme, these go from dark to light. - */ - - /* Defaults use Material Design specification */ - --jp-ui-font-color0: rgba(0, 0, 0, 1); - --jp-ui-font-color1: rgba(0, 0, 0, 0.87); - --jp-ui-font-color2: rgba(0, 0, 0, 0.54); - --jp-ui-font-color3: rgba(0, 0, 0, 0.38); - - /* - * Use these against the brand/accent/warn/error colors. - * These will typically go from light to darker, in both a dark and light theme. - */ - - --jp-ui-inverse-font-color0: rgba(255, 255, 255, 1); - --jp-ui-inverse-font-color1: rgba(255, 255, 255, 1); - --jp-ui-inverse-font-color2: rgba(255, 255, 255, 0.7); - --jp-ui-inverse-font-color3: rgba(255, 255, 255, 0.5); - - /* Content Fonts - * - * Content font variables are used for typography of user generated content. - * - * The font sizing here is done assuming that the body font size of --jp-content-font-size1 - * is applied to a parent element. When children elements, such as headings, are sized - * in em all things will be computed relative to that body size. - */ - - --jp-content-line-height: 1.6; - --jp-content-font-scale-factor: 1.2; - --jp-content-font-size0: 0.83333em; - --jp-content-font-size1: 14px; /* Base font size */ - --jp-content-font-size2: 1.2em; - --jp-content-font-size3: 1.44em; - --jp-content-font-size4: 1.728em; - --jp-content-font-size5: 2.0736em; - - /* This gives a magnification of about 125% in presentation mode over normal. */ - --jp-content-presentation-font-size1: 17px; - - --jp-content-heading-line-height: 1; - --jp-content-heading-margin-top: 1.2em; - --jp-content-heading-margin-bottom: 0.8em; - --jp-content-heading-font-weight: 500; - - /* Defaults use Material Design specification */ - --jp-content-font-color0: rgba(0, 0, 0, 1); - --jp-content-font-color1: rgba(0, 0, 0, 0.87); - --jp-content-font-color2: rgba(0, 0, 0, 0.54); - --jp-content-font-color3: rgba(0, 0, 0, 0.38); - - --jp-content-link-color: var(--md-blue-700); - - --jp-content-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', - Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', - 'Segoe UI Symbol'; - - /* - * Code Fonts - * - * Code font variables are used for typography of code and other monospaces content. - */ - - --jp-code-font-size: 13px; - --jp-code-line-height: 1.3077; /* 17px for 13px base */ - --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */ - --jp-code-font-family-default: Menlo, Consolas, 'DejaVu Sans Mono', monospace; - --jp-code-font-family: var(--jp-code-font-family-default); - - /* This gives a magnification of about 125% in presentation mode over normal. */ - --jp-code-presentation-font-size: 16px; - - /* may need to tweak cursor width if you change font size */ - --jp-code-cursor-width0: 1.4px; - --jp-code-cursor-width1: 2px; - --jp-code-cursor-width2: 4px; - - /* Layout - * - * The following are the main layout colors use in JupyterLab. In a light - * theme these would go from light to dark. - */ - - --jp-layout-color0: white; - --jp-layout-color1: white; - --jp-layout-color2: var(--md-grey-200); - --jp-layout-color3: var(--md-grey-400); - --jp-layout-color4: var(--md-grey-600); - - /* Inverse Layout - * - * The following are the inverse layout colors use in JupyterLab. In a light - * theme these would go from dark to light. - */ - - --jp-inverse-layout-color0: #111111; - --jp-inverse-layout-color1: var(--md-grey-900); - --jp-inverse-layout-color2: var(--md-grey-800); - --jp-inverse-layout-color3: var(--md-grey-700); - --jp-inverse-layout-color4: var(--md-grey-600); - - /* Brand/accent */ - - --jp-brand-color0: var(--md-blue-900); - --jp-brand-color1: var(--md-blue-700); - --jp-brand-color2: var(--md-blue-300); - --jp-brand-color3: var(--md-blue-100); - --jp-brand-color4: var(--md-blue-50); - - --jp-accent-color0: var(--md-green-900); - --jp-accent-color1: var(--md-green-700); - --jp-accent-color2: var(--md-green-300); - --jp-accent-color3: var(--md-green-100); - - /* State colors (warn, error, success, info) */ - - --jp-warn-color0: var(--md-orange-900); - --jp-warn-color1: var(--md-orange-700); - --jp-warn-color2: var(--md-orange-300); - --jp-warn-color3: var(--md-orange-100); - - --jp-error-color0: var(--md-red-900); - --jp-error-color1: var(--md-red-700); - --jp-error-color2: var(--md-red-300); - --jp-error-color3: var(--md-red-100); - - --jp-success-color0: var(--md-green-900); - --jp-success-color1: var(--md-green-700); - --jp-success-color2: var(--md-green-300); - --jp-success-color3: var(--md-green-100); - - --jp-info-color0: var(--md-cyan-900); - --jp-info-color1: var(--md-cyan-700); - --jp-info-color2: var(--md-cyan-300); - --jp-info-color3: var(--md-cyan-100); - - /* Cell specific styles */ - - --jp-cell-padding: 5px; - - --jp-cell-collapser-width: 8px; - --jp-cell-collapser-min-height: 20px; - --jp-cell-collapser-not-active-hover-opacity: 0.6; - - --jp-cell-editor-background: var(--md-grey-100); - --jp-cell-editor-border-color: var(--md-grey-300); - --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300); - --jp-cell-editor-active-background: var(--jp-layout-color0); - --jp-cell-editor-active-border-color: var(--jp-brand-color1); - - --jp-cell-prompt-width: 64px; - --jp-cell-prompt-font-family: var(--jp-code-font-family-default); - --jp-cell-prompt-letter-spacing: 0px; - --jp-cell-prompt-opacity: 1; - --jp-cell-prompt-not-active-opacity: 0.5; - --jp-cell-prompt-not-active-font-color: var(--md-grey-700); - /* A custom blend of MD grey and blue 600 - * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */ - --jp-cell-inprompt-font-color: #307fc1; - /* A custom blend of MD grey and orange 600 - * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */ - --jp-cell-outprompt-font-color: #bf5b3d; - - /* Notebook specific styles */ - - --jp-notebook-padding: 10px; - --jp-notebook-select-background: var(--jp-layout-color1); - --jp-notebook-multiselected-color: var(--md-blue-50); - - /* The scroll padding is calculated to fill enough space at the bottom of the - notebook to show one single-line cell (with appropriate padding) at the top - when the notebook is scrolled all the way to the bottom. We also subtract one - pixel so that no scrollbar appears if we have just one single-line cell in the - notebook. This padding is to enable a 'scroll past end' feature in a notebook. - */ - --jp-notebook-scroll-padding: calc( - 100% - var(--jp-code-font-size) * var(--jp-code-line-height) - - var(--jp-code-padding) - var(--jp-cell-padding) - 1px - ); - - /* Rendermime styles */ - - --jp-rendermime-error-background: #fdd; - --jp-rendermime-table-row-background: var(--md-grey-100); - --jp-rendermime-table-row-hover-background: var(--md-light-blue-50); - - /* Dialog specific styles */ - - --jp-dialog-background: rgba(0, 0, 0, 0.25); - - /* Console specific styles */ - - --jp-console-padding: 10px; - - /* Toolbar specific styles */ - - --jp-toolbar-border-color: var(--jp-border-color1); - --jp-toolbar-micro-height: 8px; - --jp-toolbar-background: var(--jp-layout-color1); - --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.24); - --jp-toolbar-header-margin: 4px 4px 0px 4px; - --jp-toolbar-active-background: var(--md-grey-300); - - /* Statusbar specific styles */ - - --jp-statusbar-height: 24px; - - /* Input field styles */ - - --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300); - --jp-input-active-background: var(--jp-layout-color1); - --jp-input-hover-background: var(--jp-layout-color1); - --jp-input-background: var(--md-grey-100); - --jp-input-border-color: var(--jp-border-color1); - --jp-input-active-border-color: var(--jp-brand-color1); - --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3); - - /* General editor styles */ - - --jp-editor-selected-background: #d9d9d9; - --jp-editor-selected-focused-background: #d7d4f0; - --jp-editor-cursor-color: var(--jp-ui-font-color0); - - /* Code mirror specific styles */ - - --jp-mirror-editor-keyword-color: #008000; - --jp-mirror-editor-atom-color: #88f; - --jp-mirror-editor-number-color: #080; - --jp-mirror-editor-def-color: #00f; - --jp-mirror-editor-variable-color: var(--md-grey-900); - --jp-mirror-editor-variable-2-color: #05a; - --jp-mirror-editor-variable-3-color: #085; - --jp-mirror-editor-punctuation-color: #05a; - --jp-mirror-editor-property-color: #05a; - --jp-mirror-editor-operator-color: #aa22ff; - --jp-mirror-editor-comment-color: #408080; - --jp-mirror-editor-string-color: #ba2121; - --jp-mirror-editor-string-2-color: #708; - --jp-mirror-editor-meta-color: #aa22ff; - --jp-mirror-editor-qualifier-color: #555; - --jp-mirror-editor-builtin-color: #008000; - --jp-mirror-editor-bracket-color: #997; - --jp-mirror-editor-tag-color: #170; - --jp-mirror-editor-attribute-color: #00c; - --jp-mirror-editor-header-color: blue; - --jp-mirror-editor-quote-color: #090; - --jp-mirror-editor-link-color: #00c; - --jp-mirror-editor-error-color: #f00; - --jp-mirror-editor-hr-color: #999; - - /* Vega extension styles */ - - --jp-vega-background: white; - - /* Sidebar-related styles */ - - --jp-sidebar-min-width: 250px; - - /* Search-related styles */ - - --jp-search-toggle-off-opacity: 0.5; - --jp-search-toggle-hover-opacity: 0.8; - --jp-search-toggle-on-opacity: 1; - --jp-search-selected-match-background-color: rgb(245, 200, 0); - --jp-search-selected-match-color: black; - --jp-search-unselected-match-background-color: var( - --jp-inverse-layout-color0 - ); - --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0); - - /* Icon colors that work well with light or dark backgrounds */ - --jp-icon-contrast-color0: var(--md-purple-600); - --jp-icon-contrast-color1: var(--md-green-600); - --jp-icon-contrast-color2: var(--md-pink-600); - --jp-icon-contrast-color3: var(--md-blue-600); -} -</style> - -<style type="text/css"> -/* Force rendering true colors when outputing to pdf */ -* { - -webkit-print-color-adjust: exact; -} - -/* Misc */ -a.anchor-link { - display: none; -} - -.highlight { - margin: 0.4em; -} - -/* Input area styling */ -.jp-InputArea { - overflow: hidden; -} - -.jp-InputArea-editor { - overflow: hidden; -} - -.CodeMirror pre { - margin: 0; - padding: 0; -} - -/* Using table instead of flexbox so that we can use break-inside property */ -/* CSS rules under this comment should not be required anymore after we move to the JupyterLab 4.0 CSS */ - - -.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { - min-width: calc( - var(--jp-cell-prompt-width) - var(--jp-private-cell-scrolling-output-offset) - ); -} - -.jp-OutputArea-child { - display: table; - width: 100%; -} - -.jp-OutputPrompt { - display: table-cell; - vertical-align: top; - min-width: var(--jp-cell-prompt-width); -} - -body[data-format='mobile'] .jp-OutputPrompt { - display: table-row; -} - -.jp-OutputArea-output { - display: table-cell; - width: 100%; -} - -body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output { - display: table-row; -} - -.jp-OutputArea-output.jp-OutputArea-executeResult { - width: 100%; -} - -/* Hiding the collapser by default */ -.jp-Collapser { - display: none; -} - -@media print { - .jp-Cell-inputWrapper, - .jp-Cell-outputWrapper { - display: block; - } - - .jp-OutputArea-child { - break-inside: avoid-page; - } -} -</style> - -<!-- Load mathjax --> - <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML-full,Safe"> </script> - <!-- MathJax configuration --> - <script type="text/x-mathjax-config"> - init_mathjax = function() { - if (window.MathJax) { - // MathJax loaded - MathJax.Hub.Config({ - TeX: { - equationNumbers: { - autoNumber: "AMS", - useLabelIds: true - } - }, - tex2jax: { - inlineMath: [ ['$','$'], ["\\(","\\)"] ], - displayMath: [ ['$$','$$'], ["\\[","\\]"] ], - processEscapes: true, - processEnvironments: true - }, - displayAlign: 'center', - CommonHTML: { - linebreaks: { - automatic: true - } - } - }); - - MathJax.Hub.Queue(["Typeset", MathJax.Hub]); - } - } - init_mathjax(); - </script> - <!-- End of mathjax configuration --></head> -<body class="jp-Notebook" data-jp-theme-light="true" data-jp-theme-name="JupyterLab Light"> -<div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [1]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">requests</span> -<span class="kn">import</span> <span class="nn">datetime</span> -<span class="kn">import</span> <span class="nn">os</span> -<span class="kn">import</span> <span class="nn">pickle</span> -<span class="kn">import</span> <span class="nn">pandas</span> <span class="k">as</span> <span class="nn">pd</span> -<span class="kn">from</span> <span class="nn">ost</span> <span class="kn">import</span> <span class="n">io</span><span class="p">,</span> <span class="n">seq</span> - -<span class="c1"># from Tara code</span> -<span class="k">def</span> <span class="nf">_get_sequence</span><span class="p">(</span><span class="n">chn</span><span class="p">):</span> - <span class="sd">"""Get the sequence out of an OST chain."""</span> - <span class="c1"># initialise</span> - <span class="n">lst_rn</span> <span class="o">=</span> <span class="n">chn</span><span class="o">.</span><span class="n">residues</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">number</span><span class="o">.</span><span class="n">num</span> - <span class="n">idx</span> <span class="o">=</span> <span class="mi">1</span> - <span class="n">sqe</span> <span class="o">=</span> <span class="n">chn</span><span class="o">.</span><span class="n">residues</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">one_letter_code</span> - <span class="k">if</span> <span class="n">lst_rn</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">sqe</span> <span class="o">=</span> <span class="s2">"-"</span> - <span class="n">idx</span> <span class="o">=</span> <span class="mi">0</span> - - <span class="k">for</span> <span class="n">res</span> <span class="ow">in</span> <span class="n">chn</span><span class="o">.</span><span class="n">residues</span><span class="p">[</span><span class="n">idx</span><span class="p">:]:</span> - <span class="n">lst_rn</span> <span class="o">+=</span> <span class="mi">1</span> - <span class="k">while</span> <span class="n">lst_rn</span> <span class="o">!=</span> <span class="n">res</span><span class="o">.</span><span class="n">number</span><span class="o">.</span><span class="n">num</span><span class="p">:</span> - <span class="n">sqe</span> <span class="o">+=</span> <span class="s2">"-"</span> - <span class="n">lst_rn</span> <span class="o">+=</span> <span class="mi">1</span> - <span class="n">sqe</span> <span class="o">+=</span> <span class="n">res</span><span class="o">.</span><span class="n">one_letter_code</span> - - <span class="k">return</span> <span class="n">sqe</span> - -<span class="k">def</span> <span class="nf">_check_sequence</span><span class="p">(</span><span class="n">up_ac</span><span class="p">,</span> <span class="n">sequence</span><span class="p">):</span> - <span class="sd">"""Verify sequence to only contain standard olc."""</span> - <span class="k">for</span> <span class="n">res</span> <span class="ow">in</span> <span class="n">sequence</span><span class="p">:</span> - <span class="k">if</span> <span class="n">res</span> <span class="ow">not</span> <span class="ow">in</span> <span class="s2">"ACDEFGHIKLMNPQRSTVWY"</span><span class="p">:</span> - <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span> - <span class="s2">"Non-standard aa found in UniProtKB sequence "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"for entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">': </span><span class="si">{</span><span class="n">res</span><span class="si">}</span><span class="s2">"</span> - <span class="p">)</span> - -<span class="k">def</span> <span class="nf">_fetch_upkb_entry</span><span class="p">(</span><span class="n">up_ac</span><span class="p">):</span> - <span class="sd">"""Fetch data for an UniProtKB entry."""</span> - <span class="c1"># This is a simple parser for UniProtKB txt format, instead of breaking it up</span> - <span class="c1"># into multiple functions, we just allow many many branches & statements,</span> - <span class="c1"># here.</span> - <span class="c1"># pylint: disable=too-many-branches,too-many-statements</span> - <span class="n">data</span> <span class="o">=</span> <span class="p">{}</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">]</span> <span class="o">=</span> <span class="s2">""</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">=</span> <span class="s2">""</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_ac"</span><span class="p">]</span> <span class="o">=</span> <span class="n">up_ac</span> - <span class="n">rspns</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="sa">f</span><span class="s2">"https://www.uniprot.org/uniprot/</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">.txt"</span><span class="p">)</span> - <span class="k">for</span> <span class="n">line</span> <span class="ow">in</span> <span class="n">rspns</span><span class="o">.</span><span class="n">iter_lines</span><span class="p">(</span><span class="n">decode_unicode</span><span class="o">=</span><span class="kc">True</span><span class="p">):</span> - <span class="k">if</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"ID "</span><span class="p">):</span> - <span class="n">sline</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">split</span><span class="p">()</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">5</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"Unusual UniProtKB ID line found:</span><span class="se">\n</span><span class="s2">'</span><span class="si">{</span><span class="n">line</span><span class="si">}</span><span class="s2">'"</span><span class="p">)</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_id"</span><span class="p">]</span> <span class="o">=</span> <span class="n">sline</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"OX NCBI_TaxID="</span><span class="p">):</span> - <span class="c1"># Following strictly the UniProtKB format: 'OX NCBI_TaxID=<ID>;'</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span> <span class="o">=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"OX NCBI_TaxID="</span><span class="p">)</span> <span class="p">:</span> <span class="o">-</span><span class="mi">1</span><span class="p">]</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">"{"</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"OS "</span><span class="p">):</span> - <span class="k">if</span> <span class="n">line</span><span class="p">[</span><span class="o">-</span><span class="mi">1</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"."</span><span class="p">:</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">]</span> <span class="o">+=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"OS "</span><span class="p">)</span> <span class="p">:</span> <span class="o">-</span><span class="mi">1</span><span class="p">]</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">]</span> <span class="o">+=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"OS "</span><span class="p">)</span> <span class="p">:</span> <span class="o">-</span><span class="mi">1</span><span class="p">]</span> <span class="o">+</span> <span class="s2">" "</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"SQ "</span><span class="p">):</span> - <span class="n">sline</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">split</span><span class="p">()</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">8</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"Unusual UniProtKB SQ line found:</span><span class="se">\n</span><span class="s2">'</span><span class="si">{</span><span class="n">line</span><span class="si">}</span><span class="s2">'"</span><span class="p">)</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_seqlen"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">sline</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_crc64"</span><span class="p">]</span> <span class="o">=</span> <span class="n">sline</span><span class="p">[</span><span class="mi">6</span><span class="p">]</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">" "</span><span class="p">):</span> - <span class="n">sline</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">split</span><span class="p">()</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> <span class="o">></span> <span class="mi">6</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span> - <span class="s2">"Unusual UniProtKB sequence data line "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"found:</span><span class="se">\n</span><span class="s2">'</span><span class="si">{</span><span class="n">line</span><span class="si">}</span><span class="s2">'"</span> - <span class="p">)</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">+=</span> <span class="s2">""</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"RP "</span><span class="p">):</span> - <span class="k">if</span> <span class="s2">"ISOFORM"</span> <span class="ow">in</span> <span class="n">line</span><span class="o">.</span><span class="n">upper</span><span class="p">():</span> - <span class="ne">RuntimeError</span><span class="p">(</span> - <span class="sa">f</span><span class="s2">"First ISOFORM found for '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">', needs "</span> <span class="o">+</span> <span class="s2">"handling."</span> - <span class="p">)</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"DT "</span><span class="p">):</span> - <span class="c1"># 2012-10-03</span> - <span class="n">dt_flds</span> <span class="o">=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"DT "</span><span class="p">)</span> <span class="p">:]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">", "</span><span class="p">)</span> - <span class="k">if</span> <span class="n">dt_flds</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">upper</span><span class="p">()</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"SEQUENCE VERSION "</span><span class="p">):</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_last_mod"</span><span class="p">]</span> <span class="o">=</span> <span class="n">datetime</span><span class="o">.</span><span class="n">datetime</span><span class="o">.</span><span class="n">strptime</span><span class="p">(</span> - <span class="n">dt_flds</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="s2">"</span><span class="si">%d</span><span class="s2">-%b-%Y"</span> - <span class="p">)</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"GN Name="</span><span class="p">):</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_gn"</span><span class="p">]</span> <span class="o">=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"GN Name="</span><span class="p">)</span> <span class="p">:]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">";"</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_gn"</span><span class="p">]</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_gn"</span><span class="p">]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">"{"</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - - <span class="c1"># we have not seen isoforms in the data set, yet, so we just set them to '.'</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_isoform"</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span> - - <span class="k">if</span> <span class="s2">"up_gn"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No gene name found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">"up_last_mod"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No sequence version found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">"up_crc64"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No CRC64 value found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">])</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No sequence found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="c1"># check that sequence length and CRC64 is correct</span> - <span class="k">if</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_seqlen"</span><span class="p">]</span> <span class="o">!=</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]):</span> - <span class="n">_abort_msg</span><span class="p">(</span> - <span class="s2">"Sequence length of SQ line and sequence data differ for "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">': </span><span class="si">{</span><span class="n">data</span><span class="p">[</span><span class="s1">'up_seqlen'</span><span class="p">]</span><span class="si">}</span><span class="s2"> != "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s1">'up_sequence'</span><span class="p">])</span><span class="si">}</span><span class="s2">"</span> - <span class="p">)</span> - <span class="n">_check_sequence</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_ac"</span><span class="p">],</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">])</span> - - <span class="k">if</span> <span class="s2">"up_id"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No ID found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">"up_ncbi_taxid"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No NCBI taxonomy ID found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">])</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No organism species found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - - <span class="k">return</span> <span class="n">data</span> - -<span class="k">def</span> <span class="nf">_get_upkb_for_sequence</span><span class="p">(</span><span class="n">sqe</span><span class="p">,</span> <span class="n">up_ac</span><span class="p">):</span> - <span class="sd">"""Get UniProtKB entry data for given sequence."""</span> - <span class="n">up_data</span> <span class="o">=</span> <span class="n">_fetch_upkb_entry</span><span class="p">(</span><span class="n">up_ac</span><span class="p">)</span> - <span class="k">if</span> <span class="n">sqe</span> <span class="o">!=</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]:</span> - <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span> - <span class="sa">f</span><span class="s2">"Sequences not equal from file: </span><span class="si">{</span><span class="n">sqe</span><span class="si">}</span><span class="s2">, from UniProtKB: "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">up_data</span><span class="p">[</span><span class="s1">'up_sequence'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="p">)</span> - - <span class="k">return</span> <span class="n">up_data</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [2]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">_get_ncbi_sequence</span><span class="p">(</span><span class="n">ncbi_ac</span><span class="p">):</span> - <span class="sd">"""Fetch OST sequence object from NCBI web service."""</span> - <span class="c1"># src: https://www.ncbi.nlm.nih.gov/books/NBK25500/#_chapter1_Downloading_Full_Records_</span> - <span class="n">rspns</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="sa">f</span><span class="s2">"https://eutils.ncbi.nlm.nih.gov/entrez/eutils/"</span> \ - <span class="sa">f</span><span class="s2">"efetch.fcgi?db=protein&id=</span><span class="si">{</span><span class="n">ncbi_ac</span><span class="si">}</span><span class="s2">"</span> \ - <span class="sa">f</span><span class="s2">"&rettype=fasta&retmode=text"</span><span class="p">)</span> - <span class="k">return</span> <span class="n">io</span><span class="o">.</span><span class="n">SequenceFromString</span><span class="p">(</span><span class="n">rspns</span><span class="o">.</span><span class="n">text</span><span class="p">,</span> <span class="s2">"fasta"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [3]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># s = _get_ncbi_sequence("CAD2068351.1")</span> -<span class="c1"># up_data = _fetch_upkb_entry("A0A485PQD1")</span> -<span class="c1"># print(s.name, s, len(s), up_data["up_sequence"] == str(s))</span> -<span class="c1"># up_data</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [4]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check USDA data</span> -<span class="c1"># metadata_file = "./OneDrive-Part/ASFV-G_proteome_accessions.csv"</span> -<span class="c1"># pdb_dir = "./OneDrive-Part/AlphaFoldSimple"</span> -<span class="n">metadata_file</span> <span class="o">=</span> <span class="s2">"./2022-08-22_updates/ASFV-G_proteome_accessions.csv"</span> -<span class="n">pdb_dir</span> <span class="o">=</span> <span class="s2">"./2022-08-22_updates/AlphaFold-RENAME"</span> -<span class="n">pkl_dir</span> <span class="o">=</span> <span class="s2">"./OneDrive-Part/PickleFiles"</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [5]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span> <span class="o">=</span> <span class="n">pd</span><span class="o">.</span><span class="n">read_csv</span><span class="p">(</span><span class="n">metadata_file</span><span class="p">)</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">Protein</span><span class="p">))</span> <span class="o">==</span> <span class="n">metadata</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"Associated PDB"</span><span class="p">]))</span> <span class="o">==</span> <span class="n">metadata</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> -<span class="n">metadata</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[5]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Protein</th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - </thead> - <tbody> - <tr> - <th>0</th> - <td>285L</td> - <td>285L.pdb</td> - <td>CAD2068351.1</td> - <td>A0A485PQD1</td> - <td>ASFV-G 285L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>1</th> - <td>A104R</td> - <td>A104R.pdb</td> - <td>CAD2068395.1</td> - <td>A0A0A1E0L7</td> - <td>ASFV-G A104R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>2</th> - <td>A118R</td> - <td>A118R.pdb</td> - <td>CAD2068397.1</td> - <td>A0A2X0RVA9</td> - <td>ASFV-G A118R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>3</th> - <td>A137R</td> - <td>A137R.pdb</td> - <td>CAD2068404.1</td> - <td>A0A2X0THQ0</td> - <td>ASFV-G A137R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>4</th> - <td>A151R</td> - <td>A151R.pdb</td> - <td>CAD2068398.1</td> - <td>A0A2X0TC55</td> - <td>ASFV-G A151R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>...</th> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - </tr> - <tr> - <th>192</th> - <td>QP509L</td> - <td>QP509L.pdb</td> - <td>CAD2068484.1</td> - <td>A0A2X0THX2</td> - <td>ASFV-G QP509L</td> - <td>This model was predicted using AlphaFold2</td> - <td>NaN</td> - <td>NaN</td> - </tr> - <tr> - <th>193</th> - <td>R298L</td> - <td>R298L.pdb</td> - <td>CAD2068482.1</td> - <td>A0A2X0SE42</td> - <td>ASFV-G R298L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>194</th> - <td>S183L</td> - <td>S183L.pdb</td> - <td>CAD2068472.1</td> - <td>A0A2X0SE34</td> - <td>ASFV-G S183L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>195</th> - <td>S273R</td> - <td>S273R.pdb</td> - <td>CAD2068473.1</td> - <td>A0A2X0TKM5</td> - <td>ASFV-G S273R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>196</th> - <td>X69R</td> - <td>X69R.pdb</td> - <td>CAD2068372.1</td> - <td>A0A2X0TKC7</td> - <td>ASFV-G X69R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - </tr> - </tbody> -</table> -<p>197 rows × 8 columns</p> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [10]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># compare new with old</span> -<span class="n">metadata_old</span> <span class="o">=</span> <span class="n">pd</span><span class="o">.</span><span class="n">read_csv</span><span class="p">(</span><span class="s2">"./OneDrive-Part/ASFV-G_proteome_accessions.csv"</span><span class="p">)</span> -<span class="k">for</span> <span class="n">key</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">"NCBI_Accession"</span><span class="p">,</span> <span class="s2">"UniProt_ID"</span><span class="p">,</span> <span class="s2">"_struct.title "</span><span class="p">]:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">key</span><span class="p">)</span> - <span class="n">tsto</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata_old</span><span class="p">[</span><span class="n">key</span><span class="p">])</span> - <span class="n">tstm</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="n">key</span><span class="p">])</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY IN OLD:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tsto</span> <span class="o">-</span> <span class="n">tstm</span><span class="p">))</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY IN NEW:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstm</span> <span class="o">-</span> <span class="n">tsto</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>NCBI_Accession -ONLY IN OLD: [] -ONLY IN NEW: [] -UniProt_ID -ONLY IN OLD: [] -ONLY IN NEW: [] -_struct.title -ONLY IN OLD: [] -ONLY IN NEW: [] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [7]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">pdb_files</span> <span class="o">=</span> <span class="p">[</span><span class="n">f</span> <span class="k">for</span> <span class="n">f</span> <span class="ow">in</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">listdir</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">))</span> <span class="k">if</span> <span class="n">f</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">".pdb"</span><span class="p">)]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [19]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check names</span> -<span class="n">pdb_file_split</span> <span class="o">=</span> <span class="p">[</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">splitext</span><span class="p">(</span><span class="n">f</span><span class="p">)</span> <span class="k">for</span> <span class="n">f</span> <span class="ow">in</span> <span class="n">pdb_files</span><span class="p">]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [9]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">tstp</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">pdb_files</span><span class="p">)</span> -<span class="n">tstm</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"Associated PDB"</span><span class="p">])</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY AS PDB:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstp</span> <span class="o">-</span> <span class="n">tstm</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY IN METADATA:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstm</span> <span class="o">-</span> <span class="n">tstp</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>ONLY AS PDB: [] -ONLY IN METADATA: [] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [10]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">tstp</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">fs</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="k">for</span> <span class="n">fs</span> <span class="ow">in</span> <span class="n">pdb_file_split</span><span class="p">)</span> -<span class="n">tstm</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">Protein</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY AS PDB:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstp</span> <span class="o">-</span> <span class="n">tstm</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY IN METADATA:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstm</span> <span class="o">-</span> <span class="n">tstp</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>ONLY AS PDB: [] -ONLY IN METADATA: [] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [11]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># can use either Protein or PDB name as index</span> -<span class="n">metadata</span> <span class="o">=</span> <span class="n">metadata</span><span class="o">.</span><span class="n">set_index</span><span class="p">(</span><span class="s2">"Protein"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [13]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># NOTE: stupid space there...</span> -<span class="n">metadata</span><span class="p">[</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"_struct.title "</span><span class="p">]</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[13]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Protein</th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - </thead> - <tbody> - </tbody> -</table> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [14]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span><span class="p">[</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"_struct.pdbx_model_detail"</span><span class="p">]</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[14]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Protein</th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - </thead> - <tbody> - </tbody> -</table> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [15]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span><span class="p">[</span><span class="o">~</span><span class="n">metadata</span><span class="o">.</span><span class="n">notes</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[15]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Protein</th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - </thead> - <tbody> - <tr> - <th>58</th> - <td>CP2475L_p14</td> - <td>CP2475L_p14.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p14</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>protein p14 from the pp220 polyprotein encoded...</td> - </tr> - <tr> - <th>59</th> - <td>CP2475L_p34</td> - <td>CP2475L_p34.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p34</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>protein p34 from the pp220 polyprotein encoded...</td> - </tr> - <tr> - <th>60</th> - <td>CP2475L_p37</td> - <td>CP2475L_p37.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p37</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>protein p37 from the pp220 polyprotein encoded...</td> - </tr> - <tr> - <th>61</th> - <td>CP2475L_p150</td> - <td>CP2475L_p150.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p150</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>protein p150 from the pp220 polyprotein encode...</td> - </tr> - <tr> - <th>62</th> - <td>CP2475L_p5</td> - <td>CP2475L_p5.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p5</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>protein p5 from the pp220 polyprotein encoded ...</td> - </tr> - <tr> - <th>69</th> - <td>D250R</td> - <td>D250R.pdb</td> - <td>CAD2068464.1</td> - <td>A0A2X0THV3</td> - <td>ASFV-G D250R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>Mislabled on NCBI and Uniport as D205R</td> - </tr> - <tr> - <th>76</th> - <td>DP79L</td> - <td>DP79L.pdb</td> - <td>CAD2068466.1</td> - <td>A0A0A1E158</td> - <td>ASFV-G DP79L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>Mislabled on Uniprot as D79L</td> - </tr> - <tr> - <th>111</th> - <td>hypothetical_01</td> - <td>hypothetical_01.pdb</td> - <td>CAD2068367.1</td> - <td>A0A485PU43</td> - <td>ASFV-G hypothetical_01</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_5_pred_0</td> - <td>labeled as hypothetical on NCBI and Uniprot</td> - </tr> - <tr> - <th>112</th> - <td>hypothetical_02</td> - <td>hypothetical_02.pdb</td> - <td>CAD2068400.1</td> - <td>A0A485PQI3</td> - <td>ASFV-G hypothetical_02</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>labeled as hypthetical on NCBI and Uniprot</td> - </tr> - <tr> - <th>113</th> - <td>hypothetical_03</td> - <td>hypothetical_03.pdb</td> - <td>CAD2068512.1</td> - <td>A0A485PZB7</td> - <td>ASFV-G hypothetical_03</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>labeled as hypthetical on NCBI and Uniprot</td> - </tr> - </tbody> -</table> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [13]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># tst = metadata.loc["hypothetical_03"]</span> -<span class="c1"># s = _get_ncbi_sequence(tst.NCBI_Accession)</span> -<span class="c1"># up_data = _fetch_upkb_entry(tst.UniProt_ID)</span> -<span class="c1"># print(s.name, s, len(s), up_data["up_sequence"] == str(s))</span> -<span class="c1"># up_data</span> - -<span class="c1"># checked all the one above manually and ok as stated (best to add to model_detail!)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [44]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check model numbers</span> -<span class="n">tst</span> <span class="o">=</span> <span class="n">metadata</span><span class="p">[</span><span class="s2">"ranking debugg model ID"</span><span class="p">]</span> -<span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">mdl_id</span> <span class="ow">in</span> <span class="n">tst</span><span class="o">.</span><span class="n">items</span><span class="p">():</span> - <span class="n">mdl_num</span> <span class="o">=</span> <span class="kc">None</span> - <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">mdl_id</span><span class="p">)</span> <span class="o">==</span> <span class="nb">str</span><span class="p">:</span> - <span class="n">mdl_id_split</span> <span class="o">=</span> <span class="n">mdl_id</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">mdl_id_split</span><span class="p">)</span> <span class="o">==</span> <span class="mi">4</span><span class="p">:</span> - <span class="n">mdl_num</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">mdl_id_split</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> - <span class="k">if</span> <span class="ow">not</span> <span class="n">mdl_num</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">mdl_id</span><span class="p">)</span> - <span class="k">elif</span> <span class="n">mdl_num</span> <span class="ow">not</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">6</span><span class="p">):</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">mdl_id</span><span class="p">,</span> <span class="n">mdl_num</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>QP509L nan -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [14]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">pkl_files</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">listdir</span><span class="p">(</span><span class="n">pkl_dir</span><span class="p">)</span> -<span class="k">for</span> <span class="n">pkl_file</span> <span class="ow">in</span> <span class="n">pkl_files</span><span class="p">:</span> - <span class="n">protein</span> <span class="o">=</span> <span class="n">pkl_file</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">,</span> <span class="mi">1</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span> - <span class="k">assert</span> <span class="n">protein</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">index</span> - <span class="k">assert</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">exists</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">,</span> <span class="n">protein</span> <span class="o">+</span> <span class="s2">".pdb"</span><span class="p">))</span> -<span class="n">pkl_file</span> <span class="o">=</span> <span class="n">pkl_files</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [15]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">model_data</span> <span class="o">=</span> <span class="n">pickle</span><span class="o">.</span><span class="n">load</span><span class="p">(</span><span class="nb">open</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pkl_dir</span><span class="p">,</span> <span class="n">pkl_file</span><span class="p">),</span> <span class="s2">"rb"</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [16]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">model_data</span><span class="o">.</span><span class="n">keys</span><span class="p">()</span> -<span class="c1"># NOTE: only pLDDT in here; may as well use the ones from the PDB file...</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[16]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>dict_keys(['distogram', 'experimentally_resolved', 'masked_msa', 'predicted_lddt', 'structure_module', 'plddt', 'ranking_confidence'])</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [17]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span> -<span class="k">for</span> <span class="n">pkl_file</span> <span class="ow">in</span> <span class="n">pkl_files</span><span class="p">:</span> - <span class="c1"># GET pLDDT from PDB file</span> - <span class="n">protein</span> <span class="o">=</span> <span class="n">pkl_file</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">,</span> <span class="mi">1</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">ent</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">,</span> <span class="n">protein</span> <span class="o">+</span> <span class="s2">".pdb"</span><span class="p">))</span> - <span class="n">bfactors</span> <span class="o">=</span> <span class="p">[]</span> - <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent</span><span class="o">.</span><span class="n">atoms</span><span class="p">:</span> - <span class="n">res_idx</span> <span class="o">=</span> <span class="n">a</span><span class="o">.</span><span class="n">residue</span><span class="o">.</span><span class="n">number</span><span class="o">.</span><span class="n">num</span> <span class="o">-</span> <span class="mi">1</span> - <span class="k">assert</span> <span class="n">res_idx</span> <span class="o"><=</span> <span class="nb">len</span><span class="p">(</span><span class="n">bfactors</span><span class="p">)</span> - <span class="k">if</span> <span class="n">res_idx</span> <span class="o"><</span> <span class="nb">len</span><span class="p">(</span><span class="n">bfactors</span><span class="p">):</span> - <span class="k">assert</span> <span class="n">a</span><span class="o">.</span><span class="n">b_factor</span> <span class="o">==</span> <span class="n">bfactors</span><span class="p">[</span><span class="n">res_idx</span><span class="p">]</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">bfactors</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">b_factor</span><span class="p">)</span> - <span class="c1"># COMPARE with pickled one</span> - <span class="n">model_data</span> <span class="o">=</span> <span class="n">pickle</span><span class="o">.</span><span class="n">load</span><span class="p">(</span><span class="nb">open</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pkl_dir</span><span class="p">,</span> <span class="n">pkl_file</span><span class="p">),</span> <span class="s2">"rb"</span><span class="p">))</span> - <span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">bfactors</span><span class="p">)</span> <span class="o">==</span> <span class="nb">len</span><span class="p">(</span><span class="n">model_data</span><span class="p">[</span><span class="s2">"plddt"</span><span class="p">])</span> - <span class="n">b1</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">round</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">asarray</span><span class="p">(</span><span class="n">bfactors</span><span class="p">),</span> <span class="mi">2</span><span class="p">)</span> - <span class="n">b2</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">round</span><span class="p">(</span><span class="n">model_data</span><span class="p">[</span><span class="s2">"plddt"</span><span class="p">],</span> <span class="mi">2</span><span class="p">)</span> - <span class="n">d_bf</span> <span class="o">=</span> <span class="n">b1</span> <span class="o">-</span> <span class="n">b2</span> - <span class="k">if</span> <span class="nb">any</span><span class="p">(</span><span class="n">d_bf</span><span class="p">):</span> - <span class="n">nz_idx</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">nonzero</span><span class="p">(</span><span class="n">d_bf</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">len_nz_idx</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">nz_idx</span><span class="p">)</span> - <span class="n">nz_idx</span> <span class="o">=</span> <span class="n">nz_idx</span><span class="p">[:</span><span class="mi">5</span><span class="p">]</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="n">len_nz_idx</span><span class="p">,</span> <span class="n">nz_idx</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">d_bf</span><span class="p">[</span><span class="n">nz_idx</span><span class="p">],</span> <span class="n">b1</span><span class="p">[</span><span class="n">nz_idx</span><span class="p">],</span> <span class="n">b2</span><span class="p">[</span><span class="n">nz_idx</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>A137R 137 [1 2 3 4 5] [-15.18 -6.81 -4.82 -12.5 -3.61] [27.34 27.25 34.49 28.27 31.02] [42.52 34.06 39.31 40.77 34.63] -A151R 151 [1 2 3 4 5] [-1.57 -5.29 -3.63 -4.76 -6.1 ] [34.45 31.08 34.97 41.78 52.73] [36.02 36.37 38.6 46.54 58.83] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [20]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">_check_subset</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">s2</span><span class="p">):</span> - <span class="c1"># check if s2 is uniquely contained in s1</span> - <span class="c1"># (and if so, returns values for seq_db_align_begin & seq_db_align_end)</span> - <span class="k">if</span> <span class="n">s1</span><span class="o">.</span><span class="n">count</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">align_begin</span> <span class="o">=</span> <span class="n">s1</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span> - <span class="n">align_end</span> <span class="o">=</span> <span class="n">align_begin</span> <span class="o">+</span> <span class="nb">len</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span> - <span class="k">return</span> <span class="n">align_begin</span><span class="p">,</span> <span class="n">align_end</span> - <span class="k">else</span><span class="p">:</span> - <span class="k">return</span> <span class="kc">None</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [21]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check shared ones</span> -<span class="k">for</span> <span class="n">protein</span><span class="p">,</span> <span class="n">pdb_ext</span> <span class="ow">in</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">pdb_file_split</span><span class="p">):</span> - <span class="k">if</span> <span class="n">protein</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">index</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"SKIPPING"</span><span class="p">,</span> <span class="n">protein</span><span class="p">)</span> - <span class="k">continue</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">row</span> <span class="o">=</span> <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">protein</span><span class="p">]</span> - <span class="n">pdb_path</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">,</span> <span class="n">protein</span> <span class="o">+</span> <span class="n">pdb_ext</span><span class="p">)</span> - <span class="n">ent</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="n">pdb_path</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">ent</span><span class="o">.</span><span class="n">chain_count</span> <span class="o">==</span> <span class="mi">1</span> - <span class="n">sqe</span> <span class="o">=</span> <span class="n">_get_sequence</span><span class="p">(</span><span class="n">ent</span><span class="o">.</span><span class="n">chains</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> - <span class="n">s_ncbi</span> <span class="o">=</span> <span class="n">_get_ncbi_sequence</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">)</span> - <span class="n">up_data</span> <span class="o">=</span> <span class="n">_fetch_upkb_entry</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">UniProt_ID</span><span class="p">)</span> - <span class="k">if</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">!=</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">):</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"inconsistent UP/NCBI sequences"</span><span class="p">,</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">],</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">))</span> - <span class="k">if</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">!=</span> <span class="n">sqe</span><span class="p">:</span> - <span class="n">tst</span> <span class="o">=</span> <span class="n">_check_subset</span><span class="p">(</span><span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">],</span> <span class="n">sqe</span><span class="p">)</span> - <span class="k">if</span> <span class="n">tst</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"PDB seq. is subset of UP"</span><span class="p">,</span> <span class="n">tst</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"inconsistent UP/PDB sequences"</span><span class="p">,</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">],</span> <span class="n">sqe</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">)</span> <span class="o">!=</span> <span class="n">sqe</span><span class="p">:</span> - <span class="n">tst</span> <span class="o">=</span> <span class="n">_check_subset</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">),</span> <span class="n">sqe</span><span class="p">)</span> - <span class="k">if</span> <span class="n">tst</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"PDB seq. is subset of NCBI"</span><span class="p">,</span> <span class="n">tst</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"inconsistent NCBI/PDB sequences"</span><span class="p">,</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">),</span> <span class="n">sqe</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>CP2475L_p14 PDB seq. is subset of UP (369, 522) -CP2475L_p14 PDB seq. is subset of NCBI (369, 522) -CP2475L_p150 PDB seq. is subset of UP (894, 2476) -CP2475L_p150 PDB seq. is subset of NCBI (894, 2476) -CP2475L_p34 PDB seq. is subset of UP (45, 368) -CP2475L_p34 PDB seq. is subset of NCBI (45, 368) -CP2475L_p37 PDB seq. is subset of UP (523, 893) -CP2475L_p37 PDB seq. is subset of NCBI (523, 893) -CP2475L_p5 PDB seq. is subset of UP (2, 39) -CP2475L_p5 PDB seq. is subset of NCBI (2, 39) -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [22]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check QP509L (take pLDDT from unrelaxed)</span> -<span class="n">ent_unr</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="s2">"./OneDrive-Part/QP509L-unrelaxed.pdb"</span><span class="p">)</span> -<span class="n">ent_rel</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="s2">"./OneDrive-Part/AlphaFoldSimple/QP509L.pdb"</span><span class="p">)</span> -<span class="c1"># NOTE: ent_rel has hydrogens and no b_factors and no chain name!</span> -<span class="nb">print</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">occupancy</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_rel</span><span class="o">.</span><span class="n">atoms</span><span class="p">),</span> <span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">b_factor</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_rel</span><span class="o">.</span><span class="n">atoms</span><span class="p">))</span> -<span class="n">ev_rel</span> <span class="o">=</span> <span class="n">ent_rel</span><span class="o">.</span><span class="n">Select</span><span class="p">(</span><span class="s2">"ele!=H"</span><span class="p">)</span> -<span class="n">ev_atoms</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">qualified_name</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ev_rel</span><span class="o">.</span><span class="n">atoms</span><span class="p">)</span> -<span class="n">eu_atoms</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">qualified_name</span><span class="p">[</span><span class="mi">2</span><span class="p">:]</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_unr</span><span class="o">.</span><span class="n">atoms</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"IN UNRELAXED:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">eu_atoms</span> <span class="o">-</span> <span class="n">ev_atoms</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"IN RELAXED:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">ev_atoms</span> <span class="o">-</span> <span class="n">eu_atoms</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>{1.0} {0.0} -IN UNRELAXED: ['ILE10.CD1', 'ILE108.CD1', 'ILE12.CD1', 'ILE132.CD1', 'ILE134.CD1', 'ILE136.CD1', 'ILE137.CD1', 'ILE147.CD1', 'ILE153.CD1', 'ILE155.CD1', 'ILE158.CD1', 'ILE191.CD1', 'ILE194.CD1', 'ILE195.CD1', 'ILE228.CD1', 'ILE232.CD1', 'ILE237.CD1', 'ILE254.CD1', 'ILE255.CD1', 'ILE256.CD1', 'ILE279.CD1', 'ILE293.CD1', 'ILE300.CD1', 'ILE303.CD1', 'ILE313.CD1', 'ILE342.CD1', 'ILE343.CD1', 'ILE344.CD1', 'ILE354.CD1', 'ILE368.CD1', 'ILE369.CD1', 'ILE393.CD1', 'ILE394.CD1', 'ILE4.CD1', 'ILE405.CD1', 'ILE413.CD1', 'ILE414.CD1', 'ILE426.CD1', 'ILE430.CD1', 'ILE442.CD1', 'ILE446.CD1', 'ILE46.CD1', 'ILE463.CD1', 'ILE471.CD1', 'ILE48.CD1', 'ILE489.CD1', 'ILE5.CD1', 'ILE61.CD1', 'ILE65.CD1', 'LYS509.O'] -IN RELAXED: ['ILE10.CD', 'ILE108.CD', 'ILE12.CD', 'ILE132.CD', 'ILE134.CD', 'ILE136.CD', 'ILE137.CD', 'ILE147.CD', 'ILE153.CD', 'ILE155.CD', 'ILE158.CD', 'ILE191.CD', 'ILE194.CD', 'ILE195.CD', 'ILE228.CD', 'ILE232.CD', 'ILE237.CD', 'ILE254.CD', 'ILE255.CD', 'ILE256.CD', 'ILE279.CD', 'ILE293.CD', 'ILE300.CD', 'ILE303.CD', 'ILE313.CD', 'ILE342.CD', 'ILE343.CD', 'ILE344.CD', 'ILE354.CD', 'ILE368.CD', 'ILE369.CD', 'ILE393.CD', 'ILE394.CD', 'ILE4.CD', 'ILE405.CD', 'ILE413.CD', 'ILE414.CD', 'ILE426.CD', 'ILE430.CD', 'ILE442.CD', 'ILE446.CD', 'ILE46.CD', 'ILE463.CD', 'ILE471.CD', 'ILE48.CD', 'ILE489.CD', 'ILE5.CD', 'ILE61.CD', 'ILE65.CD', 'LYS509.O1', 'LYS509.O2'] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [23]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># can we fix it internally?</span> -<span class="kn">import</span> <span class="nn">ost</span> -<span class="kn">from</span> <span class="nn">ost</span> <span class="kn">import</span> <span class="n">testutils</span><span class="p">,</span> <span class="n">conop</span> -<span class="kn">from</span> <span class="nn">ost.mol</span> <span class="kn">import</span> <span class="n">mm</span> -<span class="c1"># setup conop</span> -<span class="n">testutils</span><span class="o">.</span><span class="n">SetDefaultCompoundLib</span><span class="p">()</span> -<span class="n">processor</span> <span class="o">=</span> <span class="n">conop</span><span class="o">.</span><span class="n">RuleBasedProcessor</span><span class="p">(</span><span class="n">conop</span><span class="o">.</span><span class="n">GetDefaultLib</span><span class="p">())</span> -<span class="c1"># map with MM function</span> -<span class="n">mm</span><span class="o">.</span><span class="n">MMModeller</span><span class="o">.</span><span class="n">AssignPDBNaming</span><span class="p">(</span><span class="n">ent_rel</span><span class="p">)</span> -<span class="c1"># check processing</span> -<span class="n">ost</span><span class="o">.</span><span class="n">PushVerbosityLevel</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> -<span class="n">processor</span><span class="o">.</span><span class="n">Process</span><span class="p">(</span><span class="n">ent_rel</span><span class="p">)</span> -<span class="n">ost</span><span class="o">.</span><span class="n">PopVerbosityLevel</span><span class="p">()</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr"> -<pre>residue LYS509 contains unknown atom O2 -residue LYS509 contains unknown atom O1 -residue LYS509 contains unknown atom HE1 -residue LYS509 contains unknown atom HD1 -residue LYS509 contains unknown atom HG1 -residue LYS509 contains unknown atom HB1 -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [24]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">xml.dom.minidom</span> -<span class="k">def</span> <span class="nf">_get_ncbi_info</span><span class="p">(</span><span class="n">ncbi_ac</span><span class="p">):</span> - <span class="sd">"""Fetch dict with info from NCBI web service."""</span> - <span class="c1"># src: https://www.ncbi.nlm.nih.gov/books/NBK25499/#chapter4.ESummary</span> - <span class="n">rspns</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="sa">f</span><span class="s2">"https://eutils.ncbi.nlm.nih.gov/entrez/eutils/"</span> \ - <span class="sa">f</span><span class="s2">"esummary.fcgi?db=protein&id=</span><span class="si">{</span><span class="n">ncbi_ac</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="n">dom</span> <span class="o">=</span> <span class="n">xml</span><span class="o">.</span><span class="n">dom</span><span class="o">.</span><span class="n">minidom</span><span class="o">.</span><span class="n">parseString</span><span class="p">(</span><span class="n">rspns</span><span class="o">.</span><span class="n">text</span><span class="p">)</span> - <span class="n">docsums</span> <span class="o">=</span> <span class="n">dom</span><span class="o">.</span><span class="n">getElementsByTagName</span><span class="p">(</span><span class="s2">"DocSum"</span><span class="p">)</span> - <span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">docsums</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> - <span class="n">docsum</span> <span class="o">=</span> <span class="n">docsums</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">ncbi_dict</span> <span class="o">=</span> <span class="p">{}</span> - <span class="k">for</span> <span class="n">cn</span> <span class="ow">in</span> <span class="n">docsum</span><span class="o">.</span><span class="n">childNodes</span><span class="p">:</span> - <span class="k">if</span> <span class="n">cn</span><span class="o">.</span><span class="n">nodeName</span> <span class="o">==</span> <span class="s2">"Item"</span><span class="p">:</span> - <span class="n">cn_name</span> <span class="o">=</span> <span class="n">cn</span><span class="o">.</span><span class="n">getAttribute</span><span class="p">(</span><span class="s2">"Name"</span><span class="p">)</span> - <span class="n">cn_type</span> <span class="o">=</span> <span class="n">cn</span><span class="o">.</span><span class="n">getAttribute</span><span class="p">(</span><span class="s2">"Type"</span><span class="p">)</span> - <span class="k">if</span> <span class="n">cn</span><span class="o">.</span><span class="n">childNodes</span><span class="p">:</span> - <span class="n">d</span> <span class="o">=</span> <span class="n">cn</span><span class="o">.</span><span class="n">childNodes</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">data</span> - <span class="k">if</span> <span class="n">cn_type</span> <span class="o">==</span> <span class="s2">"String"</span><span class="p">:</span> - <span class="n">ncbi_dict</span><span class="p">[</span><span class="n">cn_name</span><span class="p">]</span> <span class="o">=</span> <span class="n">d</span> - <span class="k">elif</span> <span class="n">cn_type</span> <span class="o">==</span> <span class="s2">"Integer"</span><span class="p">:</span> - <span class="n">ncbi_dict</span><span class="p">[</span><span class="n">cn_name</span><span class="p">]</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">d</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span><span class="sa">f</span><span class="s2">"Unknown type </span><span class="si">{</span><span class="n">cn_type</span><span class="si">}</span><span class="s2"> for </span><span class="si">{</span><span class="n">ncbi_ac</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">ncbi_dict</span><span class="p">[</span><span class="n">cn_name</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span> - <span class="k">return</span> <span class="n">ncbi_dict</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [25]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># fetch some extra info from NCBI</span> -<span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">iterrows</span><span class="p">():</span> - <span class="n">ncbi_info</span> <span class="o">=</span> <span class="n">_get_ncbi_info</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">)</span> - <span class="c1"># Gi is some numerical sequence identifier used internally by NCBI</span> - <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">idx</span><span class="p">,</span> <span class="s2">"NCBI_Gi"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"Gi"</span><span class="p">])</span> - <span class="c1"># UpdateData is to be stored as the version date in ModelCIF</span> - <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">idx</span><span class="p">,</span> <span class="s2">"NCBI_UpdateDate"</span><span class="p">]</span> <span class="o">=</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"UpdateDate"</span><span class="p">]</span> - <span class="c1"># TaxId should be same as one from UP</span> - <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">idx</span><span class="p">,</span> <span class="s2">"NCBI_TaxId"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"TaxId"</span><span class="p">])</span> - <span class="c1"># Status expected to be live</span> - <span class="k">if</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"Status"</span><span class="p">]</span> <span class="o">!=</span> <span class="s2">"live"</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">,</span> <span class="s2">"Status"</span><span class="p">,</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"Status"</span><span class="p">])</span> - <span class="c1"># ReplacedBy expected to be empty</span> - <span class="k">if</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"ReplacedBy"</span><span class="p">]:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">,</span> <span class="s2">"ReplacedBy"</span><span class="p">,</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"ReplacedBy"</span><span class="p">])</span> - <span class="c1"># AccessionVersion expected to be NCBI_Accession</span> - <span class="k">if</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"AccessionVersion"</span><span class="p">]</span> <span class="o">!=</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">,</span> <span class="s2">"AccessionVersion"</span><span class="p">,</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"AccessionVersion"</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [26]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[26]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - <th>NCBI_Gi</th> - <th>NCBI_UpdateDate</th> - <th>NCBI_TaxId</th> - </tr> - <tr> - <th>Protein</th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - </tr> - </thead> - <tbody> - <tr> - <th>285L</th> - <td>285L.pdb</td> - <td>CAD2068351.1</td> - <td>A0A485PQD1</td> - <td>ASFV-G 285L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - <td>1886136876</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A104R</th> - <td>A104R.pdb</td> - <td>CAD2068395.1</td> - <td>A0A0A1E0L7</td> - <td>ASFV-G A104R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - <td>1886136920</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A118R</th> - <td>A118R.pdb</td> - <td>CAD2068397.1</td> - <td>A0A2X0RVA9</td> - <td>ASFV-G A118R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - <td>1886136922</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A137R</th> - <td>A137R.pdb</td> - <td>CAD2068404.1</td> - <td>A0A2X0THQ0</td> - <td>ASFV-G A137R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - <td>1886136929</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A151R</th> - <td>A151R.pdb</td> - <td>CAD2068398.1</td> - <td>A0A2X0TC55</td> - <td>ASFV-G A151R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - <td>1886136923</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>...</th> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - </tr> - <tr> - <th>QP509L</th> - <td>QP509L.pdb</td> - <td>CAD2068484.1</td> - <td>A0A2X0THX2</td> - <td>ASFV-G QP509L</td> - <td>This model was predicted using AlphaFold2</td> - <td>NaN</td> - <td>NaN</td> - <td>1886137009</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>R298L</th> - <td>R298L.pdb</td> - <td>CAD2068482.1</td> - <td>A0A2X0SE42</td> - <td>ASFV-G R298L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - <td>1886137007</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>S183L</th> - <td>S183L.pdb</td> - <td>CAD2068472.1</td> - <td>A0A2X0SE34</td> - <td>ASFV-G S183L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - <td>1886136997</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>S273R</th> - <td>S273R.pdb</td> - <td>CAD2068473.1</td> - <td>A0A2X0TKM5</td> - <td>ASFV-G S273R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - <td>1886136998</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>X69R</th> - <td>X69R.pdb</td> - <td>CAD2068372.1</td> - <td>A0A2X0TKC7</td> - <td>ASFV-G X69R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - <td>1886136897</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - </tbody> -</table> -<p>197 rows × 10 columns</p> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [27]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">)),</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_TaxId</span><span class="p">),</span> \ -<span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_Gi</span><span class="p">)),</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_UpdateDate</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[27]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>(193, {'10497'}, 193, {'2020/08/05'})</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [28]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">up_data</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[28]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>{'up_organism': 'African swine fever virus (ASFV)', - 'up_sequence': 'MMNIIKIRGKIFFAVLLEEDISLNTLSPNAVIRKI', - 'up_ac': 'A0A485PZB7', - 'up_id': 'A0A485PZB7_ASF', - 'up_last_mod': datetime.datetime(2019, 6, 5, 0, 0), - 'up_gn': 'hypthetical', - 'up_ncbi_taxid': '10497', - 'up_seqlen': 35, - 'up_crc64': '5CA27C9509292409', - 'up_isoform': None}</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div> -</body> - - - - - - - -</html> diff --git a/projects/USDA-ASFVG/tests/test.html b/projects/USDA-ASFVG/tests/test.html deleted file mode 100644 index 7f9fc8d8f0bd52a869f6842bfd0c40423a470c42..0000000000000000000000000000000000000000 --- a/projects/USDA-ASFVG/tests/test.html +++ /dev/null @@ -1,16587 +0,0 @@ -<!DOCTYPE html> -<html> -<head><meta charset="utf-8" /> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>test</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script> - - - - -<style type="text/css"> - pre { line-height: 125%; } -td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } -span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } -td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } -span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } -.highlight .hll { background-color: var(--jp-cell-editor-active-background) } -.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) } -.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */ -.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */ -.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */ -.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */ -.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */ -.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */ -.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */ -.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */ -.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */ -.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */ -.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */ -.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */ -.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */ -.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */ -.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */ -.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */ -.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */ -.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */ -.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */ -.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */ -.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */ -.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */ -.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */ -.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */ -.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */ -.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */ -.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */ -.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */ -.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */ -.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */ -.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */ -.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */ -.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */ -.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */ -.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */ -.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */ -.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */ -.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */ -.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */ -.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */ - </style> - - - -<style type="text/css"> -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* - * Mozilla scrollbar styling - */ - -/* use standard opaque scrollbars for most nodes */ -[data-jp-theme-scrollbars='true'] { - scrollbar-color: rgb(var(--jp-scrollbar-thumb-color)) - var(--jp-scrollbar-background-color); -} - -/* for code nodes, use a transparent style of scrollbar. These selectors - * will match lower in the tree, and so will override the above */ -[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar, -[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar { - scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; -} - -/* tiny scrollbar */ - -.jp-scrollbar-tiny { - scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; - scrollbar-width: thin; -} - -/* - * Webkit scrollbar styling - */ - -/* use standard opaque scrollbars for most nodes */ - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-corner { - background: var(--jp-scrollbar-background-color); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-thumb { - background: rgb(var(--jp-scrollbar-thumb-color)); - border: var(--jp-scrollbar-thumb-margin) solid transparent; - background-clip: content-box; - border-radius: var(--jp-scrollbar-thumb-radius); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:horizontal { - border-left: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); - border-right: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); -} - -[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:vertical { - border-top: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); - border-bottom: var(--jp-scrollbar-endpad) solid - var(--jp-scrollbar-background-color); -} - -/* for code nodes, use a transparent style of scrollbar */ - -[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar::-webkit-scrollbar, -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-corner, -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-corner { - background-color: transparent; -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-thumb, -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-thumb { - background: rgba(var(--jp-scrollbar-thumb-color), 0.5); - border: var(--jp-scrollbar-thumb-margin) solid transparent; - background-clip: content-box; - border-radius: var(--jp-scrollbar-thumb-radius); -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-hscrollbar::-webkit-scrollbar-track:horizontal { - border-left: var(--jp-scrollbar-endpad) solid transparent; - border-right: var(--jp-scrollbar-endpad) solid transparent; -} - -[data-jp-theme-scrollbars='true'] - .CodeMirror-vscrollbar::-webkit-scrollbar-track:vertical { - border-top: var(--jp-scrollbar-endpad) solid transparent; - border-bottom: var(--jp-scrollbar-endpad) solid transparent; -} - -/* tiny scrollbar */ - -.jp-scrollbar-tiny::-webkit-scrollbar, -.jp-scrollbar-tiny::-webkit-scrollbar-corner { - background-color: transparent; - height: 4px; - width: 4px; -} - -.jp-scrollbar-tiny::-webkit-scrollbar-thumb { - background: rgba(var(--jp-scrollbar-thumb-color), 0.5); -} - -.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal { - border-left: 0px solid transparent; - border-right: 0px solid transparent; -} - -.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical { - border-top: 0px solid transparent; - border-bottom: 0px solid transparent; -} - -/* - * Phosphor - */ - -.lm-ScrollBar[data-orientation='horizontal'] { - min-height: 16px; - max-height: 16px; - min-width: 45px; - border-top: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='vertical'] { - min-width: 16px; - max-width: 16px; - min-height: 45px; - border-left: 1px solid #a0a0a0; -} - -.lm-ScrollBar-button { - background-color: #f0f0f0; - background-position: center center; - min-height: 15px; - max-height: 15px; - min-width: 15px; - max-width: 15px; -} - -.lm-ScrollBar-button:hover { - background-color: #dadada; -} - -.lm-ScrollBar-button.lm-mod-active { - background-color: #cdcdcd; -} - -.lm-ScrollBar-track { - background: #f0f0f0; -} - -.lm-ScrollBar-thumb { - background: #cdcdcd; -} - -.lm-ScrollBar-thumb:hover { - background: #bababa; -} - -.lm-ScrollBar-thumb.lm-mod-active { - background: #a0a0a0; -} - -.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb { - height: 100%; - min-width: 15px; - border-left: 1px solid #a0a0a0; - border-right: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb { - width: 100%; - min-height: 15px; - border-top: 1px solid #a0a0a0; - border-bottom: 1px solid #a0a0a0; -} - -.lm-ScrollBar[data-orientation='horizontal'] - .lm-ScrollBar-button[data-action='decrement'] { - background-image: var(--jp-icon-caret-left); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='horizontal'] - .lm-ScrollBar-button[data-action='increment'] { - background-image: var(--jp-icon-caret-right); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='vertical'] - .lm-ScrollBar-button[data-action='decrement'] { - background-image: var(--jp-icon-caret-up); - background-size: 17px; -} - -.lm-ScrollBar[data-orientation='vertical'] - .lm-ScrollBar-button[data-action='increment'] { - background-image: var(--jp-icon-caret-down); - background-size: 17px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-Widget, /* </DEPRECATED> */ -.lm-Widget { - box-sizing: border-box; - position: relative; - overflow: hidden; - cursor: default; -} - - -/* <DEPRECATED> */ .p-Widget.p-mod-hidden, /* </DEPRECATED> */ -.lm-Widget.lm-mod-hidden { - display: none !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-CommandPalette, /* </DEPRECATED> */ -.lm-CommandPalette { - display: flex; - flex-direction: column; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-CommandPalette-search, /* </DEPRECATED> */ -.lm-CommandPalette-search { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-content, /* </DEPRECATED> */ -.lm-CommandPalette-content { - flex: 1 1 auto; - margin: 0; - padding: 0; - min-height: 0; - overflow: auto; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p-CommandPalette-header, /* </DEPRECATED> */ -.lm-CommandPalette-header { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - - -/* <DEPRECATED> */ .p-CommandPalette-item, /* </DEPRECATED> */ -.lm-CommandPalette-item { - display: flex; - flex-direction: row; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemIcon, /* </DEPRECATED> */ -.lm-CommandPalette-itemIcon { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemContent, /* </DEPRECATED> */ -.lm-CommandPalette-itemContent { - flex: 1 1 auto; - overflow: hidden; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemShortcut, /* </DEPRECATED> */ -.lm-CommandPalette-itemShortcut { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-CommandPalette-itemLabel, /* </DEPRECATED> */ -.lm-CommandPalette-itemLabel { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.lm-close-icon { - border:1px solid transparent; - background-color: transparent; - position: absolute; - z-index:1; - right:3%; - top: 0; - bottom: 0; - margin: auto; - padding: 7px 0; - display: none; - vertical-align: middle; - outline: 0; - cursor: pointer; -} -.lm-close-icon:after { - content: "X"; - display: block; - width: 15px; - height: 15px; - text-align: center; - color:#000; - font-weight: normal; - font-size: 12px; - cursor: pointer; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-DockPanel, /* </DEPRECATED> */ -.lm-DockPanel { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-DockPanel-widget, /* </DEPRECATED> */ -.lm-DockPanel-widget { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-DockPanel-tabBar, /* </DEPRECATED> */ -.lm-DockPanel-tabBar { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle, /* </DEPRECATED> */ -.lm-DockPanel-handle { - z-index: 2; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle.p-mod-hidden, /* </DEPRECATED> */ -.lm-DockPanel-handle.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-DockPanel-handle:after, /* </DEPRECATED> */ -.lm-DockPanel-handle:after { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='horizontal'], -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='horizontal'] { - cursor: ew-resize; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='vertical'], -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='vertical'] { - cursor: ns-resize; -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='horizontal']:after, -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='horizontal']:after { - left: 50%; - min-width: 8px; - transform: translateX(-50%); -} - - -/* <DEPRECATED> */ -.p-DockPanel-handle[data-orientation='vertical']:after, -/* </DEPRECATED> */ -.lm-DockPanel-handle[data-orientation='vertical']:after { - top: 50%; - min-height: 8px; - transform: translateY(-50%); -} - - -/* <DEPRECATED> */ .p-DockPanel-overlay, /* </DEPRECATED> */ -.lm-DockPanel-overlay { - z-index: 3; - box-sizing: border-box; - pointer-events: none; -} - - -/* <DEPRECATED> */ .p-DockPanel-overlay.p-mod-hidden, /* </DEPRECATED> */ -.lm-DockPanel-overlay.lm-mod-hidden { - display: none !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-Menu, /* </DEPRECATED> */ -.lm-Menu { - z-index: 10000; - position: absolute; - white-space: nowrap; - overflow-x: hidden; - overflow-y: auto; - outline: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-Menu-content, /* </DEPRECATED> */ -.lm-Menu-content { - margin: 0; - padding: 0; - display: table; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p-Menu-item, /* </DEPRECATED> */ -.lm-Menu-item { - display: table-row; -} - - -/* <DEPRECATED> */ -.p-Menu-item.p-mod-hidden, -.p-Menu-item.p-mod-collapsed, -/* </DEPRECATED> */ -.lm-Menu-item.lm-mod-hidden, -.lm-Menu-item.lm-mod-collapsed { - display: none !important; -} - - -/* <DEPRECATED> */ -.p-Menu-itemIcon, -.p-Menu-itemSubmenuIcon, -/* </DEPRECATED> */ -.lm-Menu-itemIcon, -.lm-Menu-itemSubmenuIcon { - display: table-cell; - text-align: center; -} - - -/* <DEPRECATED> */ .p-Menu-itemLabel, /* </DEPRECATED> */ -.lm-Menu-itemLabel { - display: table-cell; - text-align: left; -} - - -/* <DEPRECATED> */ .p-Menu-itemShortcut, /* </DEPRECATED> */ -.lm-Menu-itemShortcut { - display: table-cell; - text-align: right; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-MenuBar, /* </DEPRECATED> */ -.lm-MenuBar { - outline: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-MenuBar-content, /* </DEPRECATED> */ -.lm-MenuBar-content { - margin: 0; - padding: 0; - display: flex; - flex-direction: row; - list-style-type: none; -} - - -/* <DEPRECATED> */ .p--MenuBar-item, /* </DEPRECATED> */ -.lm-MenuBar-item { - box-sizing: border-box; -} - - -/* <DEPRECATED> */ -.p-MenuBar-itemIcon, -.p-MenuBar-itemLabel, -/* </DEPRECATED> */ -.lm-MenuBar-itemIcon, -.lm-MenuBar-itemLabel { - display: inline-block; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-ScrollBar, /* </DEPRECATED> */ -.lm-ScrollBar { - display: flex; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ -.p-ScrollBar[data-orientation='horizontal'], -/* </DEPRECATED> */ -.lm-ScrollBar[data-orientation='horizontal'] { - flex-direction: row; -} - - -/* <DEPRECATED> */ -.p-ScrollBar[data-orientation='vertical'], -/* </DEPRECATED> */ -.lm-ScrollBar[data-orientation='vertical'] { - flex-direction: column; -} - - -/* <DEPRECATED> */ .p-ScrollBar-button, /* </DEPRECATED> */ -.lm-ScrollBar-button { - box-sizing: border-box; - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-ScrollBar-track, /* </DEPRECATED> */ -.lm-ScrollBar-track { - box-sizing: border-box; - position: relative; - overflow: hidden; - flex: 1 1 auto; -} - - -/* <DEPRECATED> */ .p-ScrollBar-thumb, /* </DEPRECATED> */ -.lm-ScrollBar-thumb { - box-sizing: border-box; - position: absolute; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-SplitPanel-child, /* </DEPRECATED> */ -.lm-SplitPanel-child { - z-index: 0; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle, /* </DEPRECATED> */ -.lm-SplitPanel-handle { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle.p-mod-hidden, /* </DEPRECATED> */ -.lm-SplitPanel-handle.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-SplitPanel-handle:after, /* </DEPRECATED> */ -.lm-SplitPanel-handle:after { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle { - cursor: ew-resize; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle { - cursor: ns-resize; -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle:after, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after { - left: 50%; - min-width: 8px; - transform: translateX(-50%); -} - - -/* <DEPRECATED> */ -.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle:after, -/* </DEPRECATED> */ -.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after { - top: 50%; - min-height: 8px; - transform: translateY(-50%); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-TabBar, /* </DEPRECATED> */ -.lm-TabBar { - display: flex; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - - -/* <DEPRECATED> */ .p-TabBar[data-orientation='horizontal'], /* </DEPRECATED> */ -.lm-TabBar[data-orientation='horizontal'] { - flex-direction: row; - align-items: flex-end; -} - - -/* <DEPRECATED> */ .p-TabBar[data-orientation='vertical'], /* </DEPRECATED> */ -.lm-TabBar[data-orientation='vertical'] { - flex-direction: column; - align-items: flex-end; -} - - -/* <DEPRECATED> */ .p-TabBar-content, /* </DEPRECATED> */ -.lm-TabBar-content { - margin: 0; - padding: 0; - display: flex; - flex: 1 1 auto; - list-style-type: none; -} - - -/* <DEPRECATED> */ -.p-TabBar[data-orientation='horizontal'] > .p-TabBar-content, -/* </DEPRECATED> */ -.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content { - flex-direction: row; -} - - -/* <DEPRECATED> */ -.p-TabBar[data-orientation='vertical'] > .p-TabBar-content, -/* </DEPRECATED> */ -.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content { - flex-direction: column; -} - - -/* <DEPRECATED> */ .p-TabBar-tab, /* </DEPRECATED> */ -.lm-TabBar-tab { - display: flex; - flex-direction: row; - box-sizing: border-box; - overflow: hidden; -} - - -/* <DEPRECATED> */ -.p-TabBar-tabIcon, -.p-TabBar-tabCloseIcon, -/* </DEPRECATED> */ -.lm-TabBar-tabIcon, -.lm-TabBar-tabCloseIcon { - flex: 0 0 auto; -} - - -/* <DEPRECATED> */ .p-TabBar-tabLabel, /* </DEPRECATED> */ -.lm-TabBar-tabLabel { - flex: 1 1 auto; - overflow: hidden; - white-space: nowrap; -} - - -.lm-TabBar-tabInput { - user-select: all; - width: 100%; - box-sizing : border-box; -} - - -/* <DEPRECATED> */ .p-TabBar-tab.p-mod-hidden, /* </DEPRECATED> */ -.lm-TabBar-tab.lm-mod-hidden { - display: none !important; -} - - -.lm-TabBar-addButton.lm-mod-hidden { - display: none !important; -} - - -/* <DEPRECATED> */ .p-TabBar.p-mod-dragging .p-TabBar-tab, /* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging .lm-TabBar-tab { - position: relative; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab { - left: 0; - transition: left 150ms ease; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab { - top: 0; - transition: top 150ms ease; -} - - -/* <DEPRECATED> */ -.p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging, -/* </DEPRECATED> */ -.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging { - transition: none; -} - -.lm-TabBar-tabLabel .lm-TabBar-tabInput { - user-select: all; - width: 100%; - box-sizing : border-box; - background: inherit; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ .p-TabPanel-tabBar, /* </DEPRECATED> */ -.lm-TabPanel-tabBar { - z-index: 1; -} - - -/* <DEPRECATED> */ .p-TabPanel-stackedPanel, /* </DEPRECATED> */ -.lm-TabPanel-stackedPanel { - z-index: 0; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - -@charset "UTF-8"; -html{ - -webkit-box-sizing:border-box; - box-sizing:border-box; } - -*, -*::before, -*::after{ - -webkit-box-sizing:inherit; - box-sizing:inherit; } - -body{ - font-size:14px; - font-weight:400; - letter-spacing:0; - line-height:1.28581; - text-transform:none; - color:#182026; - font-family:-apple-system, "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", "Icons16", sans-serif; } - -p{ - margin-bottom:10px; - margin-top:0; } - -small{ - font-size:12px; } - -strong{ - font-weight:600; } - -::-moz-selection{ - background:rgba(125, 188, 255, 0.6); } - -::selection{ - background:rgba(125, 188, 255, 0.6); } -.bp3-heading{ - color:#182026; - font-weight:600; - margin:0 0 10px; - padding:0; } - .bp3-dark .bp3-heading{ - color:#f5f8fa; } - -h1.bp3-heading, .bp3-running-text h1{ - font-size:36px; - line-height:40px; } - -h2.bp3-heading, .bp3-running-text h2{ - font-size:28px; - line-height:32px; } - -h3.bp3-heading, .bp3-running-text h3{ - font-size:22px; - line-height:25px; } - -h4.bp3-heading, .bp3-running-text h4{ - font-size:18px; - line-height:21px; } - -h5.bp3-heading, .bp3-running-text h5{ - font-size:16px; - line-height:19px; } - -h6.bp3-heading, .bp3-running-text h6{ - font-size:14px; - line-height:16px; } -.bp3-ui-text{ - font-size:14px; - font-weight:400; - letter-spacing:0; - line-height:1.28581; - text-transform:none; } - -.bp3-monospace-text{ - font-family:monospace; - text-transform:none; } - -.bp3-text-muted{ - color:#5c7080; } - .bp3-dark .bp3-text-muted{ - color:#a7b6c2; } - -.bp3-text-disabled{ - color:rgba(92, 112, 128, 0.6); } - .bp3-dark .bp3-text-disabled{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-text-overflow-ellipsis{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; } -.bp3-running-text{ - font-size:14px; - line-height:1.5; } - .bp3-running-text h1{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h1{ - color:#f5f8fa; } - .bp3-running-text h2{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h2{ - color:#f5f8fa; } - .bp3-running-text h3{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h3{ - color:#f5f8fa; } - .bp3-running-text h4{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h4{ - color:#f5f8fa; } - .bp3-running-text h5{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h5{ - color:#f5f8fa; } - .bp3-running-text h6{ - color:#182026; - font-weight:600; - margin-bottom:20px; - margin-top:40px; } - .bp3-dark .bp3-running-text h6{ - color:#f5f8fa; } - .bp3-running-text hr{ - border:none; - border-bottom:1px solid rgba(16, 22, 26, 0.15); - margin:20px 0; } - .bp3-dark .bp3-running-text hr{ - border-color:rgba(255, 255, 255, 0.15); } - .bp3-running-text p{ - margin:0 0 10px; - padding:0; } - -.bp3-text-large{ - font-size:16px; } - -.bp3-text-small{ - font-size:12px; } -a{ - color:#106ba3; - text-decoration:none; } - a:hover{ - color:#106ba3; - cursor:pointer; - text-decoration:underline; } - a .bp3-icon, a .bp3-icon-standard, a .bp3-icon-large{ - color:inherit; } - a code, - .bp3-dark a code{ - color:inherit; } - .bp3-dark a, - .bp3-dark a:hover{ - color:#48aff0; } - .bp3-dark a .bp3-icon, .bp3-dark a .bp3-icon-standard, .bp3-dark a .bp3-icon-large, - .bp3-dark a:hover .bp3-icon, - .bp3-dark a:hover .bp3-icon-standard, - .bp3-dark a:hover .bp3-icon-large{ - color:inherit; } -.bp3-running-text code, .bp3-code{ - font-family:monospace; - text-transform:none; - background:rgba(255, 255, 255, 0.7); - border-radius:3px; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2); - color:#5c7080; - font-size:smaller; - padding:2px 5px; } - .bp3-dark .bp3-running-text code, .bp3-running-text .bp3-dark code, .bp3-dark .bp3-code{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - color:#a7b6c2; } - .bp3-running-text a > code, a > .bp3-code{ - color:#137cbd; } - .bp3-dark .bp3-running-text a > code, .bp3-running-text .bp3-dark a > code, .bp3-dark a > .bp3-code{ - color:inherit; } - -.bp3-running-text pre, .bp3-code-block{ - font-family:monospace; - text-transform:none; - background:rgba(255, 255, 255, 0.7); - border-radius:3px; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - color:#182026; - display:block; - font-size:13px; - line-height:1.4; - margin:10px 0; - padding:13px 15px 12px; - word-break:break-all; - word-wrap:break-word; } - .bp3-dark .bp3-running-text pre, .bp3-running-text .bp3-dark pre, .bp3-dark .bp3-code-block{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-running-text pre > code, .bp3-code-block > code{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; - font-size:inherit; - padding:0; } - -.bp3-running-text kbd, .bp3-key{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - color:#5c7080; - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - font-family:inherit; - font-size:12px; - height:24px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - line-height:24px; - min-width:24px; - padding:3px 6px; - vertical-align:middle; } - .bp3-running-text kbd .bp3-icon, .bp3-key .bp3-icon, .bp3-running-text kbd .bp3-icon-standard, .bp3-key .bp3-icon-standard, .bp3-running-text kbd .bp3-icon-large, .bp3-key .bp3-icon-large{ - margin-right:5px; } - .bp3-dark .bp3-running-text kbd, .bp3-running-text .bp3-dark kbd, .bp3-dark .bp3-key{ - background:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - color:#a7b6c2; } -.bp3-running-text blockquote, .bp3-blockquote{ - border-left:solid 4px rgba(167, 182, 194, 0.5); - margin:0 0 10px; - padding:0 20px; } - .bp3-dark .bp3-running-text blockquote, .bp3-running-text .bp3-dark blockquote, .bp3-dark .bp3-blockquote{ - border-color:rgba(115, 134, 148, 0.5); } -.bp3-running-text ul, -.bp3-running-text ol, .bp3-list{ - margin:10px 0; - padding-left:30px; } - .bp3-running-text ul li:not(:last-child), .bp3-running-text ol li:not(:last-child), .bp3-list li:not(:last-child){ - margin-bottom:5px; } - .bp3-running-text ul ol, .bp3-running-text ol ol, .bp3-list ol, - .bp3-running-text ul ul, - .bp3-running-text ol ul, - .bp3-list ul{ - margin-top:5px; } - -.bp3-list-unstyled{ - list-style:none; - margin:0; - padding:0; } - .bp3-list-unstyled li{ - padding:0; } -.bp3-rtl{ - text-align:right; } - -.bp3-dark{ - color:#f5f8fa; } - -:focus{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:2px; - -moz-outline-radius:6px; } - -.bp3-focus-disabled :focus{ - outline:none !important; } - .bp3-focus-disabled :focus ~ .bp3-control-indicator{ - outline:none !important; } - -.bp3-alert{ - max-width:400px; - padding:20px; } - -.bp3-alert-body{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-alert-body .bp3-icon{ - font-size:40px; - margin-right:20px; - margin-top:0; } - -.bp3-alert-contents{ - word-break:break-word; } - -.bp3-alert-footer{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:reverse; - -ms-flex-direction:row-reverse; - flex-direction:row-reverse; - margin-top:10px; } - .bp3-alert-footer .bp3-button{ - margin-left:10px; } -.bp3-breadcrumbs{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - cursor:default; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-wrap:wrap; - flex-wrap:wrap; - height:30px; - list-style:none; - margin:0; - padding:0; } - .bp3-breadcrumbs > li{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-breadcrumbs > li::after{ - background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.71 7.29l-4-4a1.003 1.003 0 00-1.42 1.42L8.59 8 5.3 11.29c-.19.18-.3.43-.3.71a1.003 1.003 0 001.71.71l4-4c.18-.18.29-.43.29-.71 0-.28-.11-.53-.29-.71z' fill='%235C7080'/%3e%3c/svg%3e"); - content:""; - display:block; - height:16px; - margin:0 5px; - width:16px; } - .bp3-breadcrumbs > li:last-of-type::after{ - display:none; } - -.bp3-breadcrumb, -.bp3-breadcrumb-current, -.bp3-breadcrumbs-collapsed{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - font-size:16px; } - -.bp3-breadcrumb, -.bp3-breadcrumbs-collapsed{ - color:#5c7080; } - -.bp3-breadcrumb:hover{ - text-decoration:none; } - -.bp3-breadcrumb.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-breadcrumb .bp3-icon{ - margin-right:5px; } - -.bp3-breadcrumb-current{ - color:inherit; - font-weight:600; } - .bp3-breadcrumb-current .bp3-input{ - font-size:inherit; - font-weight:inherit; - vertical-align:baseline; } - -.bp3-breadcrumbs-collapsed{ - background:#ced9e0; - border:none; - border-radius:3px; - cursor:pointer; - margin-right:2px; - padding:1px 5px; - vertical-align:text-bottom; } - .bp3-breadcrumbs-collapsed::before{ - background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cg fill='%235C7080'%3e%3ccircle cx='2' cy='8.03' r='2'/%3e%3ccircle cx='14' cy='8.03' r='2'/%3e%3ccircle cx='8' cy='8.03' r='2'/%3e%3c/g%3e%3c/svg%3e") center no-repeat; - content:""; - display:block; - height:16px; - width:16px; } - .bp3-breadcrumbs-collapsed:hover{ - background:#bfccd6; - color:#182026; - text-decoration:none; } - -.bp3-dark .bp3-breadcrumb, -.bp3-dark .bp3-breadcrumbs-collapsed{ - color:#a7b6c2; } - -.bp3-dark .bp3-breadcrumbs > li::after{ - color:#a7b6c2; } - -.bp3-dark .bp3-breadcrumb.bp3-disabled{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-dark .bp3-breadcrumb-current{ - color:#f5f8fa; } - -.bp3-dark .bp3-breadcrumbs-collapsed{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-breadcrumbs-collapsed:hover{ - background:rgba(16, 22, 26, 0.6); - color:#f5f8fa; } -.bp3-button{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border:none; - border-radius:3px; - cursor:pointer; - font-size:14px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - padding:5px 10px; - text-align:left; - vertical-align:middle; - min-height:30px; - min-width:30px; } - .bp3-button > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-button > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-button::before, - .bp3-button > *{ - margin-right:7px; } - .bp3-button:empty::before, - .bp3-button > :last-child{ - margin-right:0; } - .bp3-button:empty{ - padding:0 !important; } - .bp3-button:disabled, .bp3-button.bp3-disabled{ - cursor:not-allowed; } - .bp3-button.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-button.bp3-align-right, - .bp3-align-right .bp3-button{ - text-align:right; } - .bp3-button.bp3-align-left, - .bp3-align-left .bp3-button{ - text-align:left; } - .bp3-button:not([class*="bp3-intent-"]){ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; } - .bp3-button:not([class*="bp3-intent-"]):hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-button:not([class*="bp3-intent-"]):active, .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active:hover, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-button.bp3-intent-primary{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-primary:hover, .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-primary:hover{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{ - background-color:#0e5a8a; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-primary:disabled, .bp3-button.bp3-intent-primary.bp3-disabled{ - background-color:rgba(19, 124, 189, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-success{ - background-color:#0f9960; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-success:hover, .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-success:hover{ - background-color:#0d8050; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{ - background-color:#0a6640; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-success:disabled, .bp3-button.bp3-intent-success.bp3-disabled{ - background-color:rgba(15, 153, 96, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-warning{ - background-color:#d9822b; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-warning:hover, .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-warning:hover{ - background-color:#bf7326; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{ - background-color:#a66321; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-warning:disabled, .bp3-button.bp3-intent-warning.bp3-disabled{ - background-color:rgba(217, 130, 43, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button.bp3-intent-danger{ - background-color:#db3737; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-button.bp3-intent-danger:hover, .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{ - color:#ffffff; } - .bp3-button.bp3-intent-danger:hover{ - background-color:#c23030; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{ - background-color:#a82a2a; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-button.bp3-intent-danger:disabled, .bp3-button.bp3-intent-danger.bp3-disabled{ - background-color:rgba(219, 55, 55, 0.5); - background-image:none; - border-color:transparent; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.6); } - .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{ - stroke:#ffffff; } - .bp3-button.bp3-large, - .bp3-large .bp3-button{ - min-height:40px; - min-width:40px; - font-size:16px; - padding:5px 15px; } - .bp3-button.bp3-large::before, - .bp3-button.bp3-large > *, - .bp3-large .bp3-button::before, - .bp3-large .bp3-button > *{ - margin-right:10px; } - .bp3-button.bp3-large:empty::before, - .bp3-button.bp3-large > :last-child, - .bp3-large .bp3-button:empty::before, - .bp3-large .bp3-button > :last-child{ - margin-right:0; } - .bp3-button.bp3-small, - .bp3-small .bp3-button{ - min-height:24px; - min-width:24px; - padding:0 7px; } - .bp3-button.bp3-loading{ - position:relative; } - .bp3-button.bp3-loading[class*="bp3-icon-"]::before{ - visibility:hidden; } - .bp3-button.bp3-loading .bp3-button-spinner{ - margin:0; - position:absolute; } - .bp3-button.bp3-loading > :not(.bp3-button-spinner){ - visibility:hidden; } - .bp3-button[class*="bp3-icon-"]::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - color:#5c7080; } - .bp3-button .bp3-icon, .bp3-button .bp3-icon-standard, .bp3-button .bp3-icon-large{ - color:#5c7080; } - .bp3-button .bp3-icon.bp3-align-right, .bp3-button .bp3-icon-standard.bp3-align-right, .bp3-button .bp3-icon-large.bp3-align-right{ - margin-left:7px; } - .bp3-button .bp3-icon:first-child:last-child, - .bp3-button .bp3-spinner + .bp3-icon:last-child{ - margin:0 -7px; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]){ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover, .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"])[class*="bp3-icon-"]::before{ - color:#a7b6c2; } - .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-large{ - color:#a7b6c2; } - .bp3-dark .bp3-button[class*="bp3-intent-"]{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:active, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-button[class*="bp3-intent-"]:disabled, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-disabled{ - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(255, 255, 255, 0.3); } - .bp3-dark .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{ - stroke:#8a9ba8; } - .bp3-button:disabled::before, - .bp3-button:disabled .bp3-icon, .bp3-button:disabled .bp3-icon-standard, .bp3-button:disabled .bp3-icon-large, .bp3-button.bp3-disabled::before, - .bp3-button.bp3-disabled .bp3-icon, .bp3-button.bp3-disabled .bp3-icon-standard, .bp3-button.bp3-disabled .bp3-icon-large, .bp3-button[class*="bp3-intent-"]::before, - .bp3-button[class*="bp3-intent-"] .bp3-icon, .bp3-button[class*="bp3-intent-"] .bp3-icon-standard, .bp3-button[class*="bp3-intent-"] .bp3-icon-large{ - color:inherit !important; } - .bp3-button.bp3-minimal{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-button.bp3-minimal:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button.bp3-minimal:active, .bp3-button.bp3-minimal.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button.bp3-minimal:disabled, .bp3-button.bp3-minimal:disabled:hover, .bp3-button.bp3-minimal.bp3-disabled, .bp3-button.bp3-minimal.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button.bp3-minimal{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button.bp3-minimal:hover, .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button.bp3-minimal:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button.bp3-minimal:disabled, .bp3-dark .bp3-button.bp3-minimal:disabled:hover, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-primary{ - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:hover, .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-success{ - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:hover, .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-warning{ - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:hover, .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-danger{ - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:hover, .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-minimal.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - border:1px solid rgba(24, 32, 38, 0.2); - -webkit-box-sizing:border-box; - box-sizing:border-box; } - .bp3-button.bp3-outlined:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button.bp3-outlined:active, .bp3-button.bp3-outlined.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button.bp3-outlined{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button.bp3-outlined:hover, .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button.bp3-outlined:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-primary{ - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:hover, .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-success{ - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:hover, .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-warning{ - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:hover, .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-danger{ - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:hover, .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled:hover{ - border-color:rgba(92, 112, 128, 0.1); } - .bp3-dark .bp3-button.bp3-outlined{ - border-color:rgba(255, 255, 255, 0.4); } - .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{ - border-color:rgba(255, 255, 255, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-primary{ - border-color:rgba(16, 107, 163, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - border-color:rgba(16, 107, 163, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{ - border-color:rgba(72, 175, 240, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{ - border-color:rgba(72, 175, 240, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-success{ - border-color:rgba(13, 128, 80, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - border-color:rgba(13, 128, 80, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{ - border-color:rgba(61, 204, 145, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{ - border-color:rgba(61, 204, 145, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-warning{ - border-color:rgba(191, 115, 38, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - border-color:rgba(191, 115, 38, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{ - border-color:rgba(255, 179, 102, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{ - border-color:rgba(255, 179, 102, 0.2); } - .bp3-button.bp3-outlined.bp3-intent-danger{ - border-color:rgba(194, 48, 48, 0.6); } - .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - border-color:rgba(194, 48, 48, 0.2); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{ - border-color:rgba(255, 115, 115, 0.6); } - .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{ - border-color:rgba(255, 115, 115, 0.2); } - -a.bp3-button{ - text-align:center; - text-decoration:none; - -webkit-transition:none; - transition:none; } - a.bp3-button, a.bp3-button:hover, a.bp3-button:active{ - color:#182026; } - a.bp3-button.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); } - -.bp3-button-text{ - -webkit-box-flex:0; - -ms-flex:0 1 auto; - flex:0 1 auto; } - -.bp3-button.bp3-align-left .bp3-button-text, .bp3-button.bp3-align-right .bp3-button-text, -.bp3-button-group.bp3-align-left .bp3-button-text, -.bp3-button-group.bp3-align-right .bp3-button-text{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } -.bp3-button-group{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; } - .bp3-button-group .bp3-button{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - position:relative; - z-index:4; } - .bp3-button-group .bp3-button:focus{ - z-index:5; } - .bp3-button-group .bp3-button:hover{ - z-index:6; } - .bp3-button-group .bp3-button:active, .bp3-button-group .bp3-button.bp3-active{ - z-index:7; } - .bp3-button-group .bp3-button:disabled, .bp3-button-group .bp3-button.bp3-disabled{ - z-index:3; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]{ - z-index:9; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:focus{ - z-index:10; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:hover{ - z-index:11; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:active, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-active{ - z-index:12; } - .bp3-button-group .bp3-button[class*="bp3-intent-"]:disabled, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-disabled{ - z-index:8; } - .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:first-child) .bp3-button, - .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:first-child){ - border-bottom-left-radius:0; - border-top-left-radius:0; } - .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){ - border-bottom-right-radius:0; - border-top-right-radius:0; - margin-right:-1px; } - .bp3-button-group.bp3-minimal .bp3-button{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-button-group.bp3-minimal .bp3-button:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{ - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{ - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{ - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{ - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-button-group .bp3-popover-wrapper, - .bp3-button-group .bp3-popover-target{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-button-group.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-button-group .bp3-button.bp3-fill, - .bp3-button-group.bp3-fill .bp3-button:not(.bp3-fixed){ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-button-group.bp3-vertical{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - vertical-align:top; } - .bp3-button-group.bp3-vertical.bp3-fill{ - height:100%; - width:unset; } - .bp3-button-group.bp3-vertical .bp3-button{ - margin-right:0 !important; - width:100%; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:first-child .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:first-child{ - border-radius:3px 3px 0 0; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:last-child .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:last-child{ - border-radius:0 0 3px 3px; } - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:not(:last-child){ - margin-bottom:-1px; } - .bp3-button-group.bp3-align-left .bp3-button{ - text-align:left; } - .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){ - margin-right:1px; } - .bp3-dark .bp3-button-group.bp3-vertical > .bp3-popover-wrapper:not(:last-child) .bp3-button, - .bp3-dark .bp3-button-group.bp3-vertical > .bp3-button:not(:last-child){ - margin-bottom:1px; } -.bp3-callout{ - font-size:14px; - line-height:1.5; - background-color:rgba(138, 155, 168, 0.15); - border-radius:3px; - padding:10px 12px 9px; - position:relative; - width:100%; } - .bp3-callout[class*="bp3-icon-"]{ - padding-left:40px; } - .bp3-callout[class*="bp3-icon-"]::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - color:#5c7080; - left:10px; - position:absolute; - top:10px; } - .bp3-callout.bp3-callout-icon{ - padding-left:40px; } - .bp3-callout.bp3-callout-icon > .bp3-icon:first-child{ - color:#5c7080; - left:10px; - position:absolute; - top:10px; } - .bp3-callout .bp3-heading{ - line-height:20px; - margin-bottom:5px; - margin-top:0; } - .bp3-callout .bp3-heading:last-child{ - margin-bottom:0; } - .bp3-dark .bp3-callout{ - background-color:rgba(138, 155, 168, 0.2); } - .bp3-dark .bp3-callout[class*="bp3-icon-"]::before{ - color:#a7b6c2; } - .bp3-callout.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.15); } - .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-primary > .bp3-icon:first-child, - .bp3-callout.bp3-intent-primary .bp3-heading{ - color:#106ba3; } - .bp3-dark .bp3-callout.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-primary > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-primary .bp3-heading{ - color:#48aff0; } - .bp3-callout.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.15); } - .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-success > .bp3-icon:first-child, - .bp3-callout.bp3-intent-success .bp3-heading{ - color:#0d8050; } - .bp3-dark .bp3-callout.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-success > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-success .bp3-heading{ - color:#3dcc91; } - .bp3-callout.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.15); } - .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-warning > .bp3-icon:first-child, - .bp3-callout.bp3-intent-warning .bp3-heading{ - color:#bf7326; } - .bp3-dark .bp3-callout.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-warning > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-warning .bp3-heading{ - color:#ffb366; } - .bp3-callout.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.15); } - .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before, - .bp3-callout.bp3-intent-danger > .bp3-icon:first-child, - .bp3-callout.bp3-intent-danger .bp3-heading{ - color:#c23030; } - .bp3-dark .bp3-callout.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.25); } - .bp3-dark .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before, - .bp3-dark .bp3-callout.bp3-intent-danger > .bp3-icon:first-child, - .bp3-dark .bp3-callout.bp3-intent-danger .bp3-heading{ - color:#ff7373; } - .bp3-running-text .bp3-callout{ - margin:20px 0; } -.bp3-card{ - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - padding:20px; - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-card.bp3-dark, - .bp3-dark .bp3-card{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - -.bp3-elevation-0{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - .bp3-elevation-0.bp3-dark, - .bp3-dark .bp3-elevation-0{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); } - -.bp3-elevation-1{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-elevation-1.bp3-dark, - .bp3-dark .bp3-elevation-1{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-2{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); } - .bp3-elevation-2.bp3-dark, - .bp3-dark .bp3-elevation-2{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-3{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); } - .bp3-elevation-3.bp3-dark, - .bp3-dark .bp3-elevation-3{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - -.bp3-elevation-4{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); } - .bp3-elevation-4.bp3-dark, - .bp3-dark .bp3-elevation-4{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); } - -.bp3-card.bp3-interactive:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - cursor:pointer; } - .bp3-card.bp3-interactive:hover.bp3-dark, - .bp3-dark .bp3-card.bp3-interactive:hover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - -.bp3-card.bp3-interactive:active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - opacity:0.9; - -webkit-transition-duration:0; - transition-duration:0; } - .bp3-card.bp3-interactive:active.bp3-dark, - .bp3-dark .bp3-card.bp3-interactive:active{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-collapse{ - height:0; - overflow-y:hidden; - -webkit-transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-collapse .bp3-collapse-body{ - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-collapse .bp3-collapse-body[aria-hidden="true"]{ - display:none; } - -.bp3-context-menu .bp3-popover-target{ - display:block; } - -.bp3-context-menu-popover-target{ - position:fixed; } - -.bp3-divider{ - border-bottom:1px solid rgba(16, 22, 26, 0.15); - border-right:1px solid rgba(16, 22, 26, 0.15); - margin:5px; } - .bp3-dark .bp3-divider{ - border-color:rgba(16, 22, 26, 0.4); } -.bp3-dialog-container{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - min-height:100%; - pointer-events:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - width:100%; } - .bp3-dialog-container.bp3-overlay-enter > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear > .bp3-dialog{ - opacity:0; - -webkit-transform:scale(0.5); - transform:scale(0.5); } - .bp3-dialog-container.bp3-overlay-enter-active > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear-active > .bp3-dialog{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:opacity, transform; - transition-property:opacity, transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-dialog-container.bp3-overlay-exit > .bp3-dialog{ - opacity:1; - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-dialog-container.bp3-overlay-exit-active > .bp3-dialog{ - opacity:0; - -webkit-transform:scale(0.5); - transform:scale(0.5); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:opacity, transform; - transition-property:opacity, transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - -.bp3-dialog{ - background:#ebf1f5; - border-radius:6px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:30px 0; - padding-bottom:20px; - pointer-events:all; - -webkit-user-select:text; - -moz-user-select:text; - -ms-user-select:text; - user-select:text; - width:500px; } - .bp3-dialog:focus{ - outline:0; } - .bp3-dialog.bp3-dark, - .bp3-dark .bp3-dialog{ - background:#293742; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - -.bp3-dialog-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background:#ffffff; - border-radius:6px 6px 0 0; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - min-height:40px; - padding-left:20px; - padding-right:5px; - z-index:30; } - .bp3-dialog-header .bp3-icon-large, - .bp3-dialog-header .bp3-icon{ - color:#5c7080; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin-right:10px; } - .bp3-dialog-header .bp3-heading{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:inherit; - margin:0; } - .bp3-dialog-header .bp3-heading:last-child{ - margin-right:20px; } - .bp3-dark .bp3-dialog-header{ - background:#30404d; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-dialog-header .bp3-icon-large, - .bp3-dark .bp3-dialog-header .bp3-icon{ - color:#a7b6c2; } - -.bp3-dialog-body{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:18px; - margin:20px; } - -.bp3-dialog-footer{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin:0 20px; } - -.bp3-dialog-footer-actions{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:end; - -ms-flex-pack:end; - justify-content:flex-end; } - .bp3-dialog-footer-actions .bp3-button{ - margin-left:10px; } -.bp3-multistep-dialog-panels{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - -.bp3-multistep-dialog-left-panel{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-dark .bp3-multistep-dialog-left-panel{ - background:#202b33; } - -.bp3-multistep-dialog-right-panel{ - background-color:#f5f8fa; - border-left:1px solid rgba(16, 22, 26, 0.15); - border-radius:0 0 6px 0; - -webkit-box-flex:3; - -ms-flex:3; - flex:3; - min-width:0; } - .bp3-dark .bp3-multistep-dialog-right-panel{ - background-color:#293742; - border-left:1px solid rgba(16, 22, 26, 0.4); } - -.bp3-multistep-dialog-footer{ - background-color:#ffffff; - border-radius:0 0 6px 0; - border-top:1px solid rgba(16, 22, 26, 0.15); - padding:10px; } - .bp3-dark .bp3-multistep-dialog-footer{ - background:#30404d; - border-top:1px solid rgba(16, 22, 26, 0.4); } - -.bp3-dialog-step-container{ - background-color:#f5f8fa; - border-bottom:1px solid rgba(16, 22, 26, 0.15); } - .bp3-dark .bp3-dialog-step-container{ - background:#293742; - border-bottom:1px solid rgba(16, 22, 26, 0.4); } - .bp3-dialog-step-container.bp3-dialog-step-viewed{ - background-color:#ffffff; } - .bp3-dark .bp3-dialog-step-container.bp3-dialog-step-viewed{ - background:#30404d; } - -.bp3-dialog-step{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:#f5f8fa; - border-radius:6px; - cursor:not-allowed; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin:4px; - padding:6px 14px; } - .bp3-dark .bp3-dialog-step{ - background:#293742; } - .bp3-dialog-step-viewed .bp3-dialog-step{ - background-color:#ffffff; - cursor:pointer; } - .bp3-dark .bp3-dialog-step-viewed .bp3-dialog-step{ - background:#30404d; } - .bp3-dialog-step:hover{ - background-color:#f5f8fa; } - .bp3-dark .bp3-dialog-step:hover{ - background:#293742; } - -.bp3-dialog-step-icon{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:rgba(92, 112, 128, 0.6); - border-radius:50%; - color:#ffffff; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:25px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - width:25px; } - .bp3-dark .bp3-dialog-step-icon{ - background-color:rgba(167, 182, 194, 0.6); } - .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-icon{ - background-color:#2b95d6; } - .bp3-dialog-step-viewed .bp3-dialog-step-icon{ - background-color:#8a9ba8; } - -.bp3-dialog-step-title{ - color:rgba(92, 112, 128, 0.6); - -webkit-box-flex:1; - -ms-flex:1; - flex:1; - padding-left:10px; } - .bp3-dark .bp3-dialog-step-title{ - color:rgba(167, 182, 194, 0.6); } - .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-title{ - color:#2b95d6; } - .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{ - color:#182026; } - .bp3-dark .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{ - color:#f5f8fa; } -.bp3-drawer{ - background:#ffffff; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:0; - padding:0; } - .bp3-drawer:focus{ - outline:0; } - .bp3-drawer.bp3-position-top{ - height:50%; - left:0; - right:0; - top:0; } - .bp3-drawer.bp3-position-top.bp3-overlay-enter, .bp3-drawer.bp3-position-top.bp3-overlay-appear{ - -webkit-transform:translateY(-100%); - transform:translateY(-100%); } - .bp3-drawer.bp3-position-top.bp3-overlay-enter-active, .bp3-drawer.bp3-position-top.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-top.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer.bp3-position-top.bp3-overlay-exit-active{ - -webkit-transform:translateY(-100%); - transform:translateY(-100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-bottom{ - bottom:0; - height:50%; - left:0; - right:0; } - .bp3-drawer.bp3-position-bottom.bp3-overlay-enter, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear{ - -webkit-transform:translateY(100%); - transform:translateY(100%); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-enter-active, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer.bp3-position-bottom.bp3-overlay-exit-active{ - -webkit-transform:translateY(100%); - transform:translateY(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-left{ - bottom:0; - left:0; - top:0; - width:50%; } - .bp3-drawer.bp3-position-left.bp3-overlay-enter, .bp3-drawer.bp3-position-left.bp3-overlay-appear{ - -webkit-transform:translateX(-100%); - transform:translateX(-100%); } - .bp3-drawer.bp3-position-left.bp3-overlay-enter-active, .bp3-drawer.bp3-position-left.bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-left.bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer.bp3-position-left.bp3-overlay-exit-active{ - -webkit-transform:translateX(-100%); - transform:translateX(-100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-right{ - bottom:0; - right:0; - top:0; - width:50%; } - .bp3-drawer.bp3-position-right.bp3-overlay-enter, .bp3-drawer.bp3-position-right.bp3-overlay-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); } - .bp3-drawer.bp3-position-right.bp3-overlay-enter-active, .bp3-drawer.bp3-position-right.bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-position-right.bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer.bp3-position-right.bp3-overlay-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical){ - bottom:0; - right:0; - top:0; - width:50%; } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear-active{ - -webkit-transform:translateX(0); - transform:translateX(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit{ - -webkit-transform:translateX(0); - transform:translateX(0); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical{ - bottom:0; - height:50%; - left:0; - right:0; } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-appear{ - -webkit-transform:translateY(100%); - transform:translateY(100%); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-exit{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not( - .bp3-position-right).bp3-vertical.bp3-overlay-exit-active{ - -webkit-transform:translateY(100%); - transform:translateY(100%); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-drawer.bp3-dark, - .bp3-dark .bp3-drawer{ - background:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - -.bp3-drawer-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border-radius:0; - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - min-height:40px; - padding:5px; - padding-left:20px; - position:relative; } - .bp3-drawer-header .bp3-icon-large, - .bp3-drawer-header .bp3-icon{ - color:#5c7080; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - margin-right:10px; } - .bp3-drawer-header .bp3-heading{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:inherit; - margin:0; } - .bp3-drawer-header .bp3-heading:last-child{ - margin-right:20px; } - .bp3-dark .bp3-drawer-header{ - -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-drawer-header .bp3-icon-large, - .bp3-dark .bp3-drawer-header .bp3-icon{ - color:#a7b6c2; } - -.bp3-drawer-body{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:18px; - overflow:auto; } - -.bp3-drawer-footer{ - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - padding:10px 20px; - position:relative; } - .bp3-dark .bp3-drawer-footer{ - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); } -.bp3-editable-text{ - cursor:text; - display:inline-block; - max-width:100%; - position:relative; - vertical-align:top; - white-space:nowrap; } - .bp3-editable-text::before{ - bottom:-3px; - left:-3px; - position:absolute; - right:-3px; - top:-3px; - border-radius:3px; - content:""; - -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-editable-text:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-editable-text.bp3-editable-text-editing::before{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-disabled::before{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-editable-text.bp3-intent-primary .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{ - color:#137cbd; } - .bp3-editable-text.bp3-intent-primary:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); } - .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-success .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{ - color:#0f9960; } - .bp3-editable-text.bp3-intent-success:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); } - .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-warning .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{ - color:#d9822b; } - .bp3-editable-text.bp3-intent-warning:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); } - .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-editable-text.bp3-intent-danger .bp3-editable-text-input, - .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{ - color:#db3737; } - .bp3-editable-text.bp3-intent-danger:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); } - .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-editable-text:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); } - .bp3-dark .bp3-editable-text.bp3-editable-text-editing::before{ - background-color:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-disabled::before{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{ - color:#48aff0; } - .bp3-dark .bp3-editable-text.bp3-intent-primary:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); - box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{ - color:#3dcc91; } - .bp3-dark .bp3-editable-text.bp3-intent-success:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); - box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{ - color:#ffb366; } - .bp3-dark .bp3-editable-text.bp3-intent-warning:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); - box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{ - color:#ff7373; } - .bp3-dark .bp3-editable-text.bp3-intent-danger:hover::before{ - -webkit-box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); - box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); } - .bp3-dark .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{ - -webkit-box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-editable-text-input, -.bp3-editable-text-content{ - color:inherit; - display:inherit; - font:inherit; - letter-spacing:inherit; - max-width:inherit; - min-width:inherit; - position:relative; - resize:none; - text-transform:inherit; - vertical-align:top; } - -.bp3-editable-text-input{ - background:none; - border:none; - -webkit-box-shadow:none; - box-shadow:none; - padding:0; - white-space:pre-wrap; - width:100%; } - .bp3-editable-text-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-editable-text-input:focus{ - outline:none; } - .bp3-editable-text-input::-ms-clear{ - display:none; } - -.bp3-editable-text-content{ - overflow:hidden; - padding-right:2px; - text-overflow:ellipsis; - white-space:pre; } - .bp3-editable-text-editing > .bp3-editable-text-content{ - left:0; - position:absolute; - visibility:hidden; } - .bp3-editable-text-placeholder > .bp3-editable-text-content{ - color:rgba(92, 112, 128, 0.6); } - .bp3-dark .bp3-editable-text-placeholder > .bp3-editable-text-content{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-editable-text.bp3-multiline{ - display:block; } - .bp3-editable-text.bp3-multiline .bp3-editable-text-content{ - overflow:auto; - white-space:pre-wrap; - word-wrap:break-word; } -.bp3-divider{ - border-bottom:1px solid rgba(16, 22, 26, 0.15); - border-right:1px solid rgba(16, 22, 26, 0.15); - margin:5px; } - .bp3-dark .bp3-divider{ - border-color:rgba(16, 22, 26, 0.4); } -.bp3-control-group{ - -webkit-transform:translateZ(0); - transform:translateZ(0); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; } - .bp3-control-group > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-control-group > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-control-group .bp3-button, - .bp3-control-group .bp3-html-select, - .bp3-control-group .bp3-input, - .bp3-control-group .bp3-select{ - position:relative; } - .bp3-control-group .bp3-input{ - border-radius:inherit; - z-index:2; } - .bp3-control-group .bp3-input:focus{ - border-radius:3px; - z-index:14; } - .bp3-control-group .bp3-input[class*="bp3-intent"]{ - z-index:13; } - .bp3-control-group .bp3-input[class*="bp3-intent"]:focus{ - z-index:15; } - .bp3-control-group .bp3-input[readonly], .bp3-control-group .bp3-input:disabled, .bp3-control-group .bp3-input.bp3-disabled{ - z-index:1; } - .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input{ - z-index:13; } - .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input:focus{ - z-index:15; } - .bp3-control-group .bp3-button, - .bp3-control-group .bp3-html-select select, - .bp3-control-group .bp3-select select{ - -webkit-transform:translateZ(0); - transform:translateZ(0); - border-radius:inherit; - z-index:4; } - .bp3-control-group .bp3-button:focus, - .bp3-control-group .bp3-html-select select:focus, - .bp3-control-group .bp3-select select:focus{ - z-index:5; } - .bp3-control-group .bp3-button:hover, - .bp3-control-group .bp3-html-select select:hover, - .bp3-control-group .bp3-select select:hover{ - z-index:6; } - .bp3-control-group .bp3-button:active, - .bp3-control-group .bp3-html-select select:active, - .bp3-control-group .bp3-select select:active{ - z-index:7; } - .bp3-control-group .bp3-button[readonly], .bp3-control-group .bp3-button:disabled, .bp3-control-group .bp3-button.bp3-disabled, - .bp3-control-group .bp3-html-select select[readonly], - .bp3-control-group .bp3-html-select select:disabled, - .bp3-control-group .bp3-html-select select.bp3-disabled, - .bp3-control-group .bp3-select select[readonly], - .bp3-control-group .bp3-select select:disabled, - .bp3-control-group .bp3-select select.bp3-disabled{ - z-index:3; } - .bp3-control-group .bp3-button[class*="bp3-intent"], - .bp3-control-group .bp3-html-select select[class*="bp3-intent"], - .bp3-control-group .bp3-select select[class*="bp3-intent"]{ - z-index:9; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:focus, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:focus, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:focus{ - z-index:10; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:hover, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:hover, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:hover{ - z-index:11; } - .bp3-control-group .bp3-button[class*="bp3-intent"]:active, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:active, - .bp3-control-group .bp3-select select[class*="bp3-intent"]:active{ - z-index:12; } - .bp3-control-group .bp3-button[class*="bp3-intent"][readonly], .bp3-control-group .bp3-button[class*="bp3-intent"]:disabled, .bp3-control-group .bp3-button[class*="bp3-intent"].bp3-disabled, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"][readonly], - .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:disabled, - .bp3-control-group .bp3-html-select select[class*="bp3-intent"].bp3-disabled, - .bp3-control-group .bp3-select select[class*="bp3-intent"][readonly], - .bp3-control-group .bp3-select select[class*="bp3-intent"]:disabled, - .bp3-control-group .bp3-select select[class*="bp3-intent"].bp3-disabled{ - z-index:8; } - .bp3-control-group .bp3-input-group > .bp3-icon, - .bp3-control-group .bp3-input-group > .bp3-button, - .bp3-control-group .bp3-input-group > .bp3-input-left-container, - .bp3-control-group .bp3-input-group > .bp3-input-action{ - z-index:16; } - .bp3-control-group .bp3-select::after, - .bp3-control-group .bp3-html-select::after, - .bp3-control-group .bp3-select > .bp3-icon, - .bp3-control-group .bp3-html-select > .bp3-icon{ - z-index:17; } - .bp3-control-group .bp3-select:focus-within{ - z-index:5; } - .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){ - margin-right:-1px; } - .bp3-control-group:not(.bp3-vertical) > .bp3-divider:not(:first-child){ - margin-left:6px; } - .bp3-dark .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){ - margin-right:0; } - .bp3-dark .bp3-control-group:not(.bp3-vertical) > .bp3-button + .bp3-button{ - margin-left:1px; } - .bp3-control-group .bp3-popover-wrapper, - .bp3-control-group .bp3-popover-target{ - border-radius:inherit; } - .bp3-control-group > :first-child{ - border-radius:3px 0 0 3px; } - .bp3-control-group > :last-child{ - border-radius:0 3px 3px 0; - margin-right:0; } - .bp3-control-group > :only-child{ - border-radius:3px; - margin-right:0; } - .bp3-control-group .bp3-input-group .bp3-button{ - border-radius:3px; } - .bp3-control-group .bp3-numeric-input:not(:first-child) .bp3-input-group{ - border-bottom-left-radius:0; - border-top-left-radius:0; } - .bp3-control-group.bp3-fill{ - width:100%; } - .bp3-control-group > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-control-group.bp3-fill > *:not(.bp3-fixed){ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; } - .bp3-control-group.bp3-vertical{ - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-control-group.bp3-vertical > *{ - margin-top:-1px; } - .bp3-control-group.bp3-vertical > :first-child{ - border-radius:3px 3px 0 0; - margin-top:0; } - .bp3-control-group.bp3-vertical > :last-child{ - border-radius:0 0 3px 3px; } -.bp3-control{ - cursor:pointer; - display:block; - margin-bottom:10px; - position:relative; - text-transform:none; } - .bp3-control input:checked ~ .bp3-control-indicator{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-control:hover input:checked ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{ - background:#0e5a8a; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control input:disabled:checked ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-control input:checked ~ .bp3-control-indicator{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control:hover input:checked ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{ - background-color:#0e5a8a; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control input:disabled:checked ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-control:not(.bp3-align-right){ - padding-left:26px; } - .bp3-control:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-26px; } - .bp3-control.bp3-align-right{ - padding-right:26px; } - .bp3-control.bp3-align-right .bp3-control-indicator{ - margin-right:-26px; } - .bp3-control.bp3-disabled{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-control.bp3-inline{ - display:inline-block; - margin-right:20px; } - .bp3-control input{ - left:0; - opacity:0; - position:absolute; - top:0; - z-index:-1; } - .bp3-control .bp3-control-indicator{ - background-clip:padding-box; - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - border:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - cursor:pointer; - display:inline-block; - font-size:16px; - height:1em; - margin-right:10px; - margin-top:-3px; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - vertical-align:middle; - width:1em; } - .bp3-control .bp3-control-indicator::before{ - content:""; - display:block; - height:1em; - width:1em; } - .bp3-control:hover .bp3-control-indicator{ - background-color:#ebf1f5; } - .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{ - background:#d8e1e8; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control input:disabled ~ .bp3-control-indicator{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - cursor:not-allowed; } - .bp3-control input:focus ~ .bp3-control-indicator{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:2px; - -moz-outline-radius:6px; } - .bp3-control.bp3-align-right .bp3-control-indicator{ - float:right; - margin-left:10px; - margin-top:1px; } - .bp3-control.bp3-large{ - font-size:16px; } - .bp3-control.bp3-large:not(.bp3-align-right){ - padding-left:30px; } - .bp3-control.bp3-large:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-30px; } - .bp3-control.bp3-large.bp3-align-right{ - padding-right:30px; } - .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-right:-30px; } - .bp3-control.bp3-large .bp3-control-indicator{ - font-size:20px; } - .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-top:0; } - .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{ - background-color:#137cbd; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - color:#ffffff; } - .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); } - .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{ - background:#0e5a8a; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{ - background-color:#106ba3; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{ - background-color:#0e5a8a; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-control.bp3-checkbox .bp3-control-indicator{ - border-radius:3px; } - .bp3-control.bp3-checkbox input:checked ~ .bp3-control-indicator::before{ - background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M12 5c-.28 0-.53.11-.71.29L7 9.59l-2.29-2.3a1.003 1.003 0 00-1.42 1.42l3 3c.18.18.43.29.71.29s.53-.11.71-.29l5-5A1.003 1.003 0 0012 5z' fill='white'/%3e%3c/svg%3e"); } - .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator::before{ - background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M11 7H5c-.55 0-1 .45-1 1s.45 1 1 1h6c.55 0 1-.45 1-1s-.45-1-1-1z' fill='white'/%3e%3c/svg%3e"); } - .bp3-control.bp3-radio .bp3-control-indicator{ - border-radius:50%; } - .bp3-control.bp3-radio input:checked ~ .bp3-control-indicator::before{ - background-image:radial-gradient(#ffffff, #ffffff 28%, transparent 32%); } - .bp3-control.bp3-radio input:checked:disabled ~ .bp3-control-indicator::before{ - opacity:0.5; } - .bp3-control.bp3-radio input:focus ~ .bp3-control-indicator{ - -moz-outline-radius:16px; } - .bp3-control.bp3-switch input ~ .bp3-control-indicator{ - background:rgba(167, 182, 194, 0.5); } - .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{ - background:rgba(115, 134, 148, 0.5); } - .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{ - background:rgba(92, 112, 128, 0.5); } - .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{ - background:rgba(206, 217, 224, 0.5); } - .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{ - background:rgba(255, 255, 255, 0.8); } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{ - background:#137cbd; } - .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{ - background:#106ba3; } - .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{ - background:#0e5a8a; } - .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{ - background:rgba(19, 124, 189, 0.5); } - .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{ - background:rgba(255, 255, 255, 0.8); } - .bp3-control.bp3-switch:not(.bp3-align-right){ - padding-left:38px; } - .bp3-control.bp3-switch:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-38px; } - .bp3-control.bp3-switch.bp3-align-right{ - padding-right:38px; } - .bp3-control.bp3-switch.bp3-align-right .bp3-control-indicator{ - margin-right:-38px; } - .bp3-control.bp3-switch .bp3-control-indicator{ - border:none; - border-radius:1.75em; - -webkit-box-shadow:none !important; - box-shadow:none !important; - min-width:1.75em; - -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:auto; } - .bp3-control.bp3-switch .bp3-control-indicator::before{ - background:#ffffff; - border-radius:50%; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - height:calc(1em - 4px); - left:0; - margin:2px; - position:absolute; - -webkit-transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:calc(1em - 4px); } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{ - left:calc(100% - 1em); } - .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right){ - padding-left:45px; } - .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right) .bp3-control-indicator{ - margin-left:-45px; } - .bp3-control.bp3-switch.bp3-large.bp3-align-right{ - padding-right:45px; } - .bp3-control.bp3-switch.bp3-large.bp3-align-right .bp3-control-indicator{ - margin-right:-45px; } - .bp3-dark .bp3-control.bp3-switch input ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.5); } - .bp3-dark .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.7); } - .bp3-dark .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{ - background:rgba(16, 22, 26, 0.9); } - .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{ - background:rgba(57, 75, 89, 0.5); } - .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{ - background:#137cbd; } - .bp3-dark .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{ - background:#106ba3; } - .bp3-dark .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{ - background:#0e5a8a; } - .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{ - background:rgba(14, 90, 138, 0.5); } - .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{ - background:rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch .bp3-control-indicator::before{ - background:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-control.bp3-switch .bp3-switch-inner-text{ - font-size:0.7em; - text-align:center; } - .bp3-control.bp3-switch .bp3-control-indicator-child:first-child{ - line-height:0; - margin-left:0.5em; - margin-right:1.2em; - visibility:hidden; } - .bp3-control.bp3-switch .bp3-control-indicator-child:last-child{ - line-height:1em; - margin-left:1.2em; - margin-right:0.5em; - visibility:visible; } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:first-child{ - line-height:1em; - visibility:visible; } - .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:last-child{ - line-height:0; - visibility:hidden; } - .bp3-dark .bp3-control{ - color:#f5f8fa; } - .bp3-dark .bp3-control.bp3-disabled{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-control .bp3-control-indicator{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-control:hover .bp3-control-indicator{ - background-color:#30404d; } - .bp3-dark .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{ - background:#202b33; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-control input:disabled ~ .bp3-control-indicator{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - cursor:not-allowed; } - .bp3-dark .bp3-control.bp3-checkbox input:disabled:checked ~ .bp3-control-indicator, .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{ - color:rgba(167, 182, 194, 0.6); } -.bp3-file-input{ - cursor:pointer; - display:inline-block; - height:30px; - position:relative; } - .bp3-file-input input{ - margin:0; - min-width:200px; - opacity:0; } - .bp3-file-input input:disabled + .bp3-file-upload-input, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-file-input input:disabled + .bp3-file-upload-input::after, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active:hover, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active, - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-dark - .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{ - color:#182026; } - .bp3-dark .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{ - color:#f5f8fa; } - .bp3-file-input.bp3-fill{ - width:100%; } - .bp3-file-input.bp3-large, - .bp3-large .bp3-file-input{ - height:40px; } - .bp3-file-input .bp3-file-upload-input-custom-text::after{ - content:attr(bp3-button-text); } - -.bp3-file-upload-input{ - -webkit-appearance:none; - -moz-appearance:none; - appearance:none; - background:#ffffff; - border:none; - border-radius:3px; - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - color:#182026; - font-size:14px; - font-weight:400; - height:30px; - line-height:30px; - outline:none; - padding:0 10px; - -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - vertical-align:middle; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - color:rgba(92, 112, 128, 0.6); - left:0; - padding-right:80px; - position:absolute; - right:0; - top:0; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-file-upload-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-file-upload-input:focus, .bp3-file-upload-input.bp3-active{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-file-upload-input[type="search"], .bp3-file-upload-input.bp3-round{ - border-radius:30px; - -webkit-box-sizing:border-box; - box-sizing:border-box; - padding-left:10px; } - .bp3-file-upload-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-file-upload-input:disabled, .bp3-file-upload-input.bp3-disabled{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-file-upload-input::after{ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - min-height:24px; - min-width:24px; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - border-radius:3px; - content:"Browse"; - line-height:24px; - margin:3px; - position:absolute; - right:0; - text-align:center; - top:0; - width:70px; } - .bp3-file-upload-input::after:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-file-upload-input::after:active, .bp3-file-upload-input::after.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-file-upload-input::after:disabled, .bp3-file-upload-input::after.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-file-upload-input::after:disabled.bp3-active, .bp3-file-upload-input::after:disabled.bp3-active:hover, .bp3-file-upload-input::after.bp3-disabled.bp3-active, .bp3-file-upload-input::after.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-file-upload-input:hover::after{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-file-upload-input:active::after{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-large .bp3-file-upload-input{ - font-size:16px; - height:40px; - line-height:40px; - padding-right:95px; } - .bp3-large .bp3-file-upload-input[type="search"], .bp3-large .bp3-file-upload-input.bp3-round{ - padding:0 15px; } - .bp3-large .bp3-file-upload-input::after{ - min-height:30px; - min-width:30px; - line-height:30px; - margin:5px; - width:85px; } - .bp3-dark .bp3-file-upload-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input:disabled, .bp3-dark .bp3-file-upload-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::after{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-file-upload-input::after:hover, .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-file-upload-input::after:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-file-upload-input::after:disabled, .bp3-dark .bp3-file-upload-input::after.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-file-upload-input::after:disabled.bp3-active, .bp3-dark .bp3-file-upload-input::after.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-file-upload-input::after .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-file-upload-input:hover::after{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-file-upload-input:active::after{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } -.bp3-file-upload-input::after{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } -.bp3-form-group{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin:0 0 15px; } - .bp3-form-group label.bp3-label{ - margin-bottom:5px; } - .bp3-form-group .bp3-control{ - margin-top:7px; } - .bp3-form-group .bp3-form-helper-text{ - color:#5c7080; - font-size:12px; - margin-top:5px; } - .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{ - color:#106ba3; } - .bp3-form-group.bp3-intent-success .bp3-form-helper-text{ - color:#0d8050; } - .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{ - color:#bf7326; } - .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{ - color:#c23030; } - .bp3-form-group.bp3-inline{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; } - .bp3-form-group.bp3-inline.bp3-large label.bp3-label{ - line-height:40px; - margin:0 10px 0 0; } - .bp3-form-group.bp3-inline label.bp3-label{ - line-height:30px; - margin:0 10px 0 0; } - .bp3-form-group.bp3-disabled .bp3-label, - .bp3-form-group.bp3-disabled .bp3-text-muted, - .bp3-form-group.bp3-disabled .bp3-form-helper-text{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-dark .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{ - color:#48aff0; } - .bp3-dark .bp3-form-group.bp3-intent-success .bp3-form-helper-text{ - color:#3dcc91; } - .bp3-dark .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{ - color:#ffb366; } - .bp3-dark .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{ - color:#ff7373; } - .bp3-dark .bp3-form-group .bp3-form-helper-text{ - color:#a7b6c2; } - .bp3-dark .bp3-form-group.bp3-disabled .bp3-label, - .bp3-dark .bp3-form-group.bp3-disabled .bp3-text-muted, - .bp3-dark .bp3-form-group.bp3-disabled .bp3-form-helper-text{ - color:rgba(167, 182, 194, 0.6) !important; } -.bp3-input-group{ - display:block; - position:relative; } - .bp3-input-group .bp3-input{ - position:relative; - width:100%; } - .bp3-input-group .bp3-input:not(:first-child){ - padding-left:30px; } - .bp3-input-group .bp3-input:not(:last-child){ - padding-right:30px; } - .bp3-input-group .bp3-input-action, - .bp3-input-group > .bp3-input-left-container, - .bp3-input-group > .bp3-button, - .bp3-input-group > .bp3-icon{ - position:absolute; - top:0; } - .bp3-input-group .bp3-input-action:first-child, - .bp3-input-group > .bp3-input-left-container:first-child, - .bp3-input-group > .bp3-button:first-child, - .bp3-input-group > .bp3-icon:first-child{ - left:0; } - .bp3-input-group .bp3-input-action:last-child, - .bp3-input-group > .bp3-input-left-container:last-child, - .bp3-input-group > .bp3-button:last-child, - .bp3-input-group > .bp3-icon:last-child{ - right:0; } - .bp3-input-group .bp3-button{ - min-height:24px; - min-width:24px; - margin:3px; - padding:0 7px; } - .bp3-input-group .bp3-button:empty{ - padding:0; } - .bp3-input-group > .bp3-input-left-container, - .bp3-input-group > .bp3-icon{ - z-index:1; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon, - .bp3-input-group > .bp3-icon{ - color:#5c7080; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon:empty, - .bp3-input-group > .bp3-icon:empty{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; } - .bp3-input-group > .bp3-input-left-container > .bp3-icon, - .bp3-input-group > .bp3-icon, - .bp3-input-group .bp3-input-action > .bp3-spinner{ - margin:7px; } - .bp3-input-group .bp3-tag{ - margin:5px; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){ - color:#5c7080; } - .bp3-dark .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), .bp3-dark - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){ - color:#a7b6c2; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large{ - color:#5c7080; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-large, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-standard, - .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-large{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-input-group.bp3-disabled{ - cursor:not-allowed; } - .bp3-input-group.bp3-disabled .bp3-icon{ - color:rgba(92, 112, 128, 0.6); } - .bp3-input-group.bp3-large .bp3-button{ - min-height:30px; - min-width:30px; - margin:5px; } - .bp3-input-group.bp3-large > .bp3-input-left-container > .bp3-icon, - .bp3-input-group.bp3-large > .bp3-icon, - .bp3-input-group.bp3-large .bp3-input-action > .bp3-spinner{ - margin:12px; } - .bp3-input-group.bp3-large .bp3-input{ - font-size:16px; - height:40px; - line-height:40px; } - .bp3-input-group.bp3-large .bp3-input[type="search"], .bp3-input-group.bp3-large .bp3-input.bp3-round{ - padding:0 15px; } - .bp3-input-group.bp3-large .bp3-input:not(:first-child){ - padding-left:40px; } - .bp3-input-group.bp3-large .bp3-input:not(:last-child){ - padding-right:40px; } - .bp3-input-group.bp3-small .bp3-button{ - min-height:20px; - min-width:20px; - margin:2px; } - .bp3-input-group.bp3-small .bp3-tag{ - min-height:20px; - min-width:20px; - margin:2px; } - .bp3-input-group.bp3-small > .bp3-input-left-container > .bp3-icon, - .bp3-input-group.bp3-small > .bp3-icon, - .bp3-input-group.bp3-small .bp3-input-action > .bp3-spinner{ - margin:4px; } - .bp3-input-group.bp3-small .bp3-input{ - font-size:12px; - height:24px; - line-height:24px; - padding-left:8px; - padding-right:8px; } - .bp3-input-group.bp3-small .bp3-input[type="search"], .bp3-input-group.bp3-small .bp3-input.bp3-round{ - padding:0 12px; } - .bp3-input-group.bp3-small .bp3-input:not(:first-child){ - padding-left:24px; } - .bp3-input-group.bp3-small .bp3-input:not(:last-child){ - padding-right:24px; } - .bp3-input-group.bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - width:100%; } - .bp3-input-group.bp3-round .bp3-button, - .bp3-input-group.bp3-round .bp3-input, - .bp3-input-group.bp3-round .bp3-tag{ - border-radius:30px; } - .bp3-dark .bp3-input-group .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-input-group.bp3-disabled .bp3-icon{ - color:rgba(167, 182, 194, 0.6); } - .bp3-input-group.bp3-intent-primary .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-primary .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-primary .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-input-group.bp3-intent-primary .bp3-input:disabled, .bp3-input-group.bp3-intent-primary .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-primary > .bp3-icon{ - color:#106ba3; } - .bp3-dark .bp3-input-group.bp3-intent-primary > .bp3-icon{ - color:#48aff0; } - .bp3-input-group.bp3-intent-success .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-success .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-success .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-input-group.bp3-intent-success .bp3-input:disabled, .bp3-input-group.bp3-intent-success .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-success > .bp3-icon{ - color:#0d8050; } - .bp3-dark .bp3-input-group.bp3-intent-success > .bp3-icon{ - color:#3dcc91; } - .bp3-input-group.bp3-intent-warning .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-warning .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-warning .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-input-group.bp3-intent-warning .bp3-input:disabled, .bp3-input-group.bp3-intent-warning .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-warning > .bp3-icon{ - color:#bf7326; } - .bp3-dark .bp3-input-group.bp3-intent-warning > .bp3-icon{ - color:#ffb366; } - .bp3-input-group.bp3-intent-danger .bp3-input{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-danger .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input-group.bp3-intent-danger .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-input-group.bp3-intent-danger .bp3-input:disabled, .bp3-input-group.bp3-intent-danger .bp3-input.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input-group.bp3-intent-danger > .bp3-icon{ - color:#c23030; } - .bp3-dark .bp3-input-group.bp3-intent-danger > .bp3-icon{ - color:#ff7373; } -.bp3-input{ - -webkit-appearance:none; - -moz-appearance:none; - appearance:none; - background:#ffffff; - border:none; - border-radius:3px; - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - color:#182026; - font-size:14px; - font-weight:400; - height:30px; - line-height:30px; - outline:none; - padding:0 10px; - -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); - vertical-align:middle; } - .bp3-input::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input:focus, .bp3-input.bp3-active{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input[type="search"], .bp3-input.bp3-round{ - border-radius:30px; - -webkit-box-sizing:border-box; - box-sizing:border-box; - padding-left:10px; } - .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); } - .bp3-input:disabled, .bp3-input.bp3-disabled{ - background:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - resize:none; } - .bp3-input.bp3-large{ - font-size:16px; - height:40px; - line-height:40px; } - .bp3-input.bp3-large[type="search"], .bp3-input.bp3-large.bp3-round{ - padding:0 15px; } - .bp3-input.bp3-small{ - font-size:12px; - height:24px; - line-height:24px; - padding-left:8px; - padding-right:8px; } - .bp3-input.bp3-small[type="search"], .bp3-input.bp3-small.bp3-round{ - padding:0 12px; } - .bp3-input.bp3-fill{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - width:100%; } - .bp3-dark .bp3-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input:disabled, .bp3-dark .bp3-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-input.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-primary:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-primary[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-input.bp3-intent-primary:disabled, .bp3-input.bp3-intent-primary.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-primary:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-primary[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #137cbd; - box-shadow:inset 0 0 0 1px #137cbd; } - .bp3-dark .bp3-input.bp3-intent-primary:disabled, .bp3-dark .bp3-input.bp3-intent-primary.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-success{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-success:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-success[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-input.bp3-intent-success:disabled, .bp3-input.bp3-intent-success.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-success{ - -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-success:focus{ - -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-success[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #0f9960; - box-shadow:inset 0 0 0 1px #0f9960; } - .bp3-dark .bp3-input.bp3-intent-success:disabled, .bp3-dark .bp3-input.bp3-intent-success.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-warning:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-warning[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-input.bp3-intent-warning:disabled, .bp3-input.bp3-intent-warning.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-warning:focus{ - -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-warning[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #d9822b; - box-shadow:inset 0 0 0 1px #d9822b; } - .bp3-dark .bp3-input.bp3-intent-warning:disabled, .bp3-dark .bp3-input.bp3-intent-warning.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-danger:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-input.bp3-intent-danger[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-input.bp3-intent-danger:disabled, .bp3-input.bp3-intent-danger.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-input.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-danger:focus{ - -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-input.bp3-intent-danger[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px #db3737; - box-shadow:inset 0 0 0 1px #db3737; } - .bp3-dark .bp3-input.bp3-intent-danger:disabled, .bp3-dark .bp3-input.bp3-intent-danger.bp3-disabled{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-input::-ms-clear{ - display:none; } -textarea.bp3-input{ - max-width:100%; - padding:10px; } - textarea.bp3-input, textarea.bp3-input.bp3-large, textarea.bp3-input.bp3-small{ - height:auto; - line-height:inherit; } - textarea.bp3-input.bp3-small{ - padding:8px; } - .bp3-dark textarea.bp3-input{ - background:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark textarea.bp3-input::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark textarea.bp3-input:focus{ - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark textarea.bp3-input[readonly]{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark textarea.bp3-input:disabled, .bp3-dark textarea.bp3-input.bp3-disabled{ - background:rgba(57, 75, 89, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } -label.bp3-label{ - display:block; - margin-bottom:15px; - margin-top:0; } - label.bp3-label .bp3-html-select, - label.bp3-label .bp3-input, - label.bp3-label .bp3-select, - label.bp3-label .bp3-slider, - label.bp3-label .bp3-popover-wrapper{ - display:block; - margin-top:5px; - text-transform:none; } - label.bp3-label .bp3-button-group{ - margin-top:5px; } - label.bp3-label .bp3-select select, - label.bp3-label .bp3-html-select select{ - font-weight:400; - vertical-align:top; - width:100%; } - label.bp3-label.bp3-disabled, - label.bp3-label.bp3-disabled .bp3-text-muted{ - color:rgba(92, 112, 128, 0.6); } - label.bp3-label.bp3-inline{ - line-height:30px; } - label.bp3-label.bp3-inline .bp3-html-select, - label.bp3-label.bp3-inline .bp3-input, - label.bp3-label.bp3-inline .bp3-input-group, - label.bp3-label.bp3-inline .bp3-select, - label.bp3-label.bp3-inline .bp3-popover-wrapper{ - display:inline-block; - margin:0 0 0 5px; - vertical-align:top; } - label.bp3-label.bp3-inline .bp3-button-group{ - margin:0 0 0 5px; } - label.bp3-label.bp3-inline .bp3-input-group .bp3-input{ - margin-left:0; } - label.bp3-label.bp3-inline.bp3-large{ - line-height:40px; } - label.bp3-label:not(.bp3-inline) .bp3-popover-target{ - display:block; } - .bp3-dark label.bp3-label{ - color:#f5f8fa; } - .bp3-dark label.bp3-label.bp3-disabled, - .bp3-dark label.bp3-label.bp3-disabled .bp3-text-muted{ - color:rgba(167, 182, 194, 0.6); } -.bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button{ - -webkit-box-flex:1; - -ms-flex:1 1 14px; - flex:1 1 14px; - min-height:0; - padding:0; - width:30px; } - .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:first-child{ - border-radius:0 3px 0 0; } - .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:last-child{ - border-radius:0 0 3px 0; } - -.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:first-child{ - border-radius:3px 0 0 0; } - -.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:last-child{ - border-radius:0 0 0 3px; } - -.bp3-numeric-input.bp3-large .bp3-button-group.bp3-vertical > .bp3-button{ - width:40px; } - -form{ - display:block; } -.bp3-html-select select, -.bp3-select select{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - border:none; - border-radius:3px; - cursor:pointer; - font-size:14px; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - padding:5px 10px; - text-align:left; - vertical-align:middle; - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - -moz-appearance:none; - -webkit-appearance:none; - border-radius:3px; - height:30px; - padding:0 25px 0 10px; - width:100%; } - .bp3-html-select select > *, .bp3-select select > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-html-select select > .bp3-fill, .bp3-select select > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-html-select select::before, - .bp3-select select::before, .bp3-html-select select > *, .bp3-select select > *{ - margin-right:7px; } - .bp3-html-select select:empty::before, - .bp3-select select:empty::before, - .bp3-html-select select > :last-child, - .bp3-select select > :last-child{ - margin-right:0; } - .bp3-html-select select:hover, - .bp3-select select:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-html-select select:active, - .bp3-select select:active, .bp3-html-select select.bp3-active, - .bp3-select select.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-html-select select:disabled, - .bp3-select select:disabled, .bp3-html-select select.bp3-disabled, - .bp3-select select.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-html-select select:disabled.bp3-active, - .bp3-select select:disabled.bp3-active, .bp3-html-select select:disabled.bp3-active:hover, - .bp3-select select:disabled.bp3-active:hover, .bp3-html-select select.bp3-disabled.bp3-active, - .bp3-select select.bp3-disabled.bp3-active, .bp3-html-select select.bp3-disabled.bp3-active:hover, - .bp3-select select.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - -.bp3-html-select.bp3-minimal select, -.bp3-select.bp3-minimal select{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-html-select.bp3-minimal select:hover, - .bp3-select.bp3-minimal select:hover{ - background:rgba(167, 182, 194, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; - text-decoration:none; } - .bp3-html-select.bp3-minimal select:active, - .bp3-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal select.bp3-active, - .bp3-select.bp3-minimal select.bp3-active{ - background:rgba(115, 134, 148, 0.3); - -webkit-box-shadow:none; - box-shadow:none; - color:#182026; } - .bp3-html-select.bp3-minimal select:disabled, - .bp3-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal select:disabled:hover, - .bp3-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal select.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal select.bp3-disabled:hover, - .bp3-select.bp3-minimal select.bp3-disabled:hover{ - background:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-html-select.bp3-minimal select:disabled.bp3-active, - .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, - .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, - .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active{ - background:rgba(115, 134, 148, 0.3); } - .bp3-dark .bp3-html-select.bp3-minimal select, .bp3-html-select.bp3-minimal .bp3-dark select, - .bp3-dark .bp3-select.bp3-minimal select, .bp3-select.bp3-minimal .bp3-dark select{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:inherit; } - .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover, - .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover, .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active, - .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover, - .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover{ - background:rgba(138, 155, 168, 0.15); } - .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active, - .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{ - background:rgba(138, 155, 168, 0.3); - color:#f5f8fa; } - .bp3-dark .bp3-html-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal .bp3-dark select:disabled, - .bp3-dark .bp3-select.bp3-minimal select:disabled, .bp3-select.bp3-minimal .bp3-dark select:disabled, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover, - .bp3-dark .bp3-select.bp3-minimal select:disabled:hover, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover{ - background:none; - color:rgba(167, 182, 194, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-html-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active{ - background:rgba(138, 155, 168, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary, - .bp3-select.bp3-minimal select.bp3-intent-primary{ - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, - .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, - .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, - .bp3-select.bp3-minimal select.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, - .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#106ba3; } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, - .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(16, 107, 163, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{ - stroke:#106ba3; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover{ - background:rgba(19, 124, 189, 0.2); - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active{ - background:rgba(19, 124, 189, 0.3); - color:#48aff0; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled{ - background:none; - color:rgba(72, 175, 240, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active{ - background:rgba(19, 124, 189, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-success, - .bp3-select.bp3-minimal select.bp3-intent-success{ - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, - .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal select.bp3-intent-success:active, - .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, - .bp3-select.bp3-minimal select.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:active, - .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#0d8050; } - .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, - .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(13, 128, 80, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{ - stroke:#0d8050; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover{ - background:rgba(15, 153, 96, 0.2); - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active{ - background:rgba(15, 153, 96, 0.3); - color:#3dcc91; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled{ - background:none; - color:rgba(61, 204, 145, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active{ - background:rgba(15, 153, 96, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning, - .bp3-select.bp3-minimal select.bp3-intent-warning{ - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, - .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, - .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, - .bp3-select.bp3-minimal select.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, - .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#bf7326; } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, - .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(191, 115, 38, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{ - stroke:#bf7326; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover{ - background:rgba(217, 130, 43, 0.2); - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active{ - background:rgba(217, 130, 43, 0.3); - color:#ffb366; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled{ - background:none; - color:rgba(255, 179, 102, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active{ - background:rgba(217, 130, 43, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger, - .bp3-select.bp3-minimal select.bp3-intent-danger{ - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, - .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, - .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{ - background:none; - -webkit-box-shadow:none; - box-shadow:none; - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, - .bp3-select.bp3-minimal select.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, - .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#c23030; } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, - .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(194, 48, 48, 0.5); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, - .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - .bp3-html-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{ - stroke:#c23030; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover{ - background:rgba(219, 55, 55, 0.2); - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active{ - background:rgba(219, 55, 55, 0.3); - color:#ff7373; } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled{ - background:none; - color:rgba(255, 115, 115, 0.5); } - .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active, - .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active{ - background:rgba(219, 55, 55, 0.3); } - -.bp3-html-select.bp3-large select, -.bp3-select.bp3-large select{ - font-size:16px; - height:40px; - padding-right:35px; } - -.bp3-dark .bp3-html-select select, .bp3-dark .bp3-select select{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover, .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-html-select select:disabled, .bp3-dark .bp3-select select:disabled, .bp3-dark .bp3-html-select select.bp3-disabled, .bp3-dark .bp3-select select.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-html-select select:disabled.bp3-active, .bp3-dark .bp3-select select:disabled.bp3-active, .bp3-dark .bp3-html-select select.bp3-disabled.bp3-active, .bp3-dark .bp3-select select.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-html-select select .bp3-button-spinner .bp3-spinner-head, .bp3-dark .bp3-select select .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - -.bp3-html-select select:disabled, -.bp3-select select:disabled{ - background-color:rgba(206, 217, 224, 0.5); - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-html-select .bp3-icon, -.bp3-select .bp3-icon, .bp3-select::after{ - color:#5c7080; - pointer-events:none; - position:absolute; - right:7px; - top:7px; } - .bp3-html-select .bp3-disabled.bp3-icon, - .bp3-select .bp3-disabled.bp3-icon, .bp3-disabled.bp3-select::after{ - color:rgba(92, 112, 128, 0.6); } -.bp3-html-select, -.bp3-select{ - display:inline-block; - letter-spacing:normal; - position:relative; - vertical-align:middle; } - .bp3-html-select select::-ms-expand, - .bp3-select select::-ms-expand{ - display:none; } - .bp3-html-select .bp3-icon, - .bp3-select .bp3-icon{ - color:#5c7080; } - .bp3-html-select .bp3-icon:hover, - .bp3-select .bp3-icon:hover{ - color:#182026; } - .bp3-dark .bp3-html-select .bp3-icon, .bp3-dark - .bp3-select .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-html-select .bp3-icon:hover, .bp3-dark - .bp3-select .bp3-icon:hover{ - color:#f5f8fa; } - .bp3-html-select.bp3-large::after, - .bp3-html-select.bp3-large .bp3-icon, - .bp3-select.bp3-large::after, - .bp3-select.bp3-large .bp3-icon{ - right:12px; - top:12px; } - .bp3-html-select.bp3-fill, - .bp3-html-select.bp3-fill select, - .bp3-select.bp3-fill, - .bp3-select.bp3-fill select{ - width:100%; } - .bp3-dark .bp3-html-select option, .bp3-dark - .bp3-select option{ - background-color:#30404d; - color:#f5f8fa; } - .bp3-dark .bp3-html-select option:disabled, .bp3-dark - .bp3-select option:disabled{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-html-select::after, .bp3-dark - .bp3-select::after{ - color:#a7b6c2; } - -.bp3-select::after{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - content:""; } -.bp3-running-text table, table.bp3-html-table{ - border-spacing:0; - font-size:14px; } - .bp3-running-text table th, table.bp3-html-table th, - .bp3-running-text table td, - table.bp3-html-table td{ - padding:11px; - text-align:left; - vertical-align:top; } - .bp3-running-text table th, table.bp3-html-table th{ - color:#182026; - font-weight:600; } - - .bp3-running-text table td, - table.bp3-html-table td{ - color:#182026; } - .bp3-running-text table tbody tr:first-child th, table.bp3-html-table tbody tr:first-child th, - .bp3-running-text table tbody tr:first-child td, - table.bp3-html-table tbody tr:first-child td, - .bp3-running-text table tfoot tr:first-child th, - table.bp3-html-table tfoot tr:first-child th, - .bp3-running-text table tfoot tr:first-child td, - table.bp3-html-table tfoot tr:first-child td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); } - .bp3-dark .bp3-running-text table th, .bp3-running-text .bp3-dark table th, .bp3-dark table.bp3-html-table th{ - color:#f5f8fa; } - .bp3-dark .bp3-running-text table td, .bp3-running-text .bp3-dark table td, .bp3-dark table.bp3-html-table td{ - color:#f5f8fa; } - .bp3-dark .bp3-running-text table tbody tr:first-child th, .bp3-running-text .bp3-dark table tbody tr:first-child th, .bp3-dark table.bp3-html-table tbody tr:first-child th, - .bp3-dark .bp3-running-text table tbody tr:first-child td, - .bp3-running-text .bp3-dark table tbody tr:first-child td, - .bp3-dark table.bp3-html-table tbody tr:first-child td, - .bp3-dark .bp3-running-text table tfoot tr:first-child th, - .bp3-running-text .bp3-dark table tfoot tr:first-child th, - .bp3-dark table.bp3-html-table tfoot tr:first-child th, - .bp3-dark .bp3-running-text table tfoot tr:first-child td, - .bp3-running-text .bp3-dark table tfoot tr:first-child td, - .bp3-dark table.bp3-html-table tfoot tr:first-child td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); } - -table.bp3-html-table.bp3-html-table-condensed th, -table.bp3-html-table.bp3-html-table-condensed td, table.bp3-html-table.bp3-small th, -table.bp3-html-table.bp3-small td{ - padding-bottom:6px; - padding-top:6px; } - -table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{ - background:rgba(191, 204, 214, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered tbody tr td, -table.bp3-html-table.bp3-html-table-bordered tfoot tr td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); } - table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child), - table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){ - -webkit-box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{ - -webkit-box-shadow:none; - box-shadow:none; } - table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); } - -table.bp3-html-table.bp3-interactive tbody tr:hover td{ - background-color:rgba(191, 204, 214, 0.3); - cursor:pointer; } - -table.bp3-html-table.bp3-interactive tbody tr:active td{ - background-color:rgba(191, 204, 214, 0.4); } - -.bp3-dark table.bp3-html-table{ } - .bp3-dark table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{ - background:rgba(92, 112, 128, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){ - -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td, - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td{ - -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child), - .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){ - -webkit-box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{ - -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); - box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); } - .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:first-child{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:hover td{ - background-color:rgba(92, 112, 128, 0.3); - cursor:pointer; } - .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:active td{ - background-color:rgba(92, 112, 128, 0.4); } - -.bp3-key-combo{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; } - .bp3-key-combo > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-key-combo > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-key-combo::before, - .bp3-key-combo > *{ - margin-right:5px; } - .bp3-key-combo:empty::before, - .bp3-key-combo > :last-child{ - margin-right:0; } - -.bp3-hotkey-dialog{ - padding-bottom:0; - top:40px; } - .bp3-hotkey-dialog .bp3-dialog-body{ - margin:0; - padding:0; } - .bp3-hotkey-dialog .bp3-hotkey-label{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; } - -.bp3-hotkey-column{ - margin:auto; - max-height:80vh; - overflow-y:auto; - padding:30px; } - .bp3-hotkey-column .bp3-heading{ - margin-bottom:20px; } - .bp3-hotkey-column .bp3-heading:not(:first-child){ - margin-top:40px; } - -.bp3-hotkey{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:justify; - -ms-flex-pack:justify; - justify-content:space-between; - margin-left:0; - margin-right:0; } - .bp3-hotkey:not(:last-child){ - margin-bottom:10px; } -.bp3-icon{ - display:inline-block; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - vertical-align:text-bottom; } - .bp3-icon:not(:empty)::before{ - content:"" !important; - content:unset !important; } - .bp3-icon > svg{ - display:block; } - .bp3-icon > svg:not([fill]){ - fill:currentColor; } - -.bp3-icon.bp3-intent-primary, .bp3-icon-standard.bp3-intent-primary, .bp3-icon-large.bp3-intent-primary{ - color:#106ba3; } - .bp3-dark .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-icon-large.bp3-intent-primary{ - color:#48aff0; } - -.bp3-icon.bp3-intent-success, .bp3-icon-standard.bp3-intent-success, .bp3-icon-large.bp3-intent-success{ - color:#0d8050; } - .bp3-dark .bp3-icon.bp3-intent-success, .bp3-dark .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-icon-large.bp3-intent-success{ - color:#3dcc91; } - -.bp3-icon.bp3-intent-warning, .bp3-icon-standard.bp3-intent-warning, .bp3-icon-large.bp3-intent-warning{ - color:#bf7326; } - .bp3-dark .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-icon-large.bp3-intent-warning{ - color:#ffb366; } - -.bp3-icon.bp3-intent-danger, .bp3-icon-standard.bp3-intent-danger, .bp3-icon-large.bp3-intent-danger{ - color:#c23030; } - .bp3-dark .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-icon-large.bp3-intent-danger{ - color:#ff7373; } - -span.bp3-icon-standard{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - display:inline-block; } - -span.bp3-icon-large{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - display:inline-block; } - -span.bp3-icon:empty{ - font-family:"Icons20"; - font-size:inherit; - font-style:normal; - font-weight:400; - line-height:1; } - span.bp3-icon:empty::before{ - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; } - -.bp3-icon-add::before{ - content:""; } - -.bp3-icon-add-column-left::before{ - content:""; } - -.bp3-icon-add-column-right::before{ - content:""; } - -.bp3-icon-add-row-bottom::before{ - content:""; } - -.bp3-icon-add-row-top::before{ - content:""; } - -.bp3-icon-add-to-artifact::before{ - content:""; } - -.bp3-icon-add-to-folder::before{ - content:""; } - -.bp3-icon-airplane::before{ - content:""; } - -.bp3-icon-align-center::before{ - content:""; } - -.bp3-icon-align-justify::before{ - content:""; } - -.bp3-icon-align-left::before{ - content:""; } - -.bp3-icon-align-right::before{ - content:""; } - -.bp3-icon-alignment-bottom::before{ - content:""; } - -.bp3-icon-alignment-horizontal-center::before{ - content:""; } - -.bp3-icon-alignment-left::before{ - content:""; } - -.bp3-icon-alignment-right::before{ - content:""; } - -.bp3-icon-alignment-top::before{ - content:""; } - -.bp3-icon-alignment-vertical-center::before{ - content:""; } - -.bp3-icon-annotation::before{ - content:""; } - -.bp3-icon-application::before{ - content:""; } - -.bp3-icon-applications::before{ - content:""; } - -.bp3-icon-archive::before{ - content:""; } - -.bp3-icon-arrow-bottom-left::before{ - content:"↙"; } - -.bp3-icon-arrow-bottom-right::before{ - content:"↘"; } - -.bp3-icon-arrow-down::before{ - content:"↓"; } - -.bp3-icon-arrow-left::before{ - content:"←"; } - -.bp3-icon-arrow-right::before{ - content:"→"; } - -.bp3-icon-arrow-top-left::before{ - content:"↖"; } - -.bp3-icon-arrow-top-right::before{ - content:"↗"; } - -.bp3-icon-arrow-up::before{ - content:"↑"; } - -.bp3-icon-arrows-horizontal::before{ - content:"↔"; } - -.bp3-icon-arrows-vertical::before{ - content:"↕"; } - -.bp3-icon-asterisk::before{ - content:"*"; } - -.bp3-icon-automatic-updates::before{ - content:""; } - -.bp3-icon-badge::before{ - content:""; } - -.bp3-icon-ban-circle::before{ - content:""; } - -.bp3-icon-bank-account::before{ - content:""; } - -.bp3-icon-barcode::before{ - content:""; } - -.bp3-icon-blank::before{ - content:""; } - -.bp3-icon-blocked-person::before{ - content:""; } - -.bp3-icon-bold::before{ - content:""; } - -.bp3-icon-book::before{ - content:""; } - -.bp3-icon-bookmark::before{ - content:""; } - -.bp3-icon-box::before{ - content:""; } - -.bp3-icon-briefcase::before{ - content:""; } - -.bp3-icon-bring-data::before{ - content:""; } - -.bp3-icon-build::before{ - content:""; } - -.bp3-icon-calculator::before{ - content:""; } - -.bp3-icon-calendar::before{ - content:""; } - -.bp3-icon-camera::before{ - content:""; } - -.bp3-icon-caret-down::before{ - content:"⌄"; } - -.bp3-icon-caret-left::before{ - content:"〈"; } - -.bp3-icon-caret-right::before{ - content:"〉"; } - -.bp3-icon-caret-up::before{ - content:"⌃"; } - -.bp3-icon-cell-tower::before{ - content:""; } - -.bp3-icon-changes::before{ - content:""; } - -.bp3-icon-chart::before{ - content:""; } - -.bp3-icon-chat::before{ - content:""; } - -.bp3-icon-chevron-backward::before{ - content:""; } - -.bp3-icon-chevron-down::before{ - content:""; } - -.bp3-icon-chevron-forward::before{ - content:""; } - -.bp3-icon-chevron-left::before{ - content:""; } - -.bp3-icon-chevron-right::before{ - content:""; } - -.bp3-icon-chevron-up::before{ - content:""; } - -.bp3-icon-circle::before{ - content:""; } - -.bp3-icon-circle-arrow-down::before{ - content:""; } - -.bp3-icon-circle-arrow-left::before{ - content:""; } - -.bp3-icon-circle-arrow-right::before{ - content:""; } - -.bp3-icon-circle-arrow-up::before{ - content:""; } - -.bp3-icon-citation::before{ - content:""; } - -.bp3-icon-clean::before{ - content:""; } - -.bp3-icon-clipboard::before{ - content:""; } - -.bp3-icon-cloud::before{ - content:"☁"; } - -.bp3-icon-cloud-download::before{ - content:""; } - -.bp3-icon-cloud-upload::before{ - content:""; } - -.bp3-icon-code::before{ - content:""; } - -.bp3-icon-code-block::before{ - content:""; } - -.bp3-icon-cog::before{ - content:""; } - -.bp3-icon-collapse-all::before{ - content:""; } - -.bp3-icon-column-layout::before{ - content:""; } - -.bp3-icon-comment::before{ - content:""; } - -.bp3-icon-comparison::before{ - content:""; } - -.bp3-icon-compass::before{ - content:""; } - -.bp3-icon-compressed::before{ - content:""; } - -.bp3-icon-confirm::before{ - content:""; } - -.bp3-icon-console::before{ - content:""; } - -.bp3-icon-contrast::before{ - content:""; } - -.bp3-icon-control::before{ - content:""; } - -.bp3-icon-credit-card::before{ - content:""; } - -.bp3-icon-cross::before{ - content:"✗"; } - -.bp3-icon-crown::before{ - content:""; } - -.bp3-icon-cube::before{ - content:""; } - -.bp3-icon-cube-add::before{ - content:""; } - -.bp3-icon-cube-remove::before{ - content:""; } - -.bp3-icon-curved-range-chart::before{ - content:""; } - -.bp3-icon-cut::before{ - content:""; } - -.bp3-icon-dashboard::before{ - content:""; } - -.bp3-icon-data-lineage::before{ - content:""; } - -.bp3-icon-database::before{ - content:""; } - -.bp3-icon-delete::before{ - content:""; } - -.bp3-icon-delta::before{ - content:"Δ"; } - -.bp3-icon-derive-column::before{ - content:""; } - -.bp3-icon-desktop::before{ - content:""; } - -.bp3-icon-diagnosis::before{ - content:""; } - -.bp3-icon-diagram-tree::before{ - content:""; } - -.bp3-icon-direction-left::before{ - content:""; } - -.bp3-icon-direction-right::before{ - content:""; } - -.bp3-icon-disable::before{ - content:""; } - -.bp3-icon-document::before{ - content:""; } - -.bp3-icon-document-open::before{ - content:""; } - -.bp3-icon-document-share::before{ - content:""; } - -.bp3-icon-dollar::before{ - content:"$"; } - -.bp3-icon-dot::before{ - content:"•"; } - -.bp3-icon-double-caret-horizontal::before{ - content:""; } - -.bp3-icon-double-caret-vertical::before{ - content:""; } - -.bp3-icon-double-chevron-down::before{ - content:""; } - -.bp3-icon-double-chevron-left::before{ - content:""; } - -.bp3-icon-double-chevron-right::before{ - content:""; } - -.bp3-icon-double-chevron-up::before{ - content:""; } - -.bp3-icon-doughnut-chart::before{ - content:""; } - -.bp3-icon-download::before{ - content:""; } - -.bp3-icon-drag-handle-horizontal::before{ - content:""; } - -.bp3-icon-drag-handle-vertical::before{ - content:""; } - -.bp3-icon-draw::before{ - content:""; } - -.bp3-icon-drive-time::before{ - content:""; } - -.bp3-icon-duplicate::before{ - content:""; } - -.bp3-icon-edit::before{ - content:"✎"; } - -.bp3-icon-eject::before{ - content:"⏏"; } - -.bp3-icon-endorsed::before{ - content:""; } - -.bp3-icon-envelope::before{ - content:"✉"; } - -.bp3-icon-equals::before{ - content:""; } - -.bp3-icon-eraser::before{ - content:""; } - -.bp3-icon-error::before{ - content:""; } - -.bp3-icon-euro::before{ - content:"€"; } - -.bp3-icon-exchange::before{ - content:""; } - -.bp3-icon-exclude-row::before{ - content:""; } - -.bp3-icon-expand-all::before{ - content:""; } - -.bp3-icon-export::before{ - content:""; } - -.bp3-icon-eye-off::before{ - content:""; } - -.bp3-icon-eye-on::before{ - content:""; } - -.bp3-icon-eye-open::before{ - content:""; } - -.bp3-icon-fast-backward::before{ - content:""; } - -.bp3-icon-fast-forward::before{ - content:""; } - -.bp3-icon-feed::before{ - content:""; } - -.bp3-icon-feed-subscribed::before{ - content:""; } - -.bp3-icon-film::before{ - content:""; } - -.bp3-icon-filter::before{ - content:""; } - -.bp3-icon-filter-keep::before{ - content:""; } - -.bp3-icon-filter-list::before{ - content:""; } - -.bp3-icon-filter-open::before{ - content:""; } - -.bp3-icon-filter-remove::before{ - content:""; } - -.bp3-icon-flag::before{ - content:"⚑"; } - -.bp3-icon-flame::before{ - content:""; } - -.bp3-icon-flash::before{ - content:""; } - -.bp3-icon-floppy-disk::before{ - content:""; } - -.bp3-icon-flow-branch::before{ - content:""; } - -.bp3-icon-flow-end::before{ - content:""; } - -.bp3-icon-flow-linear::before{ - content:""; } - -.bp3-icon-flow-review::before{ - content:""; } - -.bp3-icon-flow-review-branch::before{ - content:""; } - -.bp3-icon-flows::before{ - content:""; } - -.bp3-icon-folder-close::before{ - content:""; } - -.bp3-icon-folder-new::before{ - content:""; } - -.bp3-icon-folder-open::before{ - content:""; } - -.bp3-icon-folder-shared::before{ - content:""; } - -.bp3-icon-folder-shared-open::before{ - content:""; } - -.bp3-icon-follower::before{ - content:""; } - -.bp3-icon-following::before{ - content:""; } - -.bp3-icon-font::before{ - content:""; } - -.bp3-icon-fork::before{ - content:""; } - -.bp3-icon-form::before{ - content:""; } - -.bp3-icon-full-circle::before{ - content:""; } - -.bp3-icon-full-stacked-chart::before{ - content:""; } - -.bp3-icon-fullscreen::before{ - content:""; } - -.bp3-icon-function::before{ - content:""; } - -.bp3-icon-gantt-chart::before{ - content:""; } - -.bp3-icon-geolocation::before{ - content:""; } - -.bp3-icon-geosearch::before{ - content:""; } - -.bp3-icon-git-branch::before{ - content:""; } - -.bp3-icon-git-commit::before{ - content:""; } - -.bp3-icon-git-merge::before{ - content:""; } - -.bp3-icon-git-new-branch::before{ - content:""; } - -.bp3-icon-git-pull::before{ - content:""; } - -.bp3-icon-git-push::before{ - content:""; } - -.bp3-icon-git-repo::before{ - content:""; } - -.bp3-icon-glass::before{ - content:""; } - -.bp3-icon-globe::before{ - content:""; } - -.bp3-icon-globe-network::before{ - content:""; } - -.bp3-icon-graph::before{ - content:""; } - -.bp3-icon-graph-remove::before{ - content:""; } - -.bp3-icon-greater-than::before{ - content:""; } - -.bp3-icon-greater-than-or-equal-to::before{ - content:""; } - -.bp3-icon-grid::before{ - content:""; } - -.bp3-icon-grid-view::before{ - content:""; } - -.bp3-icon-group-objects::before{ - content:""; } - -.bp3-icon-grouped-bar-chart::before{ - content:""; } - -.bp3-icon-hand::before{ - content:""; } - -.bp3-icon-hand-down::before{ - content:""; } - -.bp3-icon-hand-left::before{ - content:""; } - -.bp3-icon-hand-right::before{ - content:""; } - -.bp3-icon-hand-up::before{ - content:""; } - -.bp3-icon-header::before{ - content:""; } - -.bp3-icon-header-one::before{ - content:""; } - -.bp3-icon-header-two::before{ - content:""; } - -.bp3-icon-headset::before{ - content:""; } - -.bp3-icon-heart::before{ - content:"♥"; } - -.bp3-icon-heart-broken::before{ - content:""; } - -.bp3-icon-heat-grid::before{ - content:""; } - -.bp3-icon-heatmap::before{ - content:""; } - -.bp3-icon-help::before{ - content:"?"; } - -.bp3-icon-helper-management::before{ - content:""; } - -.bp3-icon-highlight::before{ - content:""; } - -.bp3-icon-history::before{ - content:""; } - -.bp3-icon-home::before{ - content:"⌂"; } - -.bp3-icon-horizontal-bar-chart::before{ - content:""; } - -.bp3-icon-horizontal-bar-chart-asc::before{ - content:""; } - -.bp3-icon-horizontal-bar-chart-desc::before{ - content:""; } - -.bp3-icon-horizontal-distribution::before{ - content:""; } - -.bp3-icon-id-number::before{ - content:""; } - -.bp3-icon-image-rotate-left::before{ - content:""; } - -.bp3-icon-image-rotate-right::before{ - content:""; } - -.bp3-icon-import::before{ - content:""; } - -.bp3-icon-inbox::before{ - content:""; } - -.bp3-icon-inbox-filtered::before{ - content:""; } - -.bp3-icon-inbox-geo::before{ - content:""; } - -.bp3-icon-inbox-search::before{ - content:""; } - -.bp3-icon-inbox-update::before{ - content:""; } - -.bp3-icon-info-sign::before{ - content:"ℹ"; } - -.bp3-icon-inheritance::before{ - content:""; } - -.bp3-icon-inner-join::before{ - content:""; } - -.bp3-icon-insert::before{ - content:""; } - -.bp3-icon-intersection::before{ - content:""; } - -.bp3-icon-ip-address::before{ - content:""; } - -.bp3-icon-issue::before{ - content:""; } - -.bp3-icon-issue-closed::before{ - content:""; } - -.bp3-icon-issue-new::before{ - content:""; } - -.bp3-icon-italic::before{ - content:""; } - -.bp3-icon-join-table::before{ - content:""; } - -.bp3-icon-key::before{ - content:""; } - -.bp3-icon-key-backspace::before{ - content:""; } - -.bp3-icon-key-command::before{ - content:""; } - -.bp3-icon-key-control::before{ - content:""; } - -.bp3-icon-key-delete::before{ - content:""; } - -.bp3-icon-key-enter::before{ - content:""; } - -.bp3-icon-key-escape::before{ - content:""; } - -.bp3-icon-key-option::before{ - content:""; } - -.bp3-icon-key-shift::before{ - content:""; } - -.bp3-icon-key-tab::before{ - content:""; } - -.bp3-icon-known-vehicle::before{ - content:""; } - -.bp3-icon-lab-test::before{ - content:""; } - -.bp3-icon-label::before{ - content:""; } - -.bp3-icon-layer::before{ - content:""; } - -.bp3-icon-layers::before{ - content:""; } - -.bp3-icon-layout::before{ - content:""; } - -.bp3-icon-layout-auto::before{ - content:""; } - -.bp3-icon-layout-balloon::before{ - content:""; } - -.bp3-icon-layout-circle::before{ - content:""; } - -.bp3-icon-layout-grid::before{ - content:""; } - -.bp3-icon-layout-group-by::before{ - content:""; } - -.bp3-icon-layout-hierarchy::before{ - content:""; } - -.bp3-icon-layout-linear::before{ - content:""; } - -.bp3-icon-layout-skew-grid::before{ - content:""; } - -.bp3-icon-layout-sorted-clusters::before{ - content:""; } - -.bp3-icon-learning::before{ - content:""; } - -.bp3-icon-left-join::before{ - content:""; } - -.bp3-icon-less-than::before{ - content:""; } - -.bp3-icon-less-than-or-equal-to::before{ - content:""; } - -.bp3-icon-lifesaver::before{ - content:""; } - -.bp3-icon-lightbulb::before{ - content:""; } - -.bp3-icon-link::before{ - content:""; } - -.bp3-icon-list::before{ - content:"☰"; } - -.bp3-icon-list-columns::before{ - content:""; } - -.bp3-icon-list-detail-view::before{ - content:""; } - -.bp3-icon-locate::before{ - content:""; } - -.bp3-icon-lock::before{ - content:""; } - -.bp3-icon-log-in::before{ - content:""; } - -.bp3-icon-log-out::before{ - content:""; } - -.bp3-icon-manual::before{ - content:""; } - -.bp3-icon-manually-entered-data::before{ - content:""; } - -.bp3-icon-map::before{ - content:""; } - -.bp3-icon-map-create::before{ - content:""; } - -.bp3-icon-map-marker::before{ - content:""; } - -.bp3-icon-maximize::before{ - content:""; } - -.bp3-icon-media::before{ - content:""; } - -.bp3-icon-menu::before{ - content:""; } - -.bp3-icon-menu-closed::before{ - content:""; } - -.bp3-icon-menu-open::before{ - content:""; } - -.bp3-icon-merge-columns::before{ - content:""; } - -.bp3-icon-merge-links::before{ - content:""; } - -.bp3-icon-minimize::before{ - content:""; } - -.bp3-icon-minus::before{ - content:"−"; } - -.bp3-icon-mobile-phone::before{ - content:""; } - -.bp3-icon-mobile-video::before{ - content:""; } - -.bp3-icon-moon::before{ - content:""; } - -.bp3-icon-more::before{ - content:""; } - -.bp3-icon-mountain::before{ - content:""; } - -.bp3-icon-move::before{ - content:""; } - -.bp3-icon-mugshot::before{ - content:""; } - -.bp3-icon-multi-select::before{ - content:""; } - -.bp3-icon-music::before{ - content:""; } - -.bp3-icon-new-drawing::before{ - content:""; } - -.bp3-icon-new-grid-item::before{ - content:""; } - -.bp3-icon-new-layer::before{ - content:""; } - -.bp3-icon-new-layers::before{ - content:""; } - -.bp3-icon-new-link::before{ - content:""; } - -.bp3-icon-new-object::before{ - content:""; } - -.bp3-icon-new-person::before{ - content:""; } - -.bp3-icon-new-prescription::before{ - content:""; } - -.bp3-icon-new-text-box::before{ - content:""; } - -.bp3-icon-ninja::before{ - content:""; } - -.bp3-icon-not-equal-to::before{ - content:""; } - -.bp3-icon-notifications::before{ - content:""; } - -.bp3-icon-notifications-updated::before{ - content:""; } - -.bp3-icon-numbered-list::before{ - content:""; } - -.bp3-icon-numerical::before{ - content:""; } - -.bp3-icon-office::before{ - content:""; } - -.bp3-icon-offline::before{ - content:""; } - -.bp3-icon-oil-field::before{ - content:""; } - -.bp3-icon-one-column::before{ - content:""; } - -.bp3-icon-outdated::before{ - content:""; } - -.bp3-icon-page-layout::before{ - content:""; } - -.bp3-icon-panel-stats::before{ - content:""; } - -.bp3-icon-panel-table::before{ - content:""; } - -.bp3-icon-paperclip::before{ - content:""; } - -.bp3-icon-paragraph::before{ - content:""; } - -.bp3-icon-path::before{ - content:""; } - -.bp3-icon-path-search::before{ - content:""; } - -.bp3-icon-pause::before{ - content:""; } - -.bp3-icon-people::before{ - content:""; } - -.bp3-icon-percentage::before{ - content:""; } - -.bp3-icon-person::before{ - content:""; } - -.bp3-icon-phone::before{ - content:"☎"; } - -.bp3-icon-pie-chart::before{ - content:""; } - -.bp3-icon-pin::before{ - content:""; } - -.bp3-icon-pivot::before{ - content:""; } - -.bp3-icon-pivot-table::before{ - content:""; } - -.bp3-icon-play::before{ - content:""; } - -.bp3-icon-plus::before{ - content:"+"; } - -.bp3-icon-polygon-filter::before{ - content:""; } - -.bp3-icon-power::before{ - content:""; } - -.bp3-icon-predictive-analysis::before{ - content:""; } - -.bp3-icon-prescription::before{ - content:""; } - -.bp3-icon-presentation::before{ - content:""; } - -.bp3-icon-print::before{ - content:"⎙"; } - -.bp3-icon-projects::before{ - content:""; } - -.bp3-icon-properties::before{ - content:""; } - -.bp3-icon-property::before{ - content:""; } - -.bp3-icon-publish-function::before{ - content:""; } - -.bp3-icon-pulse::before{ - content:""; } - -.bp3-icon-random::before{ - content:""; } - -.bp3-icon-record::before{ - content:""; } - -.bp3-icon-redo::before{ - content:""; } - -.bp3-icon-refresh::before{ - content:""; } - -.bp3-icon-regression-chart::before{ - content:""; } - -.bp3-icon-remove::before{ - content:""; } - -.bp3-icon-remove-column::before{ - content:""; } - -.bp3-icon-remove-column-left::before{ - content:""; } - -.bp3-icon-remove-column-right::before{ - content:""; } - -.bp3-icon-remove-row-bottom::before{ - content:""; } - -.bp3-icon-remove-row-top::before{ - content:""; } - -.bp3-icon-repeat::before{ - content:""; } - -.bp3-icon-reset::before{ - content:""; } - -.bp3-icon-resolve::before{ - content:""; } - -.bp3-icon-rig::before{ - content:""; } - -.bp3-icon-right-join::before{ - content:""; } - -.bp3-icon-ring::before{ - content:""; } - -.bp3-icon-rotate-document::before{ - content:""; } - -.bp3-icon-rotate-page::before{ - content:""; } - -.bp3-icon-satellite::before{ - content:""; } - -.bp3-icon-saved::before{ - content:""; } - -.bp3-icon-scatter-plot::before{ - content:""; } - -.bp3-icon-search::before{ - content:""; } - -.bp3-icon-search-around::before{ - content:""; } - -.bp3-icon-search-template::before{ - content:""; } - -.bp3-icon-search-text::before{ - content:""; } - -.bp3-icon-segmented-control::before{ - content:""; } - -.bp3-icon-select::before{ - content:""; } - -.bp3-icon-selection::before{ - content:"⦿"; } - -.bp3-icon-send-to::before{ - content:""; } - -.bp3-icon-send-to-graph::before{ - content:""; } - -.bp3-icon-send-to-map::before{ - content:""; } - -.bp3-icon-series-add::before{ - content:""; } - -.bp3-icon-series-configuration::before{ - content:""; } - -.bp3-icon-series-derived::before{ - content:""; } - -.bp3-icon-series-filtered::before{ - content:""; } - -.bp3-icon-series-search::before{ - content:""; } - -.bp3-icon-settings::before{ - content:""; } - -.bp3-icon-share::before{ - content:""; } - -.bp3-icon-shield::before{ - content:""; } - -.bp3-icon-shop::before{ - content:""; } - -.bp3-icon-shopping-cart::before{ - content:""; } - -.bp3-icon-signal-search::before{ - content:""; } - -.bp3-icon-sim-card::before{ - content:""; } - -.bp3-icon-slash::before{ - content:""; } - -.bp3-icon-small-cross::before{ - content:""; } - -.bp3-icon-small-minus::before{ - content:""; } - -.bp3-icon-small-plus::before{ - content:""; } - -.bp3-icon-small-tick::before{ - content:""; } - -.bp3-icon-snowflake::before{ - content:""; } - -.bp3-icon-social-media::before{ - content:""; } - -.bp3-icon-sort::before{ - content:""; } - -.bp3-icon-sort-alphabetical::before{ - content:""; } - -.bp3-icon-sort-alphabetical-desc::before{ - content:""; } - -.bp3-icon-sort-asc::before{ - content:""; } - -.bp3-icon-sort-desc::before{ - content:""; } - -.bp3-icon-sort-numerical::before{ - content:""; } - -.bp3-icon-sort-numerical-desc::before{ - content:""; } - -.bp3-icon-split-columns::before{ - content:""; } - -.bp3-icon-square::before{ - content:""; } - -.bp3-icon-stacked-chart::before{ - content:""; } - -.bp3-icon-star::before{ - content:"★"; } - -.bp3-icon-star-empty::before{ - content:"☆"; } - -.bp3-icon-step-backward::before{ - content:""; } - -.bp3-icon-step-chart::before{ - content:""; } - -.bp3-icon-step-forward::before{ - content:""; } - -.bp3-icon-stop::before{ - content:""; } - -.bp3-icon-stopwatch::before{ - content:""; } - -.bp3-icon-strikethrough::before{ - content:""; } - -.bp3-icon-style::before{ - content:""; } - -.bp3-icon-swap-horizontal::before{ - content:""; } - -.bp3-icon-swap-vertical::before{ - content:""; } - -.bp3-icon-symbol-circle::before{ - content:""; } - -.bp3-icon-symbol-cross::before{ - content:""; } - -.bp3-icon-symbol-diamond::before{ - content:""; } - -.bp3-icon-symbol-square::before{ - content:""; } - -.bp3-icon-symbol-triangle-down::before{ - content:""; } - -.bp3-icon-symbol-triangle-up::before{ - content:""; } - -.bp3-icon-tag::before{ - content:""; } - -.bp3-icon-take-action::before{ - content:""; } - -.bp3-icon-taxi::before{ - content:""; } - -.bp3-icon-text-highlight::before{ - content:""; } - -.bp3-icon-th::before{ - content:""; } - -.bp3-icon-th-derived::before{ - content:""; } - -.bp3-icon-th-disconnect::before{ - content:""; } - -.bp3-icon-th-filtered::before{ - content:""; } - -.bp3-icon-th-list::before{ - content:""; } - -.bp3-icon-thumbs-down::before{ - content:""; } - -.bp3-icon-thumbs-up::before{ - content:""; } - -.bp3-icon-tick::before{ - content:"✓"; } - -.bp3-icon-tick-circle::before{ - content:""; } - -.bp3-icon-time::before{ - content:"⏲"; } - -.bp3-icon-timeline-area-chart::before{ - content:""; } - -.bp3-icon-timeline-bar-chart::before{ - content:""; } - -.bp3-icon-timeline-events::before{ - content:""; } - -.bp3-icon-timeline-line-chart::before{ - content:""; } - -.bp3-icon-tint::before{ - content:""; } - -.bp3-icon-torch::before{ - content:""; } - -.bp3-icon-tractor::before{ - content:""; } - -.bp3-icon-train::before{ - content:""; } - -.bp3-icon-translate::before{ - content:""; } - -.bp3-icon-trash::before{ - content:""; } - -.bp3-icon-tree::before{ - content:""; } - -.bp3-icon-trending-down::before{ - content:""; } - -.bp3-icon-trending-up::before{ - content:""; } - -.bp3-icon-truck::before{ - content:""; } - -.bp3-icon-two-columns::before{ - content:""; } - -.bp3-icon-unarchive::before{ - content:""; } - -.bp3-icon-underline::before{ - content:"⎁"; } - -.bp3-icon-undo::before{ - content:"⎌"; } - -.bp3-icon-ungroup-objects::before{ - content:""; } - -.bp3-icon-unknown-vehicle::before{ - content:""; } - -.bp3-icon-unlock::before{ - content:""; } - -.bp3-icon-unpin::before{ - content:""; } - -.bp3-icon-unresolve::before{ - content:""; } - -.bp3-icon-updated::before{ - content:""; } - -.bp3-icon-upload::before{ - content:""; } - -.bp3-icon-user::before{ - content:""; } - -.bp3-icon-variable::before{ - content:""; } - -.bp3-icon-vertical-bar-chart-asc::before{ - content:""; } - -.bp3-icon-vertical-bar-chart-desc::before{ - content:""; } - -.bp3-icon-vertical-distribution::before{ - content:""; } - -.bp3-icon-video::before{ - content:""; } - -.bp3-icon-volume-down::before{ - content:""; } - -.bp3-icon-volume-off::before{ - content:""; } - -.bp3-icon-volume-up::before{ - content:""; } - -.bp3-icon-walk::before{ - content:""; } - -.bp3-icon-warning-sign::before{ - content:""; } - -.bp3-icon-waterfall-chart::before{ - content:""; } - -.bp3-icon-widget::before{ - content:""; } - -.bp3-icon-widget-button::before{ - content:""; } - -.bp3-icon-widget-footer::before{ - content:""; } - -.bp3-icon-widget-header::before{ - content:""; } - -.bp3-icon-wrench::before{ - content:""; } - -.bp3-icon-zoom-in::before{ - content:""; } - -.bp3-icon-zoom-out::before{ - content:""; } - -.bp3-icon-zoom-to-fit::before{ - content:""; } -.bp3-submenu > .bp3-popover-wrapper{ - display:block; } - -.bp3-submenu .bp3-popover-target{ - display:block; } - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ } - -.bp3-submenu.bp3-popover{ - -webkit-box-shadow:none; - box-shadow:none; - padding:0 5px; } - .bp3-submenu.bp3-popover > .bp3-popover-content{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-submenu.bp3-popover, .bp3-submenu.bp3-popover.bp3-dark{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-dark .bp3-submenu.bp3-popover > .bp3-popover-content, .bp3-submenu.bp3-popover.bp3-dark > .bp3-popover-content{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } -.bp3-menu{ - background:#ffffff; - border-radius:3px; - color:#182026; - list-style:none; - margin:0; - min-width:180px; - padding:5px; - text-align:left; } - -.bp3-menu-divider{ - border-top:1px solid rgba(16, 22, 26, 0.15); - display:block; - margin:5px; } - .bp3-dark .bp3-menu-divider{ - border-top-color:rgba(255, 255, 255, 0.15); } - -.bp3-menu-item{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - border-radius:2px; - color:inherit; - line-height:20px; - padding:5px 7px; - text-decoration:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-menu-item > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-menu-item > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-menu-item::before, - .bp3-menu-item > *{ - margin-right:7px; } - .bp3-menu-item:empty::before, - .bp3-menu-item > :last-child{ - margin-right:0; } - .bp3-menu-item > .bp3-fill{ - word-break:break-word; } - .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - background-color:rgba(167, 182, 194, 0.3); - cursor:pointer; - text-decoration:none; } - .bp3-menu-item.bp3-disabled{ - background-color:inherit; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-dark .bp3-menu-item{ - color:inherit; } - .bp3-dark .bp3-menu-item:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - background-color:rgba(138, 155, 168, 0.15); - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-disabled{ - background-color:inherit; - color:rgba(167, 182, 194, 0.6); } - .bp3-menu-item.bp3-intent-primary{ - color:#106ba3; } - .bp3-menu-item.bp3-intent-primary .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-primary::before, .bp3-menu-item.bp3-intent-primary::after, - .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{ - color:#106ba3; } - .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary.bp3-active{ - background-color:#137cbd; } - .bp3-menu-item.bp3-intent-primary:active{ - background-color:#106ba3; } - .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary:active, .bp3-menu-item.bp3-intent-primary:active::before, .bp3-menu-item.bp3-intent-primary:active::after, - .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-menu-item.bp3-intent-primary.bp3-active::after, - .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-success{ - color:#0d8050; } - .bp3-menu-item.bp3-intent-success .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-success::before, .bp3-menu-item.bp3-intent-success::after, - .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{ - color:#0d8050; } - .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success.bp3-active{ - background-color:#0f9960; } - .bp3-menu-item.bp3-intent-success:active{ - background-color:#0d8050; } - .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-menu-item.bp3-intent-success:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success:active, .bp3-menu-item.bp3-intent-success:active::before, .bp3-menu-item.bp3-intent-success:active::after, - .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-menu-item.bp3-intent-success.bp3-active::after, - .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-warning{ - color:#bf7326; } - .bp3-menu-item.bp3-intent-warning .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-warning::before, .bp3-menu-item.bp3-intent-warning::after, - .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{ - color:#bf7326; } - .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning.bp3-active{ - background-color:#d9822b; } - .bp3-menu-item.bp3-intent-warning:active{ - background-color:#bf7326; } - .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning:active, .bp3-menu-item.bp3-intent-warning:active::before, .bp3-menu-item.bp3-intent-warning:active::after, - .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-menu-item.bp3-intent-warning.bp3-active::after, - .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item.bp3-intent-danger{ - color:#c23030; } - .bp3-menu-item.bp3-intent-danger .bp3-icon{ - color:inherit; } - .bp3-menu-item.bp3-intent-danger::before, .bp3-menu-item.bp3-intent-danger::after, - .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{ - color:#c23030; } - .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger.bp3-active{ - background-color:#db3737; } - .bp3-menu-item.bp3-intent-danger:active{ - background-color:#c23030; } - .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, - .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label, - .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger:active, .bp3-menu-item.bp3-intent-danger:active::before, .bp3-menu-item.bp3-intent-danger:active::after, - .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-menu-item.bp3-intent-danger.bp3-active::after, - .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-menu-item::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - margin-right:7px; } - .bp3-menu-item::before, - .bp3-menu-item > .bp3-icon{ - color:#5c7080; - margin-top:2px; } - .bp3-menu-item .bp3-menu-item-label{ - color:#5c7080; } - .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ - color:inherit; } - .bp3-menu-item.bp3-active, .bp3-menu-item:active{ - background-color:rgba(115, 134, 148, 0.3); } - .bp3-menu-item.bp3-disabled{ - background-color:inherit !important; - color:rgba(92, 112, 128, 0.6) !important; - cursor:not-allowed !important; - outline:none !important; } - .bp3-menu-item.bp3-disabled::before, - .bp3-menu-item.bp3-disabled > .bp3-icon, - .bp3-menu-item.bp3-disabled .bp3-menu-item-label{ - color:rgba(92, 112, 128, 0.6) !important; } - .bp3-large .bp3-menu-item{ - font-size:16px; - line-height:22px; - padding:9px 7px; } - .bp3-large .bp3-menu-item .bp3-icon{ - margin-top:3px; } - .bp3-large .bp3-menu-item::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - margin-right:10px; - margin-top:1px; } - -button.bp3-menu-item{ - background:none; - border:none; - text-align:left; - width:100%; } -.bp3-menu-header{ - border-top:1px solid rgba(16, 22, 26, 0.15); - display:block; - margin:5px; - cursor:default; - padding-left:2px; } - .bp3-dark .bp3-menu-header{ - border-top-color:rgba(255, 255, 255, 0.15); } - .bp3-menu-header:first-of-type{ - border-top:none; } - .bp3-menu-header > h6{ - color:#182026; - font-weight:600; - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - line-height:17px; - margin:0; - padding:10px 7px 0 1px; } - .bp3-dark .bp3-menu-header > h6{ - color:#f5f8fa; } - .bp3-menu-header:first-of-type > h6{ - padding-top:0; } - .bp3-large .bp3-menu-header > h6{ - font-size:18px; - padding-bottom:5px; - padding-top:15px; } - .bp3-large .bp3-menu-header:first-of-type > h6{ - padding-top:0; } - -.bp3-dark .bp3-menu{ - background:#30404d; - color:#f5f8fa; } - -.bp3-dark .bp3-menu-item{ } - .bp3-dark .bp3-menu-item.bp3-intent-primary{ - color:#48aff0; } - .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-primary::before, .bp3-dark .bp3-menu-item.bp3-intent-primary::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{ - color:#48aff0; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active{ - background-color:#137cbd; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:active{ - background-color:#106ba3; } - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary:active, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-success{ - color:#3dcc91; } - .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-success::before, .bp3-dark .bp3-menu-item.bp3-intent-success::after, - .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{ - color:#3dcc91; } - .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active{ - background-color:#0f9960; } - .bp3-dark .bp3-menu-item.bp3-intent-success:active{ - background-color:#0d8050; } - .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success:active, .bp3-dark .bp3-menu-item.bp3-intent-success:active::before, .bp3-dark .bp3-menu-item.bp3-intent-success:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-warning{ - color:#ffb366; } - .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-warning::before, .bp3-dark .bp3-menu-item.bp3-intent-warning::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{ - color:#ffb366; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active{ - background-color:#d9822b; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:active{ - background-color:#bf7326; } - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning:active, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item.bp3-intent-danger{ - color:#ff7373; } - .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-icon{ - color:inherit; } - .bp3-dark .bp3-menu-item.bp3-intent-danger::before, .bp3-dark .bp3-menu-item.bp3-intent-danger::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{ - color:#ff7373; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active{ - background-color:#db3737; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:active{ - background-color:#c23030; } - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label, - .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, - .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger:active, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::after, - .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{ - color:#ffffff; } - .bp3-dark .bp3-menu-item::before, - .bp3-dark .bp3-menu-item > .bp3-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-menu-item .bp3-menu-item-label{ - color:#a7b6c2; } - .bp3-dark .bp3-menu-item.bp3-active, .bp3-dark .bp3-menu-item:active{ - background-color:rgba(138, 155, 168, 0.3); } - .bp3-dark .bp3-menu-item.bp3-disabled{ - color:rgba(167, 182, 194, 0.6) !important; } - .bp3-dark .bp3-menu-item.bp3-disabled::before, - .bp3-dark .bp3-menu-item.bp3-disabled > .bp3-icon, - .bp3-dark .bp3-menu-item.bp3-disabled .bp3-menu-item-label{ - color:rgba(167, 182, 194, 0.6) !important; } - -.bp3-dark .bp3-menu-divider, -.bp3-dark .bp3-menu-header{ - border-color:rgba(255, 255, 255, 0.15); } - -.bp3-dark .bp3-menu-header > h6{ - color:#f5f8fa; } - -.bp3-label .bp3-menu{ - margin-top:5px; } -.bp3-navbar{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); - height:50px; - padding:0 15px; - position:relative; - width:100%; - z-index:10; } - .bp3-navbar.bp3-dark, - .bp3-dark .bp3-navbar{ - background-color:#394b59; } - .bp3-navbar.bp3-dark{ - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-navbar{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-navbar.bp3-fixed-top{ - left:0; - position:fixed; - right:0; - top:0; } - -.bp3-navbar-heading{ - font-size:16px; - margin-right:15px; } - -.bp3-navbar-group{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:50px; } - .bp3-navbar-group.bp3-align-left{ - float:left; } - .bp3-navbar-group.bp3-align-right{ - float:right; } - -.bp3-navbar-divider{ - border-left:1px solid rgba(16, 22, 26, 0.15); - height:20px; - margin:0 10px; } - .bp3-dark .bp3-navbar-divider{ - border-left-color:rgba(255, 255, 255, 0.15); } -.bp3-non-ideal-state{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - height:100%; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - text-align:center; - width:100%; } - .bp3-non-ideal-state > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-non-ideal-state > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-non-ideal-state::before, - .bp3-non-ideal-state > *{ - margin-bottom:20px; } - .bp3-non-ideal-state:empty::before, - .bp3-non-ideal-state > :last-child{ - margin-bottom:0; } - .bp3-non-ideal-state > *{ - max-width:400px; } - -.bp3-non-ideal-state-visual{ - color:rgba(92, 112, 128, 0.6); - font-size:60px; } - .bp3-dark .bp3-non-ideal-state-visual{ - color:rgba(167, 182, 194, 0.6); } - -.bp3-overflow-list{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-wrap:nowrap; - flex-wrap:nowrap; - min-width:0; } - -.bp3-overflow-list-spacer{ - -ms-flex-negative:1; - flex-shrink:1; - width:1px; } - -body.bp3-overlay-open{ - overflow:hidden; } - -.bp3-overlay{ - bottom:0; - left:0; - position:static; - right:0; - top:0; - z-index:20; } - .bp3-overlay:not(.bp3-overlay-open){ - pointer-events:none; } - .bp3-overlay.bp3-overlay-container{ - overflow:hidden; - position:fixed; } - .bp3-overlay.bp3-overlay-container.bp3-overlay-inline{ - position:absolute; } - .bp3-overlay.bp3-overlay-scroll-container{ - overflow:auto; - position:fixed; } - .bp3-overlay.bp3-overlay-scroll-container.bp3-overlay-inline{ - position:absolute; } - .bp3-overlay.bp3-overlay-inline{ - display:inline; - overflow:visible; } - -.bp3-overlay-content{ - position:fixed; - z-index:20; } - .bp3-overlay-inline .bp3-overlay-content, - .bp3-overlay-scroll-container .bp3-overlay-content{ - position:absolute; } - -.bp3-overlay-backdrop{ - bottom:0; - left:0; - position:fixed; - right:0; - top:0; - opacity:1; - background-color:rgba(16, 22, 26, 0.7); - overflow:auto; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; - z-index:20; } - .bp3-overlay-backdrop.bp3-overlay-enter, .bp3-overlay-backdrop.bp3-overlay-appear{ - opacity:0; } - .bp3-overlay-backdrop.bp3-overlay-enter-active, .bp3-overlay-backdrop.bp3-overlay-appear-active{ - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-overlay-backdrop.bp3-overlay-exit{ - opacity:1; } - .bp3-overlay-backdrop.bp3-overlay-exit-active{ - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-overlay-backdrop:focus{ - outline:none; } - .bp3-overlay-inline .bp3-overlay-backdrop{ - position:absolute; } -.bp3-panel-stack{ - overflow:hidden; - position:relative; } - -.bp3-panel-stack-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 1px rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-negative:0; - flex-shrink:0; - height:30px; - z-index:1; } - .bp3-dark .bp3-panel-stack-header{ - -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 1px rgba(255, 255, 255, 0.15); } - .bp3-panel-stack-header > span{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; } - .bp3-panel-stack-header .bp3-heading{ - margin:0 5px; } - -.bp3-button.bp3-panel-stack-header-back{ - margin-left:5px; - padding-left:0; - white-space:nowrap; } - .bp3-button.bp3-panel-stack-header-back .bp3-icon{ - margin:0 2px; } - -.bp3-panel-stack-view{ - bottom:0; - left:0; - position:absolute; - right:0; - top:0; - background-color:#ffffff; - border-right:1px solid rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin-right:-1px; - overflow-y:auto; - z-index:1; } - .bp3-dark .bp3-panel-stack-view{ - background-color:#30404d; } - .bp3-panel-stack-view:nth-last-child(n + 4){ - display:none; } - -.bp3-panel-stack-push .bp3-panel-stack-enter, .bp3-panel-stack-push .bp3-panel-stack-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; } - -.bp3-panel-stack-push .bp3-panel-stack-enter-active, .bp3-panel-stack-push .bp3-panel-stack-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-push .bp3-panel-stack-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack-push .bp3-panel-stack-exit-active{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-pop .bp3-panel-stack-enter, .bp3-panel-stack-pop .bp3-panel-stack-appear{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; } - -.bp3-panel-stack-pop .bp3-panel-stack-enter-active, .bp3-panel-stack-pop .bp3-panel-stack-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack-pop .bp3-panel-stack-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack-pop .bp3-panel-stack-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } -.bp3-panel-stack2{ - overflow:hidden; - position:relative; } - -.bp3-panel-stack2-header{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15); - box-shadow:0 1px rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -ms-flex-negative:0; - flex-shrink:0; - height:30px; - z-index:1; } - .bp3-dark .bp3-panel-stack2-header{ - -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15); - box-shadow:0 1px rgba(255, 255, 255, 0.15); } - .bp3-panel-stack2-header > span{ - -webkit-box-align:stretch; - -ms-flex-align:stretch; - align-items:stretch; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:1; - -ms-flex:1; - flex:1; } - .bp3-panel-stack2-header .bp3-heading{ - margin:0 5px; } - -.bp3-button.bp3-panel-stack2-header-back{ - margin-left:5px; - padding-left:0; - white-space:nowrap; } - .bp3-button.bp3-panel-stack2-header-back .bp3-icon{ - margin:0 2px; } - -.bp3-panel-stack2-view{ - bottom:0; - left:0; - position:absolute; - right:0; - top:0; - background-color:#ffffff; - border-right:1px solid rgba(16, 22, 26, 0.15); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - margin-right:-1px; - overflow-y:auto; - z-index:1; } - .bp3-dark .bp3-panel-stack2-view{ - background-color:#30404d; } - .bp3-panel-stack2-view:nth-last-child(n + 4){ - display:none; } - -.bp3-panel-stack2-push .bp3-panel-stack2-enter, .bp3-panel-stack2-push .bp3-panel-stack2-appear{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; } - -.bp3-panel-stack2-push .bp3-panel-stack2-enter-active, .bp3-panel-stack2-push .bp3-panel-stack2-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-push .bp3-panel-stack2-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack2-push .bp3-panel-stack2-exit-active{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-enter, .bp3-panel-stack2-pop .bp3-panel-stack2-appear{ - -webkit-transform:translateX(-50%); - transform:translateX(-50%); - opacity:0; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-enter-active, .bp3-panel-stack2-pop .bp3-panel-stack2-appear-active{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-exit{ - -webkit-transform:translate(0%); - transform:translate(0%); - opacity:1; } - -.bp3-panel-stack2-pop .bp3-panel-stack2-exit-active{ - -webkit-transform:translateX(100%); - transform:translateX(100%); - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:400ms; - transition-duration:400ms; - -webkit-transition-property:opacity, -webkit-transform; - transition-property:opacity, -webkit-transform; - transition-property:transform, opacity; - transition-property:transform, opacity, -webkit-transform; - -webkit-transition-timing-function:ease; - transition-timing-function:ease; } -.bp3-popover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - -webkit-transform:scale(1); - transform:scale(1); - border-radius:3px; - display:inline-block; - z-index:20; } - .bp3-popover .bp3-popover-arrow{ - height:30px; - position:absolute; - width:30px; } - .bp3-popover .bp3-popover-arrow::before{ - height:20px; - margin:5px; - width:20px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover{ - margin-bottom:17px; - margin-top:-17px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{ - bottom:-11px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(-90deg); - transform:rotate(-90deg); } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover{ - margin-left:17px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{ - left:-11px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(0); - transform:rotate(0); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover{ - margin-top:17px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{ - top:-11px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover{ - margin-left:-17px; - margin-right:17px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{ - right:-11px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow svg{ - -webkit-transform:rotate(180deg); - transform:rotate(180deg); } - .bp3-tether-element-attached-middle > .bp3-popover > .bp3-popover-arrow{ - top:50%; - -webkit-transform:translateY(-50%); - transform:translateY(-50%); } - .bp3-tether-element-attached-center > .bp3-popover > .bp3-popover-arrow{ - right:50%; - -webkit-transform:translateX(50%); - transform:translateX(50%); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{ - top:-0.3934px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{ - right:-0.3934px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{ - left:-0.3934px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{ - bottom:-0.3934px; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:top left; - transform-origin:top left; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:top center; - transform-origin:top center; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:top right; - transform-origin:top right; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:center left; - transform-origin:center left; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:center center; - transform-origin:center center; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:center right; - transform-origin:center right; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-popover{ - -webkit-transform-origin:bottom left; - transform-origin:bottom left; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-popover{ - -webkit-transform-origin:bottom center; - transform-origin:bottom center; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-popover{ - -webkit-transform-origin:bottom right; - transform-origin:bottom right; } - .bp3-popover .bp3-popover-content{ - background:#ffffff; - color:inherit; } - .bp3-popover .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); } - .bp3-popover .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.1; } - .bp3-popover .bp3-popover-arrow-fill{ - fill:#ffffff; } - .bp3-popover-enter > .bp3-popover, .bp3-popover-appear > .bp3-popover{ - -webkit-transform:scale(0.3); - transform:scale(0.3); } - .bp3-popover-enter-active > .bp3-popover, .bp3-popover-appear-active > .bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-popover-exit > .bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-popover{ - -webkit-transform:scale(0.3); - transform:scale(0.3); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-popover .bp3-popover-content{ - border-radius:3px; - position:relative; } - .bp3-popover.bp3-popover-content-sizing .bp3-popover-content{ - max-width:350px; - padding:20px; } - .bp3-popover-target + .bp3-overlay .bp3-popover.bp3-popover-content-sizing{ - width:350px; } - .bp3-popover.bp3-minimal{ - margin:0 !important; } - .bp3-popover.bp3-minimal .bp3-popover-arrow{ - display:none; } - .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-enter > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-enter-active > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear-active > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover-exit > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-popover.bp3-minimal.bp3-popover{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover.bp3-dark, - .bp3-dark .bp3-popover{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-popover.bp3-dark .bp3-popover-content, - .bp3-dark .bp3-popover .bp3-popover-content{ - background:#30404d; - color:inherit; } - .bp3-popover.bp3-dark .bp3-popover-arrow::before, - .bp3-dark .bp3-popover .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); } - .bp3-popover.bp3-dark .bp3-popover-arrow-border, - .bp3-dark .bp3-popover .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.2; } - .bp3-popover.bp3-dark .bp3-popover-arrow-fill, - .bp3-dark .bp3-popover .bp3-popover-arrow-fill{ - fill:#30404d; } - -.bp3-popover-arrow::before{ - border-radius:2px; - content:""; - display:block; - position:absolute; - -webkit-transform:rotate(45deg); - transform:rotate(45deg); } - -.bp3-tether-pinned .bp3-popover-arrow{ - display:none; } - -.bp3-popover-backdrop{ - background:rgba(255, 255, 255, 0); } - -.bp3-transition-container{ - opacity:1; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - z-index:20; } - .bp3-transition-container.bp3-popover-enter, .bp3-transition-container.bp3-popover-appear{ - opacity:0; } - .bp3-transition-container.bp3-popover-enter-active, .bp3-transition-container.bp3-popover-appear-active{ - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-transition-container.bp3-popover-exit{ - opacity:1; } - .bp3-transition-container.bp3-popover-exit-active{ - opacity:0; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:opacity; - transition-property:opacity; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-transition-container:focus{ - outline:none; } - .bp3-transition-container.bp3-popover-leave .bp3-popover-content{ - pointer-events:none; } - .bp3-transition-container[data-x-out-of-boundaries]{ - display:none; } - -span.bp3-popover-target{ - display:inline-block; } - -.bp3-popover-wrapper.bp3-fill{ - width:100%; } - -.bp3-portal{ - left:0; - position:absolute; - right:0; - top:0; } -@-webkit-keyframes linear-progress-bar-stripes{ - from{ - background-position:0 0; } - to{ - background-position:30px 0; } } -@keyframes linear-progress-bar-stripes{ - from{ - background-position:0 0; } - to{ - background-position:30px 0; } } - -.bp3-progress-bar{ - background:rgba(92, 112, 128, 0.2); - border-radius:40px; - display:block; - height:8px; - overflow:hidden; - position:relative; - width:100%; } - .bp3-progress-bar .bp3-progress-meter{ - background:linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, transparent 75%); - background-color:rgba(92, 112, 128, 0.8); - background-size:30px 30px; - border-radius:40px; - height:100%; - position:absolute; - -webkit-transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - width:100%; } - .bp3-progress-bar:not(.bp3-no-animation):not(.bp3-no-stripes) .bp3-progress-meter{ - animation:linear-progress-bar-stripes 300ms linear infinite reverse; } - .bp3-progress-bar.bp3-no-stripes .bp3-progress-meter{ - background-image:none; } - -.bp3-dark .bp3-progress-bar{ - background:rgba(16, 22, 26, 0.5); } - .bp3-dark .bp3-progress-bar .bp3-progress-meter{ - background-color:#8a9ba8; } - -.bp3-progress-bar.bp3-intent-primary .bp3-progress-meter{ - background-color:#137cbd; } - -.bp3-progress-bar.bp3-intent-success .bp3-progress-meter{ - background-color:#0f9960; } - -.bp3-progress-bar.bp3-intent-warning .bp3-progress-meter{ - background-color:#d9822b; } - -.bp3-progress-bar.bp3-intent-danger .bp3-progress-meter{ - background-color:#db3737; } -@-webkit-keyframes skeleton-glow{ - from{ - background:rgba(206, 217, 224, 0.2); - border-color:rgba(206, 217, 224, 0.2); } - to{ - background:rgba(92, 112, 128, 0.2); - border-color:rgba(92, 112, 128, 0.2); } } -@keyframes skeleton-glow{ - from{ - background:rgba(206, 217, 224, 0.2); - border-color:rgba(206, 217, 224, 0.2); } - to{ - background:rgba(92, 112, 128, 0.2); - border-color:rgba(92, 112, 128, 0.2); } } -.bp3-skeleton{ - -webkit-animation:1000ms linear infinite alternate skeleton-glow; - animation:1000ms linear infinite alternate skeleton-glow; - background:rgba(206, 217, 224, 0.2); - background-clip:padding-box !important; - border-color:rgba(206, 217, 224, 0.2) !important; - border-radius:2px; - -webkit-box-shadow:none !important; - box-shadow:none !important; - color:transparent !important; - cursor:default; - pointer-events:none; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-skeleton::before, .bp3-skeleton::after, - .bp3-skeleton *{ - visibility:hidden !important; } -.bp3-slider{ - height:40px; - min-width:150px; - width:100%; - cursor:default; - outline:none; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-slider:hover{ - cursor:pointer; } - .bp3-slider:active{ - cursor:-webkit-grabbing; - cursor:grabbing; } - .bp3-slider.bp3-disabled{ - cursor:not-allowed; - opacity:0.5; } - .bp3-slider.bp3-slider-unlabeled{ - height:16px; } - -.bp3-slider-track, -.bp3-slider-progress{ - height:6px; - left:0; - right:0; - top:5px; - position:absolute; } - -.bp3-slider-track{ - border-radius:3px; - overflow:hidden; } - -.bp3-slider-progress{ - background:rgba(92, 112, 128, 0.2); } - .bp3-dark .bp3-slider-progress{ - background:rgba(16, 22, 26, 0.5); } - .bp3-slider-progress.bp3-intent-primary{ - background-color:#137cbd; } - .bp3-slider-progress.bp3-intent-success{ - background-color:#0f9960; } - .bp3-slider-progress.bp3-intent-warning{ - background-color:#d9822b; } - .bp3-slider-progress.bp3-intent-danger{ - background-color:#db3737; } - -.bp3-slider-handle{ - background-color:#f5f8fa; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0)); - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - color:#182026; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - cursor:pointer; - height:16px; - left:0; - position:absolute; - top:0; - width:16px; } - .bp3-slider-handle:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); } - .bp3-slider-handle:active, .bp3-slider-handle.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-slider-handle:disabled, .bp3-slider-handle.bp3-disabled{ - background-color:rgba(206, 217, 224, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; - outline:none; } - .bp3-slider-handle:disabled.bp3-active, .bp3-slider-handle:disabled.bp3-active:hover, .bp3-slider-handle.bp3-disabled.bp3-active, .bp3-slider-handle.bp3-disabled.bp3-active:hover{ - background:rgba(206, 217, 224, 0.7); } - .bp3-slider-handle:focus{ - z-index:1; } - .bp3-slider-handle:hover{ - background-clip:padding-box; - background-color:#ebf1f5; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2); - cursor:-webkit-grab; - cursor:grab; - z-index:2; } - .bp3-slider-handle.bp3-active{ - background-color:#d8e1e8; - background-image:none; - -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1); - cursor:-webkit-grabbing; - cursor:grabbing; } - .bp3-disabled .bp3-slider-handle{ - background:#bfccd6; - -webkit-box-shadow:none; - box-shadow:none; - pointer-events:none; } - .bp3-dark .bp3-slider-handle{ - background-color:#394b59; - background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0))); - background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0)); - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - color:#f5f8fa; } - .bp3-dark .bp3-slider-handle:hover, .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{ - color:#f5f8fa; } - .bp3-dark .bp3-slider-handle:hover{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{ - background-color:#202b33; - background-image:none; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-slider-handle:disabled, .bp3-dark .bp3-slider-handle.bp3-disabled{ - background-color:rgba(57, 75, 89, 0.5); - background-image:none; - -webkit-box-shadow:none; - box-shadow:none; - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-slider-handle:disabled.bp3-active, .bp3-dark .bp3-slider-handle.bp3-disabled.bp3-active{ - background:rgba(57, 75, 89, 0.7); } - .bp3-dark .bp3-slider-handle .bp3-button-spinner .bp3-spinner-head{ - background:rgba(16, 22, 26, 0.5); - stroke:#8a9ba8; } - .bp3-dark .bp3-slider-handle, .bp3-dark .bp3-slider-handle:hover{ - background-color:#394b59; } - .bp3-dark .bp3-slider-handle.bp3-active{ - background-color:#293742; } - .bp3-dark .bp3-disabled .bp3-slider-handle{ - background:#5c7080; - border-color:#5c7080; - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-slider-handle .bp3-slider-label{ - background:#394b59; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - color:#f5f8fa; - margin-left:8px; } - .bp3-dark .bp3-slider-handle .bp3-slider-label{ - background:#e1e8ed; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - color:#394b59; } - .bp3-disabled .bp3-slider-handle .bp3-slider-label{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-slider-handle.bp3-start, .bp3-slider-handle.bp3-end{ - width:8px; } - .bp3-slider-handle.bp3-start{ - border-bottom-right-radius:0; - border-top-right-radius:0; } - .bp3-slider-handle.bp3-end{ - border-bottom-left-radius:0; - border-top-left-radius:0; - margin-left:8px; } - .bp3-slider-handle.bp3-end .bp3-slider-label{ - margin-left:0; } - -.bp3-slider-label{ - -webkit-transform:translate(-50%, 20px); - transform:translate(-50%, 20px); - display:inline-block; - font-size:12px; - line-height:1; - padding:2px 5px; - position:absolute; - vertical-align:top; } - -.bp3-slider.bp3-vertical{ - height:150px; - min-width:40px; - width:40px; } - .bp3-slider.bp3-vertical .bp3-slider-track, - .bp3-slider.bp3-vertical .bp3-slider-progress{ - bottom:0; - height:auto; - left:5px; - top:0; - width:6px; } - .bp3-slider.bp3-vertical .bp3-slider-progress{ - top:auto; } - .bp3-slider.bp3-vertical .bp3-slider-label{ - -webkit-transform:translate(20px, 50%); - transform:translate(20px, 50%); } - .bp3-slider.bp3-vertical .bp3-slider-handle{ - top:auto; } - .bp3-slider.bp3-vertical .bp3-slider-handle .bp3-slider-label{ - margin-left:0; - margin-top:-8px; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end, .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{ - height:8px; - margin-left:0; - width:16px; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{ - border-bottom-right-radius:3px; - border-top-left-radius:0; } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start .bp3-slider-label{ - -webkit-transform:translate(20px); - transform:translate(20px); } - .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end{ - border-bottom-left-radius:0; - border-bottom-right-radius:0; - border-top-left-radius:3px; - margin-bottom:8px; } - -@-webkit-keyframes pt-spinner-animation{ - from{ - -webkit-transform:rotate(0deg); - transform:rotate(0deg); } - to{ - -webkit-transform:rotate(360deg); - transform:rotate(360deg); } } - -@keyframes pt-spinner-animation{ - from{ - -webkit-transform:rotate(0deg); - transform:rotate(0deg); } - to{ - -webkit-transform:rotate(360deg); - transform:rotate(360deg); } } - -.bp3-spinner{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-pack:center; - -ms-flex-pack:center; - justify-content:center; - overflow:visible; - vertical-align:middle; } - .bp3-spinner svg{ - display:block; } - .bp3-spinner path{ - fill-opacity:0; } - .bp3-spinner .bp3-spinner-head{ - stroke:rgba(92, 112, 128, 0.8); - stroke-linecap:round; - -webkit-transform-origin:center; - transform-origin:center; - -webkit-transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-spinner .bp3-spinner-track{ - stroke:rgba(92, 112, 128, 0.2); } - -.bp3-spinner-animation{ - -webkit-animation:pt-spinner-animation 500ms linear infinite; - animation:pt-spinner-animation 500ms linear infinite; } - .bp3-no-spin > .bp3-spinner-animation{ - -webkit-animation:none; - animation:none; } - -.bp3-dark .bp3-spinner .bp3-spinner-head{ - stroke:#8a9ba8; } - -.bp3-dark .bp3-spinner .bp3-spinner-track{ - stroke:rgba(16, 22, 26, 0.5); } - -.bp3-spinner.bp3-intent-primary .bp3-spinner-head{ - stroke:#137cbd; } - -.bp3-spinner.bp3-intent-success .bp3-spinner-head{ - stroke:#0f9960; } - -.bp3-spinner.bp3-intent-warning .bp3-spinner-head{ - stroke:#d9822b; } - -.bp3-spinner.bp3-intent-danger .bp3-spinner-head{ - stroke:#db3737; } -.bp3-tabs.bp3-vertical{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - .bp3-tabs.bp3-vertical > .bp3-tab-list{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab{ - border-radius:3px; - padding:0 10px; - width:100%; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab[aria-selected="true"]{ - background-color:rgba(19, 124, 189, 0.2); - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab-indicator-wrapper .bp3-tab-indicator{ - background-color:rgba(19, 124, 189, 0.2); - border-radius:3px; - bottom:0; - height:auto; - left:0; - right:0; - top:0; } - .bp3-tabs.bp3-vertical > .bp3-tab-panel{ - margin-top:0; - padding-left:20px; } - -.bp3-tab-list{ - -webkit-box-align:end; - -ms-flex-align:end; - align-items:flex-end; - border:none; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - list-style:none; - margin:0; - padding:0; - position:relative; } - .bp3-tab-list > *:not(:last-child){ - margin-right:20px; } - -.bp3-tab{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - color:#182026; - cursor:pointer; - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - font-size:14px; - line-height:30px; - max-width:100%; - position:relative; - vertical-align:top; } - .bp3-tab a{ - color:inherit; - display:block; - text-decoration:none; } - .bp3-tab-indicator-wrapper ~ .bp3-tab{ - background-color:transparent !important; - -webkit-box-shadow:none !important; - box-shadow:none !important; } - .bp3-tab[aria-disabled="true"]{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - .bp3-tab[aria-selected="true"]{ - border-radius:0; - -webkit-box-shadow:inset 0 -3px 0 #106ba3; - box-shadow:inset 0 -3px 0 #106ba3; } - .bp3-tab[aria-selected="true"], .bp3-tab:not([aria-disabled="true"]):hover{ - color:#106ba3; } - .bp3-tab:focus{ - -moz-outline-radius:0; } - .bp3-large > .bp3-tab{ - font-size:16px; - line-height:40px; } - -.bp3-tab-panel{ - margin-top:20px; } - .bp3-tab-panel[aria-hidden="true"]{ - display:none; } - -.bp3-tab-indicator-wrapper{ - left:0; - pointer-events:none; - position:absolute; - top:0; - -webkit-transform:translateX(0), translateY(0); - transform:translateX(0), translateY(0); - -webkit-transition:height, width, -webkit-transform; - transition:height, width, -webkit-transform; - transition:height, transform, width; - transition:height, transform, width, -webkit-transform; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tab-indicator-wrapper .bp3-tab-indicator{ - background-color:#106ba3; - bottom:0; - height:3px; - left:0; - position:absolute; - right:0; } - .bp3-tab-indicator-wrapper.bp3-no-animation{ - -webkit-transition:none; - transition:none; } - -.bp3-dark .bp3-tab{ - color:#f5f8fa; } - .bp3-dark .bp3-tab[aria-disabled="true"]{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tab[aria-selected="true"]{ - -webkit-box-shadow:inset 0 -3px 0 #48aff0; - box-shadow:inset 0 -3px 0 #48aff0; } - .bp3-dark .bp3-tab[aria-selected="true"], .bp3-dark .bp3-tab:not([aria-disabled="true"]):hover{ - color:#48aff0; } - -.bp3-dark .bp3-tab-indicator{ - background-color:#48aff0; } - -.bp3-flex-expander{ - -webkit-box-flex:1; - -ms-flex:1 1; - flex:1 1; } -.bp3-tag{ - display:-webkit-inline-box; - display:-ms-inline-flexbox; - display:inline-flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - background-color:#5c7080; - border:none; - border-radius:3px; - -webkit-box-shadow:none; - box-shadow:none; - color:#f5f8fa; - font-size:12px; - line-height:16px; - max-width:100%; - min-height:20px; - min-width:20px; - padding:2px 6px; - position:relative; } - .bp3-tag.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-interactive:hover{ - background-color:rgba(92, 112, 128, 0.85); } - .bp3-tag.bp3-interactive.bp3-active, .bp3-tag.bp3-interactive:active{ - background-color:rgba(92, 112, 128, 0.7); } - .bp3-tag > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag::before, - .bp3-tag > *{ - margin-right:4px; } - .bp3-tag:empty::before, - .bp3-tag > :last-child{ - margin-right:0; } - .bp3-tag:focus{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:0; - -moz-outline-radius:6px; } - .bp3-tag.bp3-round{ - border-radius:30px; - padding-left:8px; - padding-right:8px; } - .bp3-dark .bp3-tag{ - background-color:#bfccd6; - color:#182026; } - .bp3-dark .bp3-tag.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-interactive:hover{ - background-color:rgba(191, 204, 214, 0.85); } - .bp3-dark .bp3-tag.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-interactive:active{ - background-color:rgba(191, 204, 214, 0.7); } - .bp3-dark .bp3-tag > .bp3-icon, .bp3-dark .bp3-tag .bp3-icon-standard, .bp3-dark .bp3-tag .bp3-icon-large{ - fill:currentColor; } - .bp3-tag > .bp3-icon, .bp3-tag .bp3-icon-standard, .bp3-tag .bp3-icon-large{ - fill:#ffffff; } - .bp3-tag.bp3-large, - .bp3-large .bp3-tag{ - font-size:14px; - line-height:20px; - min-height:30px; - min-width:30px; - padding:5px 10px; } - .bp3-tag.bp3-large::before, - .bp3-tag.bp3-large > *, - .bp3-large .bp3-tag::before, - .bp3-large .bp3-tag > *{ - margin-right:7px; } - .bp3-tag.bp3-large:empty::before, - .bp3-tag.bp3-large > :last-child, - .bp3-large .bp3-tag:empty::before, - .bp3-large .bp3-tag > :last-child{ - margin-right:0; } - .bp3-tag.bp3-large.bp3-round, - .bp3-large .bp3-tag.bp3-round{ - padding-left:12px; - padding-right:12px; } - .bp3-tag.bp3-intent-primary{ - background:#137cbd; - color:#ffffff; } - .bp3-tag.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.85); } - .bp3-tag.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.7); } - .bp3-tag.bp3-intent-success{ - background:#0f9960; - color:#ffffff; } - .bp3-tag.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.85); } - .bp3-tag.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.7); } - .bp3-tag.bp3-intent-warning{ - background:#d9822b; - color:#ffffff; } - .bp3-tag.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.85); } - .bp3-tag.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.7); } - .bp3-tag.bp3-intent-danger{ - background:#db3737; - color:#ffffff; } - .bp3-tag.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.85); } - .bp3-tag.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.7); } - .bp3-tag.bp3-fill{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - width:100%; } - .bp3-tag.bp3-minimal > .bp3-icon, .bp3-tag.bp3-minimal .bp3-icon-standard, .bp3-tag.bp3-minimal .bp3-icon-large{ - fill:#5c7080; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){ - background-color:rgba(138, 155, 168, 0.2); - color:#182026; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{ - background-color:rgba(92, 112, 128, 0.3); } - .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{ - background-color:rgba(92, 112, 128, 0.4); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){ - color:#f5f8fa; } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{ - background-color:rgba(191, 204, 214, 0.3); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{ - background-color:rgba(191, 204, 214, 0.4); } - .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) > .bp3-icon, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-large{ - fill:#a7b6c2; } - .bp3-tag.bp3-minimal.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.15); - color:#106ba3; } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-primary > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-large{ - fill:#137cbd; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary{ - background-color:rgba(19, 124, 189, 0.25); - color:#48aff0; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{ - background-color:rgba(19, 124, 189, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{ - background-color:rgba(19, 124, 189, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.15); - color:#0d8050; } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-success > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-large{ - fill:#0f9960; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success{ - background-color:rgba(15, 153, 96, 0.25); - color:#3dcc91; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{ - background-color:rgba(15, 153, 96, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{ - background-color:rgba(15, 153, 96, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.15); - color:#bf7326; } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-warning > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-large{ - fill:#d9822b; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning{ - background-color:rgba(217, 130, 43, 0.25); - color:#ffb366; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{ - background-color:rgba(217, 130, 43, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{ - background-color:rgba(217, 130, 43, 0.45); } - .bp3-tag.bp3-minimal.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.15); - color:#c23030; } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.25); } - .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.35); } - .bp3-tag.bp3-minimal.bp3-intent-danger > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-large{ - fill:#db3737; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger{ - background-color:rgba(219, 55, 55, 0.25); - color:#ff7373; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{ - cursor:pointer; } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{ - background-color:rgba(219, 55, 55, 0.35); } - .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{ - background-color:rgba(219, 55, 55, 0.45); } - -.bp3-tag-remove{ - background:none; - border:none; - color:inherit; - cursor:pointer; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin-bottom:-2px; - margin-right:-6px !important; - margin-top:-2px; - opacity:0.5; - padding:2px; - padding-left:0; } - .bp3-tag-remove:hover{ - background:none; - opacity:0.8; - text-decoration:none; } - .bp3-tag-remove:active{ - opacity:1; } - .bp3-tag-remove:empty::before{ - font-family:"Icons16", sans-serif; - font-size:16px; - font-style:normal; - font-weight:400; - line-height:1; - -moz-osx-font-smoothing:grayscale; - -webkit-font-smoothing:antialiased; - content:""; } - .bp3-large .bp3-tag-remove{ - margin-right:-10px !important; - padding:0 5px 0 0; } - .bp3-large .bp3-tag-remove:empty::before{ - font-family:"Icons20", sans-serif; - font-size:20px; - font-style:normal; - font-weight:400; - line-height:1; } -.bp3-tag-input{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - cursor:text; - height:auto; - line-height:inherit; - min-height:30px; - padding-left:5px; - padding-right:0; } - .bp3-tag-input > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag-input > .bp3-tag-input-values{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag-input .bp3-tag-input-icon{ - color:#5c7080; - margin-left:2px; - margin-right:7px; - margin-top:7px; } - .bp3-tag-input .bp3-tag-input-values{ - display:-webkit-box; - display:-ms-flexbox; - display:flex; - -webkit-box-orient:horizontal; - -webkit-box-direction:normal; - -ms-flex-direction:row; - flex-direction:row; - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - -ms-flex-item-align:stretch; - align-self:stretch; - -ms-flex-wrap:wrap; - flex-wrap:wrap; - margin-right:7px; - margin-top:5px; - min-width:0; } - .bp3-tag-input .bp3-tag-input-values > *{ - -webkit-box-flex:0; - -ms-flex-positive:0; - flex-grow:0; - -ms-flex-negative:0; - flex-shrink:0; } - .bp3-tag-input .bp3-tag-input-values > .bp3-fill{ - -webkit-box-flex:1; - -ms-flex-positive:1; - flex-grow:1; - -ms-flex-negative:1; - flex-shrink:1; } - .bp3-tag-input .bp3-tag-input-values::before, - .bp3-tag-input .bp3-tag-input-values > *{ - margin-right:5px; } - .bp3-tag-input .bp3-tag-input-values:empty::before, - .bp3-tag-input .bp3-tag-input-values > :last-child{ - margin-right:0; } - .bp3-tag-input .bp3-tag-input-values:first-child .bp3-input-ghost:first-child{ - padding-left:5px; } - .bp3-tag-input .bp3-tag-input-values > *{ - margin-bottom:5px; } - .bp3-tag-input .bp3-tag{ - overflow-wrap:break-word; } - .bp3-tag-input .bp3-tag.bp3-active{ - outline:rgba(19, 124, 189, 0.6) auto 2px; - outline-offset:0; - -moz-outline-radius:6px; } - .bp3-tag-input .bp3-input-ghost{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - line-height:20px; - width:80px; } - .bp3-tag-input .bp3-input-ghost:disabled, .bp3-tag-input .bp3-input-ghost.bp3-disabled{ - cursor:not-allowed; } - .bp3-tag-input .bp3-button, - .bp3-tag-input .bp3-spinner{ - margin:3px; - margin-left:0; } - .bp3-tag-input .bp3-button{ - min-height:24px; - min-width:24px; - padding:0 7px; } - .bp3-tag-input.bp3-large{ - height:auto; - min-height:40px; } - .bp3-tag-input.bp3-large::before, - .bp3-tag-input.bp3-large > *{ - margin-right:10px; } - .bp3-tag-input.bp3-large:empty::before, - .bp3-tag-input.bp3-large > :last-child{ - margin-right:0; } - .bp3-tag-input.bp3-large .bp3-tag-input-icon{ - margin-left:5px; - margin-top:10px; } - .bp3-tag-input.bp3-large .bp3-input-ghost{ - line-height:30px; } - .bp3-tag-input.bp3-large .bp3-button{ - min-height:30px; - min-width:30px; - padding:5px 10px; - margin:5px; - margin-left:0; } - .bp3-tag-input.bp3-large .bp3-spinner{ - margin:8px; - margin-left:0; } - .bp3-tag-input.bp3-active{ - background-color:#ffffff; - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-success{ - -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-tag-input.bp3-active.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); } - .bp3-dark .bp3-tag-input .bp3-tag-input-icon, .bp3-tag-input.bp3-dark .bp3-tag-input-icon{ - color:#a7b6c2; } - .bp3-dark .bp3-tag-input .bp3-input-ghost, .bp3-tag-input.bp3-dark .bp3-input-ghost{ - color:#f5f8fa; } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-webkit-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-webkit-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-moz-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-moz-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost:-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost:-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-ms-input-placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input .bp3-input-ghost::placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::placeholder{ - color:rgba(167, 182, 194, 0.6); } - .bp3-dark .bp3-tag-input.bp3-active, .bp3-tag-input.bp3-dark.bp3-active{ - background-color:rgba(16, 22, 26, 0.3); - -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-primary, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-primary{ - -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-success, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-success{ - -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-warning, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-warning{ - -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-danger, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-danger{ - -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); } - -.bp3-input-ghost{ - background:none; - border:none; - -webkit-box-shadow:none; - box-shadow:none; - padding:0; } - .bp3-input-ghost::-webkit-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::-moz-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost:-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::-ms-input-placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost::placeholder{ - color:rgba(92, 112, 128, 0.6); - opacity:1; } - .bp3-input-ghost:focus{ - outline:none !important; } -.bp3-toast{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - display:-webkit-box; - display:-ms-flexbox; - display:flex; - margin:20px 0 0; - max-width:500px; - min-width:300px; - pointer-events:all; - position:relative !important; } - .bp3-toast.bp3-toast-enter, .bp3-toast.bp3-toast-appear{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); } - .bp3-toast.bp3-toast-enter-active, .bp3-toast.bp3-toast-appear-active{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-toast.bp3-toast-enter ~ .bp3-toast, .bp3-toast.bp3-toast-appear ~ .bp3-toast{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); } - .bp3-toast.bp3-toast-enter-active ~ .bp3-toast, .bp3-toast.bp3-toast-appear-active ~ .bp3-toast{ - -webkit-transform:translateY(0); - transform:translateY(0); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); - transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); } - .bp3-toast.bp3-toast-exit{ - opacity:1; - -webkit-filter:blur(0); - filter:blur(0); } - .bp3-toast.bp3-toast-exit-active{ - opacity:0; - -webkit-filter:blur(10px); - filter:blur(10px); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:300ms; - transition-duration:300ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:opacity, filter; - transition-property:opacity, filter, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-toast.bp3-toast-exit ~ .bp3-toast{ - -webkit-transform:translateY(0); - transform:translateY(0); } - .bp3-toast.bp3-toast-exit-active ~ .bp3-toast{ - -webkit-transform:translateY(-40px); - transform:translateY(-40px); - -webkit-transition-delay:50ms; - transition-delay:50ms; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-toast .bp3-button-group{ - -webkit-box-flex:0; - -ms-flex:0 0 auto; - flex:0 0 auto; - padding:5px; - padding-left:0; } - .bp3-toast > .bp3-icon{ - color:#5c7080; - margin:12px; - margin-right:0; } - .bp3-toast.bp3-dark, - .bp3-dark .bp3-toast{ - background-color:#394b59; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-toast.bp3-dark > .bp3-icon, - .bp3-dark .bp3-toast > .bp3-icon{ - color:#a7b6c2; } - .bp3-toast[class*="bp3-intent-"] a{ - color:rgba(255, 255, 255, 0.7); } - .bp3-toast[class*="bp3-intent-"] a:hover{ - color:#ffffff; } - .bp3-toast[class*="bp3-intent-"] > .bp3-icon{ - color:#ffffff; } - .bp3-toast[class*="bp3-intent-"] .bp3-button, .bp3-toast[class*="bp3-intent-"] .bp3-button::before, - .bp3-toast[class*="bp3-intent-"] .bp3-button .bp3-icon, .bp3-toast[class*="bp3-intent-"] .bp3-button:active{ - color:rgba(255, 255, 255, 0.7) !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button:focus{ - outline-color:rgba(255, 255, 255, 0.5); } - .bp3-toast[class*="bp3-intent-"] .bp3-button:hover{ - background-color:rgba(255, 255, 255, 0.15) !important; - color:#ffffff !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button:active{ - background-color:rgba(255, 255, 255, 0.3) !important; - color:#ffffff !important; } - .bp3-toast[class*="bp3-intent-"] .bp3-button::after{ - background:rgba(255, 255, 255, 0.3) !important; } - .bp3-toast.bp3-intent-primary{ - background-color:#137cbd; - color:#ffffff; } - .bp3-toast.bp3-intent-success{ - background-color:#0f9960; - color:#ffffff; } - .bp3-toast.bp3-intent-warning{ - background-color:#d9822b; - color:#ffffff; } - .bp3-toast.bp3-intent-danger{ - background-color:#db3737; - color:#ffffff; } - -.bp3-toast-message{ - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - padding:11px; - word-break:break-word; } - -.bp3-toast-container{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box !important; - display:-ms-flexbox !important; - display:flex !important; - -webkit-box-orient:vertical; - -webkit-box-direction:normal; - -ms-flex-direction:column; - flex-direction:column; - left:0; - overflow:hidden; - padding:0 20px 20px; - pointer-events:none; - right:0; - z-index:40; } - .bp3-toast-container.bp3-toast-container-in-portal{ - position:fixed; } - .bp3-toast-container.bp3-toast-container-inline{ - position:absolute; } - .bp3-toast-container.bp3-toast-container-top{ - top:0; } - .bp3-toast-container.bp3-toast-container-bottom{ - bottom:0; - -webkit-box-orient:vertical; - -webkit-box-direction:reverse; - -ms-flex-direction:column-reverse; - flex-direction:column-reverse; - top:auto; } - .bp3-toast-container.bp3-toast-container-left{ - -webkit-box-align:start; - -ms-flex-align:start; - align-items:flex-start; } - .bp3-toast-container.bp3-toast-container-right{ - -webkit-box-align:end; - -ms-flex-align:end; - align-items:flex-end; } - -.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active), -.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active) ~ .bp3-toast, .bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active), -.bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active) ~ .bp3-toast, -.bp3-toast-container-bottom .bp3-toast.bp3-toast-exit-active ~ .bp3-toast, -.bp3-toast-container-bottom .bp3-toast.bp3-toast-leave-active ~ .bp3-toast{ - -webkit-transform:translateY(60px); - transform:translateY(60px); } -.bp3-tooltip{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-tooltip .bp3-popover-arrow{ - height:22px; - position:absolute; - width:22px; } - .bp3-tooltip .bp3-popover-arrow::before{ - height:14px; - margin:4px; - width:14px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip{ - margin-bottom:11px; - margin-top:-11px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{ - bottom:-8px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(-90deg); - transform:rotate(-90deg); } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip{ - margin-left:11px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{ - left:-8px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(0); - transform:rotate(0); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip{ - margin-top:11px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{ - top:-8px; } - .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip{ - margin-left:-11px; - margin-right:11px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{ - right:-8px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow svg{ - -webkit-transform:rotate(180deg); - transform:rotate(180deg); } - .bp3-tether-element-attached-middle > .bp3-tooltip > .bp3-popover-arrow{ - top:50%; - -webkit-transform:translateY(-50%); - transform:translateY(-50%); } - .bp3-tether-element-attached-center > .bp3-tooltip > .bp3-popover-arrow{ - right:50%; - -webkit-transform:translateX(50%); - transform:translateX(50%); } - .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{ - top:-0.22183px; } - .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{ - right:-0.22183px; } - .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{ - left:-0.22183px; } - .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{ - bottom:-0.22183px; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:top left; - transform-origin:top left; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:top center; - transform-origin:top center; } - .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:top right; - transform-origin:top right; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:center left; - transform-origin:center left; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:center center; - transform-origin:center center; } - .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:center right; - transform-origin:center right; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-tooltip{ - -webkit-transform-origin:bottom left; - transform-origin:bottom left; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-tooltip{ - -webkit-transform-origin:bottom center; - transform-origin:bottom center; } - .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-tooltip{ - -webkit-transform-origin:bottom right; - transform-origin:bottom right; } - .bp3-tooltip .bp3-popover-content{ - background:#394b59; - color:#f5f8fa; } - .bp3-tooltip .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); } - .bp3-tooltip .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.1; } - .bp3-tooltip .bp3-popover-arrow-fill{ - fill:#394b59; } - .bp3-popover-enter > .bp3-tooltip, .bp3-popover-appear > .bp3-tooltip{ - -webkit-transform:scale(0.8); - transform:scale(0.8); } - .bp3-popover-enter-active > .bp3-tooltip, .bp3-popover-appear-active > .bp3-tooltip{ - -webkit-transform:scale(1); - transform:scale(1); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-popover-exit > .bp3-tooltip{ - -webkit-transform:scale(1); - transform:scale(1); } - .bp3-popover-exit-active > .bp3-tooltip{ - -webkit-transform:scale(0.8); - transform:scale(0.8); - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:100ms; - transition-duration:100ms; - -webkit-transition-property:-webkit-transform; - transition-property:-webkit-transform; - transition-property:transform; - transition-property:transform, -webkit-transform; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tooltip .bp3-popover-content{ - padding:10px 12px; } - .bp3-tooltip.bp3-dark, - .bp3-dark .bp3-tooltip{ - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); } - .bp3-tooltip.bp3-dark .bp3-popover-content, - .bp3-dark .bp3-tooltip .bp3-popover-content{ - background:#e1e8ed; - color:#394b59; } - .bp3-tooltip.bp3-dark .bp3-popover-arrow::before, - .bp3-dark .bp3-tooltip .bp3-popover-arrow::before{ - -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); - box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); } - .bp3-tooltip.bp3-dark .bp3-popover-arrow-border, - .bp3-dark .bp3-tooltip .bp3-popover-arrow-border{ - fill:#10161a; - fill-opacity:0.2; } - .bp3-tooltip.bp3-dark .bp3-popover-arrow-fill, - .bp3-dark .bp3-tooltip .bp3-popover-arrow-fill{ - fill:#e1e8ed; } - .bp3-tooltip.bp3-intent-primary .bp3-popover-content{ - background:#137cbd; - color:#ffffff; } - .bp3-tooltip.bp3-intent-primary .bp3-popover-arrow-fill{ - fill:#137cbd; } - .bp3-tooltip.bp3-intent-success .bp3-popover-content{ - background:#0f9960; - color:#ffffff; } - .bp3-tooltip.bp3-intent-success .bp3-popover-arrow-fill{ - fill:#0f9960; } - .bp3-tooltip.bp3-intent-warning .bp3-popover-content{ - background:#d9822b; - color:#ffffff; } - .bp3-tooltip.bp3-intent-warning .bp3-popover-arrow-fill{ - fill:#d9822b; } - .bp3-tooltip.bp3-intent-danger .bp3-popover-content{ - background:#db3737; - color:#ffffff; } - .bp3-tooltip.bp3-intent-danger .bp3-popover-arrow-fill{ - fill:#db3737; } - -.bp3-tooltip-indicator{ - border-bottom:dotted 1px; - cursor:help; } -.bp3-tree .bp3-icon, .bp3-tree .bp3-icon-standard, .bp3-tree .bp3-icon-large{ - color:#5c7080; } - .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-tree .bp3-icon-large.bp3-intent-primary{ - color:#137cbd; } - .bp3-tree .bp3-icon.bp3-intent-success, .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-tree .bp3-icon-large.bp3-intent-success{ - color:#0f9960; } - .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-tree .bp3-icon-large.bp3-intent-warning{ - color:#d9822b; } - .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-tree .bp3-icon-large.bp3-intent-danger{ - color:#db3737; } - -.bp3-tree-node-list{ - list-style:none; - margin:0; - padding-left:0; } - -.bp3-tree-root{ - background-color:transparent; - cursor:default; - padding-left:0; - position:relative; } - -.bp3-tree-node-content-0{ - padding-left:0px; } - -.bp3-tree-node-content-1{ - padding-left:23px; } - -.bp3-tree-node-content-2{ - padding-left:46px; } - -.bp3-tree-node-content-3{ - padding-left:69px; } - -.bp3-tree-node-content-4{ - padding-left:92px; } - -.bp3-tree-node-content-5{ - padding-left:115px; } - -.bp3-tree-node-content-6{ - padding-left:138px; } - -.bp3-tree-node-content-7{ - padding-left:161px; } - -.bp3-tree-node-content-8{ - padding-left:184px; } - -.bp3-tree-node-content-9{ - padding-left:207px; } - -.bp3-tree-node-content-10{ - padding-left:230px; } - -.bp3-tree-node-content-11{ - padding-left:253px; } - -.bp3-tree-node-content-12{ - padding-left:276px; } - -.bp3-tree-node-content-13{ - padding-left:299px; } - -.bp3-tree-node-content-14{ - padding-left:322px; } - -.bp3-tree-node-content-15{ - padding-left:345px; } - -.bp3-tree-node-content-16{ - padding-left:368px; } - -.bp3-tree-node-content-17{ - padding-left:391px; } - -.bp3-tree-node-content-18{ - padding-left:414px; } - -.bp3-tree-node-content-19{ - padding-left:437px; } - -.bp3-tree-node-content-20{ - padding-left:460px; } - -.bp3-tree-node-content{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; - height:30px; - padding-right:5px; - width:100%; } - .bp3-tree-node-content:hover{ - background-color:rgba(191, 204, 214, 0.4); } - -.bp3-tree-node-caret, -.bp3-tree-node-caret-none{ - min-width:30px; } - -.bp3-tree-node-caret{ - color:#5c7080; - cursor:pointer; - padding:7px; - -webkit-transform:rotate(0deg); - transform:rotate(0deg); - -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); - transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-tree-node-caret:hover{ - color:#182026; } - .bp3-dark .bp3-tree-node-caret{ - color:#a7b6c2; } - .bp3-dark .bp3-tree-node-caret:hover{ - color:#f5f8fa; } - .bp3-tree-node-caret.bp3-tree-node-caret-open{ - -webkit-transform:rotate(90deg); - transform:rotate(90deg); } - .bp3-tree-node-caret.bp3-icon-standard::before{ - content:""; } - -.bp3-tree-node-icon{ - margin-right:7px; - position:relative; } - -.bp3-tree-node-label{ - overflow:hidden; - text-overflow:ellipsis; - white-space:nowrap; - word-wrap:normal; - -webkit-box-flex:1; - -ms-flex:1 1 auto; - flex:1 1 auto; - position:relative; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-tree-node-label span{ - display:inline; } - -.bp3-tree-node-secondary-label{ - padding:0 5px; - -webkit-user-select:none; - -moz-user-select:none; - -ms-user-select:none; - user-select:none; } - .bp3-tree-node-secondary-label .bp3-popover-wrapper, - .bp3-tree-node-secondary-label .bp3-popover-target{ - -webkit-box-align:center; - -ms-flex-align:center; - align-items:center; - display:-webkit-box; - display:-ms-flexbox; - display:flex; } - -.bp3-tree-node.bp3-disabled .bp3-tree-node-content{ - background-color:inherit; - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-tree-node.bp3-disabled .bp3-tree-node-caret, -.bp3-tree-node.bp3-disabled .bp3-tree-node-icon{ - color:rgba(92, 112, 128, 0.6); - cursor:not-allowed; } - -.bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{ - background-color:#137cbd; } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content, - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-standard, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-large{ - color:#ffffff; } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret::before{ - color:rgba(255, 255, 255, 0.7); } - .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret:hover::before{ - color:#ffffff; } - -.bp3-dark .bp3-tree-node-content:hover{ - background-color:rgba(92, 112, 128, 0.3); } - -.bp3-dark .bp3-tree .bp3-icon, .bp3-dark .bp3-tree .bp3-icon-standard, .bp3-dark .bp3-tree .bp3-icon-large{ - color:#a7b6c2; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-primary{ - color:#137cbd; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-success{ - color:#0f9960; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-warning{ - color:#d9822b; } - .bp3-dark .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-danger{ - color:#db3737; } - -.bp3-dark .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{ - background-color:#137cbd; } -.bp3-omnibar{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; - background-color:#ffffff; - border-radius:3px; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); - left:calc(50% - 250px); - top:20vh; - width:500px; - z-index:21; } - .bp3-omnibar.bp3-overlay-enter, .bp3-omnibar.bp3-overlay-appear{ - -webkit-filter:blur(20px); - filter:blur(20px); - opacity:0.2; } - .bp3-omnibar.bp3-overlay-enter-active, .bp3-omnibar.bp3-overlay-appear-active{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:filter, opacity; - transition-property:filter, opacity, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-omnibar.bp3-overlay-exit{ - -webkit-filter:blur(0); - filter:blur(0); - opacity:1; } - .bp3-omnibar.bp3-overlay-exit-active{ - -webkit-filter:blur(20px); - filter:blur(20px); - opacity:0.2; - -webkit-transition-delay:0; - transition-delay:0; - -webkit-transition-duration:200ms; - transition-duration:200ms; - -webkit-transition-property:opacity, -webkit-filter; - transition-property:opacity, -webkit-filter; - transition-property:filter, opacity; - transition-property:filter, opacity, -webkit-filter; - -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); - transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); } - .bp3-omnibar .bp3-input{ - background-color:transparent; - border-radius:0; } - .bp3-omnibar .bp3-input, .bp3-omnibar .bp3-input:focus{ - -webkit-box-shadow:none; - box-shadow:none; } - .bp3-omnibar .bp3-menu{ - background-color:transparent; - border-radius:0; - -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15); - max-height:calc(60vh - 40px); - overflow:auto; } - .bp3-omnibar .bp3-menu:empty{ - display:none; } - .bp3-dark .bp3-omnibar, .bp3-omnibar.bp3-dark{ - background-color:#30404d; - -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); - box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); } - -.bp3-omnibar-overlay .bp3-overlay-backdrop{ - background-color:rgba(16, 22, 26, 0.2); } - -.bp3-select-popover .bp3-popover-content{ - padding:5px; } - -.bp3-select-popover .bp3-input-group{ - margin-bottom:0; } - -.bp3-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; - padding:0; } - .bp3-select-popover .bp3-menu:not(:first-child){ - padding-top:5px; } - -.bp3-multi-select{ - min-width:150px; } - -.bp3-multi-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; } - -.bp3-select-popover .bp3-popover-content{ - padding:5px; } - -.bp3-select-popover .bp3-input-group{ - margin-bottom:0; } - -.bp3-select-popover .bp3-menu{ - max-height:300px; - max-width:400px; - overflow:auto; - padding:0; } - .bp3-select-popover .bp3-menu:not(:first-child){ - padding-top:5px; } -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */ - -/** - * (DEPRECATED) Support for consuming icons as CSS background images - */ - -/* Icons urls */ - -:root { - --jp-icon-add: url(); - --jp-icon-bug: url(); - --jp-icon-build: url(); - --jp-icon-caret-down-empty-thin: url(); - --jp-icon-caret-down-empty: url(); - --jp-icon-caret-down: url(); - --jp-icon-caret-left: url(); - --jp-icon-caret-right: url(); - --jp-icon-caret-up-empty-thin: url(); - --jp-icon-caret-up: url(); - --jp-icon-case-sensitive: url(); - --jp-icon-check: url(); - --jp-icon-circle-empty: url(); - --jp-icon-circle: url(); - --jp-icon-clear: url(); - --jp-icon-close: url(); - --jp-icon-code: url(); - --jp-icon-console: url(); - --jp-icon-copy: url(); - --jp-icon-copyright: url(); - --jp-icon-cut: url(); - --jp-icon-download: url(); - --jp-icon-edit: url(); - --jp-icon-ellipses: url(); - --jp-icon-extension: url(); - --jp-icon-fast-forward: url(); - --jp-icon-file-upload: url(); - --jp-icon-file: url(); - --jp-icon-filter-list: url(); - --jp-icon-folder: url(); - --jp-icon-html5: url(); - --jp-icon-image: url(); - --jp-icon-inspector: url(); - --jp-icon-json: url(); - --jp-icon-julia: url(); - --jp-icon-jupyter-favicon: url(); - --jp-icon-jupyter: url(); - --jp-icon-jupyterlab-wordmark: url(); - --jp-icon-kernel: url(); - --jp-icon-keyboard: url(); - --jp-icon-launcher: url(); - --jp-icon-line-form: url(); - --jp-icon-link: url(); - --jp-icon-list: url(); - --jp-icon-listings-info: url(); - --jp-icon-markdown: url(); - --jp-icon-new-folder: url(); - --jp-icon-not-trusted: url(); - --jp-icon-notebook: url(); - --jp-icon-numbering: url(); - --jp-icon-offline-bolt: url(); - --jp-icon-palette: url(); - --jp-icon-paste: url(); - --jp-icon-pdf: url(); - --jp-icon-python: url(); - --jp-icon-r-kernel: url(); - --jp-icon-react: url(); - --jp-icon-redo: url(); - --jp-icon-refresh: url(); - --jp-icon-regex: url(); - --jp-icon-run: url(); - --jp-icon-running: url(); - --jp-icon-save: url(); - --jp-icon-search: url(); - --jp-icon-settings: url(); - --jp-icon-spreadsheet: url(); - --jp-icon-stop: url(); - --jp-icon-tab: url(); - --jp-icon-table-rows: url(); - --jp-icon-tag: url(); - --jp-icon-terminal: url(); - --jp-icon-text-editor: url(); - --jp-icon-toc: url(); - --jp-icon-tree-view: url(); - --jp-icon-trusted: url(); - --jp-icon-undo: url(); - --jp-icon-vega: url(); - --jp-icon-yaml: url(); -} - -/* Icon CSS class declarations */ - -.jp-AddIcon { - background-image: var(--jp-icon-add); -} -.jp-BugIcon { - background-image: var(--jp-icon-bug); -} -.jp-BuildIcon { - background-image: var(--jp-icon-build); -} -.jp-CaretDownEmptyIcon { - background-image: var(--jp-icon-caret-down-empty); -} -.jp-CaretDownEmptyThinIcon { - background-image: var(--jp-icon-caret-down-empty-thin); -} -.jp-CaretDownIcon { - background-image: var(--jp-icon-caret-down); -} -.jp-CaretLeftIcon { - background-image: var(--jp-icon-caret-left); -} -.jp-CaretRightIcon { - background-image: var(--jp-icon-caret-right); -} -.jp-CaretUpEmptyThinIcon { - background-image: var(--jp-icon-caret-up-empty-thin); -} -.jp-CaretUpIcon { - background-image: var(--jp-icon-caret-up); -} -.jp-CaseSensitiveIcon { - background-image: var(--jp-icon-case-sensitive); -} -.jp-CheckIcon { - background-image: var(--jp-icon-check); -} -.jp-CircleEmptyIcon { - background-image: var(--jp-icon-circle-empty); -} -.jp-CircleIcon { - background-image: var(--jp-icon-circle); -} -.jp-ClearIcon { - background-image: var(--jp-icon-clear); -} -.jp-CloseIcon { - background-image: var(--jp-icon-close); -} -.jp-CodeIcon { - background-image: var(--jp-icon-code); -} -.jp-ConsoleIcon { - background-image: var(--jp-icon-console); -} -.jp-CopyIcon { - background-image: var(--jp-icon-copy); -} -.jp-CopyrightIcon { - background-image: var(--jp-icon-copyright); -} -.jp-CutIcon { - background-image: var(--jp-icon-cut); -} -.jp-DownloadIcon { - background-image: var(--jp-icon-download); -} -.jp-EditIcon { - background-image: var(--jp-icon-edit); -} -.jp-EllipsesIcon { - background-image: var(--jp-icon-ellipses); -} -.jp-ExtensionIcon { - background-image: var(--jp-icon-extension); -} -.jp-FastForwardIcon { - background-image: var(--jp-icon-fast-forward); -} -.jp-FileIcon { - background-image: var(--jp-icon-file); -} -.jp-FileUploadIcon { - background-image: var(--jp-icon-file-upload); -} -.jp-FilterListIcon { - background-image: var(--jp-icon-filter-list); -} -.jp-FolderIcon { - background-image: var(--jp-icon-folder); -} -.jp-Html5Icon { - background-image: var(--jp-icon-html5); -} -.jp-ImageIcon { - background-image: var(--jp-icon-image); -} -.jp-InspectorIcon { - background-image: var(--jp-icon-inspector); -} -.jp-JsonIcon { - background-image: var(--jp-icon-json); -} -.jp-JuliaIcon { - background-image: var(--jp-icon-julia); -} -.jp-JupyterFaviconIcon { - background-image: var(--jp-icon-jupyter-favicon); -} -.jp-JupyterIcon { - background-image: var(--jp-icon-jupyter); -} -.jp-JupyterlabWordmarkIcon { - background-image: var(--jp-icon-jupyterlab-wordmark); -} -.jp-KernelIcon { - background-image: var(--jp-icon-kernel); -} -.jp-KeyboardIcon { - background-image: var(--jp-icon-keyboard); -} -.jp-LauncherIcon { - background-image: var(--jp-icon-launcher); -} -.jp-LineFormIcon { - background-image: var(--jp-icon-line-form); -} -.jp-LinkIcon { - background-image: var(--jp-icon-link); -} -.jp-ListIcon { - background-image: var(--jp-icon-list); -} -.jp-ListingsInfoIcon { - background-image: var(--jp-icon-listings-info); -} -.jp-MarkdownIcon { - background-image: var(--jp-icon-markdown); -} -.jp-NewFolderIcon { - background-image: var(--jp-icon-new-folder); -} -.jp-NotTrustedIcon { - background-image: var(--jp-icon-not-trusted); -} -.jp-NotebookIcon { - background-image: var(--jp-icon-notebook); -} -.jp-NumberingIcon { - background-image: var(--jp-icon-numbering); -} -.jp-OfflineBoltIcon { - background-image: var(--jp-icon-offline-bolt); -} -.jp-PaletteIcon { - background-image: var(--jp-icon-palette); -} -.jp-PasteIcon { - background-image: var(--jp-icon-paste); -} -.jp-PdfIcon { - background-image: var(--jp-icon-pdf); -} -.jp-PythonIcon { - background-image: var(--jp-icon-python); -} -.jp-RKernelIcon { - background-image: var(--jp-icon-r-kernel); -} -.jp-ReactIcon { - background-image: var(--jp-icon-react); -} -.jp-RedoIcon { - background-image: var(--jp-icon-redo); -} -.jp-RefreshIcon { - background-image: var(--jp-icon-refresh); -} -.jp-RegexIcon { - background-image: var(--jp-icon-regex); -} -.jp-RunIcon { - background-image: var(--jp-icon-run); -} -.jp-RunningIcon { - background-image: var(--jp-icon-running); -} -.jp-SaveIcon { - background-image: var(--jp-icon-save); -} -.jp-SearchIcon { - background-image: var(--jp-icon-search); -} -.jp-SettingsIcon { - background-image: var(--jp-icon-settings); -} -.jp-SpreadsheetIcon { - background-image: var(--jp-icon-spreadsheet); -} -.jp-StopIcon { - background-image: var(--jp-icon-stop); -} -.jp-TabIcon { - background-image: var(--jp-icon-tab); -} -.jp-TableRowsIcon { - background-image: var(--jp-icon-table-rows); -} -.jp-TagIcon { - background-image: var(--jp-icon-tag); -} -.jp-TerminalIcon { - background-image: var(--jp-icon-terminal); -} -.jp-TextEditorIcon { - background-image: var(--jp-icon-text-editor); -} -.jp-TocIcon { - background-image: var(--jp-icon-toc); -} -.jp-TreeViewIcon { - background-image: var(--jp-icon-tree-view); -} -.jp-TrustedIcon { - background-image: var(--jp-icon-trusted); -} -.jp-UndoIcon { - background-image: var(--jp-icon-undo); -} -.jp-VegaIcon { - background-image: var(--jp-icon-vega); -} -.jp-YamlIcon { - background-image: var(--jp-icon-yaml); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * (DEPRECATED) Support for consuming icons as CSS background images - */ - -.jp-Icon, -.jp-MaterialIcon { - background-position: center; - background-repeat: no-repeat; - background-size: 16px; - min-width: 16px; - min-height: 16px; -} - -.jp-Icon-cover { - background-position: center; - background-repeat: no-repeat; - background-size: cover; -} - -/** - * (DEPRECATED) Support for specific CSS icon sizes - */ - -.jp-Icon-16 { - background-size: 16px; - min-width: 16px; - min-height: 16px; -} - -.jp-Icon-18 { - background-size: 18px; - min-width: 18px; - min-height: 18px; -} - -.jp-Icon-20 { - background-size: 20px; - min-width: 20px; - min-height: 20px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * Support for icons as inline SVG HTMLElements - */ - -/* recolor the primary elements of an icon */ -.jp-icon0[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon1[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon2[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon3[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon4[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon0[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon1[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon2[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon3[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon4[stroke] { - stroke: var(--jp-inverse-layout-color4); -} -/* recolor the accent elements of an icon */ -.jp-icon-accent0[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-accent1[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-accent2[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-accent3[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-accent4[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-accent0[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-accent1[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-accent2[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-accent3[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-accent4[stroke] { - stroke: var(--jp-layout-color4); -} -/* set the color of an icon to transparent */ -.jp-icon-none[fill] { - fill: none; -} - -.jp-icon-none[stroke] { - stroke: none; -} -/* brand icon colors. Same for light and dark */ -.jp-icon-brand0[fill] { - fill: var(--jp-brand-color0); -} -.jp-icon-brand1[fill] { - fill: var(--jp-brand-color1); -} -.jp-icon-brand2[fill] { - fill: var(--jp-brand-color2); -} -.jp-icon-brand3[fill] { - fill: var(--jp-brand-color3); -} -.jp-icon-brand4[fill] { - fill: var(--jp-brand-color4); -} - -.jp-icon-brand0[stroke] { - stroke: var(--jp-brand-color0); -} -.jp-icon-brand1[stroke] { - stroke: var(--jp-brand-color1); -} -.jp-icon-brand2[stroke] { - stroke: var(--jp-brand-color2); -} -.jp-icon-brand3[stroke] { - stroke: var(--jp-brand-color3); -} -.jp-icon-brand4[stroke] { - stroke: var(--jp-brand-color4); -} -/* warn icon colors. Same for light and dark */ -.jp-icon-warn0[fill] { - fill: var(--jp-warn-color0); -} -.jp-icon-warn1[fill] { - fill: var(--jp-warn-color1); -} -.jp-icon-warn2[fill] { - fill: var(--jp-warn-color2); -} -.jp-icon-warn3[fill] { - fill: var(--jp-warn-color3); -} - -.jp-icon-warn0[stroke] { - stroke: var(--jp-warn-color0); -} -.jp-icon-warn1[stroke] { - stroke: var(--jp-warn-color1); -} -.jp-icon-warn2[stroke] { - stroke: var(--jp-warn-color2); -} -.jp-icon-warn3[stroke] { - stroke: var(--jp-warn-color3); -} -/* icon colors that contrast well with each other and most backgrounds */ -.jp-icon-contrast0[fill] { - fill: var(--jp-icon-contrast-color0); -} -.jp-icon-contrast1[fill] { - fill: var(--jp-icon-contrast-color1); -} -.jp-icon-contrast2[fill] { - fill: var(--jp-icon-contrast-color2); -} -.jp-icon-contrast3[fill] { - fill: var(--jp-icon-contrast-color3); -} - -.jp-icon-contrast0[stroke] { - stroke: var(--jp-icon-contrast-color0); -} -.jp-icon-contrast1[stroke] { - stroke: var(--jp-icon-contrast-color1); -} -.jp-icon-contrast2[stroke] { - stroke: var(--jp-icon-contrast-color2); -} -.jp-icon-contrast3[stroke] { - stroke: var(--jp-icon-contrast-color3); -} - -/* CSS for icons in selected items in the settings editor */ -#setting-editor .jp-PluginList .jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} -#setting-editor - .jp-PluginList - .jp-mod-selected - .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} - -/* CSS for icons in selected filebrowser listing items */ -.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} -.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} - -/* CSS for icons in selected tabs in the sidebar tab manager */ -#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable[fill] { - fill: #fff; -} - -#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} -#tab-manager - .lm-TabBar-tab.jp-mod-active - .jp-icon-hover - :hover - .jp-icon-selectable[fill] { - fill: var(--jp-brand-color1); -} - -#tab-manager - .lm-TabBar-tab.jp-mod-active - .jp-icon-hover - :hover - .jp-icon-selectable-inverse[fill] { - fill: #fff; -} - -/** - * TODO: come up with non css-hack solution for showing the busy icon on top - * of the close icon - * CSS for complex behavior of close icon of tabs in the sidebar tab manager - */ -#tab-manager - .lm-TabBar-tab.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon3[fill] { - fill: none; -} -#tab-manager - .lm-TabBar-tab.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: var(--jp-inverse-layout-color3); -} - -#tab-manager - .lm-TabBar-tab.jp-mod-dirty.jp-mod-active - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: #fff; -} - -/** -* TODO: come up with non css-hack solution for showing the busy icon on top -* of the close icon -* CSS for complex behavior of close icon of tabs in the main area tabbar -*/ -.lm-DockPanel-tabBar - .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon3[fill] { - fill: none; -} -.lm-DockPanel-tabBar - .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty - > .lm-TabBar-tabCloseIcon - > :not(:hover) - > .jp-icon-busy[fill] { - fill: var(--jp-inverse-layout-color3); -} - -/* CSS for icons in status bar */ -#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] { - fill: #fff; -} - -#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] { - fill: var(--jp-brand-color1); -} -/* special handling for splash icon CSS. While the theme CSS reloads during - splash, the splash icon can loose theming. To prevent that, we set a - default for its color variable */ -:root { - --jp-warn-color0: var(--md-orange-700); -} - -/* not sure what to do with this one, used in filebrowser listing */ -.jp-DragIcon { - margin-right: 4px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/** - * Support for alt colors for icons as inline SVG HTMLElements - */ - -/* alt recolor the primary elements of an icon */ -.jp-icon-alt .jp-icon0[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-alt .jp-icon1[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-alt .jp-icon2[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-alt .jp-icon3[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-alt .jp-icon4[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-alt .jp-icon0[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-alt .jp-icon1[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-alt .jp-icon2[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-alt .jp-icon3[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-alt .jp-icon4[stroke] { - stroke: var(--jp-layout-color4); -} - -/* alt recolor the accent elements of an icon */ -.jp-icon-alt .jp-icon-accent0[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-alt .jp-icon-accent1[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-alt .jp-icon-accent2[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-alt .jp-icon-accent3[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-alt .jp-icon-accent4[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-alt .jp-icon-accent0[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-alt .jp-icon-accent1[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-alt .jp-icon-accent2[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-alt .jp-icon-accent3[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-alt .jp-icon-accent4[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-icon-hoverShow:not(:hover) svg { - display: none !important; -} - -/** - * Support for hover colors for icons as inline SVG HTMLElements - */ - -/** - * regular colors - */ - -/* recolor the primary elements of an icon */ -.jp-icon-hover :hover .jp-icon0-hover[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-hover :hover .jp-icon1-hover[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-hover :hover .jp-icon2-hover[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-hover :hover .jp-icon3-hover[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-hover :hover .jp-icon4-hover[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-hover :hover .jp-icon0-hover[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-hover :hover .jp-icon1-hover[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-hover :hover .jp-icon2-hover[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-hover :hover .jp-icon3-hover[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-hover :hover .jp-icon4-hover[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/* recolor the accent elements of an icon */ -.jp-icon-hover :hover .jp-icon-accent0-hover[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-hover :hover .jp-icon-accent1-hover[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-hover :hover .jp-icon-accent2-hover[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-hover :hover .jp-icon-accent3-hover[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-hover :hover .jp-icon-accent4-hover[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] { - stroke: var(--jp-layout-color4); -} - -/* set the color of an icon to transparent */ -.jp-icon-hover :hover .jp-icon-none-hover[fill] { - fill: none; -} - -.jp-icon-hover :hover .jp-icon-none-hover[stroke] { - stroke: none; -} - -/** - * inverse colors - */ - -/* inverse recolor the primary elements of an icon */ -.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] { - fill: var(--jp-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] { - fill: var(--jp-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] { - fill: var(--jp-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] { - fill: var(--jp-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] { - fill: var(--jp-layout-color4); -} - -.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] { - stroke: var(--jp-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] { - stroke: var(--jp-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] { - stroke: var(--jp-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] { - stroke: var(--jp-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] { - stroke: var(--jp-layout-color4); -} - -/* inverse recolor the accent elements of an icon */ -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] { - fill: var(--jp-inverse-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] { - fill: var(--jp-inverse-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] { - fill: var(--jp-inverse-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] { - fill: var(--jp-inverse-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] { - fill: var(--jp-inverse-layout-color4); -} - -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] { - stroke: var(--jp-inverse-layout-color0); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] { - stroke: var(--jp-inverse-layout-color1); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] { - stroke: var(--jp-inverse-layout-color2); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] { - stroke: var(--jp-inverse-layout-color3); -} -.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] { - stroke: var(--jp-inverse-layout-color4); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-switch { - display: flex; - align-items: center; - padding-left: 4px; - padding-right: 4px; - font-size: var(--jp-ui-font-size1); - background-color: transparent; - color: var(--jp-ui-font-color1); - border: none; - height: 20px; -} - -.jp-switch:hover { - background-color: var(--jp-layout-color2); -} - -.jp-switch-label { - margin-right: 5px; -} - -.jp-switch-track { - cursor: pointer; - background-color: var(--jp-border-color1); - -webkit-transition: 0.4s; - transition: 0.4s; - border-radius: 34px; - height: 16px; - width: 35px; - position: relative; -} - -.jp-switch-track::before { - content: ''; - position: absolute; - height: 10px; - width: 10px; - margin: 3px; - left: 0px; - background-color: var(--jp-ui-inverse-font-color1); - -webkit-transition: 0.4s; - transition: 0.4s; - border-radius: 50%; -} - -.jp-switch[aria-checked='true'] .jp-switch-track { - background-color: var(--jp-warn-color0); -} - -.jp-switch[aria-checked='true'] .jp-switch-track::before { - /* track width (35) - margins (3 + 3) - thumb width (10) */ - left: 19px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* Sibling imports */ - -/* Override Blueprint's _reset.scss styles */ -html { - box-sizing: unset; -} - -*, -*::before, -*::after { - box-sizing: unset; -} - -body { - color: unset; - font-family: var(--jp-ui-font-family); -} - -p { - margin-top: unset; - margin-bottom: unset; -} - -small { - font-size: unset; -} - -strong { - font-weight: unset; -} - -/* Override Blueprint's _typography.scss styles */ -a { - text-decoration: unset; - color: unset; -} -a:hover { - text-decoration: unset; - color: unset; -} - -/* Override Blueprint's _accessibility.scss styles */ -:focus { - outline: unset; - outline-offset: unset; - -moz-outline-radius: unset; -} - -/* Styles for ui-components */ -.jp-Button { - border-radius: var(--jp-border-radius); - padding: 0px 12px; - font-size: var(--jp-ui-font-size1); -} - -/* Use our own theme for hover styles */ -button.jp-Button.bp3-button.bp3-minimal:hover { - background-color: var(--jp-layout-color2); -} -.jp-Button.minimal { - color: unset !important; -} - -.jp-Button.jp-ToolbarButtonComponent { - text-transform: none; -} - -.jp-InputGroup input { - box-sizing: border-box; - border-radius: 0; - background-color: transparent; - color: var(--jp-ui-font-color0); - box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); -} - -.jp-InputGroup input:focus { - box-shadow: inset 0 0 0 var(--jp-border-width) - var(--jp-input-active-box-shadow-color), - inset 0 0 0 3px var(--jp-input-active-box-shadow-color); -} - -.jp-InputGroup input::placeholder, -input::placeholder { - color: var(--jp-ui-font-color3); -} - -.jp-BPIcon { - display: inline-block; - vertical-align: middle; - margin: auto; -} - -/* Stop blueprint futzing with our icon fills */ -.bp3-icon.jp-BPIcon > svg:not([fill]) { - fill: var(--jp-inverse-layout-color3); -} - -.jp-InputGroupAction { - padding: 6px; -} - -.jp-HTMLSelect.jp-DefaultStyle select { - background-color: initial; - border: none; - border-radius: 0; - box-shadow: none; - color: var(--jp-ui-font-color0); - display: block; - font-size: var(--jp-ui-font-size1); - height: 24px; - line-height: 14px; - padding: 0 25px 0 10px; - text-align: left; - -moz-appearance: none; - -webkit-appearance: none; -} - -/* Use our own theme for hover and option styles */ -.jp-HTMLSelect.jp-DefaultStyle select:hover, -.jp-HTMLSelect.jp-DefaultStyle select > option { - background-color: var(--jp-layout-color2); - color: var(--jp-ui-font-color0); -} -select { - box-sizing: border-box; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Collapse { - display: flex; - flex-direction: column; - align-items: stretch; - border-top: 1px solid var(--jp-border-color2); - border-bottom: 1px solid var(--jp-border-color2); -} - -.jp-Collapse-header { - padding: 1px 12px; - color: var(--jp-ui-font-color1); - background-color: var(--jp-layout-color1); - font-size: var(--jp-ui-font-size2); -} - -.jp-Collapse-header:hover { - background-color: var(--jp-layout-color2); -} - -.jp-Collapse-contents { - padding: 0px 12px 0px 12px; - background-color: var(--jp-layout-color1); - color: var(--jp-ui-font-color1); - overflow: auto; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-commandpalette-search-height: 28px; -} - -/*----------------------------------------------------------------------------- -| Overall styles -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette { - padding-bottom: 0px; - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); -} - -/*----------------------------------------------------------------------------- -| Modal variant -|----------------------------------------------------------------------------*/ - -.jp-ModalCommandPalette { - position: absolute; - z-index: 10000; - top: 38px; - left: 30%; - margin: 0; - padding: 4px; - width: 40%; - box-shadow: var(--jp-elevation-z4); - border-radius: 4px; - background: var(--jp-layout-color0); -} - -.jp-ModalCommandPalette .lm-CommandPalette { - max-height: 40vh; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after { - display: none; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header { - display: none; -} - -.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item { - margin-left: 4px; - margin-right: 4px; -} - -.jp-ModalCommandPalette - .lm-CommandPalette - .lm-CommandPalette-item.lm-mod-disabled { - display: none; -} - -/*----------------------------------------------------------------------------- -| Search -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette-search { - padding: 4px; - background-color: var(--jp-layout-color1); - z-index: 2; -} - -.lm-CommandPalette-wrapper { - overflow: overlay; - padding: 0px 9px; - background-color: var(--jp-input-active-background); - height: 30px; - box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); -} - -.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper { - box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color), - inset 0 0 0 3px var(--jp-input-active-box-shadow-color); -} - -.jp-SearchIconGroup { - color: white; - background-color: var(--jp-brand-color1); - position: absolute; - top: 4px; - right: 4px; - padding: 5px 5px 1px 5px; -} - -.jp-SearchIconGroup svg { - height: 20px; - width: 20px; -} - -.jp-SearchIconGroup .jp-icon3[fill] { - fill: var(--jp-layout-color0); -} - -.lm-CommandPalette-input { - background: transparent; - width: calc(100% - 18px); - float: left; - border: none; - outline: none; - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - line-height: var(--jp-private-commandpalette-search-height); -} - -.lm-CommandPalette-input::-webkit-input-placeholder, -.lm-CommandPalette-input::-moz-placeholder, -.lm-CommandPalette-input:-ms-input-placeholder { - color: var(--jp-ui-font-color2); - font-size: var(--jp-ui-font-size1); -} - -/*----------------------------------------------------------------------------- -| Results -|----------------------------------------------------------------------------*/ - -.lm-CommandPalette-header:first-child { - margin-top: 0px; -} - -.lm-CommandPalette-header { - border-bottom: solid var(--jp-border-width) var(--jp-border-color2); - color: var(--jp-ui-font-color1); - cursor: pointer; - display: flex; - font-size: var(--jp-ui-font-size0); - font-weight: 600; - letter-spacing: 1px; - margin-top: 8px; - padding: 8px 0 8px 12px; - text-transform: uppercase; -} - -.lm-CommandPalette-header.lm-mod-active { - background: var(--jp-layout-color2); -} - -.lm-CommandPalette-header > mark { - background-color: transparent; - font-weight: bold; - color: var(--jp-ui-font-color1); -} - -.lm-CommandPalette-item { - padding: 4px 12px 4px 4px; - color: var(--jp-ui-font-color1); - font-size: var(--jp-ui-font-size1); - font-weight: 400; - display: flex; -} - -.lm-CommandPalette-item.lm-mod-disabled { - color: var(--jp-ui-font-color2); -} - -.lm-CommandPalette-item.lm-mod-active { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-inverse-font-color0); -} - -.lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] { - fill: var(--jp-layout-color0); -} - -.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-inverse-font-color0); -} - -.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) { - background: var(--jp-layout-color2); -} - -.lm-CommandPalette-itemContent { - overflow: hidden; -} - -.lm-CommandPalette-itemLabel > mark { - color: var(--jp-ui-font-color0); - background-color: transparent; - font-weight: bold; -} - -.lm-CommandPalette-item.lm-mod-disabled mark { - color: var(--jp-ui-font-color2); -} - -.lm-CommandPalette-item .lm-CommandPalette-itemIcon { - margin: 0 4px 0 0; - position: relative; - width: 16px; - top: 2px; - flex: 0 0 auto; -} - -.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon { - opacity: 0.6; -} - -.lm-CommandPalette-item .lm-CommandPalette-itemShortcut { - flex: 0 0 auto; -} - -.lm-CommandPalette-itemCaption { - display: none; -} - -.lm-CommandPalette-content { - background-color: var(--jp-layout-color1); -} - -.lm-CommandPalette-content:empty:after { - content: 'No results'; - margin: auto; - margin-top: 20px; - width: 100px; - display: block; - font-size: var(--jp-ui-font-size2); - font-family: var(--jp-ui-font-family); - font-weight: lighter; -} - -.lm-CommandPalette-emptyMessage { - text-align: center; - margin-top: 24px; - line-height: 1.32; - padding: 0px 8px; - color: var(--jp-content-font-color3); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Dialog { - position: absolute; - z-index: 10000; - display: flex; - flex-direction: column; - align-items: center; - justify-content: center; - top: 0px; - left: 0px; - margin: 0; - padding: 0; - width: 100%; - height: 100%; - background: var(--jp-dialog-background); -} - -.jp-Dialog-content { - display: flex; - flex-direction: column; - margin-left: auto; - margin-right: auto; - background: var(--jp-layout-color1); - padding: 24px; - padding-bottom: 12px; - min-width: 300px; - min-height: 150px; - max-width: 1000px; - max-height: 500px; - box-sizing: border-box; - box-shadow: var(--jp-elevation-z20); - word-wrap: break-word; - border-radius: var(--jp-border-radius); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color1); - resize: both; -} - -.jp-Dialog-button { - overflow: visible; -} - -button.jp-Dialog-button:focus { - outline: 1px solid var(--jp-brand-color1); - outline-offset: 4px; - -moz-outline-radius: 0px; -} - -button.jp-Dialog-button:focus::-moz-focus-inner { - border: 0; -} - -button.jp-Dialog-close-button { - padding: 0; - height: 100%; - min-width: unset; - min-height: unset; -} - -.jp-Dialog-header { - display: flex; - justify-content: space-between; - flex: 0 0 auto; - padding-bottom: 12px; - font-size: var(--jp-ui-font-size3); - font-weight: 400; - color: var(--jp-ui-font-color0); -} - -.jp-Dialog-body { - display: flex; - flex-direction: column; - flex: 1 1 auto; - font-size: var(--jp-ui-font-size1); - background: var(--jp-layout-color1); - overflow: auto; -} - -.jp-Dialog-footer { - display: flex; - flex-direction: row; - justify-content: flex-end; - flex: 0 0 auto; - margin-left: -12px; - margin-right: -12px; - padding: 12px; -} - -.jp-Dialog-title { - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; -} - -.jp-Dialog-body > .jp-select-wrapper { - width: 100%; -} - -.jp-Dialog-body > button { - padding: 0px 16px; -} - -.jp-Dialog-body > label { - line-height: 1.4; - color: var(--jp-ui-font-color0); -} - -.jp-Dialog-button.jp-mod-styled:not(:last-child) { - margin-right: 12px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-HoverBox { - position: fixed; -} - -.jp-HoverBox.jp-mod-outofview { - display: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-IFrame { - width: 100%; - height: 100%; -} - -.jp-IFrame > iframe { - border: none; -} - -/* -When drag events occur, `p-mod-override-cursor` is added to the body. -Because iframes steal all cursor events, the following two rules are necessary -to suppress pointer events while resize drags are occurring. There may be a -better solution to this problem. -*/ -body.lm-mod-override-cursor .jp-IFrame { - position: relative; -} - -body.lm-mod-override-cursor .jp-IFrame:before { - content: ''; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; -} - -.jp-Input-Boolean-Dialog { - flex-direction: row-reverse; - align-items: end; - width: 100%; -} - -.jp-Input-Boolean-Dialog > label { - flex: 1 1 auto; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-MainAreaWidget > :focus { - outline: none; -} - -/** - * google-material-color v1.2.6 - * https://github.com/danlevan/google-material-color - */ -:root { - --md-red-50: #ffebee; - --md-red-100: #ffcdd2; - --md-red-200: #ef9a9a; - --md-red-300: #e57373; - --md-red-400: #ef5350; - --md-red-500: #f44336; - --md-red-600: #e53935; - --md-red-700: #d32f2f; - --md-red-800: #c62828; - --md-red-900: #b71c1c; - --md-red-A100: #ff8a80; - --md-red-A200: #ff5252; - --md-red-A400: #ff1744; - --md-red-A700: #d50000; - - --md-pink-50: #fce4ec; - --md-pink-100: #f8bbd0; - --md-pink-200: #f48fb1; - --md-pink-300: #f06292; - --md-pink-400: #ec407a; - --md-pink-500: #e91e63; - --md-pink-600: #d81b60; - --md-pink-700: #c2185b; - --md-pink-800: #ad1457; - --md-pink-900: #880e4f; - --md-pink-A100: #ff80ab; - --md-pink-A200: #ff4081; - --md-pink-A400: #f50057; - --md-pink-A700: #c51162; - - --md-purple-50: #f3e5f5; - --md-purple-100: #e1bee7; - --md-purple-200: #ce93d8; - --md-purple-300: #ba68c8; - --md-purple-400: #ab47bc; - --md-purple-500: #9c27b0; - --md-purple-600: #8e24aa; - --md-purple-700: #7b1fa2; - --md-purple-800: #6a1b9a; - --md-purple-900: #4a148c; - --md-purple-A100: #ea80fc; - --md-purple-A200: #e040fb; - --md-purple-A400: #d500f9; - --md-purple-A700: #aa00ff; - - --md-deep-purple-50: #ede7f6; - --md-deep-purple-100: #d1c4e9; - --md-deep-purple-200: #b39ddb; - --md-deep-purple-300: #9575cd; - --md-deep-purple-400: #7e57c2; - --md-deep-purple-500: #673ab7; - --md-deep-purple-600: #5e35b1; - --md-deep-purple-700: #512da8; - --md-deep-purple-800: #4527a0; - --md-deep-purple-900: #311b92; - --md-deep-purple-A100: #b388ff; - --md-deep-purple-A200: #7c4dff; - --md-deep-purple-A400: #651fff; - --md-deep-purple-A700: #6200ea; - - --md-indigo-50: #e8eaf6; - --md-indigo-100: #c5cae9; - --md-indigo-200: #9fa8da; - --md-indigo-300: #7986cb; - --md-indigo-400: #5c6bc0; - --md-indigo-500: #3f51b5; - --md-indigo-600: #3949ab; - --md-indigo-700: #303f9f; - --md-indigo-800: #283593; - --md-indigo-900: #1a237e; - --md-indigo-A100: #8c9eff; - --md-indigo-A200: #536dfe; - --md-indigo-A400: #3d5afe; - --md-indigo-A700: #304ffe; - - --md-blue-50: #e3f2fd; - --md-blue-100: #bbdefb; - --md-blue-200: #90caf9; - --md-blue-300: #64b5f6; - --md-blue-400: #42a5f5; - --md-blue-500: #2196f3; - --md-blue-600: #1e88e5; - --md-blue-700: #1976d2; - --md-blue-800: #1565c0; - --md-blue-900: #0d47a1; - --md-blue-A100: #82b1ff; - --md-blue-A200: #448aff; - --md-blue-A400: #2979ff; - --md-blue-A700: #2962ff; - - --md-light-blue-50: #e1f5fe; - --md-light-blue-100: #b3e5fc; - --md-light-blue-200: #81d4fa; - --md-light-blue-300: #4fc3f7; - --md-light-blue-400: #29b6f6; - --md-light-blue-500: #03a9f4; - --md-light-blue-600: #039be5; - --md-light-blue-700: #0288d1; - --md-light-blue-800: #0277bd; - --md-light-blue-900: #01579b; - --md-light-blue-A100: #80d8ff; - --md-light-blue-A200: #40c4ff; - --md-light-blue-A400: #00b0ff; - --md-light-blue-A700: #0091ea; - - --md-cyan-50: #e0f7fa; - --md-cyan-100: #b2ebf2; - --md-cyan-200: #80deea; - --md-cyan-300: #4dd0e1; - --md-cyan-400: #26c6da; - --md-cyan-500: #00bcd4; - --md-cyan-600: #00acc1; - --md-cyan-700: #0097a7; - --md-cyan-800: #00838f; - --md-cyan-900: #006064; - --md-cyan-A100: #84ffff; - --md-cyan-A200: #18ffff; - --md-cyan-A400: #00e5ff; - --md-cyan-A700: #00b8d4; - - --md-teal-50: #e0f2f1; - --md-teal-100: #b2dfdb; - --md-teal-200: #80cbc4; - --md-teal-300: #4db6ac; - --md-teal-400: #26a69a; - --md-teal-500: #009688; - --md-teal-600: #00897b; - --md-teal-700: #00796b; - --md-teal-800: #00695c; - --md-teal-900: #004d40; - --md-teal-A100: #a7ffeb; - --md-teal-A200: #64ffda; - --md-teal-A400: #1de9b6; - --md-teal-A700: #00bfa5; - - --md-green-50: #e8f5e9; - --md-green-100: #c8e6c9; - --md-green-200: #a5d6a7; - --md-green-300: #81c784; - --md-green-400: #66bb6a; - --md-green-500: #4caf50; - --md-green-600: #43a047; - --md-green-700: #388e3c; - --md-green-800: #2e7d32; - --md-green-900: #1b5e20; - --md-green-A100: #b9f6ca; - --md-green-A200: #69f0ae; - --md-green-A400: #00e676; - --md-green-A700: #00c853; - - --md-light-green-50: #f1f8e9; - --md-light-green-100: #dcedc8; - --md-light-green-200: #c5e1a5; - --md-light-green-300: #aed581; - --md-light-green-400: #9ccc65; - --md-light-green-500: #8bc34a; - --md-light-green-600: #7cb342; - --md-light-green-700: #689f38; - --md-light-green-800: #558b2f; - --md-light-green-900: #33691e; - --md-light-green-A100: #ccff90; - --md-light-green-A200: #b2ff59; - --md-light-green-A400: #76ff03; - --md-light-green-A700: #64dd17; - - --md-lime-50: #f9fbe7; - --md-lime-100: #f0f4c3; - --md-lime-200: #e6ee9c; - --md-lime-300: #dce775; - --md-lime-400: #d4e157; - --md-lime-500: #cddc39; - --md-lime-600: #c0ca33; - --md-lime-700: #afb42b; - --md-lime-800: #9e9d24; - --md-lime-900: #827717; - --md-lime-A100: #f4ff81; - --md-lime-A200: #eeff41; - --md-lime-A400: #c6ff00; - --md-lime-A700: #aeea00; - - --md-yellow-50: #fffde7; - --md-yellow-100: #fff9c4; - --md-yellow-200: #fff59d; - --md-yellow-300: #fff176; - --md-yellow-400: #ffee58; - --md-yellow-500: #ffeb3b; - --md-yellow-600: #fdd835; - --md-yellow-700: #fbc02d; - --md-yellow-800: #f9a825; - --md-yellow-900: #f57f17; - --md-yellow-A100: #ffff8d; - --md-yellow-A200: #ffff00; - --md-yellow-A400: #ffea00; - --md-yellow-A700: #ffd600; - - --md-amber-50: #fff8e1; - --md-amber-100: #ffecb3; - --md-amber-200: #ffe082; - --md-amber-300: #ffd54f; - --md-amber-400: #ffca28; - --md-amber-500: #ffc107; - --md-amber-600: #ffb300; - --md-amber-700: #ffa000; - --md-amber-800: #ff8f00; - --md-amber-900: #ff6f00; - --md-amber-A100: #ffe57f; - --md-amber-A200: #ffd740; - --md-amber-A400: #ffc400; - --md-amber-A700: #ffab00; - - --md-orange-50: #fff3e0; - --md-orange-100: #ffe0b2; - --md-orange-200: #ffcc80; - --md-orange-300: #ffb74d; - --md-orange-400: #ffa726; - --md-orange-500: #ff9800; - --md-orange-600: #fb8c00; - --md-orange-700: #f57c00; - --md-orange-800: #ef6c00; - --md-orange-900: #e65100; - --md-orange-A100: #ffd180; - --md-orange-A200: #ffab40; - --md-orange-A400: #ff9100; - --md-orange-A700: #ff6d00; - - --md-deep-orange-50: #fbe9e7; - --md-deep-orange-100: #ffccbc; - --md-deep-orange-200: #ffab91; - --md-deep-orange-300: #ff8a65; - --md-deep-orange-400: #ff7043; - --md-deep-orange-500: #ff5722; - --md-deep-orange-600: #f4511e; - --md-deep-orange-700: #e64a19; - --md-deep-orange-800: #d84315; - --md-deep-orange-900: #bf360c; - --md-deep-orange-A100: #ff9e80; - --md-deep-orange-A200: #ff6e40; - --md-deep-orange-A400: #ff3d00; - --md-deep-orange-A700: #dd2c00; - - --md-brown-50: #efebe9; - --md-brown-100: #d7ccc8; - --md-brown-200: #bcaaa4; - --md-brown-300: #a1887f; - --md-brown-400: #8d6e63; - --md-brown-500: #795548; - --md-brown-600: #6d4c41; - --md-brown-700: #5d4037; - --md-brown-800: #4e342e; - --md-brown-900: #3e2723; - - --md-grey-50: #fafafa; - --md-grey-100: #f5f5f5; - --md-grey-200: #eeeeee; - --md-grey-300: #e0e0e0; - --md-grey-400: #bdbdbd; - --md-grey-500: #9e9e9e; - --md-grey-600: #757575; - --md-grey-700: #616161; - --md-grey-800: #424242; - --md-grey-900: #212121; - - --md-blue-grey-50: #eceff1; - --md-blue-grey-100: #cfd8dc; - --md-blue-grey-200: #b0bec5; - --md-blue-grey-300: #90a4ae; - --md-blue-grey-400: #78909c; - --md-blue-grey-500: #607d8b; - --md-blue-grey-600: #546e7a; - --md-blue-grey-700: #455a64; - --md-blue-grey-800: #37474f; - --md-blue-grey-900: #263238; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Spinner { - position: absolute; - display: flex; - justify-content: center; - align-items: center; - z-index: 10; - left: 0; - top: 0; - width: 100%; - height: 100%; - background: var(--jp-layout-color0); - outline: none; -} - -.jp-SpinnerContent { - font-size: 10px; - margin: 50px auto; - text-indent: -9999em; - width: 3em; - height: 3em; - border-radius: 50%; - background: var(--jp-brand-color3); - background: linear-gradient( - to right, - #f37626 10%, - rgba(255, 255, 255, 0) 42% - ); - position: relative; - animation: load3 1s infinite linear, fadeIn 1s; -} - -.jp-SpinnerContent:before { - width: 50%; - height: 50%; - background: #f37626; - border-radius: 100% 0 0 0; - position: absolute; - top: 0; - left: 0; - content: ''; -} - -.jp-SpinnerContent:after { - background: var(--jp-layout-color0); - width: 75%; - height: 75%; - border-radius: 50%; - content: ''; - margin: auto; - position: absolute; - top: 0; - left: 0; - bottom: 0; - right: 0; -} - -@keyframes fadeIn { - 0% { - opacity: 0; - } - 100% { - opacity: 1; - } -} - -@keyframes load3 { - 0% { - transform: rotate(0deg); - } - 100% { - transform: rotate(360deg); - } -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -button.jp-mod-styled { - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - border: none; - box-sizing: border-box; - text-align: center; - line-height: 32px; - height: 32px; - padding: 0px 12px; - letter-spacing: 0.8px; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -input.jp-mod-styled { - background: var(--jp-input-background); - height: 28px; - box-sizing: border-box; - border: var(--jp-border-width) solid var(--jp-border-color1); - padding-left: 7px; - padding-right: 7px; - font-size: var(--jp-ui-font-size2); - color: var(--jp-ui-font-color0); - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -input[type='checkbox'].jp-mod-styled { - appearance: checkbox; - -webkit-appearance: checkbox; - -moz-appearance: checkbox; - height: auto; -} - -input.jp-mod-styled:focus { - border: var(--jp-border-width) solid var(--md-blue-500); - box-shadow: inset 0 0 4px var(--md-blue-300); -} - -.jp-FileDialog-Checkbox { - margin-top: 35px; - display: flex; - flex-direction: row; - align-items: end; - width: 100%; -} - -.jp-FileDialog-Checkbox > label { - flex: 1 1 auto; -} - -.jp-select-wrapper { - display: flex; - position: relative; - flex-direction: column; - padding: 1px; - background-color: var(--jp-layout-color1); - height: 28px; - box-sizing: border-box; - margin-bottom: 12px; -} - -.jp-select-wrapper.jp-mod-focused select.jp-mod-styled { - border: var(--jp-border-width) solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); - background-color: var(--jp-input-active-background); -} - -select.jp-mod-styled:hover { - background-color: var(--jp-layout-color1); - cursor: pointer; - color: var(--jp-ui-font-color0); - background-color: var(--jp-input-hover-background); - box-shadow: inset 0 0px 1px rgba(0, 0, 0, 0.5); -} - -select.jp-mod-styled { - flex: 1 1 auto; - height: 32px; - width: 100%; - font-size: var(--jp-ui-font-size2); - background: var(--jp-input-background); - color: var(--jp-ui-font-color0); - padding: 0 25px 0 8px; - border: var(--jp-border-width) solid var(--jp-input-border-color); - border-radius: 0px; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-toolbar-height: calc( - 28px + var(--jp-border-width) - ); /* leave 28px for content */ -} - -.jp-Toolbar { - color: var(--jp-ui-font-color1); - flex: 0 0 auto; - display: flex; - flex-direction: row; - border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); - box-shadow: var(--jp-toolbar-box-shadow); - background: var(--jp-toolbar-background); - min-height: var(--jp-toolbar-micro-height); - padding: 2px; - z-index: 1; - overflow-x: auto; -} - -/* Toolbar items */ - -.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer { - flex-grow: 1; - flex-shrink: 1; -} - -.jp-Toolbar-item.jp-Toolbar-kernelStatus { - display: inline-block; - width: 32px; - background-repeat: no-repeat; - background-position: center; - background-size: 16px; -} - -.jp-Toolbar > .jp-Toolbar-item { - flex: 0 0 auto; - display: flex; - padding-left: 1px; - padding-right: 1px; - font-size: var(--jp-ui-font-size1); - line-height: var(--jp-private-toolbar-height); - height: 100%; -} - -/* Toolbar buttons */ - -/* This is the div we use to wrap the react component into a Widget */ -div.jp-ToolbarButton { - color: transparent; - border: none; - box-sizing: border-box; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; - padding: 0px; - margin: 0px; -} - -button.jp-ToolbarButtonComponent { - background: var(--jp-layout-color1); - border: none; - box-sizing: border-box; - outline: none; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; - padding: 0px 6px; - margin: 0px; - height: 24px; - border-radius: var(--jp-border-radius); - display: flex; - align-items: center; - text-align: center; - font-size: 14px; - min-width: unset; - min-height: unset; -} - -button.jp-ToolbarButtonComponent:disabled { - opacity: 0.4; -} - -button.jp-ToolbarButtonComponent span { - padding: 0px; - flex: 0 0 auto; -} - -button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label { - font-size: var(--jp-ui-font-size1); - line-height: 100%; - padding-left: 2px; - color: var(--jp-ui-font-color1); -} - -#jp-main-dock-panel[data-mode='single-document'] - .jp-MainAreaWidget - > .jp-Toolbar.jp-Toolbar-micro { - padding: 0; - min-height: 0; -} - -#jp-main-dock-panel[data-mode='single-document'] - .jp-MainAreaWidget - > .jp-Toolbar { - border: none; - box-shadow: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2017, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Copyright (c) 2014-2017, PhosphorJS Contributors -| -| Distributed under the terms of the BSD 3-Clause License. -| -| The full license is in the file LICENSE, distributed with this software. -|----------------------------------------------------------------------------*/ - - -/* <DEPRECATED> */ body.p-mod-override-cursor *, /* </DEPRECATED> */ -body.lm-mod-override-cursor * { - cursor: inherit !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) 2014-2016, Jupyter Development Team. -| -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-JSONEditor { - display: flex; - flex-direction: column; - width: 100%; -} - -.jp-JSONEditor-host { - flex: 1 1 auto; - border: var(--jp-border-width) solid var(--jp-input-border-color); - border-radius: 0px; - background: var(--jp-layout-color0); - min-height: 50px; - padding: 1px; -} - -.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host { - border-color: red; - outline-color: red; -} - -.jp-JSONEditor-header { - display: flex; - flex: 1 0 auto; - padding: 0 0 0 12px; -} - -.jp-JSONEditor-header label { - flex: 0 0 auto; -} - -.jp-JSONEditor-commitButton { - height: 16px; - width: 16px; - background-size: 18px; - background-repeat: no-repeat; - background-position: center; -} - -.jp-JSONEditor-host.jp-mod-focused { - background-color: var(--jp-input-active-background); - border: 1px solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); -} - -.jp-Editor.jp-mod-dropTarget { - border: var(--jp-border-width) solid var(--jp-input-active-border-color); - box-shadow: var(--jp-input-box-shadow); -} - -/* BASICS */ - -.CodeMirror { - /* Set height, width, borders, and global font properties here */ - font-family: monospace; - height: 300px; - color: black; - direction: ltr; -} - -/* PADDING */ - -.CodeMirror-lines { - padding: 4px 0; /* Vertical padding around content */ -} -.CodeMirror pre.CodeMirror-line, -.CodeMirror pre.CodeMirror-line-like { - padding: 0 4px; /* Horizontal padding of content */ -} - -.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { - background-color: white; /* The little square between H and V scrollbars */ -} - -/* GUTTER */ - -.CodeMirror-gutters { - border-right: 1px solid #ddd; - background-color: #f7f7f7; - white-space: nowrap; -} -.CodeMirror-linenumbers {} -.CodeMirror-linenumber { - padding: 0 3px 0 5px; - min-width: 20px; - text-align: right; - color: #999; - white-space: nowrap; -} - -.CodeMirror-guttermarker { color: black; } -.CodeMirror-guttermarker-subtle { color: #999; } - -/* CURSOR */ - -.CodeMirror-cursor { - border-left: 1px solid black; - border-right: none; - width: 0; -} -/* Shown when moving in bi-directional text */ -.CodeMirror div.CodeMirror-secondarycursor { - border-left: 1px solid silver; -} -.cm-fat-cursor .CodeMirror-cursor { - width: auto; - border: 0 !important; - background: #7e7; -} -.cm-fat-cursor div.CodeMirror-cursors { - z-index: 1; -} -.cm-fat-cursor-mark { - background-color: rgba(20, 255, 20, 0.5); - -webkit-animation: blink 1.06s steps(1) infinite; - -moz-animation: blink 1.06s steps(1) infinite; - animation: blink 1.06s steps(1) infinite; -} -.cm-animate-fat-cursor { - width: auto; - border: 0; - -webkit-animation: blink 1.06s steps(1) infinite; - -moz-animation: blink 1.06s steps(1) infinite; - animation: blink 1.06s steps(1) infinite; - background-color: #7e7; -} -@-moz-keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} -@-webkit-keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} -@keyframes blink { - 0% {} - 50% { background-color: transparent; } - 100% {} -} - -/* Can style cursor different in overwrite (non-insert) mode */ -.CodeMirror-overwrite .CodeMirror-cursor {} - -.cm-tab { display: inline-block; text-decoration: inherit; } - -.CodeMirror-rulers { - position: absolute; - left: 0; right: 0; top: -50px; bottom: 0; - overflow: hidden; -} -.CodeMirror-ruler { - border-left: 1px solid #ccc; - top: 0; bottom: 0; - position: absolute; -} - -/* DEFAULT THEME */ - -.cm-s-default .cm-header {color: blue;} -.cm-s-default .cm-quote {color: #090;} -.cm-negative {color: #d44;} -.cm-positive {color: #292;} -.cm-header, .cm-strong {font-weight: bold;} -.cm-em {font-style: italic;} -.cm-link {text-decoration: underline;} -.cm-strikethrough {text-decoration: line-through;} - -.cm-s-default .cm-keyword {color: #708;} -.cm-s-default .cm-atom {color: #219;} -.cm-s-default .cm-number {color: #164;} -.cm-s-default .cm-def {color: #00f;} -.cm-s-default .cm-variable, -.cm-s-default .cm-punctuation, -.cm-s-default .cm-property, -.cm-s-default .cm-operator {} -.cm-s-default .cm-variable-2 {color: #05a;} -.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;} -.cm-s-default .cm-comment {color: #a50;} -.cm-s-default .cm-string {color: #a11;} -.cm-s-default .cm-string-2 {color: #f50;} -.cm-s-default .cm-meta {color: #555;} -.cm-s-default .cm-qualifier {color: #555;} -.cm-s-default .cm-builtin {color: #30a;} -.cm-s-default .cm-bracket {color: #997;} -.cm-s-default .cm-tag {color: #170;} -.cm-s-default .cm-attribute {color: #00c;} -.cm-s-default .cm-hr {color: #999;} -.cm-s-default .cm-link {color: #00c;} - -.cm-s-default .cm-error {color: #f00;} -.cm-invalidchar {color: #f00;} - -.CodeMirror-composing { border-bottom: 2px solid; } - -/* Default styles for common addons */ - -div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;} -div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;} -.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); } -.CodeMirror-activeline-background {background: #e8f2ff;} - -/* STOP */ - -/* The rest of this file contains styles related to the mechanics of - the editor. You probably shouldn't touch them. */ - -.CodeMirror { - position: relative; - overflow: hidden; - background: white; -} - -.CodeMirror-scroll { - overflow: scroll !important; /* Things will break if this is overridden */ - /* 50px is the magic margin used to hide the element's real scrollbars */ - /* See overflow: hidden in .CodeMirror */ - margin-bottom: -50px; margin-right: -50px; - padding-bottom: 50px; - height: 100%; - outline: none; /* Prevent dragging from highlighting the element */ - position: relative; -} -.CodeMirror-sizer { - position: relative; - border-right: 50px solid transparent; -} - -/* The fake, visible scrollbars. Used to force redraw during scrolling - before actual scrolling happens, thus preventing shaking and - flickering artifacts. */ -.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { - position: absolute; - z-index: 6; - display: none; - outline: none; -} -.CodeMirror-vscrollbar { - right: 0; top: 0; - overflow-x: hidden; - overflow-y: scroll; -} -.CodeMirror-hscrollbar { - bottom: 0; left: 0; - overflow-y: hidden; - overflow-x: scroll; -} -.CodeMirror-scrollbar-filler { - right: 0; bottom: 0; -} -.CodeMirror-gutter-filler { - left: 0; bottom: 0; -} - -.CodeMirror-gutters { - position: absolute; left: 0; top: 0; - min-height: 100%; - z-index: 3; -} -.CodeMirror-gutter { - white-space: normal; - height: 100%; - display: inline-block; - vertical-align: top; - margin-bottom: -50px; -} -.CodeMirror-gutter-wrapper { - position: absolute; - z-index: 4; - background: none !important; - border: none !important; -} -.CodeMirror-gutter-background { - position: absolute; - top: 0; bottom: 0; - z-index: 4; -} -.CodeMirror-gutter-elt { - position: absolute; - cursor: default; - z-index: 4; -} -.CodeMirror-gutter-wrapper ::selection { background-color: transparent } -.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent } - -.CodeMirror-lines { - cursor: text; - min-height: 1px; /* prevents collapsing before first draw */ -} -.CodeMirror pre.CodeMirror-line, -.CodeMirror pre.CodeMirror-line-like { - /* Reset some styles that the rest of the page might have set */ - -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; - border-width: 0; - background: transparent; - font-family: inherit; - font-size: inherit; - margin: 0; - white-space: pre; - word-wrap: normal; - line-height: inherit; - color: inherit; - z-index: 2; - position: relative; - overflow: visible; - -webkit-tap-highlight-color: transparent; - -webkit-font-variant-ligatures: contextual; - font-variant-ligatures: contextual; -} -.CodeMirror-wrap pre.CodeMirror-line, -.CodeMirror-wrap pre.CodeMirror-line-like { - word-wrap: break-word; - white-space: pre-wrap; - word-break: normal; -} - -.CodeMirror-linebackground { - position: absolute; - left: 0; right: 0; top: 0; bottom: 0; - z-index: 0; -} - -.CodeMirror-linewidget { - position: relative; - z-index: 2; - padding: 0.1px; /* Force widget margins to stay inside of the container */ -} - -.CodeMirror-widget {} - -.CodeMirror-rtl pre { direction: rtl; } - -.CodeMirror-code { - outline: none; -} - -/* Force content-box sizing for the elements where we expect it */ -.CodeMirror-scroll, -.CodeMirror-sizer, -.CodeMirror-gutter, -.CodeMirror-gutters, -.CodeMirror-linenumber { - -moz-box-sizing: content-box; - box-sizing: content-box; -} - -.CodeMirror-measure { - position: absolute; - width: 100%; - height: 0; - overflow: hidden; - visibility: hidden; -} - -.CodeMirror-cursor { - position: absolute; - pointer-events: none; -} -.CodeMirror-measure pre { position: static; } - -div.CodeMirror-cursors { - visibility: hidden; - position: relative; - z-index: 3; -} -div.CodeMirror-dragcursors { - visibility: visible; -} - -.CodeMirror-focused div.CodeMirror-cursors { - visibility: visible; -} - -.CodeMirror-selected { background: #d9d9d9; } -.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; } -.CodeMirror-crosshair { cursor: crosshair; } -.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; } -.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; } - -.cm-searching { - background-color: #ffa; - background-color: rgba(255, 255, 0, .4); -} - -/* Used to force a border model for a node */ -.cm-force-border { padding-right: .1px; } - -@media print { - /* Hide the cursor when printing */ - .CodeMirror div.CodeMirror-cursors { - visibility: hidden; - } -} - -/* See issue #2901 */ -.cm-tab-wrap-hack:after { content: ''; } - -/* Help users use markselection to safely style text background */ -span.CodeMirror-selectedtext { background: none; } - -.CodeMirror-dialog { - position: absolute; - left: 0; right: 0; - background: inherit; - z-index: 15; - padding: .1em .8em; - overflow: hidden; - color: inherit; -} - -.CodeMirror-dialog-top { - border-bottom: 1px solid #eee; - top: 0; -} - -.CodeMirror-dialog-bottom { - border-top: 1px solid #eee; - bottom: 0; -} - -.CodeMirror-dialog input { - border: none; - outline: none; - background: transparent; - width: 20em; - color: inherit; - font-family: monospace; -} - -.CodeMirror-dialog button { - font-size: 70%; -} - -.CodeMirror-foldmarker { - color: blue; - text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px; - font-family: arial; - line-height: .3; - cursor: pointer; -} -.CodeMirror-foldgutter { - width: .7em; -} -.CodeMirror-foldgutter-open, -.CodeMirror-foldgutter-folded { - cursor: pointer; -} -.CodeMirror-foldgutter-open:after { - content: "\25BE"; -} -.CodeMirror-foldgutter-folded:after { - content: "\25B8"; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.CodeMirror { - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - font-family: var(--jp-code-font-family); - border: 0; - border-radius: 0; - height: auto; - /* Changed to auto to autogrow */ -} - -.CodeMirror pre { - padding: 0 var(--jp-code-padding); -} - -.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-dialog { - background-color: var(--jp-layout-color0); - color: var(--jp-content-font-color1); -} - -/* This causes https://github.com/jupyter/jupyterlab/issues/522 */ -/* May not cause it not because we changed it! */ -.CodeMirror-lines { - padding: var(--jp-code-padding) 0; -} - -.CodeMirror-linenumber { - padding: 0 8px; -} - -.jp-CodeMirrorEditor { - cursor: text; -} - -.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color); -} - -/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */ -@media screen and (min-width: 2138px) and (max-width: 4319px) { - .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width1) solid - var(--jp-editor-cursor-color); - } -} - -/* When zoomed out less than 33% */ -@media screen and (min-width: 4320px) { - .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width2) solid - var(--jp-editor-cursor-color); - } -} - -.CodeMirror.jp-mod-readOnly .CodeMirror-cursor { - display: none; -} - -.CodeMirror-gutters { - border-right: 1px solid var(--jp-border-color2); - background-color: var(--jp-layout-color0); -} - -.jp-CollaboratorCursor { - border-left: 5px solid transparent; - border-right: 5px solid transparent; - border-top: none; - border-bottom: 3px solid; - background-clip: content-box; - margin-left: -5px; - margin-right: -5px; -} - -.CodeMirror-selectedtext.cm-searching { - background-color: var(--jp-search-selected-match-background-color) !important; - color: var(--jp-search-selected-match-color) !important; -} - -.cm-searching { - background-color: var( - --jp-search-unselected-match-background-color - ) !important; - color: var(--jp-search-unselected-match-color) !important; -} - -.CodeMirror-focused .CodeMirror-selected { - background-color: var(--jp-editor-selected-focused-background); -} - -.CodeMirror-selected { - background-color: var(--jp-editor-selected-background); -} - -.jp-CollaboratorCursor-hover { - position: absolute; - z-index: 1; - transform: translateX(-50%); - color: white; - border-radius: 3px; - padding-left: 4px; - padding-right: 4px; - padding-top: 1px; - padding-bottom: 1px; - text-align: center; - font-size: var(--jp-ui-font-size1); - white-space: nowrap; -} - -.jp-CodeMirror-ruler { - border-left: 1px dashed var(--jp-border-color2); -} - -/** - * Here is our jupyter theme for CodeMirror syntax highlighting - * This is used in our marked.js syntax highlighting and CodeMirror itself - * The string "jupyter" is set in ../codemirror/widget.DEFAULT_CODEMIRROR_THEME - * This came from the classic notebook, which came form highlight.js/GitHub - */ - -/** - * CodeMirror themes are handling the background/color in this way. This works - * fine for CodeMirror editors outside the notebook, but the notebook styles - * these things differently. - */ -.CodeMirror.cm-s-jupyter { - background: var(--jp-layout-color0); - color: var(--jp-content-font-color1); -} - -/* In the notebook, we want this styling to be handled by its container */ -.jp-CodeConsole .CodeMirror.cm-s-jupyter, -.jp-Notebook .CodeMirror.cm-s-jupyter { - background: transparent; -} - -.cm-s-jupyter .CodeMirror-cursor { - border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color); -} -.cm-s-jupyter span.cm-keyword { - color: var(--jp-mirror-editor-keyword-color); - font-weight: bold; -} -.cm-s-jupyter span.cm-atom { - color: var(--jp-mirror-editor-atom-color); -} -.cm-s-jupyter span.cm-number { - color: var(--jp-mirror-editor-number-color); -} -.cm-s-jupyter span.cm-def { - color: var(--jp-mirror-editor-def-color); -} -.cm-s-jupyter span.cm-variable { - color: var(--jp-mirror-editor-variable-color); -} -.cm-s-jupyter span.cm-variable-2 { - color: var(--jp-mirror-editor-variable-2-color); -} -.cm-s-jupyter span.cm-variable-3 { - color: var(--jp-mirror-editor-variable-3-color); -} -.cm-s-jupyter span.cm-punctuation { - color: var(--jp-mirror-editor-punctuation-color); -} -.cm-s-jupyter span.cm-property { - color: var(--jp-mirror-editor-property-color); -} -.cm-s-jupyter span.cm-operator { - color: var(--jp-mirror-editor-operator-color); - font-weight: bold; -} -.cm-s-jupyter span.cm-comment { - color: var(--jp-mirror-editor-comment-color); - font-style: italic; -} -.cm-s-jupyter span.cm-string { - color: var(--jp-mirror-editor-string-color); -} -.cm-s-jupyter span.cm-string-2 { - color: var(--jp-mirror-editor-string-2-color); -} -.cm-s-jupyter span.cm-meta { - color: var(--jp-mirror-editor-meta-color); -} -.cm-s-jupyter span.cm-qualifier { - color: var(--jp-mirror-editor-qualifier-color); -} -.cm-s-jupyter span.cm-builtin { - color: var(--jp-mirror-editor-builtin-color); -} -.cm-s-jupyter span.cm-bracket { - color: var(--jp-mirror-editor-bracket-color); -} -.cm-s-jupyter span.cm-tag { - color: var(--jp-mirror-editor-tag-color); -} -.cm-s-jupyter span.cm-attribute { - color: var(--jp-mirror-editor-attribute-color); -} -.cm-s-jupyter span.cm-header { - color: var(--jp-mirror-editor-header-color); -} -.cm-s-jupyter span.cm-quote { - color: var(--jp-mirror-editor-quote-color); -} -.cm-s-jupyter span.cm-link { - color: var(--jp-mirror-editor-link-color); -} -.cm-s-jupyter span.cm-error { - color: var(--jp-mirror-editor-error-color); -} -.cm-s-jupyter span.cm-hr { - color: #999; -} - -.cm-s-jupyter span.cm-tab { - background: url(); - background-position: right; - background-repeat: no-repeat; -} - -.cm-s-jupyter .CodeMirror-activeline-background, -.cm-s-jupyter .CodeMirror-gutter { - background-color: var(--jp-layout-color2); -} - -/* Styles for shared cursors (remote cursor locations and selected ranges) */ -.jp-CodeMirrorEditor .remote-caret { - position: relative; - border-left: 2px solid black; - margin-left: -1px; - margin-right: -1px; - box-sizing: border-box; -} - -.jp-CodeMirrorEditor .remote-caret > div { - white-space: nowrap; - position: absolute; - top: -1.15em; - padding-bottom: 0.05em; - left: -2px; - font-size: 0.95em; - background-color: rgb(250, 129, 0); - font-family: var(--jp-ui-font-family); - font-weight: bold; - line-height: normal; - user-select: none; - color: white; - padding-left: 2px; - padding-right: 2px; - z-index: 3; - transition: opacity 0.3s ease-in-out; -} - -.jp-CodeMirrorEditor .remote-caret.hide-name > div { - transition-delay: 0.7s; - opacity: 0; -} - -.jp-CodeMirrorEditor .remote-caret:hover > div { - opacity: 1; - transition-delay: 0s; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| RenderedText -|----------------------------------------------------------------------------*/ - -:root { - /* This is the padding value to fill the gaps between lines containing spans with background color. */ - --jp-private-code-span-padding: calc( - (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2 - ); -} - -.jp-RenderedText { - text-align: left; - padding-left: var(--jp-code-padding); - line-height: var(--jp-code-line-height); - font-family: var(--jp-code-font-family); -} - -.jp-RenderedText pre, -.jp-RenderedJavaScript pre, -.jp-RenderedHTMLCommon pre { - color: var(--jp-content-font-color1); - font-size: var(--jp-code-font-size); - border: none; - margin: 0px; - padding: 0px; -} - -.jp-RenderedText pre a:link { - text-decoration: none; - color: var(--jp-content-link-color); -} -.jp-RenderedText pre a:hover { - text-decoration: underline; - color: var(--jp-content-link-color); -} -.jp-RenderedText pre a:visited { - text-decoration: none; - color: var(--jp-content-link-color); -} - -/* console foregrounds and backgrounds */ -.jp-RenderedText pre .ansi-black-fg { - color: #3e424d; -} -.jp-RenderedText pre .ansi-red-fg { - color: #e75c58; -} -.jp-RenderedText pre .ansi-green-fg { - color: #00a250; -} -.jp-RenderedText pre .ansi-yellow-fg { - color: #ddb62b; -} -.jp-RenderedText pre .ansi-blue-fg { - color: #208ffb; -} -.jp-RenderedText pre .ansi-magenta-fg { - color: #d160c4; -} -.jp-RenderedText pre .ansi-cyan-fg { - color: #60c6c8; -} -.jp-RenderedText pre .ansi-white-fg { - color: #c5c1b4; -} - -.jp-RenderedText pre .ansi-black-bg { - background-color: #3e424d; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-red-bg { - background-color: #e75c58; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-green-bg { - background-color: #00a250; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-yellow-bg { - background-color: #ddb62b; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-blue-bg { - background-color: #208ffb; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-magenta-bg { - background-color: #d160c4; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-cyan-bg { - background-color: #60c6c8; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-white-bg { - background-color: #c5c1b4; - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-black-intense-fg { - color: #282c36; -} -.jp-RenderedText pre .ansi-red-intense-fg { - color: #b22b31; -} -.jp-RenderedText pre .ansi-green-intense-fg { - color: #007427; -} -.jp-RenderedText pre .ansi-yellow-intense-fg { - color: #b27d12; -} -.jp-RenderedText pre .ansi-blue-intense-fg { - color: #0065ca; -} -.jp-RenderedText pre .ansi-magenta-intense-fg { - color: #a03196; -} -.jp-RenderedText pre .ansi-cyan-intense-fg { - color: #258f8f; -} -.jp-RenderedText pre .ansi-white-intense-fg { - color: #a1a6b2; -} - -.jp-RenderedText pre .ansi-black-intense-bg { - background-color: #282c36; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-red-intense-bg { - background-color: #b22b31; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-green-intense-bg { - background-color: #007427; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-yellow-intense-bg { - background-color: #b27d12; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-blue-intense-bg { - background-color: #0065ca; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-magenta-intense-bg { - background-color: #a03196; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-cyan-intense-bg { - background-color: #258f8f; - padding: var(--jp-private-code-span-padding) 0; -} -.jp-RenderedText pre .ansi-white-intense-bg { - background-color: #a1a6b2; - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-default-inverse-fg { - color: var(--jp-ui-inverse-font-color0); -} -.jp-RenderedText pre .ansi-default-inverse-bg { - background-color: var(--jp-inverse-layout-color0); - padding: var(--jp-private-code-span-padding) 0; -} - -.jp-RenderedText pre .ansi-bold { - font-weight: bold; -} -.jp-RenderedText pre .ansi-underline { - text-decoration: underline; -} - -.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] { - background: var(--jp-rendermime-error-background); - padding-top: var(--jp-code-padding); -} - -/*----------------------------------------------------------------------------- -| RenderedLatex -|----------------------------------------------------------------------------*/ - -.jp-RenderedLatex { - color: var(--jp-content-font-color1); - font-size: var(--jp-content-font-size1); - line-height: var(--jp-content-line-height); -} - -/* Left-justify outputs.*/ -.jp-OutputArea-output.jp-RenderedLatex { - padding: var(--jp-code-padding); - text-align: left; -} - -/*----------------------------------------------------------------------------- -| RenderedHTML -|----------------------------------------------------------------------------*/ - -.jp-RenderedHTMLCommon { - color: var(--jp-content-font-color1); - font-family: var(--jp-content-font-family); - font-size: var(--jp-content-font-size1); - line-height: var(--jp-content-line-height); - /* Give a bit more R padding on Markdown text to keep line lengths reasonable */ - padding-right: 20px; -} - -.jp-RenderedHTMLCommon em { - font-style: italic; -} - -.jp-RenderedHTMLCommon strong { - font-weight: bold; -} - -.jp-RenderedHTMLCommon u { - text-decoration: underline; -} - -.jp-RenderedHTMLCommon a:link { - text-decoration: none; - color: var(--jp-content-link-color); -} - -.jp-RenderedHTMLCommon a:hover { - text-decoration: underline; - color: var(--jp-content-link-color); -} - -.jp-RenderedHTMLCommon a:visited { - text-decoration: none; - color: var(--jp-content-link-color); -} - -/* Headings */ - -.jp-RenderedHTMLCommon h1, -.jp-RenderedHTMLCommon h2, -.jp-RenderedHTMLCommon h3, -.jp-RenderedHTMLCommon h4, -.jp-RenderedHTMLCommon h5, -.jp-RenderedHTMLCommon h6 { - line-height: var(--jp-content-heading-line-height); - font-weight: var(--jp-content-heading-font-weight); - font-style: normal; - margin: var(--jp-content-heading-margin-top) 0 - var(--jp-content-heading-margin-bottom) 0; -} - -.jp-RenderedHTMLCommon h1:first-child, -.jp-RenderedHTMLCommon h2:first-child, -.jp-RenderedHTMLCommon h3:first-child, -.jp-RenderedHTMLCommon h4:first-child, -.jp-RenderedHTMLCommon h5:first-child, -.jp-RenderedHTMLCommon h6:first-child { - margin-top: calc(0.5 * var(--jp-content-heading-margin-top)); -} - -.jp-RenderedHTMLCommon h1:last-child, -.jp-RenderedHTMLCommon h2:last-child, -.jp-RenderedHTMLCommon h3:last-child, -.jp-RenderedHTMLCommon h4:last-child, -.jp-RenderedHTMLCommon h5:last-child, -.jp-RenderedHTMLCommon h6:last-child { - margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom)); -} - -.jp-RenderedHTMLCommon h1 { - font-size: var(--jp-content-font-size5); -} - -.jp-RenderedHTMLCommon h2 { - font-size: var(--jp-content-font-size4); -} - -.jp-RenderedHTMLCommon h3 { - font-size: var(--jp-content-font-size3); -} - -.jp-RenderedHTMLCommon h4 { - font-size: var(--jp-content-font-size2); -} - -.jp-RenderedHTMLCommon h5 { - font-size: var(--jp-content-font-size1); -} - -.jp-RenderedHTMLCommon h6 { - font-size: var(--jp-content-font-size0); -} - -/* Lists */ - -.jp-RenderedHTMLCommon ul:not(.list-inline), -.jp-RenderedHTMLCommon ol:not(.list-inline) { - padding-left: 2em; -} - -.jp-RenderedHTMLCommon ul { - list-style: disc; -} - -.jp-RenderedHTMLCommon ul ul { - list-style: square; -} - -.jp-RenderedHTMLCommon ul ul ul { - list-style: circle; -} - -.jp-RenderedHTMLCommon ol { - list-style: decimal; -} - -.jp-RenderedHTMLCommon ol ol { - list-style: upper-alpha; -} - -.jp-RenderedHTMLCommon ol ol ol { - list-style: lower-alpha; -} - -.jp-RenderedHTMLCommon ol ol ol ol { - list-style: lower-roman; -} - -.jp-RenderedHTMLCommon ol ol ol ol ol { - list-style: decimal; -} - -.jp-RenderedHTMLCommon ol, -.jp-RenderedHTMLCommon ul { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon ul ul, -.jp-RenderedHTMLCommon ul ol, -.jp-RenderedHTMLCommon ol ul, -.jp-RenderedHTMLCommon ol ol { - margin-bottom: 0em; -} - -.jp-RenderedHTMLCommon hr { - color: var(--jp-border-color2); - background-color: var(--jp-border-color1); - margin-top: 1em; - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon > pre { - margin: 1.5em 2em; -} - -.jp-RenderedHTMLCommon pre, -.jp-RenderedHTMLCommon code { - border: 0; - background-color: var(--jp-layout-color0); - color: var(--jp-content-font-color1); - font-family: var(--jp-code-font-family); - font-size: inherit; - line-height: var(--jp-code-line-height); - padding: 0; - white-space: pre-wrap; -} - -.jp-RenderedHTMLCommon :not(pre) > code { - background-color: var(--jp-layout-color2); - padding: 1px 5px; -} - -/* Tables */ - -.jp-RenderedHTMLCommon table { - border-collapse: collapse; - border-spacing: 0; - border: none; - color: var(--jp-ui-font-color1); - font-size: 12px; - table-layout: fixed; - margin-left: auto; - margin-right: auto; -} - -.jp-RenderedHTMLCommon thead { - border-bottom: var(--jp-border-width) solid var(--jp-border-color1); - vertical-align: bottom; -} - -.jp-RenderedHTMLCommon td, -.jp-RenderedHTMLCommon th, -.jp-RenderedHTMLCommon tr { - vertical-align: middle; - padding: 0.5em 0.5em; - line-height: normal; - white-space: normal; - max-width: none; - border: none; -} - -.jp-RenderedMarkdown.jp-RenderedHTMLCommon td, -.jp-RenderedMarkdown.jp-RenderedHTMLCommon th { - max-width: none; -} - -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td, -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th, -:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr { - text-align: right; -} - -.jp-RenderedHTMLCommon th { - font-weight: bold; -} - -.jp-RenderedHTMLCommon tbody tr:nth-child(odd) { - background: var(--jp-layout-color0); -} - -.jp-RenderedHTMLCommon tbody tr:nth-child(even) { - background: var(--jp-rendermime-table-row-background); -} - -.jp-RenderedHTMLCommon tbody tr:hover { - background: var(--jp-rendermime-table-row-hover-background); -} - -.jp-RenderedHTMLCommon table { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon p { - text-align: left; - margin: 0px; -} - -.jp-RenderedHTMLCommon p { - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon img { - -moz-force-broken-image-icon: 1; -} - -/* Restrict to direct children as other images could be nested in other content. */ -.jp-RenderedHTMLCommon > img { - display: block; - margin-left: 0; - margin-right: 0; - margin-bottom: 1em; -} - -/* Change color behind transparent images if they need it... */ -[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background { - background-color: var(--jp-inverse-layout-color1); -} -[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background { - background-color: var(--jp-inverse-layout-color1); -} -/* ...or leave it untouched if they don't */ -[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-dark-background { -} -[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-light-background { -} - -.jp-RenderedHTMLCommon img, -.jp-RenderedImage img, -.jp-RenderedHTMLCommon svg, -.jp-RenderedSVG svg { - max-width: 100%; - height: auto; -} - -.jp-RenderedHTMLCommon img.jp-mod-unconfined, -.jp-RenderedImage img.jp-mod-unconfined, -.jp-RenderedHTMLCommon svg.jp-mod-unconfined, -.jp-RenderedSVG svg.jp-mod-unconfined { - max-width: none; -} - -.jp-RenderedHTMLCommon .alert { - padding: var(--jp-notebook-padding); - border: var(--jp-border-width) solid transparent; - border-radius: var(--jp-border-radius); - margin-bottom: 1em; -} - -.jp-RenderedHTMLCommon .alert-info { - color: var(--jp-info-color0); - background-color: var(--jp-info-color3); - border-color: var(--jp-info-color2); -} -.jp-RenderedHTMLCommon .alert-info hr { - border-color: var(--jp-info-color3); -} -.jp-RenderedHTMLCommon .alert-info > p:last-child, -.jp-RenderedHTMLCommon .alert-info > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-warning { - color: var(--jp-warn-color0); - background-color: var(--jp-warn-color3); - border-color: var(--jp-warn-color2); -} -.jp-RenderedHTMLCommon .alert-warning hr { - border-color: var(--jp-warn-color3); -} -.jp-RenderedHTMLCommon .alert-warning > p:last-child, -.jp-RenderedHTMLCommon .alert-warning > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-success { - color: var(--jp-success-color0); - background-color: var(--jp-success-color3); - border-color: var(--jp-success-color2); -} -.jp-RenderedHTMLCommon .alert-success hr { - border-color: var(--jp-success-color3); -} -.jp-RenderedHTMLCommon .alert-success > p:last-child, -.jp-RenderedHTMLCommon .alert-success > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon .alert-danger { - color: var(--jp-error-color0); - background-color: var(--jp-error-color3); - border-color: var(--jp-error-color2); -} -.jp-RenderedHTMLCommon .alert-danger hr { - border-color: var(--jp-error-color3); -} -.jp-RenderedHTMLCommon .alert-danger > p:last-child, -.jp-RenderedHTMLCommon .alert-danger > ul:last-child { - margin-bottom: 0; -} - -.jp-RenderedHTMLCommon blockquote { - margin: 1em 2em; - padding: 0 1em; - border-left: 5px solid var(--jp-border-color2); -} - -a.jp-InternalAnchorLink { - visibility: hidden; - margin-left: 8px; - color: var(--md-blue-800); -} - -h1:hover .jp-InternalAnchorLink, -h2:hover .jp-InternalAnchorLink, -h3:hover .jp-InternalAnchorLink, -h4:hover .jp-InternalAnchorLink, -h5:hover .jp-InternalAnchorLink, -h6:hover .jp-InternalAnchorLink { - visibility: visible; -} - -.jp-RenderedHTMLCommon kbd { - background-color: var(--jp-rendermime-table-row-background); - border: 1px solid var(--jp-border-color0); - border-bottom-color: var(--jp-border-color2); - border-radius: 3px; - box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25); - display: inline-block; - font-size: 0.8em; - line-height: 1em; - padding: 0.2em 0.5em; -} - -/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0. - * At the bottom of cells this is a bit too much as there is also spacing - * between cells. Going all the way to 0 gets too tight between markdown and - * code cells. - */ -.jp-RenderedHTMLCommon > *:last-child { - margin-bottom: 0.5em; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-MimeDocument { - outline: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-filebrowser-button-height: 28px; - --jp-private-filebrowser-button-width: 48px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-FileBrowser { - display: flex; - flex-direction: column; - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); -} - -.jp-FileBrowser-toolbar.jp-Toolbar { - border-bottom: none; - height: auto; - margin: var(--jp-toolbar-header-margin); - box-shadow: none; -} - -.jp-BreadCrumbs { - flex: 0 0 auto; - margin: 8px 12px 8px 12px; -} - -.jp-BreadCrumbs-item { - margin: 0px 2px; - padding: 0px 2px; - border-radius: var(--jp-border-radius); - cursor: pointer; -} - -.jp-BreadCrumbs-item:hover { - background-color: var(--jp-layout-color2); -} - -.jp-BreadCrumbs-item:first-child { - margin-left: 0px; -} - -.jp-BreadCrumbs-item.jp-mod-dropTarget { - background-color: var(--jp-brand-color2); - opacity: 0.7; -} - -/*----------------------------------------------------------------------------- -| Buttons -|----------------------------------------------------------------------------*/ - -.jp-FileBrowser-toolbar.jp-Toolbar { - padding: 0px; - margin: 8px 12px 0px 12px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar { - justify-content: flex-start; -} - -.jp-FileBrowser-toolbar.jp-Toolbar .jp-Toolbar-item { - flex: 0 0 auto; - padding-left: 0px; - padding-right: 2px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar .jp-ToolbarButtonComponent { - width: 40px; -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent { - width: 72px; - background: var(--jp-brand-color1); -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent:focus-visible { - background-color: var(--jp-brand-color0); -} - -.jp-FileBrowser-toolbar.jp-Toolbar - .jp-Toolbar-item:first-child - .jp-ToolbarButtonComponent - .jp-icon3 { - fill: white; -} - -/*----------------------------------------------------------------------------- -| Other styles -|----------------------------------------------------------------------------*/ - -.jp-FileDialog.jp-mod-conflict input { - color: var(--jp-error-color1); -} - -.jp-FileDialog .jp-new-name-title { - margin-top: 12px; -} - -.jp-LastModified-hidden { - display: none; -} - -.jp-FileBrowser-filterBox { - padding: 0px; - flex: 0 0 auto; - margin: 8px 12px 0px 12px; -} - -/*----------------------------------------------------------------------------- -| DirListing -|----------------------------------------------------------------------------*/ - -.jp-DirListing { - flex: 1 1 auto; - display: flex; - flex-direction: column; - outline: 0; -} - -.jp-DirListing:focus-visible { - border: 1px solid var(--jp-brand-color1); -} - -.jp-DirListing-header { - flex: 0 0 auto; - display: flex; - flex-direction: row; - overflow: hidden; - border-top: var(--jp-border-width) solid var(--jp-border-color2); - border-bottom: var(--jp-border-width) solid var(--jp-border-color1); - box-shadow: var(--jp-toolbar-box-shadow); - z-index: 2; -} - -.jp-DirListing-headerItem { - padding: 4px 12px 2px 12px; - font-weight: 500; -} - -.jp-DirListing-headerItem:hover { - background: var(--jp-layout-color2); -} - -.jp-DirListing-headerItem.jp-id-name { - flex: 1 0 84px; -} - -.jp-DirListing-headerItem.jp-id-modified { - flex: 0 0 112px; - border-left: var(--jp-border-width) solid var(--jp-border-color2); - text-align: right; -} - -.jp-id-narrow { - display: none; - flex: 0 0 5px; - padding: 4px 4px; - border-left: var(--jp-border-width) solid var(--jp-border-color2); - text-align: right; - color: var(--jp-border-color2); -} - -.jp-DirListing-narrow .jp-id-narrow { - display: block; -} - -.jp-DirListing-narrow .jp-id-modified, -.jp-DirListing-narrow .jp-DirListing-itemModified { - display: none; -} - -.jp-DirListing-headerItem.jp-mod-selected { - font-weight: 600; -} - -/* increase specificity to override bundled default */ -.jp-DirListing-content { - flex: 1 1 auto; - margin: 0; - padding: 0; - list-style-type: none; - overflow: auto; - background-color: var(--jp-layout-color1); -} - -.jp-DirListing-content mark { - color: var(--jp-ui-font-color0); - background-color: transparent; - font-weight: bold; -} - -.jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark { - color: var(--jp-ui-inverse-font-color0); -} - -/* Style the directory listing content when a user drops a file to upload */ -.jp-DirListing.jp-mod-native-drop .jp-DirListing-content { - outline: 5px dashed rgba(128, 128, 128, 0.5); - outline-offset: -10px; - cursor: copy; -} - -.jp-DirListing-item { - display: flex; - flex-direction: row; - padding: 4px 12px; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -.jp-DirListing-item[data-is-dot] { - opacity: 75%; -} - -.jp-DirListing-item.jp-mod-selected { - color: var(--jp-ui-inverse-font-color1); - background: var(--jp-brand-color1); -} - -.jp-DirListing-item.jp-mod-dropTarget { - background: var(--jp-brand-color3); -} - -.jp-DirListing-item:hover:not(.jp-mod-selected) { - background: var(--jp-layout-color2); -} - -.jp-DirListing-itemIcon { - flex: 0 0 20px; - margin-right: 4px; -} - -.jp-DirListing-itemText { - flex: 1 0 64px; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - user-select: none; -} - -.jp-DirListing-itemModified { - flex: 0 0 125px; - text-align: right; -} - -.jp-DirListing-editor { - flex: 1 0 64px; - outline: none; - border: none; -} - -.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon:before { - color: var(--jp-success-color1); - content: '\25CF'; - font-size: 8px; - position: absolute; - left: -8px; -} - -.jp-DirListing-item.jp-mod-running.jp-mod-selected - .jp-DirListing-itemIcon:before { - color: var(--jp-ui-inverse-font-color1); -} - -.jp-DirListing-item.lm-mod-drag-image, -.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image { - font-size: var(--jp-ui-font-size1); - padding-left: 4px; - margin-left: 4px; - width: 160px; - background-color: var(--jp-ui-inverse-font-color2); - box-shadow: var(--jp-elevation-z2); - border-radius: 0px; - color: var(--jp-ui-font-color1); - transform: translateX(-40%) translateY(-58%); -} - -.jp-DirListing-deadSpace { - flex: 1 1 auto; - margin: 0; - padding: 0; - list-style-type: none; - overflow: auto; - background-color: var(--jp-layout-color1); -} - -.jp-Document { - min-width: 120px; - min-height: 120px; - outline: none; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { -} - -/*----------------------------------------------------------------------------- -| Main OutputArea -| OutputArea has a list of Outputs -|----------------------------------------------------------------------------*/ - -.jp-OutputArea { - overflow-y: auto; -} - -.jp-OutputArea-child { - display: flex; - flex-direction: row; -} - -body[data-format='mobile'] .jp-OutputArea-child { - flex-direction: column; -} - -.jp-OutputPrompt { - flex: 0 0 var(--jp-cell-prompt-width); - color: var(--jp-cell-outprompt-font-color); - font-family: var(--jp-cell-prompt-font-family); - padding: var(--jp-code-padding); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; - opacity: var(--jp-cell-prompt-opacity); - /* Right align prompt text, don't wrap to handle large prompt numbers */ - text-align: right; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - /* Disable text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -body[data-format='mobile'] .jp-OutputPrompt { - flex: 0 0 auto; - text-align: left; -} - -.jp-OutputArea-output { - height: auto; - overflow: auto; - user-select: text; - -moz-user-select: text; - -webkit-user-select: text; - -ms-user-select: text; -} - -.jp-OutputArea-child .jp-OutputArea-output { - flex-grow: 1; - flex-shrink: 1; -} - -body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output { - margin-left: var(--jp-notebook-padding); -} - -/** - * Isolated output. - */ -.jp-OutputArea-output.jp-mod-isolated { - width: 100%; - display: block; -} - -/* -When drag events occur, `p-mod-override-cursor` is added to the body. -Because iframes steal all cursor events, the following two rules are necessary -to suppress pointer events while resize drags are occurring. There may be a -better solution to this problem. -*/ -body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated { - position: relative; -} - -body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated:before { - content: ''; - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: transparent; -} - -/* pre */ - -.jp-OutputArea-output pre { - border: none; - margin: 0px; - padding: 0px; - overflow-x: auto; - overflow-y: auto; - word-break: break-all; - word-wrap: break-word; - white-space: pre-wrap; -} - -/* tables */ - -.jp-OutputArea-output.jp-RenderedHTMLCommon table { - margin-left: 0; - margin-right: 0; -} - -/* description lists */ - -.jp-OutputArea-output dl, -.jp-OutputArea-output dt, -.jp-OutputArea-output dd { - display: block; -} - -.jp-OutputArea-output dl { - width: 100%; - overflow: hidden; - padding: 0; - margin: 0; -} - -.jp-OutputArea-output dt { - font-weight: bold; - float: left; - width: 20%; - padding: 0; - margin: 0; -} - -.jp-OutputArea-output dd { - float: left; - width: 80%; - padding: 0; - margin: 0; -} - -/* Hide the gutter in case of - * - nested output areas (e.g. in the case of output widgets) - * - mirrored output areas - */ -.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt { - display: none; -} - -/*----------------------------------------------------------------------------- -| executeResult is added to any Output-result for the display of the object -| returned by a cell -|----------------------------------------------------------------------------*/ - -.jp-OutputArea-output.jp-OutputArea-executeResult { - margin-left: 0px; - flex: 1 1 auto; -} - -/* Text output with the Out[] prompt needs a top padding to match the - * alignment of the Out[] prompt itself. - */ -.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output { - padding-top: var(--jp-code-padding); - border-top: var(--jp-border-width) solid transparent; -} - -/*----------------------------------------------------------------------------- -| The Stdin output -|----------------------------------------------------------------------------*/ - -.jp-OutputArea-stdin { - line-height: var(--jp-code-line-height); - padding-top: var(--jp-code-padding); - display: flex; -} - -.jp-Stdin-prompt { - color: var(--jp-content-font-color0); - padding-right: var(--jp-code-padding); - vertical-align: baseline; - flex: 0 0 auto; -} - -.jp-Stdin-input { - font-family: var(--jp-code-font-family); - font-size: inherit; - color: inherit; - background-color: inherit; - width: 42%; - min-width: 200px; - /* make sure input baseline aligns with prompt */ - vertical-align: baseline; - /* padding + margin = 0.5em between prompt and cursor */ - padding: 0em 0.25em; - margin: 0em 0.25em; - flex: 0 0 70%; -} - -.jp-Stdin-input:focus { - box-shadow: none; -} - -/*----------------------------------------------------------------------------- -| Output Area View -|----------------------------------------------------------------------------*/ - -.jp-LinkedOutputView .jp-OutputArea { - height: 100%; - display: block; -} - -.jp-LinkedOutputView .jp-OutputArea-output:only-child { - height: 100%; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -.jp-Collapser { - flex: 0 0 var(--jp-cell-collapser-width); - padding: 0px; - margin: 0px; - border: none; - outline: none; - background: transparent; - border-radius: var(--jp-border-radius); - opacity: 1; -} - -.jp-Collapser-child { - display: block; - width: 100%; - box-sizing: border-box; - /* height: 100% doesn't work because the height of its parent is computed from content */ - position: absolute; - top: 0px; - bottom: 0px; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Header/Footer -|----------------------------------------------------------------------------*/ - -/* Hidden by zero height by default */ -.jp-CellHeader, -.jp-CellFooter { - height: 0px; - width: 100%; - padding: 0px; - margin: 0px; - border: none; - outline: none; - background: transparent; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Input -|----------------------------------------------------------------------------*/ - -/* All input areas */ -.jp-InputArea { - display: flex; - flex-direction: row; - overflow: hidden; -} - -body[data-format='mobile'] .jp-InputArea { - flex-direction: column; -} - -.jp-InputArea-editor { - flex: 1 1 auto; - overflow: hidden; -} - -.jp-InputArea-editor { - /* This is the non-active, default styling */ - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - border-radius: 0px; - background: var(--jp-cell-editor-background); -} - -body[data-format='mobile'] .jp-InputArea-editor { - margin-left: var(--jp-notebook-padding); -} - -.jp-InputPrompt { - flex: 0 0 var(--jp-cell-prompt-width); - color: var(--jp-cell-inprompt-font-color); - font-family: var(--jp-cell-prompt-font-family); - padding: var(--jp-code-padding); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - opacity: var(--jp-cell-prompt-opacity); - line-height: var(--jp-code-line-height); - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; - opacity: var(--jp-cell-prompt-opacity); - /* Right align prompt text, don't wrap to handle large prompt numbers */ - text-align: right; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - /* Disable text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - -body[data-format='mobile'] .jp-InputPrompt { - flex: 0 0 auto; - text-align: left; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Placeholder -|----------------------------------------------------------------------------*/ - -.jp-Placeholder { - display: flex; - flex-direction: row; - flex: 1 1 auto; -} - -.jp-Placeholder-prompt { - box-sizing: border-box; -} - -.jp-Placeholder-content { - flex: 1 1 auto; - border: none; - background: transparent; - height: 20px; - box-sizing: border-box; -} - -.jp-Placeholder-content .jp-MoreHorizIcon { - width: 32px; - height: 16px; - border: 1px solid transparent; - border-radius: var(--jp-border-radius); -} - -.jp-Placeholder-content .jp-MoreHorizIcon:hover { - border: 1px solid var(--jp-border-color1); - box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.25); - background-color: var(--jp-layout-color0); -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-cell-scrolling-output-offset: 5px; -} - -/*----------------------------------------------------------------------------- -| Cell -|----------------------------------------------------------------------------*/ - -.jp-Cell { - padding: var(--jp-cell-padding); - margin: 0px; - border: none; - outline: none; - background: transparent; -} - -/*----------------------------------------------------------------------------- -| Common input/output -|----------------------------------------------------------------------------*/ - -.jp-Cell-inputWrapper, -.jp-Cell-outputWrapper { - display: flex; - flex-direction: row; - padding: 0px; - margin: 0px; - /* Added to reveal the box-shadow on the input and output collapsers. */ - overflow: visible; -} - -/* Only input/output areas inside cells */ -.jp-Cell-inputArea, -.jp-Cell-outputArea { - flex: 1 1 auto; -} - -/*----------------------------------------------------------------------------- -| Collapser -|----------------------------------------------------------------------------*/ - -/* Make the output collapser disappear when there is not output, but do so - * in a manner that leaves it in the layout and preserves its width. - */ -.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser { - border: none !important; - background: transparent !important; -} - -.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser { - min-height: var(--jp-cell-collapser-min-height); -} - -/*----------------------------------------------------------------------------- -| Output -|----------------------------------------------------------------------------*/ - -/* Put a space between input and output when there IS output */ -.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper { - margin-top: 5px; -} - -.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea { - overflow-y: auto; - max-height: 200px; - box-shadow: inset 0 0 6px 2px rgba(0, 0, 0, 0.3); - margin-left: var(--jp-private-cell-scrolling-output-offset); -} - -.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { - flex: 0 0 - calc( - var(--jp-cell-prompt-width) - - var(--jp-private-cell-scrolling-output-offset) - ); -} - -/*----------------------------------------------------------------------------- -| CodeCell -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| MarkdownCell -|----------------------------------------------------------------------------*/ - -.jp-MarkdownOutput { - flex: 1 1 auto; - margin-top: 0; - margin-bottom: 0; - padding-left: var(--jp-code-padding); -} - -.jp-MarkdownOutput.jp-RenderedHTMLCommon { - overflow: auto; -} - -.jp-showHiddenCellsButton { - margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding)); - margin-top: var(--jp-code-padding); - border: 1px solid var(--jp-border-color2); - background-color: var(--jp-border-color3) !important; - color: var(--jp-content-font-color0) !important; -} - -.jp-showHiddenCellsButton:hover { - background-color: var(--jp-border-color2) !important; -} - -.jp-collapseHeadingButton { - display: none; -} - -.jp-MarkdownCell:hover .jp-collapseHeadingButton { - display: flex; - min-height: var(--jp-cell-collapser-min-height); - position: absolute; - right: 0; - top: 0; - bottom: 0; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Variables -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- - -/*----------------------------------------------------------------------------- -| Styles -|----------------------------------------------------------------------------*/ - -.jp-NotebookPanel-toolbar { - padding: 2px; -} - -.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused { - border: none; - box-shadow: none; -} - -.jp-Notebook-toolbarCellTypeDropdown select { - height: 24px; - font-size: var(--jp-ui-font-size1); - line-height: 14px; - border-radius: 0; - display: block; -} - -.jp-Notebook-toolbarCellTypeDropdown span { - top: 5px !important; -} - -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Private CSS variables -|----------------------------------------------------------------------------*/ - -:root { - --jp-private-notebook-dragImage-width: 304px; - --jp-private-notebook-dragImage-height: 36px; - --jp-private-notebook-selected-color: var(--md-blue-400); - --jp-private-notebook-active-color: var(--md-green-400); -} - -/*----------------------------------------------------------------------------- -| Imports -|----------------------------------------------------------------------------*/ - -/*----------------------------------------------------------------------------- -| Notebook -|----------------------------------------------------------------------------*/ - -.jp-NotebookPanel { - display: block; - height: 100%; -} - -.jp-NotebookPanel.jp-Document { - min-width: 240px; - min-height: 120px; -} - -.jp-Notebook { - padding: var(--jp-notebook-padding); - outline: none; - overflow: auto; - background: var(--jp-layout-color0); -} - -.jp-Notebook.jp-mod-scrollPastEnd::after { - display: block; - content: ''; - min-height: var(--jp-notebook-scroll-padding); -} - -.jp-MainAreaWidget-ContainStrict .jp-Notebook * { - contain: strict; -} - -.jp-Notebook-render * { - contain: none !important; -} - -.jp-Notebook .jp-Cell { - overflow: visible; -} - -.jp-Notebook .jp-Cell .jp-InputPrompt { - cursor: move; - float: left; -} - -/*----------------------------------------------------------------------------- -| Notebook state related styling -| -| The notebook and cells each have states, here are the possibilities: -| -| - Notebook -| - Command -| - Edit -| - Cell -| - None -| - Active (only one can be active) -| - Selected (the cells actions are applied to) -| - Multiselected (when multiple selected, the cursor) -| - No outputs -|----------------------------------------------------------------------------*/ - -/* Command or edit modes */ - -.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt { - opacity: var(--jp-cell-prompt-not-active-opacity); - color: var(--jp-cell-prompt-not-active-font-color); -} - -.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt { - opacity: var(--jp-cell-prompt-not-active-opacity); - color: var(--jp-cell-prompt-not-active-font-color); -} - -/* cell is active */ -.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser { - background: var(--jp-brand-color1); -} - -/* cell is dirty */ -.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt { - color: var(--jp-warn-color1); -} -.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt:before { - color: var(--jp-warn-color1); - content: '•'; -} - -.jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser { - background: var(--jp-warn-color1); -} - -/* collapser is hovered */ -.jp-Notebook .jp-Cell .jp-Collapser:hover { - box-shadow: var(--jp-elevation-z2); - background: var(--jp-brand-color1); - opacity: var(--jp-cell-collapser-not-active-hover-opacity); -} - -/* cell is active and collapser is hovered */ -.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover { - background: var(--jp-brand-color0); - opacity: 1; -} - -/* Command mode */ - -.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected { - background: var(--jp-notebook-multiselected-color); -} - -.jp-Notebook.jp-mod-commandMode - .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) { - background: transparent; -} - -/* Edit mode */ - -.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor { - border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color); - box-shadow: var(--jp-input-box-shadow); - background-color: var(--jp-cell-editor-active-background); -} - -/*----------------------------------------------------------------------------- -| Notebook drag and drop -|----------------------------------------------------------------------------*/ - -.jp-Notebook-cell.jp-mod-dropSource { - opacity: 0.5; -} - -.jp-Notebook-cell.jp-mod-dropTarget, -.jp-Notebook.jp-mod-commandMode - .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget { - border-top-color: var(--jp-private-notebook-selected-color); - border-top-style: solid; - border-top-width: 2px; -} - -.jp-dragImage { - display: block; - flex-direction: row; - width: var(--jp-private-notebook-dragImage-width); - height: var(--jp-private-notebook-dragImage-height); - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - background: var(--jp-cell-editor-background); - overflow: visible; -} - -.jp-dragImage-singlePrompt { - box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); -} - -.jp-dragImage .jp-dragImage-content { - flex: 1 1 auto; - z-index: 2; - font-size: var(--jp-code-font-size); - font-family: var(--jp-code-font-family); - line-height: var(--jp-code-line-height); - padding: var(--jp-code-padding); - border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); - background: var(--jp-cell-editor-background-color); - color: var(--jp-content-font-color3); - text-align: left; - margin: 4px 4px 4px 0px; -} - -.jp-dragImage .jp-dragImage-prompt { - flex: 0 0 auto; - min-width: 36px; - color: var(--jp-cell-inprompt-font-color); - padding: var(--jp-code-padding); - padding-left: 12px; - font-family: var(--jp-cell-prompt-font-family); - letter-spacing: var(--jp-cell-prompt-letter-spacing); - line-height: 1.9; - font-size: var(--jp-code-font-size); - border: var(--jp-border-width) solid transparent; -} - -.jp-dragImage-multipleBack { - z-index: -1; - position: absolute; - height: 32px; - width: 300px; - top: 8px; - left: 8px; - background: var(--jp-layout-color2); - border: var(--jp-border-width) solid var(--jp-input-border-color); - box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12); -} - -/*----------------------------------------------------------------------------- -| Cell toolbar -|----------------------------------------------------------------------------*/ - -.jp-NotebookTools { - display: block; - min-width: var(--jp-sidebar-min-width); - color: var(--jp-ui-font-color1); - background: var(--jp-layout-color1); - /* This is needed so that all font sizing of children done in ems is - * relative to this base size */ - font-size: var(--jp-ui-font-size1); - overflow: auto; -} - -.jp-NotebookTools-tool { - padding: 0px 12px 0 12px; -} - -.jp-ActiveCellTool { - padding: 12px; - background-color: var(--jp-layout-color1); - border-top: none !important; -} - -.jp-ActiveCellTool .jp-InputArea-prompt { - flex: 0 0 auto; - padding-left: 0px; -} - -.jp-ActiveCellTool .jp-InputArea-editor { - flex: 1 1 auto; - background: var(--jp-cell-editor-background); - border-color: var(--jp-cell-editor-border-color); -} - -.jp-ActiveCellTool .jp-InputArea-editor .CodeMirror { - background: transparent; -} - -.jp-MetadataEditorTool { - flex-direction: column; - padding: 12px 0px 12px 0px; -} - -.jp-RankedPanel > :not(:first-child) { - margin-top: 12px; -} - -.jp-KeySelector select.jp-mod-styled { - font-size: var(--jp-ui-font-size1); - color: var(--jp-ui-font-color0); - border: var(--jp-border-width) solid var(--jp-border-color1); -} - -.jp-KeySelector label, -.jp-MetadataEditorTool label { - line-height: 1.4; -} - -.jp-NotebookTools .jp-select-wrapper { - margin-top: 4px; - margin-bottom: 0px; -} - -.jp-NotebookTools .jp-Collapse { - margin-top: 16px; -} - -/*----------------------------------------------------------------------------- -| Presentation Mode (.jp-mod-presentationMode) -|----------------------------------------------------------------------------*/ - -.jp-mod-presentationMode .jp-Notebook { - --jp-content-font-size1: var(--jp-content-presentation-font-size1); - --jp-code-font-size: var(--jp-code-presentation-font-size); -} - -.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt, -.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt { - flex: 0 0 110px; -} - -/*----------------------------------------------------------------------------- -| Placeholder -|----------------------------------------------------------------------------*/ - -.jp-Cell-Placeholder { - padding-left: 55px; -} - -.jp-Cell-Placeholder-wrapper { - background: #fff; - border: 1px solid; - border-color: #e5e6e9 #dfe0e4 #d0d1d5; - border-radius: 4px; - -webkit-border-radius: 4px; - margin: 10px 15px; -} - -.jp-Cell-Placeholder-wrapper-inner { - padding: 15px; - position: relative; -} - -.jp-Cell-Placeholder-wrapper-body { - background-repeat: repeat; - background-size: 50% auto; -} - -.jp-Cell-Placeholder-wrapper-body div { - background: #f6f7f8; - background-image: -webkit-linear-gradient( - left, - #f6f7f8 0%, - #edeef1 20%, - #f6f7f8 40%, - #f6f7f8 100% - ); - background-repeat: no-repeat; - background-size: 800px 104px; - height: 104px; - position: relative; -} - -.jp-Cell-Placeholder-wrapper-body div { - position: absolute; - right: 15px; - left: 15px; - top: 15px; -} - -div.jp-Cell-Placeholder-h1 { - top: 20px; - height: 20px; - left: 15px; - width: 150px; -} - -div.jp-Cell-Placeholder-h2 { - left: 15px; - top: 50px; - height: 10px; - width: 100px; -} - -div.jp-Cell-Placeholder-content-1, -div.jp-Cell-Placeholder-content-2, -div.jp-Cell-Placeholder-content-3 { - left: 15px; - right: 15px; - height: 10px; -} - -div.jp-Cell-Placeholder-content-1 { - top: 100px; -} - -div.jp-Cell-Placeholder-content-2 { - top: 120px; -} - -div.jp-Cell-Placeholder-content-3 { - top: 140px; -} - -</style> - - <style type="text/css"> -/*----------------------------------------------------------------------------- -| Copyright (c) Jupyter Development Team. -| Distributed under the terms of the Modified BSD License. -|----------------------------------------------------------------------------*/ - -/* -The following CSS variables define the main, public API for styling JupyterLab. -These variables should be used by all plugins wherever possible. In other -words, plugins should not define custom colors, sizes, etc unless absolutely -necessary. This enables users to change the visual theme of JupyterLab -by changing these variables. - -Many variables appear in an ordered sequence (0,1,2,3). These sequences -are designed to work well together, so for example, `--jp-border-color1` should -be used with `--jp-layout-color1`. The numbers have the following meanings: - -* 0: super-primary, reserved for special emphasis -* 1: primary, most important under normal situations -* 2: secondary, next most important under normal situations -* 3: tertiary, next most important under normal situations - -Throughout JupyterLab, we are mostly following principles from Google's -Material Design when selecting colors. We are not, however, following -all of MD as it is not optimized for dense, information rich UIs. -*/ - -:root { - /* Elevation - * - * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here: - * - * https://github.com/material-components/material-components-web - * https://material-components-web.appspot.com/elevation.html - */ - - --jp-shadow-base-lightness: 0; - --jp-shadow-umbra-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.2 - ); - --jp-shadow-penumbra-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.14 - ); - --jp-shadow-ambient-color: rgba( - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - var(--jp-shadow-base-lightness), - 0.12 - ); - --jp-elevation-z0: none; - --jp-elevation-z1: 0px 2px 1px -1px var(--jp-shadow-umbra-color), - 0px 1px 1px 0px var(--jp-shadow-penumbra-color), - 0px 1px 3px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z2: 0px 3px 1px -2px var(--jp-shadow-umbra-color), - 0px 2px 2px 0px var(--jp-shadow-penumbra-color), - 0px 1px 5px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z4: 0px 2px 4px -1px var(--jp-shadow-umbra-color), - 0px 4px 5px 0px var(--jp-shadow-penumbra-color), - 0px 1px 10px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z6: 0px 3px 5px -1px var(--jp-shadow-umbra-color), - 0px 6px 10px 0px var(--jp-shadow-penumbra-color), - 0px 1px 18px 0px var(--jp-shadow-ambient-color); - --jp-elevation-z8: 0px 5px 5px -3px var(--jp-shadow-umbra-color), - 0px 8px 10px 1px var(--jp-shadow-penumbra-color), - 0px 3px 14px 2px var(--jp-shadow-ambient-color); - --jp-elevation-z12: 0px 7px 8px -4px var(--jp-shadow-umbra-color), - 0px 12px 17px 2px var(--jp-shadow-penumbra-color), - 0px 5px 22px 4px var(--jp-shadow-ambient-color); - --jp-elevation-z16: 0px 8px 10px -5px var(--jp-shadow-umbra-color), - 0px 16px 24px 2px var(--jp-shadow-penumbra-color), - 0px 6px 30px 5px var(--jp-shadow-ambient-color); - --jp-elevation-z20: 0px 10px 13px -6px var(--jp-shadow-umbra-color), - 0px 20px 31px 3px var(--jp-shadow-penumbra-color), - 0px 8px 38px 7px var(--jp-shadow-ambient-color); - --jp-elevation-z24: 0px 11px 15px -7px var(--jp-shadow-umbra-color), - 0px 24px 38px 3px var(--jp-shadow-penumbra-color), - 0px 9px 46px 8px var(--jp-shadow-ambient-color); - - /* Borders - * - * The following variables, specify the visual styling of borders in JupyterLab. - */ - - --jp-border-width: 1px; - --jp-border-color0: var(--md-grey-400); - --jp-border-color1: var(--md-grey-400); - --jp-border-color2: var(--md-grey-300); - --jp-border-color3: var(--md-grey-200); - --jp-border-radius: 2px; - - /* UI Fonts - * - * The UI font CSS variables are used for the typography all of the JupyterLab - * user interface elements that are not directly user generated content. - * - * The font sizing here is done assuming that the body font size of --jp-ui-font-size1 - * is applied to a parent element. When children elements, such as headings, are sized - * in em all things will be computed relative to that body size. - */ - - --jp-ui-font-scale-factor: 1.2; - --jp-ui-font-size0: 0.83333em; - --jp-ui-font-size1: 13px; /* Base font size */ - --jp-ui-font-size2: 1.2em; - --jp-ui-font-size3: 1.44em; - - --jp-ui-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, - Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'; - - /* - * Use these font colors against the corresponding main layout colors. - * In a light theme, these go from dark to light. - */ - - /* Defaults use Material Design specification */ - --jp-ui-font-color0: rgba(0, 0, 0, 1); - --jp-ui-font-color1: rgba(0, 0, 0, 0.87); - --jp-ui-font-color2: rgba(0, 0, 0, 0.54); - --jp-ui-font-color3: rgba(0, 0, 0, 0.38); - - /* - * Use these against the brand/accent/warn/error colors. - * These will typically go from light to darker, in both a dark and light theme. - */ - - --jp-ui-inverse-font-color0: rgba(255, 255, 255, 1); - --jp-ui-inverse-font-color1: rgba(255, 255, 255, 1); - --jp-ui-inverse-font-color2: rgba(255, 255, 255, 0.7); - --jp-ui-inverse-font-color3: rgba(255, 255, 255, 0.5); - - /* Content Fonts - * - * Content font variables are used for typography of user generated content. - * - * The font sizing here is done assuming that the body font size of --jp-content-font-size1 - * is applied to a parent element. When children elements, such as headings, are sized - * in em all things will be computed relative to that body size. - */ - - --jp-content-line-height: 1.6; - --jp-content-font-scale-factor: 1.2; - --jp-content-font-size0: 0.83333em; - --jp-content-font-size1: 14px; /* Base font size */ - --jp-content-font-size2: 1.2em; - --jp-content-font-size3: 1.44em; - --jp-content-font-size4: 1.728em; - --jp-content-font-size5: 2.0736em; - - /* This gives a magnification of about 125% in presentation mode over normal. */ - --jp-content-presentation-font-size1: 17px; - - --jp-content-heading-line-height: 1; - --jp-content-heading-margin-top: 1.2em; - --jp-content-heading-margin-bottom: 0.8em; - --jp-content-heading-font-weight: 500; - - /* Defaults use Material Design specification */ - --jp-content-font-color0: rgba(0, 0, 0, 1); - --jp-content-font-color1: rgba(0, 0, 0, 0.87); - --jp-content-font-color2: rgba(0, 0, 0, 0.54); - --jp-content-font-color3: rgba(0, 0, 0, 0.38); - - --jp-content-link-color: var(--md-blue-700); - - --jp-content-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', - Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', - 'Segoe UI Symbol'; - - /* - * Code Fonts - * - * Code font variables are used for typography of code and other monospaces content. - */ - - --jp-code-font-size: 13px; - --jp-code-line-height: 1.3077; /* 17px for 13px base */ - --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */ - --jp-code-font-family-default: Menlo, Consolas, 'DejaVu Sans Mono', monospace; - --jp-code-font-family: var(--jp-code-font-family-default); - - /* This gives a magnification of about 125% in presentation mode over normal. */ - --jp-code-presentation-font-size: 16px; - - /* may need to tweak cursor width if you change font size */ - --jp-code-cursor-width0: 1.4px; - --jp-code-cursor-width1: 2px; - --jp-code-cursor-width2: 4px; - - /* Layout - * - * The following are the main layout colors use in JupyterLab. In a light - * theme these would go from light to dark. - */ - - --jp-layout-color0: white; - --jp-layout-color1: white; - --jp-layout-color2: var(--md-grey-200); - --jp-layout-color3: var(--md-grey-400); - --jp-layout-color4: var(--md-grey-600); - - /* Inverse Layout - * - * The following are the inverse layout colors use in JupyterLab. In a light - * theme these would go from dark to light. - */ - - --jp-inverse-layout-color0: #111111; - --jp-inverse-layout-color1: var(--md-grey-900); - --jp-inverse-layout-color2: var(--md-grey-800); - --jp-inverse-layout-color3: var(--md-grey-700); - --jp-inverse-layout-color4: var(--md-grey-600); - - /* Brand/accent */ - - --jp-brand-color0: var(--md-blue-900); - --jp-brand-color1: var(--md-blue-700); - --jp-brand-color2: var(--md-blue-300); - --jp-brand-color3: var(--md-blue-100); - --jp-brand-color4: var(--md-blue-50); - - --jp-accent-color0: var(--md-green-900); - --jp-accent-color1: var(--md-green-700); - --jp-accent-color2: var(--md-green-300); - --jp-accent-color3: var(--md-green-100); - - /* State colors (warn, error, success, info) */ - - --jp-warn-color0: var(--md-orange-900); - --jp-warn-color1: var(--md-orange-700); - --jp-warn-color2: var(--md-orange-300); - --jp-warn-color3: var(--md-orange-100); - - --jp-error-color0: var(--md-red-900); - --jp-error-color1: var(--md-red-700); - --jp-error-color2: var(--md-red-300); - --jp-error-color3: var(--md-red-100); - - --jp-success-color0: var(--md-green-900); - --jp-success-color1: var(--md-green-700); - --jp-success-color2: var(--md-green-300); - --jp-success-color3: var(--md-green-100); - - --jp-info-color0: var(--md-cyan-900); - --jp-info-color1: var(--md-cyan-700); - --jp-info-color2: var(--md-cyan-300); - --jp-info-color3: var(--md-cyan-100); - - /* Cell specific styles */ - - --jp-cell-padding: 5px; - - --jp-cell-collapser-width: 8px; - --jp-cell-collapser-min-height: 20px; - --jp-cell-collapser-not-active-hover-opacity: 0.6; - - --jp-cell-editor-background: var(--md-grey-100); - --jp-cell-editor-border-color: var(--md-grey-300); - --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300); - --jp-cell-editor-active-background: var(--jp-layout-color0); - --jp-cell-editor-active-border-color: var(--jp-brand-color1); - - --jp-cell-prompt-width: 64px; - --jp-cell-prompt-font-family: var(--jp-code-font-family-default); - --jp-cell-prompt-letter-spacing: 0px; - --jp-cell-prompt-opacity: 1; - --jp-cell-prompt-not-active-opacity: 0.5; - --jp-cell-prompt-not-active-font-color: var(--md-grey-700); - /* A custom blend of MD grey and blue 600 - * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */ - --jp-cell-inprompt-font-color: #307fc1; - /* A custom blend of MD grey and orange 600 - * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */ - --jp-cell-outprompt-font-color: #bf5b3d; - - /* Notebook specific styles */ - - --jp-notebook-padding: 10px; - --jp-notebook-select-background: var(--jp-layout-color1); - --jp-notebook-multiselected-color: var(--md-blue-50); - - /* The scroll padding is calculated to fill enough space at the bottom of the - notebook to show one single-line cell (with appropriate padding) at the top - when the notebook is scrolled all the way to the bottom. We also subtract one - pixel so that no scrollbar appears if we have just one single-line cell in the - notebook. This padding is to enable a 'scroll past end' feature in a notebook. - */ - --jp-notebook-scroll-padding: calc( - 100% - var(--jp-code-font-size) * var(--jp-code-line-height) - - var(--jp-code-padding) - var(--jp-cell-padding) - 1px - ); - - /* Rendermime styles */ - - --jp-rendermime-error-background: #fdd; - --jp-rendermime-table-row-background: var(--md-grey-100); - --jp-rendermime-table-row-hover-background: var(--md-light-blue-50); - - /* Dialog specific styles */ - - --jp-dialog-background: rgba(0, 0, 0, 0.25); - - /* Console specific styles */ - - --jp-console-padding: 10px; - - /* Toolbar specific styles */ - - --jp-toolbar-border-color: var(--jp-border-color1); - --jp-toolbar-micro-height: 8px; - --jp-toolbar-background: var(--jp-layout-color1); - --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.24); - --jp-toolbar-header-margin: 4px 4px 0px 4px; - --jp-toolbar-active-background: var(--md-grey-300); - - /* Statusbar specific styles */ - - --jp-statusbar-height: 24px; - - /* Input field styles */ - - --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300); - --jp-input-active-background: var(--jp-layout-color1); - --jp-input-hover-background: var(--jp-layout-color1); - --jp-input-background: var(--md-grey-100); - --jp-input-border-color: var(--jp-border-color1); - --jp-input-active-border-color: var(--jp-brand-color1); - --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3); - - /* General editor styles */ - - --jp-editor-selected-background: #d9d9d9; - --jp-editor-selected-focused-background: #d7d4f0; - --jp-editor-cursor-color: var(--jp-ui-font-color0); - - /* Code mirror specific styles */ - - --jp-mirror-editor-keyword-color: #008000; - --jp-mirror-editor-atom-color: #88f; - --jp-mirror-editor-number-color: #080; - --jp-mirror-editor-def-color: #00f; - --jp-mirror-editor-variable-color: var(--md-grey-900); - --jp-mirror-editor-variable-2-color: #05a; - --jp-mirror-editor-variable-3-color: #085; - --jp-mirror-editor-punctuation-color: #05a; - --jp-mirror-editor-property-color: #05a; - --jp-mirror-editor-operator-color: #aa22ff; - --jp-mirror-editor-comment-color: #408080; - --jp-mirror-editor-string-color: #ba2121; - --jp-mirror-editor-string-2-color: #708; - --jp-mirror-editor-meta-color: #aa22ff; - --jp-mirror-editor-qualifier-color: #555; - --jp-mirror-editor-builtin-color: #008000; - --jp-mirror-editor-bracket-color: #997; - --jp-mirror-editor-tag-color: #170; - --jp-mirror-editor-attribute-color: #00c; - --jp-mirror-editor-header-color: blue; - --jp-mirror-editor-quote-color: #090; - --jp-mirror-editor-link-color: #00c; - --jp-mirror-editor-error-color: #f00; - --jp-mirror-editor-hr-color: #999; - - /* Vega extension styles */ - - --jp-vega-background: white; - - /* Sidebar-related styles */ - - --jp-sidebar-min-width: 250px; - - /* Search-related styles */ - - --jp-search-toggle-off-opacity: 0.5; - --jp-search-toggle-hover-opacity: 0.8; - --jp-search-toggle-on-opacity: 1; - --jp-search-selected-match-background-color: rgb(245, 200, 0); - --jp-search-selected-match-color: black; - --jp-search-unselected-match-background-color: var( - --jp-inverse-layout-color0 - ); - --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0); - - /* Icon colors that work well with light or dark backgrounds */ - --jp-icon-contrast-color0: var(--md-purple-600); - --jp-icon-contrast-color1: var(--md-green-600); - --jp-icon-contrast-color2: var(--md-pink-600); - --jp-icon-contrast-color3: var(--md-blue-600); -} -</style> - -<style type="text/css"> -/* Force rendering true colors when outputing to pdf */ -* { - -webkit-print-color-adjust: exact; -} - -/* Misc */ -a.anchor-link { - display: none; -} - -.highlight { - margin: 0.4em; -} - -/* Input area styling */ -.jp-InputArea { - overflow: hidden; -} - -.jp-InputArea-editor { - overflow: hidden; -} - -.CodeMirror pre { - margin: 0; - padding: 0; -} - -/* Using table instead of flexbox so that we can use break-inside property */ -/* CSS rules under this comment should not be required anymore after we move to the JupyterLab 4.0 CSS */ - - -.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { - min-width: calc( - var(--jp-cell-prompt-width) - var(--jp-private-cell-scrolling-output-offset) - ); -} - -.jp-OutputArea-child { - display: table; - width: 100%; -} - -.jp-OutputPrompt { - display: table-cell; - vertical-align: top; - min-width: var(--jp-cell-prompt-width); -} - -body[data-format='mobile'] .jp-OutputPrompt { - display: table-row; -} - -.jp-OutputArea-output { - display: table-cell; - width: 100%; -} - -body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output { - display: table-row; -} - -.jp-OutputArea-output.jp-OutputArea-executeResult { - width: 100%; -} - -/* Hiding the collapser by default */ -.jp-Collapser { - display: none; -} - -@media print { - .jp-Cell-inputWrapper, - .jp-Cell-outputWrapper { - display: block; - } - - .jp-OutputArea-child { - break-inside: avoid-page; - } -} -</style> - -<!-- Load mathjax --> - <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML-full,Safe"> </script> - <!-- MathJax configuration --> - <script type="text/x-mathjax-config"> - init_mathjax = function() { - if (window.MathJax) { - // MathJax loaded - MathJax.Hub.Config({ - TeX: { - equationNumbers: { - autoNumber: "AMS", - useLabelIds: true - } - }, - tex2jax: { - inlineMath: [ ['$','$'], ["\\(","\\)"] ], - displayMath: [ ['$$','$$'], ["\\[","\\]"] ], - processEscapes: true, - processEnvironments: true - }, - displayAlign: 'center', - CommonHTML: { - linebreaks: { - automatic: true - } - } - }); - - MathJax.Hub.Queue(["Typeset", MathJax.Hub]); - } - } - init_mathjax(); - </script> - <!-- End of mathjax configuration --></head> -<body class="jp-Notebook" data-jp-theme-light="true" data-jp-theme-name="JupyterLab Light"> -<div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [1]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">requests</span> -<span class="kn">import</span> <span class="nn">datetime</span> -<span class="kn">import</span> <span class="nn">os</span> -<span class="kn">import</span> <span class="nn">pandas</span> <span class="k">as</span> <span class="nn">pd</span> -<span class="kn">import</span> <span class="nn">xml.dom.minidom</span> -<span class="kn">from</span> <span class="nn">ost</span> <span class="kn">import</span> <span class="n">io</span> - -<span class="c1"># from Tara code</span> -<span class="k">def</span> <span class="nf">_get_sequence</span><span class="p">(</span><span class="n">chn</span><span class="p">):</span> - <span class="sd">"""Get the sequence out of an OST chain."""</span> - <span class="c1"># initialise</span> - <span class="n">lst_rn</span> <span class="o">=</span> <span class="n">chn</span><span class="o">.</span><span class="n">residues</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">number</span><span class="o">.</span><span class="n">num</span> - <span class="n">idx</span> <span class="o">=</span> <span class="mi">1</span> - <span class="n">sqe</span> <span class="o">=</span> <span class="n">chn</span><span class="o">.</span><span class="n">residues</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">one_letter_code</span> - <span class="k">if</span> <span class="n">lst_rn</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">sqe</span> <span class="o">=</span> <span class="s2">"-"</span> - <span class="n">idx</span> <span class="o">=</span> <span class="mi">0</span> - - <span class="k">for</span> <span class="n">res</span> <span class="ow">in</span> <span class="n">chn</span><span class="o">.</span><span class="n">residues</span><span class="p">[</span><span class="n">idx</span><span class="p">:]:</span> - <span class="n">lst_rn</span> <span class="o">+=</span> <span class="mi">1</span> - <span class="k">while</span> <span class="n">lst_rn</span> <span class="o">!=</span> <span class="n">res</span><span class="o">.</span><span class="n">number</span><span class="o">.</span><span class="n">num</span><span class="p">:</span> - <span class="n">sqe</span> <span class="o">+=</span> <span class="s2">"-"</span> - <span class="n">lst_rn</span> <span class="o">+=</span> <span class="mi">1</span> - <span class="n">sqe</span> <span class="o">+=</span> <span class="n">res</span><span class="o">.</span><span class="n">one_letter_code</span> - - <span class="k">return</span> <span class="n">sqe</span> - -<span class="k">def</span> <span class="nf">_check_sequence</span><span class="p">(</span><span class="n">up_ac</span><span class="p">,</span> <span class="n">sequence</span><span class="p">):</span> - <span class="sd">"""Verify sequence to only contain standard olc."""</span> - <span class="k">for</span> <span class="n">res</span> <span class="ow">in</span> <span class="n">sequence</span><span class="p">:</span> - <span class="k">if</span> <span class="n">res</span> <span class="ow">not</span> <span class="ow">in</span> <span class="s2">"ACDEFGHIKLMNPQRSTVWY"</span><span class="p">:</span> - <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span> - <span class="s2">"Non-standard aa found in UniProtKB sequence "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"for entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">': </span><span class="si">{</span><span class="n">res</span><span class="si">}</span><span class="s2">"</span> - <span class="p">)</span> - -<span class="k">def</span> <span class="nf">_fetch_upkb_entry</span><span class="p">(</span><span class="n">up_ac</span><span class="p">):</span> - <span class="sd">"""Fetch data for an UniProtKB entry."""</span> - <span class="c1"># This is a simple parser for UniProtKB txt format, instead of breaking it up</span> - <span class="c1"># into multiple functions, we just allow many many branches & statements,</span> - <span class="c1"># here.</span> - <span class="c1"># pylint: disable=too-many-branches,too-many-statements</span> - <span class="n">data</span> <span class="o">=</span> <span class="p">{}</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">]</span> <span class="o">=</span> <span class="s2">""</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">=</span> <span class="s2">""</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_ac"</span><span class="p">]</span> <span class="o">=</span> <span class="n">up_ac</span> - <span class="n">rspns</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="sa">f</span><span class="s2">"https://www.uniprot.org/uniprot/</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">.txt"</span><span class="p">)</span> - <span class="k">for</span> <span class="n">line</span> <span class="ow">in</span> <span class="n">rspns</span><span class="o">.</span><span class="n">iter_lines</span><span class="p">(</span><span class="n">decode_unicode</span><span class="o">=</span><span class="kc">True</span><span class="p">):</span> - <span class="k">if</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"ID "</span><span class="p">):</span> - <span class="n">sline</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">split</span><span class="p">()</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">5</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"Unusual UniProtKB ID line found:</span><span class="se">\n</span><span class="s2">'</span><span class="si">{</span><span class="n">line</span><span class="si">}</span><span class="s2">'"</span><span class="p">)</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_id"</span><span class="p">]</span> <span class="o">=</span> <span class="n">sline</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"OX NCBI_TaxID="</span><span class="p">):</span> - <span class="c1"># Following strictly the UniProtKB format: 'OX NCBI_TaxID=<ID>;'</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span> <span class="o">=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"OX NCBI_TaxID="</span><span class="p">)</span> <span class="p">:</span> <span class="o">-</span><span class="mi">1</span><span class="p">]</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">"{"</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"OS "</span><span class="p">):</span> - <span class="k">if</span> <span class="n">line</span><span class="p">[</span><span class="o">-</span><span class="mi">1</span><span class="p">]</span> <span class="o">==</span> <span class="s2">"."</span><span class="p">:</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">]</span> <span class="o">+=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"OS "</span><span class="p">)</span> <span class="p">:</span> <span class="o">-</span><span class="mi">1</span><span class="p">]</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">]</span> <span class="o">+=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"OS "</span><span class="p">)</span> <span class="p">:</span> <span class="o">-</span><span class="mi">1</span><span class="p">]</span> <span class="o">+</span> <span class="s2">" "</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"SQ "</span><span class="p">):</span> - <span class="n">sline</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">split</span><span class="p">()</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">8</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"Unusual UniProtKB SQ line found:</span><span class="se">\n</span><span class="s2">'</span><span class="si">{</span><span class="n">line</span><span class="si">}</span><span class="s2">'"</span><span class="p">)</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_seqlen"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">sline</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_crc64"</span><span class="p">]</span> <span class="o">=</span> <span class="n">sline</span><span class="p">[</span><span class="mi">6</span><span class="p">]</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">" "</span><span class="p">):</span> - <span class="n">sline</span> <span class="o">=</span> <span class="n">line</span><span class="o">.</span><span class="n">split</span><span class="p">()</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> <span class="o">></span> <span class="mi">6</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span> - <span class="s2">"Unusual UniProtKB sequence data line "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"found:</span><span class="se">\n</span><span class="s2">'</span><span class="si">{</span><span class="n">line</span><span class="si">}</span><span class="s2">'"</span> - <span class="p">)</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">+=</span> <span class="s2">""</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">sline</span><span class="p">)</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"RP "</span><span class="p">):</span> - <span class="k">if</span> <span class="s2">"ISOFORM"</span> <span class="ow">in</span> <span class="n">line</span><span class="o">.</span><span class="n">upper</span><span class="p">():</span> - <span class="ne">RuntimeError</span><span class="p">(</span> - <span class="sa">f</span><span class="s2">"First ISOFORM found for '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">', needs "</span> <span class="o">+</span> <span class="s2">"handling."</span> - <span class="p">)</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"DT "</span><span class="p">):</span> - <span class="c1"># 2012-10-03</span> - <span class="n">dt_flds</span> <span class="o">=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"DT "</span><span class="p">)</span> <span class="p">:]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">", "</span><span class="p">)</span> - <span class="k">if</span> <span class="n">dt_flds</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">upper</span><span class="p">()</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"SEQUENCE VERSION "</span><span class="p">):</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_last_mod"</span><span class="p">]</span> <span class="o">=</span> <span class="n">datetime</span><span class="o">.</span><span class="n">datetime</span><span class="o">.</span><span class="n">strptime</span><span class="p">(</span> - <span class="n">dt_flds</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="s2">"</span><span class="si">%d</span><span class="s2">-%b-%Y"</span> - <span class="p">)</span> - <span class="k">elif</span> <span class="n">line</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"GN Name="</span><span class="p">):</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_gn"</span><span class="p">]</span> <span class="o">=</span> <span class="n">line</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"GN Name="</span><span class="p">)</span> <span class="p">:]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">";"</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_gn"</span><span class="p">]</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_gn"</span><span class="p">]</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s2">"{"</span><span class="p">)[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - - <span class="c1"># we have not seen isoforms in the data set, yet, so we just set them to '.'</span> - <span class="n">data</span><span class="p">[</span><span class="s2">"up_isoform"</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span> - - <span class="k">if</span> <span class="s2">"up_gn"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No gene name found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">"up_last_mod"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No sequence version found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">"up_crc64"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No CRC64 value found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">])</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No sequence found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="c1"># check that sequence length and CRC64 is correct</span> - <span class="k">if</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_seqlen"</span><span class="p">]</span> <span class="o">!=</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]):</span> - <span class="n">_abort_msg</span><span class="p">(</span> - <span class="s2">"Sequence length of SQ line and sequence data differ for "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">': </span><span class="si">{</span><span class="n">data</span><span class="p">[</span><span class="s1">'up_seqlen'</span><span class="p">]</span><span class="si">}</span><span class="s2"> != "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s1">'up_sequence'</span><span class="p">])</span><span class="si">}</span><span class="s2">"</span> - <span class="p">)</span> - <span class="n">_check_sequence</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_ac"</span><span class="p">],</span> <span class="n">data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">])</span> - - <span class="k">if</span> <span class="s2">"up_id"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No ID found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="s2">"up_ncbi_taxid"</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">data</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No NCBI taxonomy ID found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s2">"up_organism"</span><span class="p">])</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span> - <span class="n">_abort_msg</span><span class="p">(</span><span class="sa">f</span><span class="s2">"No organism species found for UniProtKB entry '</span><span class="si">{</span><span class="n">up_ac</span><span class="si">}</span><span class="s2">'."</span><span class="p">)</span> - - <span class="k">return</span> <span class="n">data</span> - -<span class="k">def</span> <span class="nf">_get_upkb_for_sequence</span><span class="p">(</span><span class="n">sqe</span><span class="p">,</span> <span class="n">up_ac</span><span class="p">):</span> - <span class="sd">"""Get UniProtKB entry data for given sequence."""</span> - <span class="n">up_data</span> <span class="o">=</span> <span class="n">_fetch_upkb_entry</span><span class="p">(</span><span class="n">up_ac</span><span class="p">)</span> - <span class="k">if</span> <span class="n">sqe</span> <span class="o">!=</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]:</span> - <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span> - <span class="sa">f</span><span class="s2">"Sequences not equal from file: </span><span class="si">{</span><span class="n">sqe</span><span class="si">}</span><span class="s2">, from UniProtKB: "</span> - <span class="o">+</span> <span class="sa">f</span><span class="s2">"</span><span class="si">{</span><span class="n">up_data</span><span class="p">[</span><span class="s1">'up_sequence'</span><span class="p">]</span><span class="si">}</span><span class="s2">"</span> - <span class="p">)</span> - - <span class="k">return</span> <span class="n">up_data</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [2]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">_get_ncbi_sequence</span><span class="p">(</span><span class="n">ncbi_ac</span><span class="p">):</span> - <span class="sd">"""Fetch OST sequence object from NCBI web service."""</span> - <span class="c1"># src: https://www.ncbi.nlm.nih.gov/books/NBK25500/#_chapter1_Downloading_Full_Records_</span> - <span class="n">rspns</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="sa">f</span><span class="s2">"https://eutils.ncbi.nlm.nih.gov/entrez/eutils/"</span> \ - <span class="sa">f</span><span class="s2">"efetch.fcgi?db=protein&id=</span><span class="si">{</span><span class="n">ncbi_ac</span><span class="si">}</span><span class="s2">"</span> \ - <span class="sa">f</span><span class="s2">"&rettype=fasta&retmode=text"</span><span class="p">)</span> - <span class="k">return</span> <span class="n">io</span><span class="o">.</span><span class="n">SequenceFromString</span><span class="p">(</span><span class="n">rspns</span><span class="o">.</span><span class="n">text</span><span class="p">,</span> <span class="s2">"fasta"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [3]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># s = _get_ncbi_sequence("CAD2068351.1")</span> -<span class="c1"># up_data = _fetch_upkb_entry("A0A485PQD1")</span> -<span class="c1"># print(s.name, s, len(s), up_data["up_sequence"] == str(s))</span> -<span class="c1"># up_data</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [5]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check USDA data</span> -<span class="n">metadata_file</span> <span class="o">=</span> <span class="s2">"./InputFiles/ASFV-G_proteome_accessions.csv"</span> -<span class="n">pdb_dir</span> <span class="o">=</span> <span class="s2">"./InputFiles/AlphaFold-RENAME"</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [6]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span> <span class="o">=</span> <span class="n">pd</span><span class="o">.</span><span class="n">read_csv</span><span class="p">(</span><span class="n">metadata_file</span><span class="p">)</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">Protein</span><span class="p">))</span> <span class="o">==</span> <span class="n">metadata</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"Associated PDB"</span><span class="p">]))</span> <span class="o">==</span> <span class="n">metadata</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> -<span class="n">metadata</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[6]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Protein</th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - </thead> - <tbody> - <tr> - <th>0</th> - <td>285L</td> - <td>285L.pdb</td> - <td>CAD2068351.1</td> - <td>A0A485PQD1</td> - <td>ASFV-G 285L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>1</th> - <td>A104R</td> - <td>A104R.pdb</td> - <td>CAD2068395.1</td> - <td>A0A0A1E0L7</td> - <td>ASFV-G A104R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>2</th> - <td>A118R</td> - <td>A118R.pdb</td> - <td>CAD2068397.1</td> - <td>A0A2X0RVA9</td> - <td>ASFV-G A118R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>3</th> - <td>A137R</td> - <td>A137R.pdb</td> - <td>CAD2068404.1</td> - <td>A0A2X0THQ0</td> - <td>ASFV-G A137R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>4</th> - <td>A151R</td> - <td>A151R.pdb</td> - <td>CAD2068398.1</td> - <td>A0A2X0TC55</td> - <td>ASFV-G A151R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>...</th> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - </tr> - <tr> - <th>192</th> - <td>QP509L</td> - <td>QP509L.pdb</td> - <td>CAD2068484.1</td> - <td>A0A2X0THX2</td> - <td>ASFV-G QP509L</td> - <td>This model was predicted using AlphaFold2</td> - <td>NaN</td> - <td>NaN</td> - </tr> - <tr> - <th>193</th> - <td>R298L</td> - <td>R298L.pdb</td> - <td>CAD2068482.1</td> - <td>A0A2X0SE42</td> - <td>ASFV-G R298L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>194</th> - <td>S183L</td> - <td>S183L.pdb</td> - <td>CAD2068472.1</td> - <td>A0A2X0SE34</td> - <td>ASFV-G S183L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>195</th> - <td>S273R</td> - <td>S273R.pdb</td> - <td>CAD2068473.1</td> - <td>A0A2X0TKM5</td> - <td>ASFV-G S273R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - </tr> - <tr> - <th>196</th> - <td>X69R</td> - <td>X69R.pdb</td> - <td>CAD2068372.1</td> - <td>A0A2X0TKC7</td> - <td>ASFV-G X69R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - </tr> - </tbody> -</table> -<p>197 rows × 8 columns</p> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [66]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">pdb_files</span> <span class="o">=</span> <span class="p">[</span><span class="n">f</span> <span class="k">for</span> <span class="n">f</span> <span class="ow">in</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">listdir</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">))</span> <span class="k">if</span> <span class="n">f</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">".pdb"</span><span class="p">)]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [67]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check names</span> -<span class="n">pdb_file_split</span> <span class="o">=</span> <span class="p">[</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">splitext</span><span class="p">(</span><span class="n">f</span><span class="p">)</span> <span class="k">for</span> <span class="n">f</span> <span class="ow">in</span> <span class="n">pdb_files</span><span class="p">]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [68]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># CHECK THAT PDB FILES MATCH EXISTING ONES</span> -<span class="c1"># -> extra QP509L-unrelaxed expected</span> -<span class="n">tstp</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">pdb_files</span><span class="p">)</span> -<span class="n">tstm</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"Associated PDB"</span><span class="p">])</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY AS PDB:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstp</span> <span class="o">-</span> <span class="n">tstm</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY IN METADATA:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstm</span> <span class="o">-</span> <span class="n">tstp</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>ONLY AS PDB: ['QP509L-unrelaxed.pdb'] -ONLY IN METADATA: [] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [70]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># CHECK THAT FILE NAMES MATCH PROTEIN NAMES</span> -<span class="n">tstp</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">fs</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="k">for</span> <span class="n">fs</span> <span class="ow">in</span> <span class="n">pdb_file_split</span><span class="p">)</span> -<span class="n">tstm</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">Protein</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY AS PDB:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstp</span> <span class="o">-</span> <span class="n">tstm</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"ONLY IN METADATA:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">tstm</span> <span class="o">-</span> <span class="n">tstp</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>ONLY AS PDB: ['QP509L-unrelaxed'] -ONLY IN METADATA: [] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [14]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># can use either Protein or PDB name as index</span> -<span class="n">metadata</span> <span class="o">=</span> <span class="n">metadata</span><span class="o">.</span><span class="n">set_index</span><span class="p">(</span><span class="s2">"Protein"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [15]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># NOTE: stupid space there...</span> -<span class="n">metadata</span><span class="p">[</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"_struct.title "</span><span class="p">]</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[15]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - <tr> - <th>Protein</th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - </tr> - </thead> - <tbody> - </tbody> -</table> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [16]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span><span class="p">[</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"_struct.pdbx_model_detail"</span><span class="p">]</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[16]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - <tr> - <th>Protein</th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - </tr> - </thead> - <tbody> - </tbody> -</table> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [17]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span><span class="p">[</span><span class="o">~</span><span class="n">metadata</span><span class="o">.</span><span class="n">notes</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[17]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - </tr> - <tr> - <th>Protein</th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - </tr> - </thead> - <tbody> - <tr> - <th>CP2475L_p14</th> - <td>CP2475L_p14.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p14</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>protein p14 from the pp220 polyprotein encoded...</td> - </tr> - <tr> - <th>CP2475L_p34</th> - <td>CP2475L_p34.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p34</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>protein p34 from the pp220 polyprotein encoded...</td> - </tr> - <tr> - <th>CP2475L_p37</th> - <td>CP2475L_p37.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p37</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>protein p37 from the pp220 polyprotein encoded...</td> - </tr> - <tr> - <th>CP2475L_p150</th> - <td>CP2475L_p150.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p150</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>protein p150 from the pp220 polyprotein encode...</td> - </tr> - <tr> - <th>CP2475L_p5</th> - <td>CP2475L_p5.pdb</td> - <td>CAD2068454.1</td> - <td>A0A2X0THU5</td> - <td>ASFV-G CP2475L p5</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>protein p5 from the pp220 polyprotein encoded ...</td> - </tr> - <tr> - <th>D250R</th> - <td>D250R.pdb</td> - <td>CAD2068464.1</td> - <td>A0A2X0THV3</td> - <td>ASFV-G D250R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>Mislabled on NCBI and Uniport as D205R</td> - </tr> - <tr> - <th>DP79L</th> - <td>DP79L.pdb</td> - <td>CAD2068466.1</td> - <td>A0A0A1E158</td> - <td>ASFV-G DP79L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>Mislabled on Uniprot as D79L</td> - </tr> - <tr> - <th>hypothetical_01</th> - <td>hypothetical_01.pdb</td> - <td>CAD2068367.1</td> - <td>A0A485PU43</td> - <td>ASFV-G hypothetical_01</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_5_pred_0</td> - <td>labeled as hypothetical on NCBI and Uniprot</td> - </tr> - <tr> - <th>hypothetical_02</th> - <td>hypothetical_02.pdb</td> - <td>CAD2068400.1</td> - <td>A0A485PQI3</td> - <td>ASFV-G hypothetical_02</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>labeled as hypthetical on NCBI and Uniprot</td> - </tr> - <tr> - <th>hypothetical_03</th> - <td>hypothetical_03.pdb</td> - <td>CAD2068512.1</td> - <td>A0A485PZB7</td> - <td>ASFV-G hypothetical_03</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>labeled as hypthetical on NCBI and Uniprot</td> - </tr> - </tbody> -</table> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [126]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">for</span> <span class="n">mdl_notes</span> <span class="ow">in</span> <span class="n">metadata</span><span class="p">[</span><span class="o">~</span><span class="n">metadata</span><span class="o">.</span><span class="n">notes</span><span class="o">.</span><span class="n">isna</span><span class="p">()]</span><span class="o">.</span><span class="n">notes</span><span class="p">:</span> - <span class="n">mdl_notes</span> <span class="o">=</span> <span class="n">mdl_notes</span><span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">"hypthetical"</span><span class="p">,</span> <span class="s2">"hypothetical"</span><span class="p">)</span> \ - <span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">"Uniport"</span><span class="p">,</span> <span class="s2">"UniProt"</span><span class="p">)</span> \ - <span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">"Uniprot"</span><span class="p">,</span> <span class="s2">"UniProt"</span><span class="p">)</span> \ - <span class="o">.</span><span class="n">replace</span><span class="p">(</span><span class="s2">"Mislabled"</span><span class="p">,</span> <span class="s2">"mislabeled"</span><span class="p">)</span> - <span class="nb">print</span><span class="p">(</span><span class="n">mdl_notes</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>protein p14 from the pp220 polyprotein encoded by CP2475L -protein p34 from the pp220 polyprotein encoded by CP2475L -protein p37 from the pp220 polyprotein encoded by CP2475L -protein p150 from the pp220 polyprotein encoded by CP2475L -protein p5 from the pp220 polyprotein encoded by CP2475L -mislabeled on NCBI and UniProt as D205R -mislabeled on UniProt as D79L -labeled as hypothetical on NCBI and UniProt -labeled as hypothetical on NCBI and UniProt -labeled as hypothetical on NCBI and UniProt -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [121]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">mdl_notes</span> <span class="o">=</span> <span class="s1">'labeled as hypthetical on NCBI and Uniprot'</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[121]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>'labeled as hypothetical on NCBI and Uniprot'</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [31]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># tst = metadata.loc["hypothetical_03"]</span> -<span class="c1"># s = _get_ncbi_sequence(tst.NCBI_Accession)</span> -<span class="c1"># up_data = _fetch_upkb_entry(tst.UniProt_ID)</span> -<span class="c1"># print(s.name, s, len(s), up_data["up_sequence"] == str(s))</span> -<span class="c1"># up_data</span> - -<span class="c1"># checked all the one above manually and ok as stated (best to add to model_detail!)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [113]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># special one...</span> -<span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="s2">"QP509L"</span><span class="p">]</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[113]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>Associated PDB QP509L.pdb -NCBI_Accession CAD2068484.1 -UniProt_ID A0A2X0THX2 -_struct.title ASFV-G QP509L -_struct.pdbx_model_detail This model was predicted using AlphaFold2 -ranking debugg model ID NaN -notes NaN -NCBI_Gi 1886137009 -NCBI_UpdateDate 2020/08/05 -NCBI_TaxId 10497 -Name: QP509L, dtype: object</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [33]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"_struct.pdbx_model_detail"</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[33]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>{'This model was predicted using AlphaFold2'}</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [34]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="p">[</span><span class="s2">"_struct.title "</span><span class="p">]))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[34]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>197</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [35]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check model numbers</span> -<span class="n">tst</span> <span class="o">=</span> <span class="n">metadata</span><span class="p">[</span><span class="s2">"ranking debugg model ID"</span><span class="p">]</span> -<span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">mdl_id</span> <span class="ow">in</span> <span class="n">tst</span><span class="o">.</span><span class="n">items</span><span class="p">():</span> - <span class="n">mdl_num</span> <span class="o">=</span> <span class="kc">None</span> - <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">mdl_id</span><span class="p">)</span> <span class="o">==</span> <span class="nb">str</span><span class="p">:</span> - <span class="n">mdl_id_split</span> <span class="o">=</span> <span class="n">mdl_id</span><span class="o">.</span><span class="n">split</span><span class="p">(</span><span class="s1">'_'</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">mdl_id_split</span><span class="p">)</span> <span class="o">==</span> <span class="mi">4</span><span class="p">:</span> - <span class="n">mdl_num</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">mdl_id_split</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> - <span class="k">if</span> <span class="ow">not</span> <span class="n">mdl_num</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">mdl_id</span><span class="p">)</span> - <span class="k">elif</span> <span class="n">mdl_num</span> <span class="ow">not</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">6</span><span class="p">):</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">mdl_id</span><span class="p">,</span> <span class="n">mdl_num</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>QP509L nan -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [36]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">_check_subset</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">s2</span><span class="p">):</span> - <span class="c1"># check if s2 is uniquely contained in s1</span> - <span class="c1"># (and if so, returns values for seq_db_align_begin & seq_db_align_end)</span> - <span class="k">if</span> <span class="n">s1</span><span class="o">.</span><span class="n">count</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">align_begin</span> <span class="o">=</span> <span class="n">s1</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span> - <span class="n">align_end</span> <span class="o">=</span> <span class="n">align_begin</span> <span class="o">+</span> <span class="nb">len</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span> - <span class="k">return</span> <span class="n">align_begin</span><span class="p">,</span> <span class="n">align_end</span> - <span class="k">else</span><span class="p">:</span> - <span class="k">return</span> <span class="kc">None</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [37]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check shared ones</span> -<span class="k">for</span> <span class="n">protein</span><span class="p">,</span> <span class="n">pdb_ext</span> <span class="ow">in</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">pdb_file_split</span><span class="p">):</span> - <span class="k">if</span> <span class="n">protein</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">index</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"SKIPPING"</span><span class="p">,</span> <span class="n">protein</span><span class="p">)</span> - <span class="k">continue</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">row</span> <span class="o">=</span> <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">protein</span><span class="p">]</span> - <span class="n">pdb_path</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">,</span> <span class="n">protein</span> <span class="o">+</span> <span class="n">pdb_ext</span><span class="p">)</span> - <span class="n">ent</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="n">pdb_path</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">ent</span><span class="o">.</span><span class="n">chain_count</span> <span class="o">==</span> <span class="mi">1</span> - <span class="n">sqe</span> <span class="o">=</span> <span class="n">_get_sequence</span><span class="p">(</span><span class="n">ent</span><span class="o">.</span><span class="n">chains</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> - <span class="n">s_ncbi</span> <span class="o">=</span> <span class="n">_get_ncbi_sequence</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">)</span> - <span class="n">up_data</span> <span class="o">=</span> <span class="n">_fetch_upkb_entry</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">UniProt_ID</span><span class="p">)</span> - <span class="k">if</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">!=</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">):</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"inconsistent UP/NCBI sequences"</span><span class="p">,</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">],</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">))</span> - <span class="k">if</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">]</span> <span class="o">!=</span> <span class="n">sqe</span><span class="p">:</span> - <span class="n">tst</span> <span class="o">=</span> <span class="n">_check_subset</span><span class="p">(</span><span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">],</span> <span class="n">sqe</span><span class="p">)</span> - <span class="k">if</span> <span class="n">tst</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"PDB seq. is subset of UP"</span><span class="p">,</span> <span class="n">tst</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"inconsistent UP/PDB sequences"</span><span class="p">,</span> <span class="n">up_data</span><span class="p">[</span><span class="s2">"up_sequence"</span><span class="p">],</span> <span class="n">sqe</span><span class="p">)</span> - <span class="k">if</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">)</span> <span class="o">!=</span> <span class="n">sqe</span><span class="p">:</span> - <span class="n">tst</span> <span class="o">=</span> <span class="n">_check_subset</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">),</span> <span class="n">sqe</span><span class="p">)</span> - <span class="k">if</span> <span class="n">tst</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"PDB seq. is subset of NCBI"</span><span class="p">,</span> <span class="n">tst</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="s2">"inconsistent NCBI/PDB sequences"</span><span class="p">,</span> <span class="nb">str</span><span class="p">(</span><span class="n">s_ncbi</span><span class="p">),</span> <span class="n">sqe</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>CP2475L_p14 PDB seq. is subset of UP (369, 522) -CP2475L_p14 PDB seq. is subset of NCBI (369, 522) -CP2475L_p150 PDB seq. is subset of UP (894, 2476) -CP2475L_p150 PDB seq. is subset of NCBI (894, 2476) -CP2475L_p34 PDB seq. is subset of UP (45, 368) -CP2475L_p34 PDB seq. is subset of NCBI (45, 368) -CP2475L_p37 PDB seq. is subset of UP (523, 893) -CP2475L_p37 PDB seq. is subset of NCBI (523, 893) -CP2475L_p5 PDB seq. is subset of UP (2, 39) -CP2475L_p5 PDB seq. is subset of NCBI (2, 39) -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [65]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check QP509L (take pLDDT from unrelaxed)</span> -<span class="n">ent_unr</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="s2">"./InputFiles/AlphaFold-RENAME/QP509L-unrelaxed.pdb"</span><span class="p">)</span> -<span class="n">ent_rel</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="s2">"./InputFiles/AlphaFold-RENAME/QP509L.pdb"</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">occupancy</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_rel</span><span class="o">.</span><span class="n">atoms</span><span class="p">),</span> <span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">b_factor</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_rel</span><span class="o">.</span><span class="n">atoms</span><span class="p">))</span> -<span class="n">ev_atoms</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">qualified_name</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_rel</span><span class="o">.</span><span class="n">atoms</span><span class="p">)</span> -<span class="n">eu_atoms</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">a</span><span class="o">.</span><span class="n">qualified_name</span> <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">ent_unr</span><span class="o">.</span><span class="n">atoms</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"IN UNRELAXED:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">eu_atoms</span> <span class="o">-</span> <span class="n">ev_atoms</span><span class="p">))</span> -<span class="nb">print</span><span class="p">(</span><span class="s2">"IN RELAXED:"</span><span class="p">,</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">ev_atoms</span> <span class="o">-</span> <span class="n">eu_atoms</span><span class="p">))</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>{1.0} {0.0} -IN UNRELAXED: [] -IN RELAXED: [] -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [43]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">_get_ncbi_info</span><span class="p">(</span><span class="n">ncbi_ac</span><span class="p">):</span> - <span class="sd">"""Fetch dict with info from NCBI web service."""</span> - <span class="c1"># src: https://www.ncbi.nlm.nih.gov/books/NBK25499/#chapter4.ESummary</span> - <span class="n">rspns</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="sa">f</span><span class="s2">"https://eutils.ncbi.nlm.nih.gov/entrez/eutils/"</span> \ - <span class="sa">f</span><span class="s2">"esummary.fcgi?db=protein&id=</span><span class="si">{</span><span class="n">ncbi_ac</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="n">dom</span> <span class="o">=</span> <span class="n">xml</span><span class="o">.</span><span class="n">dom</span><span class="o">.</span><span class="n">minidom</span><span class="o">.</span><span class="n">parseString</span><span class="p">(</span><span class="n">rspns</span><span class="o">.</span><span class="n">text</span><span class="p">)</span> - <span class="n">docsums</span> <span class="o">=</span> <span class="n">dom</span><span class="o">.</span><span class="n">getElementsByTagName</span><span class="p">(</span><span class="s2">"DocSum"</span><span class="p">)</span> - <span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="n">docsums</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span> - <span class="n">docsum</span> <span class="o">=</span> <span class="n">docsums</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> - <span class="n">ncbi_dict</span> <span class="o">=</span> <span class="p">{}</span> - <span class="k">for</span> <span class="n">cn</span> <span class="ow">in</span> <span class="n">docsum</span><span class="o">.</span><span class="n">childNodes</span><span class="p">:</span> - <span class="k">if</span> <span class="n">cn</span><span class="o">.</span><span class="n">nodeName</span> <span class="o">==</span> <span class="s2">"Item"</span><span class="p">:</span> - <span class="n">cn_name</span> <span class="o">=</span> <span class="n">cn</span><span class="o">.</span><span class="n">getAttribute</span><span class="p">(</span><span class="s2">"Name"</span><span class="p">)</span> - <span class="n">cn_type</span> <span class="o">=</span> <span class="n">cn</span><span class="o">.</span><span class="n">getAttribute</span><span class="p">(</span><span class="s2">"Type"</span><span class="p">)</span> - <span class="k">if</span> <span class="n">cn</span><span class="o">.</span><span class="n">childNodes</span><span class="p">:</span> - <span class="n">d</span> <span class="o">=</span> <span class="n">cn</span><span class="o">.</span><span class="n">childNodes</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">data</span> - <span class="k">if</span> <span class="n">cn_type</span> <span class="o">==</span> <span class="s2">"String"</span><span class="p">:</span> - <span class="n">ncbi_dict</span><span class="p">[</span><span class="n">cn_name</span><span class="p">]</span> <span class="o">=</span> <span class="n">d</span> - <span class="k">elif</span> <span class="n">cn_type</span> <span class="o">==</span> <span class="s2">"Integer"</span><span class="p">:</span> - <span class="n">ncbi_dict</span><span class="p">[</span><span class="n">cn_name</span><span class="p">]</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">d</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span><span class="sa">f</span><span class="s2">"Unknown type </span><span class="si">{</span><span class="n">cn_type</span><span class="si">}</span><span class="s2"> for </span><span class="si">{</span><span class="n">ncbi_ac</span><span class="si">}</span><span class="s2">"</span><span class="p">)</span> - <span class="k">else</span><span class="p">:</span> - <span class="n">ncbi_dict</span><span class="p">[</span><span class="n">cn_name</span><span class="p">]</span> <span class="o">=</span> <span class="kc">None</span> - <span class="k">return</span> <span class="n">ncbi_dict</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [44]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># fetch some extra info from NCBI</span> -<span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">iterrows</span><span class="p">():</span> - <span class="n">ncbi_info</span> <span class="o">=</span> <span class="n">_get_ncbi_info</span><span class="p">(</span><span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">)</span> - <span class="c1"># Gi is some numerical sequence identifier used internally by NCBI</span> - <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">idx</span><span class="p">,</span> <span class="s2">"NCBI_Gi"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"Gi"</span><span class="p">])</span> - <span class="c1"># UpdateData is to be stored as the version date in ModelCIF</span> - <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">idx</span><span class="p">,</span> <span class="s2">"NCBI_UpdateDate"</span><span class="p">]</span> <span class="o">=</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"UpdateDate"</span><span class="p">]</span> - <span class="c1"># TaxId should be same as one from UP</span> - <span class="n">metadata</span><span class="o">.</span><span class="n">loc</span><span class="p">[</span><span class="n">idx</span><span class="p">,</span> <span class="s2">"NCBI_TaxId"</span><span class="p">]</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"TaxId"</span><span class="p">])</span> - <span class="c1"># Status expected to be live</span> - <span class="k">if</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"Status"</span><span class="p">]</span> <span class="o">!=</span> <span class="s2">"live"</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">,</span> <span class="s2">"Status"</span><span class="p">,</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"Status"</span><span class="p">])</span> - <span class="c1"># ReplacedBy expected to be empty</span> - <span class="k">if</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"ReplacedBy"</span><span class="p">]:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">,</span> <span class="s2">"ReplacedBy"</span><span class="p">,</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"ReplacedBy"</span><span class="p">])</span> - <span class="c1"># AccessionVersion expected to be NCBI_Accession</span> - <span class="k">if</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"AccessionVersion"</span><span class="p">]</span> <span class="o">!=</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">row</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">,</span> <span class="s2">"AccessionVersion"</span><span class="p">,</span> <span class="n">ncbi_info</span><span class="p">[</span><span class="s2">"AccessionVersion"</span><span class="p">])</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [45]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">metadata</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[45]:</div> - - - -<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html"> -<div> -<style scoped> - .dataframe tbody tr th:only-of-type { - vertical-align: middle; - } - - .dataframe tbody tr th { - vertical-align: top; - } - - .dataframe thead th { - text-align: right; - } -</style> -<table border="1" class="dataframe"> - <thead> - <tr style="text-align: right;"> - <th></th> - <th>Associated PDB</th> - <th>NCBI_Accession</th> - <th>UniProt_ID</th> - <th>_struct.title</th> - <th>_struct.pdbx_model_detail</th> - <th>ranking debugg model ID</th> - <th>notes</th> - <th>NCBI_Gi</th> - <th>NCBI_UpdateDate</th> - <th>NCBI_TaxId</th> - </tr> - <tr> - <th>Protein</th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - <th></th> - </tr> - </thead> - <tbody> - <tr> - <th>285L</th> - <td>285L.pdb</td> - <td>CAD2068351.1</td> - <td>A0A485PQD1</td> - <td>ASFV-G 285L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - <td>1886136876</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A104R</th> - <td>A104R.pdb</td> - <td>CAD2068395.1</td> - <td>A0A0A1E0L7</td> - <td>ASFV-G A104R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - <td>1886136920</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A118R</th> - <td>A118R.pdb</td> - <td>CAD2068397.1</td> - <td>A0A2X0RVA9</td> - <td>ASFV-G A118R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_1_pred_0</td> - <td>NaN</td> - <td>1886136922</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A137R</th> - <td>A137R.pdb</td> - <td>CAD2068404.1</td> - <td>A0A2X0THQ0</td> - <td>ASFV-G A137R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - <td>1886136929</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>A151R</th> - <td>A151R.pdb</td> - <td>CAD2068398.1</td> - <td>A0A2X0TC55</td> - <td>ASFV-G A151R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - <td>1886136923</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>...</th> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - <td>...</td> - </tr> - <tr> - <th>QP509L</th> - <td>QP509L.pdb</td> - <td>CAD2068484.1</td> - <td>A0A2X0THX2</td> - <td>ASFV-G QP509L</td> - <td>This model was predicted using AlphaFold2</td> - <td>NaN</td> - <td>NaN</td> - <td>1886137009</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>R298L</th> - <td>R298L.pdb</td> - <td>CAD2068482.1</td> - <td>A0A2X0SE42</td> - <td>ASFV-G R298L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_3_pred_0</td> - <td>NaN</td> - <td>1886137007</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>S183L</th> - <td>S183L.pdb</td> - <td>CAD2068472.1</td> - <td>A0A2X0SE34</td> - <td>ASFV-G S183L</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_4_pred_0</td> - <td>NaN</td> - <td>1886136997</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>S273R</th> - <td>S273R.pdb</td> - <td>CAD2068473.1</td> - <td>A0A2X0TKM5</td> - <td>ASFV-G S273R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - <td>1886136998</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - <tr> - <th>X69R</th> - <td>X69R.pdb</td> - <td>CAD2068372.1</td> - <td>A0A2X0TKC7</td> - <td>ASFV-G X69R</td> - <td>This model was predicted using AlphaFold2</td> - <td>model_2_pred_0</td> - <td>NaN</td> - <td>1886136897</td> - <td>2020/08/05</td> - <td>10497</td> - </tr> - </tbody> -</table> -<p>197 rows × 10 columns</p> -</div> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [46]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_Accession</span><span class="p">)),</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_TaxId</span><span class="p">),</span> \ -<span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_Gi</span><span class="p">)),</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">NCBI_UpdateDate</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[46]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>(193, {'10497'}, 193, {'2020/08/05'})</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [54]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># all matching tax IDs?</span> -<span class="k">for</span> <span class="n">protein</span><span class="p">,</span> <span class="n">upac</span> <span class="ow">in</span> <span class="n">metadata</span><span class="o">.</span><span class="n">UniProt_ID</span><span class="o">.</span><span class="n">items</span><span class="p">():</span> - <span class="n">up_info</span> <span class="o">=</span> <span class="n">_fetch_upkb_entry</span><span class="p">(</span><span class="n">upac</span><span class="p">)</span> - <span class="k">if</span> <span class="n">up_info</span><span class="p">[</span><span class="s2">"up_ncbi_taxid"</span><span class="p">]</span> <span class="o">!=</span> <span class="s2">"10497"</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="n">protein</span><span class="p">,</span> <span class="n">up_info</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [64]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check PDB files</span> -<span class="kn">import</span> <span class="nn">ost</span> -<span class="kn">from</span> <span class="nn">ost</span> <span class="kn">import</span> <span class="n">testutils</span><span class="p">,</span> <span class="n">conop</span> -<span class="c1"># setup conop</span> -<span class="n">testutils</span><span class="o">.</span><span class="n">SetDefaultCompoundLib</span><span class="p">()</span> -<span class="n">io</span><span class="o">.</span><span class="n">profiles</span><span class="p">[</span><span class="s1">'DEFAULT'</span><span class="p">]</span><span class="o">.</span><span class="n">processor</span> <span class="o">=</span> <span class="n">conop</span><span class="o">.</span><span class="n">RuleBasedProcessor</span><span class="p">(</span><span class="n">conop</span><span class="o">.</span><span class="n">GetDefaultLib</span><span class="p">())</span> -<span class="c1"># check processing</span> -<span class="n">ost</span><span class="o">.</span><span class="n">PushVerbosityLevel</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span> -<span class="k">for</span> <span class="n">protein</span><span class="p">,</span> <span class="n">pdb_ext</span> <span class="ow">in</span> <span class="nb">sorted</span><span class="p">(</span><span class="n">pdb_file_split</span><span class="p">):</span> - <span class="n">pdb_path</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">pdb_dir</span><span class="p">,</span> <span class="n">protein</span> <span class="o">+</span> <span class="n">pdb_ext</span><span class="p">)</span> - <span class="n">ent</span> <span class="o">=</span> <span class="n">io</span><span class="o">.</span><span class="n">LoadPDB</span><span class="p">(</span><span class="n">pdb_path</span><span class="p">)</span> -<span class="n">ost</span><span class="o">.</span><span class="n">PopVerbosityLevel</span><span class="p">()</span> -<span class="c1"># NOTE: lack of output means that all atom names are ok</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [84]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">up_info</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[84]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>{'up_organism': 'African swine fever virus (ASFV)', - 'up_sequence': 'MLLYIVIIVACIISKLVPNEYWAIHLFFIIMIFMVYMYEKLDIHQKSQFWNYTMSGLSGHNVQVTCKCY', - 'up_ac': 'A0A2X0TKC7', - 'up_id': 'A0A2X0TKC7_ASF', - 'up_last_mod': datetime.datetime(2018, 9, 12, 0, 0), - 'up_gn': 'X69R CDS', - 'up_ncbi_taxid': '10497', - 'up_seqlen': 69, - 'up_crc64': '3B92E4DB323A7A74', - 'up_isoform': None}</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [85]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">ncbi_info</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[85]:</div> - - - - -<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain"> -<pre>{'Caption': 'CAD2068372', - 'Title': 'X69R CDS [African swine fever virus]', - 'Extra': 'gi|1886136897|emb|CAD2068372.1|[1886136897]', - 'Gi': 1886136897, - 'CreateDate': '2010/08/18', - 'UpdateDate': '2020/08/05', - 'Flags': 0, - 'TaxId': 10497, - 'Length': 69, - 'Status': 'live', - 'ReplacedBy': None, - 'Comment': ' ', - 'AccessionVersion': 'CAD2068372.1'}</pre> -</div> - -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [154]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># check files that were converted (input is std out from run cut to only include "translating...")</span> -<span class="n">log_lines</span> <span class="o">=</span> <span class="nb">open</span><span class="p">(</span><span class="s2">"./script_out.txt"</span><span class="p">)</span><span class="o">.</span><span class="n">readlines</span><span class="p">()</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [155]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># plenty of assertions in here should also catch any errors...</span> -<span class="n">idx</span> <span class="o">=</span> <span class="mi">1</span> -<span class="n">timings</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> -<span class="k">while</span> <span class="n">idx</span> <span class="o"><</span> <span class="nb">len</span><span class="p">(</span><span class="n">log_lines</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span><span class="p">:</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">if</span> <span class="s2">"already done..."</span> <span class="ow">in</span> <span class="n">l</span><span class="p">:</span> - <span class="n">idx</span> <span class="o">+=</span> <span class="mi">1</span> - <span class="k">continue</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"translating"</span><span class="p">)</span> - <span class="n">mdl_title</span> <span class="o">=</span> <span class="n">l</span><span class="p">[</span><span class="nb">len</span><span class="p">(</span><span class="s2">"translating"</span><span class="p">):</span><span class="o">-</span><span class="mi">3</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">if</span> <span class="n">mdl_title</span> <span class="ow">in</span> <span class="n">timings</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="s2">"WEIRD"</span><span class="p">,</span> <span class="n">l</span><span class="p">)</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"preparing data"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_prep</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"generating ModelCIF objects"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_cif</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">3</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"processing QA scores"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_qa</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">4</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"write to disk"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)"</span><span class="p">)</span> - <span class="n">t_write</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">2</span><span class="p">])</span> - <span class="n">l</span> <span class="o">=</span> <span class="n">log_lines</span><span class="p">[</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">5</span><span class="p">]</span><span class="o">.</span><span class="n">strip</span><span class="p">()</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">startswith</span><span class="p">(</span><span class="s2">"... done with"</span><span class="p">)</span> - <span class="k">assert</span> <span class="n">l</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s2">"s)."</span><span class="p">)</span> - <span class="n">t_all</span> <span class="o">=</span> <span class="nb">float</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">split</span><span class="p">()[</span><span class="o">-</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">:</span><span class="o">-</span><span class="mi">3</span><span class="p">])</span> - <span class="n">timings</span><span class="p">[</span><span class="n">mdl_title</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span> - <span class="s2">"t_prep"</span><span class="p">:</span> <span class="n">t_prep</span><span class="p">,</span> - <span class="s2">"t_cif"</span><span class="p">:</span> <span class="n">t_cif</span><span class="p">,</span> - <span class="s2">"t_qa"</span><span class="p">:</span> <span class="n">t_qa</span><span class="p">,</span> - <span class="s2">"t_write"</span><span class="p">:</span> <span class="n">t_write</span><span class="p">,</span> - <span class="s2">"t_all"</span><span class="p">:</span> <span class="n">t_all</span> - <span class="p">}</span> - <span class="n">idx</span> <span class="o">+=</span> <span class="mi">6</span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [156]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"DONE </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">timings</span><span class="p">)</span><span class="si">}</span><span class="s2"> models"</span><span class="p">)</span> -<span class="n">mdl_titles</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">metadata</span><span class="o">.</span><span class="n">index</span><span class="p">)</span> -<span class="k">assert</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">timings</span><span class="p">)</span> <span class="o">-</span> <span class="n">mdl_titles</span><span class="p">)</span> <span class="o">==</span> <span class="mi">0</span> -<span class="n">missing_ones</span> <span class="o">=</span> <span class="n">mdl_titles</span> <span class="o">-</span> <span class="nb">set</span><span class="p">(</span><span class="n">timings</span><span class="p">)</span> -<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"MISSING </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">missing_ones</span><span class="p">)</span><span class="si">}</span><span class="s2"> models"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>DONE 197 models -MISSING 0 models -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [157]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span><span class="n">k_parts</span> <span class="o">=</span> <span class="p">[</span><span class="s2">"t_prep"</span><span class="p">,</span> <span class="s2">"t_cif"</span><span class="p">,</span> <span class="s2">"t_qa"</span><span class="p">,</span> <span class="s2">"t_write"</span><span class="p">]</span> -<span class="n">totals</span> <span class="o">=</span> <span class="p">{</span><span class="n">k</span><span class="p">:</span> <span class="nb">sum</span><span class="p">(</span><span class="n">v</span><span class="p">[</span><span class="n">k</span><span class="p">]</span> <span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="n">timings</span><span class="o">.</span><span class="n">values</span><span class="p">())</span> \ - <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">k_parts</span> <span class="o">+</span> <span class="p">[</span><span class="s2">"t_all"</span><span class="p">]}</span> -<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"TOTAL TIME SPENT: </span><span class="si">{</span><span class="nb">round</span><span class="p">(</span><span class="n">totals</span><span class="p">[</span><span class="s1">'t_all'</span><span class="p">],</span> <span class="mi">2</span><span class="p">)</span><span class="si">}</span><span class="s2"> s"</span><span class="p">)</span> -<span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">k_parts</span><span class="p">:</span> - <span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">"-> </span><span class="si">{</span><span class="n">k</span><span class="si">}</span><span class="s2">: </span><span class="si">{</span><span class="nb">round</span><span class="p">(</span><span class="mi">100</span> <span class="o">*</span> <span class="n">totals</span><span class="p">[</span><span class="n">k</span><span class="p">]</span> <span class="o">/</span> <span class="n">totals</span><span class="p">[</span><span class="s1">'t_all'</span><span class="p">],</span> <span class="mi">1</span><span class="p">)</span><span class="si">}</span><span class="s2">%"</span><span class="p">)</span> -</pre></div> - - </div> -</div> -</div> -</div> - -<div class="jp-Cell-outputWrapper"> -<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> -</div> - - -<div class="jp-OutputArea jp-Cell-outputArea"> - -<div class="jp-OutputArea-child"> - - - <div class="jp-OutputPrompt jp-OutputArea-prompt"></div> - - -<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain"> -<pre>TOTAL TIME SPENT: 356.38 s --> t_prep: 80.5% --> t_cif: 1.2% --> t_qa: 0.0% --> t_write: 17.8% -</pre> -</div> -</div> - -</div> - -</div> - -</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs "> -<div class="jp-Cell-inputWrapper"> -<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> -</div> -<div class="jp-InputArea jp-Cell-inputArea"> -<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div> -<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> - <div class="CodeMirror cm-s-jupyter"> -<div class=" highlight hl-ipython3"><pre><span></span> -</pre></div> - - </div> -</div> -</div> -</div> - -</div> -</body> - - - - - - - -</html> diff --git a/projects/USDA-ASFVG/tests/test.ipynb b/projects/USDA-ASFVG/tests/test.ipynb deleted file mode 100644 index 4109e9da9c93379a0e64847cab43e4904ad1106a..0000000000000000000000000000000000000000 --- a/projects/USDA-ASFVG/tests/test.ipynb +++ /dev/null @@ -1,1681 +0,0 @@ -{ - "cells": [ - { - "cell_type": "code", - "execution_count": 1, - "id": "ac0e1325", - "metadata": {}, - "outputs": [], - "source": [ - "import requests\n", - "import datetime\n", - "import os\n", - "import pandas as pd\n", - "import xml.dom.minidom\n", - "from ost import io\n", - "\n", - "# from Tara code\n", - "def _get_sequence(chn):\n", - " \"\"\"Get the sequence out of an OST chain.\"\"\"\n", - " # initialise\n", - " lst_rn = chn.residues[0].number.num\n", - " idx = 1\n", - " sqe = chn.residues[0].one_letter_code\n", - " if lst_rn != 1:\n", - " sqe = \"-\"\n", - " idx = 0\n", - "\n", - " for res in chn.residues[idx:]:\n", - " lst_rn += 1\n", - " while lst_rn != res.number.num:\n", - " sqe += \"-\"\n", - " lst_rn += 1\n", - " sqe += res.one_letter_code\n", - "\n", - " return sqe\n", - "\n", - "def _check_sequence(up_ac, sequence):\n", - " \"\"\"Verify sequence to only contain standard olc.\"\"\"\n", - " for res in sequence:\n", - " if res not in \"ACDEFGHIKLMNPQRSTVWY\":\n", - " raise RuntimeError(\n", - " \"Non-standard aa found in UniProtKB sequence \"\n", - " + f\"for entry '{up_ac}': {res}\"\n", - " )\n", - "\n", - "def _fetch_upkb_entry(up_ac):\n", - " \"\"\"Fetch data for an UniProtKB entry.\"\"\"\n", - " # This is a simple parser for UniProtKB txt format, instead of breaking it up\n", - " # into multiple functions, we just allow many many branches & statements,\n", - " # here.\n", - " # pylint: disable=too-many-branches,too-many-statements\n", - " data = {}\n", - " data[\"up_organism\"] = \"\"\n", - " data[\"up_sequence\"] = \"\"\n", - " data[\"up_ac\"] = up_ac\n", - " rspns = requests.get(f\"https://www.uniprot.org/uniprot/{up_ac}.txt\")\n", - " for line in rspns.iter_lines(decode_unicode=True):\n", - " if line.startswith(\"ID \"):\n", - " sline = line.split()\n", - " if len(sline) != 5:\n", - " _abort_msg(f\"Unusual UniProtKB ID line found:\\n'{line}'\")\n", - " data[\"up_id\"] = sline[1]\n", - " elif line.startswith(\"OX NCBI_TaxID=\"):\n", - " # Following strictly the UniProtKB format: 'OX NCBI_TaxID=<ID>;'\n", - " data[\"up_ncbi_taxid\"] = line[len(\"OX NCBI_TaxID=\") : -1]\n", - " data[\"up_ncbi_taxid\"] = data[\"up_ncbi_taxid\"].split(\"{\")[0].strip()\n", - " elif line.startswith(\"OS \"):\n", - " if line[-1] == \".\":\n", - " data[\"up_organism\"] += line[len(\"OS \") : -1]\n", - " else:\n", - " data[\"up_organism\"] += line[len(\"OS \") : -1] + \" \"\n", - " elif line.startswith(\"SQ \"):\n", - " sline = line.split()\n", - " if len(sline) != 8:\n", - " _abort_msg(f\"Unusual UniProtKB SQ line found:\\n'{line}'\")\n", - " data[\"up_seqlen\"] = int(sline[2])\n", - " data[\"up_crc64\"] = sline[6]\n", - " elif line.startswith(\" \"):\n", - " sline = line.split()\n", - " if len(sline) > 6:\n", - " _abort_msg(\n", - " \"Unusual UniProtKB sequence data line \"\n", - " + f\"found:\\n'{line}'\"\n", - " )\n", - " data[\"up_sequence\"] += \"\".join(sline)\n", - " elif line.startswith(\"RP \"):\n", - " if \"ISOFORM\" in line.upper():\n", - " RuntimeError(\n", - " f\"First ISOFORM found for '{up_ac}', needs \" + \"handling.\"\n", - " )\n", - " elif line.startswith(\"DT \"):\n", - " # 2012-10-03\n", - " dt_flds = line[len(\"DT \") :].split(\", \")\n", - " if dt_flds[1].upper().startswith(\"SEQUENCE VERSION \"):\n", - " data[\"up_last_mod\"] = datetime.datetime.strptime(\n", - " dt_flds[0], \"%d-%b-%Y\"\n", - " )\n", - " elif line.startswith(\"GN Name=\"):\n", - " data[\"up_gn\"] = line[len(\"GN Name=\") :].split(\";\")[0]\n", - " data[\"up_gn\"] = data[\"up_gn\"].split(\"{\")[0].strip()\n", - "\n", - " # we have not seen isoforms in the data set, yet, so we just set them to '.'\n", - " data[\"up_isoform\"] = None\n", - "\n", - " if \"up_gn\" not in data:\n", - " _abort_msg(f\"No gene name found for UniProtKB entry '{up_ac}'.\")\n", - " if \"up_last_mod\" not in data:\n", - " _abort_msg(f\"No sequence version found for UniProtKB entry '{up_ac}'.\")\n", - " if \"up_crc64\" not in data:\n", - " _abort_msg(f\"No CRC64 value found for UniProtKB entry '{up_ac}'.\")\n", - " if len(data[\"up_sequence\"]) == 0:\n", - " _abort_msg(f\"No sequence found for UniProtKB entry '{up_ac}'.\")\n", - " # check that sequence length and CRC64 is correct\n", - " if data[\"up_seqlen\"] != len(data[\"up_sequence\"]):\n", - " _abort_msg(\n", - " \"Sequence length of SQ line and sequence data differ for \"\n", - " + f\"UniProtKB entry '{up_ac}': {data['up_seqlen']} != \"\n", - " + f\"{len(data['up_sequence'])}\"\n", - " )\n", - " _check_sequence(data[\"up_ac\"], data[\"up_sequence\"])\n", - "\n", - " if \"up_id\" not in data:\n", - " _abort_msg(f\"No ID found for UniProtKB entry '{up_ac}'.\")\n", - " if \"up_ncbi_taxid\" not in data:\n", - " _abort_msg(f\"No NCBI taxonomy ID found for UniProtKB entry '{up_ac}'.\")\n", - " if len(data[\"up_organism\"]) == 0:\n", - " _abort_msg(f\"No organism species found for UniProtKB entry '{up_ac}'.\")\n", - "\n", - " return data\n", - "\n", - "def _get_upkb_for_sequence(sqe, up_ac):\n", - " \"\"\"Get UniProtKB entry data for given sequence.\"\"\"\n", - " up_data = _fetch_upkb_entry(up_ac)\n", - " if sqe != up_data[\"up_sequence\"]:\n", - " raise RuntimeError(\n", - " f\"Sequences not equal from file: {sqe}, from UniProtKB: \"\n", - " + f\"{up_data['up_sequence']}\"\n", - " )\n", - "\n", - " return up_data" - ] - }, - { - "cell_type": "code", - "execution_count": 2, - "id": "37bece22", - "metadata": {}, - "outputs": [], - "source": [ - "def _get_ncbi_sequence(ncbi_ac):\n", - " \"\"\"Fetch OST sequence object from NCBI web service.\"\"\"\n", - " # src: https://www.ncbi.nlm.nih.gov/books/NBK25500/#_chapter1_Downloading_Full_Records_\n", - " rspns = requests.get(f\"https://eutils.ncbi.nlm.nih.gov/entrez/eutils/\" \\\n", - " f\"efetch.fcgi?db=protein&id={ncbi_ac}\" \\\n", - " f\"&rettype=fasta&retmode=text\")\n", - " return io.SequenceFromString(rspns.text, \"fasta\")" - ] - }, - { - "cell_type": "code", - "execution_count": 3, - "id": "3f83b12d", - "metadata": {}, - "outputs": [], - "source": [ - "# s = _get_ncbi_sequence(\"CAD2068351.1\")\n", - "# up_data = _fetch_upkb_entry(\"A0A485PQD1\")\n", - "# print(s.name, s, len(s), up_data[\"up_sequence\"] == str(s))\n", - "# up_data" - ] - }, - { - "cell_type": "code", - "execution_count": 5, - "id": "ff132158", - "metadata": {}, - "outputs": [], - "source": [ - "# check USDA data\n", - "metadata_file = \"./InputFiles/ASFV-G_proteome_accessions.csv\"\n", - "pdb_dir = \"./InputFiles/AlphaFold-RENAME\"" - ] - }, - { - "cell_type": "code", - "execution_count": 6, - "id": "d8ca29cb", - "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "<div>\n", - "<style scoped>\n", - " .dataframe tbody tr th:only-of-type {\n", - " vertical-align: middle;\n", - " }\n", - "\n", - " .dataframe tbody tr th {\n", - " vertical-align: top;\n", - " }\n", - "\n", - " .dataframe thead th {\n", - " text-align: right;\n", - " }\n", - "</style>\n", - "<table border=\"1\" class=\"dataframe\">\n", - " <thead>\n", - " <tr style=\"text-align: right;\">\n", - " <th></th>\n", - " <th>Protein</th>\n", - " <th>Associated PDB</th>\n", - " <th>NCBI_Accession</th>\n", - " <th>UniProt_ID</th>\n", - " <th>_struct.title</th>\n", - " <th>_struct.pdbx_model_detail</th>\n", - " <th>ranking debugg model ID</th>\n", - " <th>notes</th>\n", - " </tr>\n", - " </thead>\n", - " <tbody>\n", - " <tr>\n", - " <th>0</th>\n", - " <td>285L</td>\n", - " <td>285L.pdb</td>\n", - " <td>CAD2068351.1</td>\n", - " <td>A0A485PQD1</td>\n", - " <td>ASFV-G 285L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_1_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>1</th>\n", - " <td>A104R</td>\n", - " <td>A104R.pdb</td>\n", - " <td>CAD2068395.1</td>\n", - " <td>A0A0A1E0L7</td>\n", - " <td>ASFV-G A104R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_2_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>2</th>\n", - " <td>A118R</td>\n", - " <td>A118R.pdb</td>\n", - " <td>CAD2068397.1</td>\n", - " <td>A0A2X0RVA9</td>\n", - " <td>ASFV-G A118R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_1_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>3</th>\n", - " <td>A137R</td>\n", - " <td>A137R.pdb</td>\n", - " <td>CAD2068404.1</td>\n", - " <td>A0A2X0THQ0</td>\n", - " <td>ASFV-G A137R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>4</th>\n", - " <td>A151R</td>\n", - " <td>A151R.pdb</td>\n", - " <td>CAD2068398.1</td>\n", - " <td>A0A2X0TC55</td>\n", - " <td>ASFV-G A151R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>...</th>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>192</th>\n", - " <td>QP509L</td>\n", - " <td>QP509L.pdb</td>\n", - " <td>CAD2068484.1</td>\n", - " <td>A0A2X0THX2</td>\n", - " <td>ASFV-G QP509L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>NaN</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>193</th>\n", - " <td>R298L</td>\n", - " <td>R298L.pdb</td>\n", - " <td>CAD2068482.1</td>\n", - " <td>A0A2X0SE42</td>\n", - " <td>ASFV-G R298L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>194</th>\n", - " <td>S183L</td>\n", - " <td>S183L.pdb</td>\n", - " <td>CAD2068472.1</td>\n", - " <td>A0A2X0SE34</td>\n", - " <td>ASFV-G S183L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>195</th>\n", - " <td>S273R</td>\n", - " <td>S273R.pdb</td>\n", - " <td>CAD2068473.1</td>\n", - " <td>A0A2X0TKM5</td>\n", - " <td>ASFV-G S273R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_2_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " <tr>\n", - " <th>196</th>\n", - " <td>X69R</td>\n", - " <td>X69R.pdb</td>\n", - " <td>CAD2068372.1</td>\n", - " <td>A0A2X0TKC7</td>\n", - " <td>ASFV-G X69R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_2_pred_0</td>\n", - " <td>NaN</td>\n", - " </tr>\n", - " </tbody>\n", - "</table>\n", - "<p>197 rows × 8 columns</p>\n", - "</div>" - ], - "text/plain": [ - " Protein Associated PDB NCBI_Accession UniProt_ID _struct.title \\\n", - "0 285L 285L.pdb CAD2068351.1 A0A485PQD1 ASFV-G 285L \n", - "1 A104R A104R.pdb CAD2068395.1 A0A0A1E0L7 ASFV-G A104R \n", - "2 A118R A118R.pdb CAD2068397.1 A0A2X0RVA9 ASFV-G A118R \n", - "3 A137R A137R.pdb CAD2068404.1 A0A2X0THQ0 ASFV-G A137R \n", - "4 A151R A151R.pdb CAD2068398.1 A0A2X0TC55 ASFV-G A151R \n", - ".. ... ... ... ... ... \n", - "192 QP509L QP509L.pdb CAD2068484.1 A0A2X0THX2 ASFV-G QP509L \n", - "193 R298L R298L.pdb CAD2068482.1 A0A2X0SE42 ASFV-G R298L \n", - "194 S183L S183L.pdb CAD2068472.1 A0A2X0SE34 ASFV-G S183L \n", - "195 S273R S273R.pdb CAD2068473.1 A0A2X0TKM5 ASFV-G S273R \n", - "196 X69R X69R.pdb CAD2068372.1 A0A2X0TKC7 ASFV-G X69R \n", - "\n", - " _struct.pdbx_model_detail ranking debugg model ID notes \n", - "0 This model was predicted using AlphaFold2 model_1_pred_0 NaN \n", - "1 This model was predicted using AlphaFold2 model_2_pred_0 NaN \n", - "2 This model was predicted using AlphaFold2 model_1_pred_0 NaN \n", - "3 This model was predicted using AlphaFold2 model_3_pred_0 NaN \n", - "4 This model was predicted using AlphaFold2 model_4_pred_0 NaN \n", - ".. ... ... ... \n", - "192 This model was predicted using AlphaFold2 NaN NaN \n", - "193 This model was predicted using AlphaFold2 model_3_pred_0 NaN \n", - "194 This model was predicted using AlphaFold2 model_4_pred_0 NaN \n", - "195 This model was predicted using AlphaFold2 model_2_pred_0 NaN \n", - "196 This model was predicted using AlphaFold2 model_2_pred_0 NaN \n", - "\n", - "[197 rows x 8 columns]" - ] - }, - "execution_count": 6, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "metadata = pd.read_csv(metadata_file)\n", - "assert len(set(metadata.Protein)) == metadata.shape[0]\n", - "assert len(set(metadata[\"Associated PDB\"])) == metadata.shape[0]\n", - "metadata" - ] - }, - { - "cell_type": "code", - "execution_count": 66, - "id": "cc7150d4", - "metadata": {}, - "outputs": [], - "source": [ - "pdb_files = [f for f in sorted(os.listdir(pdb_dir)) if f.endswith(\".pdb\")]" - ] - }, - { - "cell_type": "code", - "execution_count": 67, - "id": "c038aa57", - "metadata": {}, - "outputs": [], - "source": [ - "# check names\n", - "pdb_file_split = [os.path.splitext(f) for f in pdb_files]" - ] - }, - { - "cell_type": "code", - "execution_count": 68, - "id": "287a8d61", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "ONLY AS PDB: ['QP509L-unrelaxed.pdb']\n", - "ONLY IN METADATA: []\n" - ] - } - ], - "source": [ - "# CHECK THAT PDB FILES MATCH EXISTING ONES\n", - "# -> extra QP509L-unrelaxed expected\n", - "tstp = set(pdb_files)\n", - "tstm = set(metadata[\"Associated PDB\"])\n", - "print(\"ONLY AS PDB:\", sorted(tstp - tstm))\n", - "print(\"ONLY IN METADATA:\", sorted(tstm - tstp))" - ] - }, - { - "cell_type": "code", - "execution_count": 70, - "id": "cbf8d9ac", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "ONLY AS PDB: ['QP509L-unrelaxed']\n", - "ONLY IN METADATA: []\n" - ] - } - ], - "source": [ - "# CHECK THAT FILE NAMES MATCH PROTEIN NAMES\n", - "tstp = set(fs[0] for fs in pdb_file_split)\n", - "tstm = set(metadata.Protein)\n", - "print(\"ONLY AS PDB:\", sorted(tstp - tstm))\n", - "print(\"ONLY IN METADATA:\", sorted(tstm - tstp))" - ] - }, - { - "cell_type": "code", - "execution_count": 14, - "id": "95c0209e", - "metadata": {}, - "outputs": [], - "source": [ - "# can use either Protein or PDB name as index\n", - "metadata = metadata.set_index(\"Protein\")" - ] - }, - { - "cell_type": "code", - "execution_count": 15, - "id": "68a98f97", - "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "<div>\n", - "<style scoped>\n", - " .dataframe tbody tr th:only-of-type {\n", - " vertical-align: middle;\n", - " }\n", - "\n", - " .dataframe tbody tr th {\n", - " vertical-align: top;\n", - " }\n", - "\n", - " .dataframe thead th {\n", - " text-align: right;\n", - " }\n", - "</style>\n", - "<table border=\"1\" class=\"dataframe\">\n", - " <thead>\n", - " <tr style=\"text-align: right;\">\n", - " <th></th>\n", - " <th>Associated PDB</th>\n", - " <th>NCBI_Accession</th>\n", - " <th>UniProt_ID</th>\n", - " <th>_struct.title</th>\n", - " <th>_struct.pdbx_model_detail</th>\n", - " <th>ranking debugg model ID</th>\n", - " <th>notes</th>\n", - " </tr>\n", - " <tr>\n", - " <th>Protein</th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " </tr>\n", - " </thead>\n", - " <tbody>\n", - " </tbody>\n", - "</table>\n", - "</div>" - ], - "text/plain": [ - "Empty DataFrame\n", - "Columns: [Associated PDB, NCBI_Accession, UniProt_ID, _struct.title , _struct.pdbx_model_detail, ranking debugg model ID, notes]\n", - "Index: []" - ] - }, - "execution_count": 15, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "# NOTE: stupid space there...\n", - "metadata[metadata[\"_struct.title \"].isna()]" - ] - }, - { - "cell_type": "code", - "execution_count": 16, - "id": "628099f5", - "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "<div>\n", - "<style scoped>\n", - " .dataframe tbody tr th:only-of-type {\n", - " vertical-align: middle;\n", - " }\n", - "\n", - " .dataframe tbody tr th {\n", - " vertical-align: top;\n", - " }\n", - "\n", - " .dataframe thead th {\n", - " text-align: right;\n", - " }\n", - "</style>\n", - "<table border=\"1\" class=\"dataframe\">\n", - " <thead>\n", - " <tr style=\"text-align: right;\">\n", - " <th></th>\n", - " <th>Associated PDB</th>\n", - " <th>NCBI_Accession</th>\n", - " <th>UniProt_ID</th>\n", - " <th>_struct.title</th>\n", - " <th>_struct.pdbx_model_detail</th>\n", - " <th>ranking debugg model ID</th>\n", - " <th>notes</th>\n", - " </tr>\n", - " <tr>\n", - " <th>Protein</th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " </tr>\n", - " </thead>\n", - " <tbody>\n", - " </tbody>\n", - "</table>\n", - "</div>" - ], - "text/plain": [ - "Empty DataFrame\n", - "Columns: [Associated PDB, NCBI_Accession, UniProt_ID, _struct.title , _struct.pdbx_model_detail, ranking debugg model ID, notes]\n", - "Index: []" - ] - }, - "execution_count": 16, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "metadata[metadata[\"_struct.pdbx_model_detail\"].isna()]" - ] - }, - { - "cell_type": "code", - "execution_count": 17, - "id": "79f8dbfa", - "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "<div>\n", - "<style scoped>\n", - " .dataframe tbody tr th:only-of-type {\n", - " vertical-align: middle;\n", - " }\n", - "\n", - " .dataframe tbody tr th {\n", - " vertical-align: top;\n", - " }\n", - "\n", - " .dataframe thead th {\n", - " text-align: right;\n", - " }\n", - "</style>\n", - "<table border=\"1\" class=\"dataframe\">\n", - " <thead>\n", - " <tr style=\"text-align: right;\">\n", - " <th></th>\n", - " <th>Associated PDB</th>\n", - " <th>NCBI_Accession</th>\n", - " <th>UniProt_ID</th>\n", - " <th>_struct.title</th>\n", - " <th>_struct.pdbx_model_detail</th>\n", - " <th>ranking debugg model ID</th>\n", - " <th>notes</th>\n", - " </tr>\n", - " <tr>\n", - " <th>Protein</th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " </tr>\n", - " </thead>\n", - " <tbody>\n", - " <tr>\n", - " <th>CP2475L_p14</th>\n", - " <td>CP2475L_p14.pdb</td>\n", - " <td>CAD2068454.1</td>\n", - " <td>A0A2X0THU5</td>\n", - " <td>ASFV-G CP2475L p14</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>protein p14 from the pp220 polyprotein encoded...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>CP2475L_p34</th>\n", - " <td>CP2475L_p34.pdb</td>\n", - " <td>CAD2068454.1</td>\n", - " <td>A0A2X0THU5</td>\n", - " <td>ASFV-G CP2475L p34</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>protein p34 from the pp220 polyprotein encoded...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>CP2475L_p37</th>\n", - " <td>CP2475L_p37.pdb</td>\n", - " <td>CAD2068454.1</td>\n", - " <td>A0A2X0THU5</td>\n", - " <td>ASFV-G CP2475L p37</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>protein p37 from the pp220 polyprotein encoded...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>CP2475L_p150</th>\n", - " <td>CP2475L_p150.pdb</td>\n", - " <td>CAD2068454.1</td>\n", - " <td>A0A2X0THU5</td>\n", - " <td>ASFV-G CP2475L p150</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_1_pred_0</td>\n", - " <td>protein p150 from the pp220 polyprotein encode...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>CP2475L_p5</th>\n", - " <td>CP2475L_p5.pdb</td>\n", - " <td>CAD2068454.1</td>\n", - " <td>A0A2X0THU5</td>\n", - " <td>ASFV-G CP2475L p5</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>protein p5 from the pp220 polyprotein encoded ...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>D250R</th>\n", - " <td>D250R.pdb</td>\n", - " <td>CAD2068464.1</td>\n", - " <td>A0A2X0THV3</td>\n", - " <td>ASFV-G D250R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>Mislabled on NCBI and Uniport as D205R</td>\n", - " </tr>\n", - " <tr>\n", - " <th>DP79L</th>\n", - " <td>DP79L.pdb</td>\n", - " <td>CAD2068466.1</td>\n", - " <td>A0A0A1E158</td>\n", - " <td>ASFV-G DP79L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>Mislabled on Uniprot as D79L</td>\n", - " </tr>\n", - " <tr>\n", - " <th>hypothetical_01</th>\n", - " <td>hypothetical_01.pdb</td>\n", - " <td>CAD2068367.1</td>\n", - " <td>A0A485PU43</td>\n", - " <td>ASFV-G hypothetical_01</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_5_pred_0</td>\n", - " <td>labeled as hypothetical on NCBI and Uniprot</td>\n", - " </tr>\n", - " <tr>\n", - " <th>hypothetical_02</th>\n", - " <td>hypothetical_02.pdb</td>\n", - " <td>CAD2068400.1</td>\n", - " <td>A0A485PQI3</td>\n", - " <td>ASFV-G hypothetical_02</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>labeled as hypthetical on NCBI and Uniprot</td>\n", - " </tr>\n", - " <tr>\n", - " <th>hypothetical_03</th>\n", - " <td>hypothetical_03.pdb</td>\n", - " <td>CAD2068512.1</td>\n", - " <td>A0A485PZB7</td>\n", - " <td>ASFV-G hypothetical_03</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>labeled as hypthetical on NCBI and Uniprot</td>\n", - " </tr>\n", - " </tbody>\n", - "</table>\n", - "</div>" - ], - "text/plain": [ - " Associated PDB NCBI_Accession UniProt_ID \\\n", - "Protein \n", - "CP2475L_p14 CP2475L_p14.pdb CAD2068454.1 A0A2X0THU5 \n", - "CP2475L_p34 CP2475L_p34.pdb CAD2068454.1 A0A2X0THU5 \n", - "CP2475L_p37 CP2475L_p37.pdb CAD2068454.1 A0A2X0THU5 \n", - "CP2475L_p150 CP2475L_p150.pdb CAD2068454.1 A0A2X0THU5 \n", - "CP2475L_p5 CP2475L_p5.pdb CAD2068454.1 A0A2X0THU5 \n", - "D250R D250R.pdb CAD2068464.1 A0A2X0THV3 \n", - "DP79L DP79L.pdb CAD2068466.1 A0A0A1E158 \n", - "hypothetical_01 hypothetical_01.pdb CAD2068367.1 A0A485PU43 \n", - "hypothetical_02 hypothetical_02.pdb CAD2068400.1 A0A485PQI3 \n", - "hypothetical_03 hypothetical_03.pdb CAD2068512.1 A0A485PZB7 \n", - "\n", - " _struct.title \\\n", - "Protein \n", - "CP2475L_p14 ASFV-G CP2475L p14 \n", - "CP2475L_p34 ASFV-G CP2475L p34 \n", - "CP2475L_p37 ASFV-G CP2475L p37 \n", - "CP2475L_p150 ASFV-G CP2475L p150 \n", - "CP2475L_p5 ASFV-G CP2475L p5 \n", - "D250R ASFV-G D250R \n", - "DP79L ASFV-G DP79L \n", - "hypothetical_01 ASFV-G hypothetical_01 \n", - "hypothetical_02 ASFV-G hypothetical_02 \n", - "hypothetical_03 ASFV-G hypothetical_03 \n", - "\n", - " _struct.pdbx_model_detail \\\n", - "Protein \n", - "CP2475L_p14 This model was predicted using AlphaFold2 \n", - "CP2475L_p34 This model was predicted using AlphaFold2 \n", - "CP2475L_p37 This model was predicted using AlphaFold2 \n", - "CP2475L_p150 This model was predicted using AlphaFold2 \n", - "CP2475L_p5 This model was predicted using AlphaFold2 \n", - "D250R This model was predicted using AlphaFold2 \n", - "DP79L This model was predicted using AlphaFold2 \n", - "hypothetical_01 This model was predicted using AlphaFold2 \n", - "hypothetical_02 This model was predicted using AlphaFold2 \n", - "hypothetical_03 This model was predicted using AlphaFold2 \n", - "\n", - " ranking debugg model ID \\\n", - "Protein \n", - "CP2475L_p14 model_4_pred_0 \n", - "CP2475L_p34 model_4_pred_0 \n", - "CP2475L_p37 model_4_pred_0 \n", - "CP2475L_p150 model_1_pred_0 \n", - "CP2475L_p5 model_3_pred_0 \n", - "D250R model_3_pred_0 \n", - "DP79L model_3_pred_0 \n", - "hypothetical_01 model_5_pred_0 \n", - "hypothetical_02 model_3_pred_0 \n", - "hypothetical_03 model_3_pred_0 \n", - "\n", - " notes \n", - "Protein \n", - "CP2475L_p14 protein p14 from the pp220 polyprotein encoded... \n", - "CP2475L_p34 protein p34 from the pp220 polyprotein encoded... \n", - "CP2475L_p37 protein p37 from the pp220 polyprotein encoded... \n", - "CP2475L_p150 protein p150 from the pp220 polyprotein encode... \n", - "CP2475L_p5 protein p5 from the pp220 polyprotein encoded ... \n", - "D250R Mislabled on NCBI and Uniport as D205R \n", - "DP79L Mislabled on Uniprot as D79L \n", - "hypothetical_01 labeled as hypothetical on NCBI and Uniprot \n", - "hypothetical_02 labeled as hypthetical on NCBI and Uniprot \n", - "hypothetical_03 labeled as hypthetical on NCBI and Uniprot " - ] - }, - "execution_count": 17, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "metadata[~metadata.notes.isna()]" - ] - }, - { - "cell_type": "code", - "execution_count": 126, - "id": "30f0abc2", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "protein p14 from the pp220 polyprotein encoded by CP2475L\n", - "protein p34 from the pp220 polyprotein encoded by CP2475L\n", - "protein p37 from the pp220 polyprotein encoded by CP2475L\n", - "protein p150 from the pp220 polyprotein encoded by CP2475L\n", - "protein p5 from the pp220 polyprotein encoded by CP2475L\n", - "mislabeled on NCBI and UniProt as D205R\n", - "mislabeled on UniProt as D79L\n", - "labeled as hypothetical on NCBI and UniProt\n", - "labeled as hypothetical on NCBI and UniProt\n", - "labeled as hypothetical on NCBI and UniProt\n" - ] - } - ], - "source": [ - "for mdl_notes in metadata[~metadata.notes.isna()].notes:\n", - " mdl_notes = mdl_notes.replace(\"hypthetical\", \"hypothetical\") \\\n", - " .replace(\"Uniport\", \"UniProt\") \\\n", - " .replace(\"Uniprot\", \"UniProt\") \\\n", - " .replace(\"Mislabled\", \"mislabeled\")\n", - " print(mdl_notes)" - ] - }, - { - "cell_type": "code", - "execution_count": 121, - "id": "9b11b709", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "'labeled as hypothetical on NCBI and Uniprot'" - ] - }, - "execution_count": 121, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "mdl_notes = 'labeled as hypthetical on NCBI and Uniprot'" - ] - }, - { - "cell_type": "code", - "execution_count": 31, - "id": "4e1a1d06", - "metadata": {}, - "outputs": [], - "source": [ - "# tst = metadata.loc[\"hypothetical_03\"]\n", - "# s = _get_ncbi_sequence(tst.NCBI_Accession)\n", - "# up_data = _fetch_upkb_entry(tst.UniProt_ID)\n", - "# print(s.name, s, len(s), up_data[\"up_sequence\"] == str(s))\n", - "# up_data\n", - "\n", - "# checked all the one above manually and ok as stated (best to add to model_detail!)" - ] - }, - { - "cell_type": "code", - "execution_count": 113, - "id": "5f53cdc7", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "Associated PDB QP509L.pdb\n", - "NCBI_Accession CAD2068484.1\n", - "UniProt_ID A0A2X0THX2\n", - "_struct.title ASFV-G QP509L\n", - "_struct.pdbx_model_detail This model was predicted using AlphaFold2\n", - "ranking debugg model ID NaN\n", - "notes NaN\n", - "NCBI_Gi 1886137009\n", - "NCBI_UpdateDate 2020/08/05\n", - "NCBI_TaxId 10497\n", - "Name: QP509L, dtype: object" - ] - }, - "execution_count": 113, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "# special one...\n", - "metadata.loc[\"QP509L\"]" - ] - }, - { - "cell_type": "code", - "execution_count": 33, - "id": "84497409", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "{'This model was predicted using AlphaFold2'}" - ] - }, - "execution_count": 33, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "set(metadata[\"_struct.pdbx_model_detail\"])" - ] - }, - { - "cell_type": "code", - "execution_count": 34, - "id": "3836742d", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "197" - ] - }, - "execution_count": 34, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "len(set(metadata[\"_struct.title \"]))" - ] - }, - { - "cell_type": "code", - "execution_count": 35, - "id": "6bb77c3e", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "QP509L nan\n" - ] - } - ], - "source": [ - "# check model numbers\n", - "tst = metadata[\"ranking debugg model ID\"]\n", - "for idx, mdl_id in tst.items():\n", - " mdl_num = None\n", - " if type(mdl_id) == str:\n", - " mdl_id_split = mdl_id.split('_')\n", - " if len(mdl_id_split) == 4:\n", - " mdl_num = int(mdl_id_split[1])\n", - " if not mdl_num:\n", - " print(idx, mdl_id)\n", - " elif mdl_num not in range(1, 6):\n", - " print(idx, mdl_id, mdl_num)" - ] - }, - { - "cell_type": "code", - "execution_count": 36, - "id": "7b163025", - "metadata": {}, - "outputs": [], - "source": [ - "def _check_subset(s1, s2):\n", - " # check if s2 is uniquely contained in s1\n", - " # (and if so, returns values for seq_db_align_begin & seq_db_align_end)\n", - " if s1.count(s2) == 1:\n", - " align_begin = s1.find(s2) + 1\n", - " align_end = align_begin + len(s2) - 1\n", - " return align_begin, align_end\n", - " else:\n", - " return None" - ] - }, - { - "cell_type": "code", - "execution_count": 37, - "id": "0fe8bd2f", - "metadata": { - "scrolled": true - }, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "CP2475L_p14 PDB seq. is subset of UP (369, 522)\n", - "CP2475L_p14 PDB seq. is subset of NCBI (369, 522)\n", - "CP2475L_p150 PDB seq. is subset of UP (894, 2476)\n", - "CP2475L_p150 PDB seq. is subset of NCBI (894, 2476)\n", - "CP2475L_p34 PDB seq. is subset of UP (45, 368)\n", - "CP2475L_p34 PDB seq. is subset of NCBI (45, 368)\n", - "CP2475L_p37 PDB seq. is subset of UP (523, 893)\n", - "CP2475L_p37 PDB seq. is subset of NCBI (523, 893)\n", - "CP2475L_p5 PDB seq. is subset of UP (2, 39)\n", - "CP2475L_p5 PDB seq. is subset of NCBI (2, 39)\n" - ] - } - ], - "source": [ - "# check shared ones\n", - "for protein, pdb_ext in sorted(pdb_file_split):\n", - " if protein not in metadata.index:\n", - " print(\"SKIPPING\", protein)\n", - " continue\n", - " else:\n", - " row = metadata.loc[protein]\n", - " pdb_path = os.path.join(pdb_dir, protein + pdb_ext)\n", - " ent = io.LoadPDB(pdb_path)\n", - " assert ent.chain_count == 1\n", - " sqe = _get_sequence(ent.chains[0])\n", - " s_ncbi = _get_ncbi_sequence(row.NCBI_Accession)\n", - " up_data = _fetch_upkb_entry(row.UniProt_ID)\n", - " if up_data[\"up_sequence\"] != str(s_ncbi):\n", - " print(protein, \"inconsistent UP/NCBI sequences\", up_data[\"up_sequence\"], str(s_ncbi))\n", - " if up_data[\"up_sequence\"] != sqe:\n", - " tst = _check_subset(up_data[\"up_sequence\"], sqe)\n", - " if tst:\n", - " print(protein, \"PDB seq. is subset of UP\", tst)\n", - " else:\n", - " print(protein, \"inconsistent UP/PDB sequences\", up_data[\"up_sequence\"], sqe)\n", - " if str(s_ncbi) != sqe:\n", - " tst = _check_subset(str(s_ncbi), sqe)\n", - " if tst:\n", - " print(protein, \"PDB seq. is subset of NCBI\", tst)\n", - " else:\n", - " print(protein, \"inconsistent NCBI/PDB sequences\", str(s_ncbi), sqe)" - ] - }, - { - "cell_type": "code", - "execution_count": 65, - "id": "48165d13", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "{1.0} {0.0}\n", - "IN UNRELAXED: []\n", - "IN RELAXED: []\n" - ] - } - ], - "source": [ - "# check QP509L (take pLDDT from unrelaxed)\n", - "ent_unr = io.LoadPDB(\"./InputFiles/AlphaFold-RENAME/QP509L-unrelaxed.pdb\")\n", - "ent_rel = io.LoadPDB(\"./InputFiles/AlphaFold-RENAME/QP509L.pdb\")\n", - "print(set(a.occupancy for a in ent_rel.atoms), set(a.b_factor for a in ent_rel.atoms))\n", - "ev_atoms = set(a.qualified_name for a in ent_rel.atoms)\n", - "eu_atoms = set(a.qualified_name for a in ent_unr.atoms)\n", - "print(\"IN UNRELAXED:\", sorted(eu_atoms - ev_atoms))\n", - "print(\"IN RELAXED:\", sorted(ev_atoms - eu_atoms))" - ] - }, - { - "cell_type": "code", - "execution_count": 43, - "id": "fadfbdd0", - "metadata": {}, - "outputs": [], - "source": [ - "def _get_ncbi_info(ncbi_ac):\n", - " \"\"\"Fetch dict with info from NCBI web service.\"\"\"\n", - " # src: https://www.ncbi.nlm.nih.gov/books/NBK25499/#chapter4.ESummary\n", - " rspns = requests.get(f\"https://eutils.ncbi.nlm.nih.gov/entrez/eutils/\" \\\n", - " f\"esummary.fcgi?db=protein&id={ncbi_ac}\")\n", - " dom = xml.dom.minidom.parseString(rspns.text)\n", - " docsums = dom.getElementsByTagName(\"DocSum\")\n", - " assert len(docsums) == 1\n", - " docsum = docsums[0]\n", - " ncbi_dict = {}\n", - " for cn in docsum.childNodes:\n", - " if cn.nodeName == \"Item\":\n", - " cn_name = cn.getAttribute(\"Name\")\n", - " cn_type = cn.getAttribute(\"Type\")\n", - " if cn.childNodes:\n", - " d = cn.childNodes[0].data\n", - " if cn_type == \"String\":\n", - " ncbi_dict[cn_name] = d\n", - " elif cn_type == \"Integer\":\n", - " ncbi_dict[cn_name] = int(d)\n", - " else:\n", - " raise RuntimeError(f\"Unknown type {cn_type} for {ncbi_ac}\")\n", - " else:\n", - " ncbi_dict[cn_name] = None\n", - " return ncbi_dict" - ] - }, - { - "cell_type": "code", - "execution_count": 44, - "id": "1114ebce", - "metadata": {}, - "outputs": [], - "source": [ - "# fetch some extra info from NCBI\n", - "for idx, row in metadata.iterrows():\n", - " ncbi_info = _get_ncbi_info(row.NCBI_Accession)\n", - " # Gi is some numerical sequence identifier used internally by NCBI\n", - " metadata.loc[idx, \"NCBI_Gi\"] = str(ncbi_info[\"Gi\"])\n", - " # UpdateData is to be stored as the version date in ModelCIF\n", - " metadata.loc[idx, \"NCBI_UpdateDate\"] = ncbi_info[\"UpdateDate\"]\n", - " # TaxId should be same as one from UP\n", - " metadata.loc[idx, \"NCBI_TaxId\"] = str(ncbi_info[\"TaxId\"])\n", - " # Status expected to be live\n", - " if ncbi_info[\"Status\"] != \"live\":\n", - " print(idx, row.NCBI_Accession, \"Status\", ncbi_info[\"Status\"])\n", - " # ReplacedBy expected to be empty\n", - " if ncbi_info[\"ReplacedBy\"]:\n", - " print(idx, row.NCBI_Accession, \"ReplacedBy\", ncbi_info[\"ReplacedBy\"])\n", - " # AccessionVersion expected to be NCBI_Accession\n", - " if ncbi_info[\"AccessionVersion\"] != row.NCBI_Accession:\n", - " print(idx, row.NCBI_Accession, \"AccessionVersion\", ncbi_info[\"AccessionVersion\"])" - ] - }, - { - "cell_type": "code", - "execution_count": 45, - "id": "e5d1ea29", - "metadata": { - "scrolled": true - }, - "outputs": [ - { - "data": { - "text/html": [ - "<div>\n", - "<style scoped>\n", - " .dataframe tbody tr th:only-of-type {\n", - " vertical-align: middle;\n", - " }\n", - "\n", - " .dataframe tbody tr th {\n", - " vertical-align: top;\n", - " }\n", - "\n", - " .dataframe thead th {\n", - " text-align: right;\n", - " }\n", - "</style>\n", - "<table border=\"1\" class=\"dataframe\">\n", - " <thead>\n", - " <tr style=\"text-align: right;\">\n", - " <th></th>\n", - " <th>Associated PDB</th>\n", - " <th>NCBI_Accession</th>\n", - " <th>UniProt_ID</th>\n", - " <th>_struct.title</th>\n", - " <th>_struct.pdbx_model_detail</th>\n", - " <th>ranking debugg model ID</th>\n", - " <th>notes</th>\n", - " <th>NCBI_Gi</th>\n", - " <th>NCBI_UpdateDate</th>\n", - " <th>NCBI_TaxId</th>\n", - " </tr>\n", - " <tr>\n", - " <th>Protein</th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " <th></th>\n", - " </tr>\n", - " </thead>\n", - " <tbody>\n", - " <tr>\n", - " <th>285L</th>\n", - " <td>285L.pdb</td>\n", - " <td>CAD2068351.1</td>\n", - " <td>A0A485PQD1</td>\n", - " <td>ASFV-G 285L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_1_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136876</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>A104R</th>\n", - " <td>A104R.pdb</td>\n", - " <td>CAD2068395.1</td>\n", - " <td>A0A0A1E0L7</td>\n", - " <td>ASFV-G A104R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_2_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136920</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>A118R</th>\n", - " <td>A118R.pdb</td>\n", - " <td>CAD2068397.1</td>\n", - " <td>A0A2X0RVA9</td>\n", - " <td>ASFV-G A118R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_1_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136922</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>A137R</th>\n", - " <td>A137R.pdb</td>\n", - " <td>CAD2068404.1</td>\n", - " <td>A0A2X0THQ0</td>\n", - " <td>ASFV-G A137R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136929</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>A151R</th>\n", - " <td>A151R.pdb</td>\n", - " <td>CAD2068398.1</td>\n", - " <td>A0A2X0TC55</td>\n", - " <td>ASFV-G A151R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136923</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>...</th>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " <td>...</td>\n", - " </tr>\n", - " <tr>\n", - " <th>QP509L</th>\n", - " <td>QP509L.pdb</td>\n", - " <td>CAD2068484.1</td>\n", - " <td>A0A2X0THX2</td>\n", - " <td>ASFV-G QP509L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>NaN</td>\n", - " <td>NaN</td>\n", - " <td>1886137009</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>R298L</th>\n", - " <td>R298L.pdb</td>\n", - " <td>CAD2068482.1</td>\n", - " <td>A0A2X0SE42</td>\n", - " <td>ASFV-G R298L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_3_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886137007</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>S183L</th>\n", - " <td>S183L.pdb</td>\n", - " <td>CAD2068472.1</td>\n", - " <td>A0A2X0SE34</td>\n", - " <td>ASFV-G S183L</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_4_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136997</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>S273R</th>\n", - " <td>S273R.pdb</td>\n", - " <td>CAD2068473.1</td>\n", - " <td>A0A2X0TKM5</td>\n", - " <td>ASFV-G S273R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_2_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136998</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " <tr>\n", - " <th>X69R</th>\n", - " <td>X69R.pdb</td>\n", - " <td>CAD2068372.1</td>\n", - " <td>A0A2X0TKC7</td>\n", - " <td>ASFV-G X69R</td>\n", - " <td>This model was predicted using AlphaFold2</td>\n", - " <td>model_2_pred_0</td>\n", - " <td>NaN</td>\n", - " <td>1886136897</td>\n", - " <td>2020/08/05</td>\n", - " <td>10497</td>\n", - " </tr>\n", - " </tbody>\n", - "</table>\n", - "<p>197 rows × 10 columns</p>\n", - "</div>" - ], - "text/plain": [ - " Associated PDB NCBI_Accession UniProt_ID _struct.title \\\n", - "Protein \n", - "285L 285L.pdb CAD2068351.1 A0A485PQD1 ASFV-G 285L \n", - "A104R A104R.pdb CAD2068395.1 A0A0A1E0L7 ASFV-G A104R \n", - "A118R A118R.pdb CAD2068397.1 A0A2X0RVA9 ASFV-G A118R \n", - "A137R A137R.pdb CAD2068404.1 A0A2X0THQ0 ASFV-G A137R \n", - "A151R A151R.pdb CAD2068398.1 A0A2X0TC55 ASFV-G A151R \n", - "... ... ... ... ... \n", - "QP509L QP509L.pdb CAD2068484.1 A0A2X0THX2 ASFV-G QP509L \n", - "R298L R298L.pdb CAD2068482.1 A0A2X0SE42 ASFV-G R298L \n", - "S183L S183L.pdb CAD2068472.1 A0A2X0SE34 ASFV-G S183L \n", - "S273R S273R.pdb CAD2068473.1 A0A2X0TKM5 ASFV-G S273R \n", - "X69R X69R.pdb CAD2068372.1 A0A2X0TKC7 ASFV-G X69R \n", - "\n", - " _struct.pdbx_model_detail ranking debugg model ID \\\n", - "Protein \n", - "285L This model was predicted using AlphaFold2 model_1_pred_0 \n", - "A104R This model was predicted using AlphaFold2 model_2_pred_0 \n", - "A118R This model was predicted using AlphaFold2 model_1_pred_0 \n", - "A137R This model was predicted using AlphaFold2 model_3_pred_0 \n", - "A151R This model was predicted using AlphaFold2 model_4_pred_0 \n", - "... ... ... \n", - "QP509L This model was predicted using AlphaFold2 NaN \n", - "R298L This model was predicted using AlphaFold2 model_3_pred_0 \n", - "S183L This model was predicted using AlphaFold2 model_4_pred_0 \n", - "S273R This model was predicted using AlphaFold2 model_2_pred_0 \n", - "X69R This model was predicted using AlphaFold2 model_2_pred_0 \n", - "\n", - " notes NCBI_Gi NCBI_UpdateDate NCBI_TaxId \n", - "Protein \n", - "285L NaN 1886136876 2020/08/05 10497 \n", - "A104R NaN 1886136920 2020/08/05 10497 \n", - "A118R NaN 1886136922 2020/08/05 10497 \n", - "A137R NaN 1886136929 2020/08/05 10497 \n", - "A151R NaN 1886136923 2020/08/05 10497 \n", - "... ... ... ... ... \n", - "QP509L NaN 1886137009 2020/08/05 10497 \n", - "R298L NaN 1886137007 2020/08/05 10497 \n", - "S183L NaN 1886136997 2020/08/05 10497 \n", - "S273R NaN 1886136998 2020/08/05 10497 \n", - "X69R NaN 1886136897 2020/08/05 10497 \n", - "\n", - "[197 rows x 10 columns]" - ] - }, - "execution_count": 45, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "metadata" - ] - }, - { - "cell_type": "code", - "execution_count": 46, - "id": "b8d18043", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "(193, {'10497'}, 193, {'2020/08/05'})" - ] - }, - "execution_count": 46, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "len(set(metadata.NCBI_Accession)), set(metadata.NCBI_TaxId), \\\n", - "len(set(metadata.NCBI_Gi)), set(metadata.NCBI_UpdateDate)" - ] - }, - { - "cell_type": "code", - "execution_count": 54, - "id": "4385bd3d", - "metadata": {}, - "outputs": [], - "source": [ - "# all matching tax IDs?\n", - "for protein, upac in metadata.UniProt_ID.items():\n", - " up_info = _fetch_upkb_entry(upac)\n", - " if up_info[\"up_ncbi_taxid\"] != \"10497\":\n", - " print(protein, up_info)" - ] - }, - { - "cell_type": "code", - "execution_count": 64, - "id": "0376a9e3", - "metadata": {}, - "outputs": [], - "source": [ - "# check PDB files\n", - "import ost\n", - "from ost import testutils, conop\n", - "# setup conop\n", - "testutils.SetDefaultCompoundLib()\n", - "io.profiles['DEFAULT'].processor = conop.RuleBasedProcessor(conop.GetDefaultLib())\n", - "# check processing\n", - "ost.PushVerbosityLevel(2)\n", - "for protein, pdb_ext in sorted(pdb_file_split):\n", - " pdb_path = os.path.join(pdb_dir, protein + pdb_ext)\n", - " ent = io.LoadPDB(pdb_path)\n", - "ost.PopVerbosityLevel()\n", - "# NOTE: lack of output means that all atom names are ok" - ] - }, - { - "cell_type": "code", - "execution_count": 84, - "id": "5a857298", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "{'up_organism': 'African swine fever virus (ASFV)',\n", - " 'up_sequence': 'MLLYIVIIVACIISKLVPNEYWAIHLFFIIMIFMVYMYEKLDIHQKSQFWNYTMSGLSGHNVQVTCKCY',\n", - " 'up_ac': 'A0A2X0TKC7',\n", - " 'up_id': 'A0A2X0TKC7_ASF',\n", - " 'up_last_mod': datetime.datetime(2018, 9, 12, 0, 0),\n", - " 'up_gn': 'X69R CDS',\n", - " 'up_ncbi_taxid': '10497',\n", - " 'up_seqlen': 69,\n", - " 'up_crc64': '3B92E4DB323A7A74',\n", - " 'up_isoform': None}" - ] - }, - "execution_count": 84, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "up_info" - ] - }, - { - "cell_type": "code", - "execution_count": 85, - "id": "6c8d2b8a", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "{'Caption': 'CAD2068372',\n", - " 'Title': 'X69R CDS [African swine fever virus]',\n", - " 'Extra': 'gi|1886136897|emb|CAD2068372.1|[1886136897]',\n", - " 'Gi': 1886136897,\n", - " 'CreateDate': '2010/08/18',\n", - " 'UpdateDate': '2020/08/05',\n", - " 'Flags': 0,\n", - " 'TaxId': 10497,\n", - " 'Length': 69,\n", - " 'Status': 'live',\n", - " 'ReplacedBy': None,\n", - " 'Comment': ' ',\n", - " 'AccessionVersion': 'CAD2068372.1'}" - ] - }, - "execution_count": 85, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "ncbi_info" - ] - }, - { - "cell_type": "code", - "execution_count": 154, - "id": "f7097a09", - "metadata": {}, - "outputs": [], - "source": [ - "# check files that were converted (input is std out from run cut to only include \"translating...\")\n", - "log_lines = open(\"./script_out.txt\").readlines()" - ] - }, - { - "cell_type": "code", - "execution_count": 155, - "id": "34ed53d8", - "metadata": {}, - "outputs": [], - "source": [ - "# plenty of assertions in here should also catch any errors...\n", - "idx = 1\n", - "timings = dict()\n", - "while idx < len(log_lines) - 1:\n", - " l = log_lines[idx].strip()\n", - " if \"already done...\" in l:\n", - " idx += 1\n", - " continue\n", - " assert l.startswith(\"translating\")\n", - " mdl_title = l[len(\"translating\"):-3].strip()\n", - " if mdl_title in timings:\n", - " print(\"WEIRD\", l)\n", - " l = log_lines[idx + 1].strip()\n", - " assert l.startswith(\"preparing data\")\n", - " assert l.endswith(\"s)\")\n", - " t_prep = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 2].strip()\n", - " assert l.startswith(\"generating ModelCIF objects\")\n", - " assert l.endswith(\"s)\")\n", - " t_cif = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 3].strip()\n", - " assert l.startswith(\"processing QA scores\")\n", - " assert l.endswith(\"s)\")\n", - " t_qa = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 4].strip()\n", - " assert l.startswith(\"write to disk\")\n", - " assert l.endswith(\"s)\")\n", - " t_write = float(l.split()[-1][1:-2])\n", - " l = log_lines[idx + 5].strip()\n", - " assert l.startswith(\"... done with\")\n", - " assert l.endswith(\"s).\")\n", - " t_all = float(l.split()[-1][1:-3])\n", - " timings[mdl_title] = {\n", - " \"t_prep\": t_prep,\n", - " \"t_cif\": t_cif,\n", - " \"t_qa\": t_qa,\n", - " \"t_write\": t_write,\n", - " \"t_all\": t_all\n", - " }\n", - " idx += 6" - ] - }, - { - "cell_type": "code", - "execution_count": 156, - "id": "876acf01", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "DONE 197 models\n", - "MISSING 0 models\n" - ] - } - ], - "source": [ - "print(f\"DONE {len(timings)} models\")\n", - "mdl_titles = set(metadata.index)\n", - "assert len(set(timings) - mdl_titles) == 0\n", - "missing_ones = mdl_titles - set(timings)\n", - "print(f\"MISSING {len(missing_ones)} models\")" - ] - }, - { - "cell_type": "code", - "execution_count": 157, - "id": "612a1791", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "TOTAL TIME SPENT: 356.38 s\n", - "-> t_prep: 80.5%\n", - "-> t_cif: 1.2%\n", - "-> t_qa: 0.0%\n", - "-> t_write: 17.8%\n" - ] - } - ], - "source": [ - "k_parts = [\"t_prep\", \"t_cif\", \"t_qa\", \"t_write\"]\n", - "totals = {k: sum(v[k] for v in timings.values()) \\\n", - " for k in k_parts + [\"t_all\"]}\n", - "print(f\"TOTAL TIME SPENT: {round(totals['t_all'], 2)} s\")\n", - "for k in k_parts:\n", - " print(f\"-> {k}: {round(100 * totals[k] / totals['t_all'], 1)}%\")" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "id": "283d223f", - "metadata": {}, - "outputs": [], - "source": [] - } - ], - "metadata": { - "kernelspec": { - "display_name": "Python 3 (ipykernel)", - "language": "python", - "name": "python3" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.8.10" - } - }, - "nbformat": 4, - "nbformat_minor": 5 -} diff --git a/projects/USDA-ASFVG/tests/test_modelCIF_MA.py b/projects/USDA-ASFVG/tests/test_modelCIF_MA.py deleted file mode 100644 index fc71c3ceab51fea843ea52e26410e9def438df8d..0000000000000000000000000000000000000000 --- a/projects/USDA-ASFVG/tests/test_modelCIF_MA.py +++ /dev/null @@ -1,476 +0,0 @@ -# USAGE: python test_modelCIF_MA.py [CIF-FILE] -# OUTPUT: preview of MA entry - -import gemmi, sys - -################################################################################ -# define converters for printing or for html (here markdown used for display) -def _make_url(link_text, link_url): - return f"[{link_text}]({link_url})" -def _make_list(list_top, list_items): - list_texts = [f"- {item}" for item in list_items] - list_text = '\n'.join(list_texts) - if list_texts: - return(f"{list_top}\n{list_text}") -def _make_multiline_text(lines): - return '\n'.join(lines) -def _make_paragraph(text): - return f"{text}\n\n" -################################################################################ - -################################################################################ -# HELPERS -################################################################################ -def _get_chain_entity(block): - # NOTE: adapted from ParseCIF (asym_ids as list and handle optional fields) - chain_entity = {} - - ma_target_entity = block.find( - "_ma_target_entity_instance.", ["asym_id", "entity_id"] - ) - if ma_target_entity: - for row in ma_target_entity: - if row["entity_id"] in chain_entity: - chain_entity[row["entity_id"]]["asym_ids"].append( - gemmi.cif.as_string(row["asym_id"]) - ) - else: - chain_entity[row["entity_id"]] = { - "asym_ids": [row["asym_id"]], - "ma_target_ref_db_details": [], - } - - for row in block.find("_entity.", ["id", "pdbx_description"]): - chain_entity[row["id"]].update( - {"pdbx_description": gemmi.cif.as_string(row["pdbx_description"])} - ) - - cols = [ - "target_entity_id", - "db_accession", - "db_name", - "?db_name_other_details", - "?organism_scientific", - "?seq_db_align_begin", - "?seq_db_align_end", - ] - # NOTE: row[col] doesn't work with '?' in find! Bad crashed happen if you try... - for row in block.find("_ma_target_ref_db_details.", cols): - json_obj = {} - target_entity_id = row[0] # make sure this stays at idx 0 in cols! - for idx, cq in enumerate(cols): - if cq.startswith('?'): - col = cq[1:] - if not row.has(idx) or gemmi.cif.is_null(row[idx]): - json_obj[col] = None - continue - else: - col = cq - if col != "target_entity_id": - if col.find("seq_db_align") > -1: - json_obj[col] = gemmi.cif.as_int(row[idx]) - else: - json_obj[col] = gemmi.cif.as_string(row[idx]) - chain_entity[target_entity_id][ - "ma_target_ref_db_details" - ].append(json_obj) - - for row in block.find( - "_entity_poly.", - ["entity_id", "pdbx_strand_id", "pdbx_seq_one_letter_code"], - ): - chain_entity[row["entity_id"]]["olc"] = gemmi.cif.as_string( - row["pdbx_seq_one_letter_code"] - ).replace("\n", "") - - return chain_entity - -def _fetch_qa_data(block): - """Get 3 lists of QA scores and extract global scores.""" - # fetch main info - table = block.find("_ma_qa_metric.", ["id", "name", "mode", "type"]) - qa_dict = dict() # for easy access: keyed on "id" and rest as dict - for row in table: - d = {key: row.str(idx + 1) for idx, key in enumerate(["name", "mode", "type"])} - qa_dict[row.str(0)] = d - # fetch global scores - qa_global = [] - table = block.find("_ma_qa_metric_global.", ["metric_id", "metric_value"]) - for row in table: - metric_id = row.str(0) - metric_value = gemmi.cif.as_number(row.get(1)) - if metric_id in qa_dict: - assert qa_dict[metric_id]["mode"] == "global" - qa_dict[metric_id]["value"] = metric_value - qa_global.append(qa_dict[metric_id]) - # fetch local scores - qa_local = [d for d in qa_dict.values() if d["mode"] == "local"] - qa_local_pairwise = [d for d in qa_dict.values() if d["mode"] == "local-pairwise"] - return qa_global, qa_local, qa_local_pairwise -################################################################################ - -################################################################################ -# TEXT GETTERS -# -> each function turns gemmi-block into a text -# -> bits that could be reused elsewhere are given by helpers above -################################################################################ -def _get_title_text(block): - title = block.find_value("_struct.title") - if title: - title = gemmi.cif.as_string(title) - if title: - return title - else: - return "NO TITLE" - -def _get_overview_text(block): - abstract = block.find_value("_struct.pdbx_model_details") - if abstract: - abstract = gemmi.cif.as_string(abstract) - if abstract: - text = _make_paragraph(abstract) - else: - text = _make_paragraph("NO ABSTRACT") - # TODO: "TOFILL" below to be filled by MA using info from model set - text += _make_paragraph('This model is part of the dataset "TOFILL"') - return text - -def _get_entity_text(block): - # NOTE: reuse (updated!) code from ParseCIF - chain_entity = _get_chain_entity(block) - # do it - item_strings = [] - for ent in chain_entity: - item_title = f"{chain_entity[ent]['pdbx_description']} " \ - f"(chains: {', '.join(chain_entity[ent]['asym_ids'])})" - db_links = [item_title] - for i, ref in enumerate(chain_entity[ent]["ma_target_ref_db_details"]): - if ref["db_name"] == "UNP": - link_text = ref['db_accession'] - link_url = f"https://www.uniprot.org/uniprot/{ref['db_accession']}" - db_link = f"UniProt: {_make_url(link_text, link_url)}" - elif ref["db_name"] == "OrthoDB": - link_text = ref['db_accession'] - link_url = f"https://www.orthodb.org/?query={ref['db_accession']}" - db_link = f"OrthoDB: {_make_url(link_text, link_url)}" - elif ref["db_name"] == "NCBI": - link_text = ref['db_accession'] - link_url = f"https://www.ncbi.nlm.nih.gov/protein/{ref['db_accession']}" - db_link = f"NCBI: {_make_url(link_text, link_url)}" - elif ref["db_name"] == "Other" and ref["db_name_other_details"]: - db_link = f"{ref['db_name_other_details']}: {ref['db_accession']}" - else: - db_link = f"{ref['db_name']}: {ref['db_accession']}" - if ref['seq_db_align_begin'] and ref['seq_db_align_end']: - db_link += f" {ref['seq_db_align_begin']}-{ref['seq_db_align_end']}" - if ref['organism_scientific']: - db_link += f"; {ref['organism_scientific']}" - db_links.append(db_link) - item_strings.append(_make_multiline_text(db_links)) - # and into a paragraph... - if item_strings: - list_top = f"The following molecular entities are in the model:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_sw_text(block): - # get author names for each citation - tmp = dict() - for row in block.find("_citation_author.", ["citation_id", "name"]): - cid = row.str(0) - name = row.str(1) - if cid not in tmp: - tmp[cid] = {"name": name.split()[0].split(",")[0], "etal": ""} - else: - tmp[cid]["etal"] = " et al." - cit_names = {cid: (d["name"] + d["etal"]) for cid, d in tmp.items()} - # add year if available - table = block.find("_citation.", ["id", "?year"]) - if table.has_column(1): - for row in table: - cid = row.str(0) - year = row.str(1) - if cid in cit_names and year: - cit_names[cid] += " " + year - # add URL if available - cit_urls = {} - table = block.find("_citation.", ["id", "?pdbx_database_id_DOI", "?pdbx_database_id_PubMed"]) - formatters = ["https://doi.org/%s", - "https://www.ncbi.nlm.nih.gov/pubmed/%s"] - for row in table: - cid = row.str(0) - # add whichever URL we find first - for i in range(1, table.width()): - if row.has(i) and row.str(i): - cit_urls[cid] = formatters[i - 1] % row.str(i) - break - # now map this to software - item_strings = [] - table = block.find("_software.", ["name", "?location", "?version", "?citation_id"]) - for row in table: - sw_name = row.str(0) - if row.has(1) and row.str(1): - item = _make_url(sw_name, row.str(1)) - else: - item = sw_name - if row.has(2) and row.str(2): - item += f" ({row.str(2)})" - if row.has(3) and row.str(3) in cit_names: - cid = row.str(3) - if cid in cit_urls: - item += f" ({_make_url(cit_names[cid], cit_urls[cid])})" - else: - item += f" ({cit_names[cid]})" - item_strings.append(item) - # and into a paragraph... - if item_strings: - list_top = f"The following software was used:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_ref_db_text(block): - # look for DBs with version or release date - item_strings = [] - table = block.find("_ma_data_ref_db.", ["name", "?version", "?release_date"]) - for row in table: - item = f"{row.str(0)}" - # add whichever version we find first - for i in range(1, 3): - if row.has(i) and row.str(i): - item += f" ({row.str(i)})" - break - item_strings.append(item) - # and into a paragraph... - if item_strings: - list_top = f"The following reference databases were used:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_tpl_text(block): - # collect info per tpl-id - tpl_dict = {} # keyed on template_id - # fetch main info - cols = ["template_id", "target_asym_id", "template_auth_asym_id", - "?template_label_asym_id"] - for row in block.find("_ma_template_details.", cols): - tid = row.str(0) - tpl_dict[tid] = { - "trg_asym_id": row.str(1), - "tpl_auth_asym_id": row.str(2) - } - if row.has(3) and row.str(3): - tpl_dict[tid]["tpl_label_asym_id"] = row.str(3) - # add ref DBs - cols = ["template_id", "db_accession_code", "db_name", - "?db_name_other_details"] - for row in block.find("_ma_template_ref_db_details.", cols): - tid = row.str(0) - if tid in tpl_dict: - tpl_dict[tid]["db_acc"] = row.str(1) - if row.str(2) == "Other" and row.has(3) and row.str(3): - tpl_dict[tid]["db_name"] = row.str(3) - else: - tpl_dict[tid]["db_name"] = row.str(2) - # add info for small molecules - cols = ["template_id", "?comp_id", "?details"] - for row in block.find("_ma_template_non_poly.", cols): - tid = row.str(0) - if tid in tpl_dict: - if row.has(1) and row.str(1): - tpl_dict[tid]["non_poly_comp_id"] = row.str(1) - if row.has(2) and row.str(2): - tpl_dict[tid]["non_poly_details"] = row.str(2) - # aggregate per template for diplaying - tpl_td = dict() - for tpl in tpl_dict.values(): - did = f"{tpl['db_name']}-{tpl['db_acc']}" - if did not in tpl_td: - if tpl['db_name'] == "PDB": - link_url = f"http://dx.doi.org/10.2210/pdb{tpl['db_acc']}/pdb" - elif tpl['db_name'] == "PubChem": - link_url = f"https://pubchem.ncbi.nlm.nih.gov/compound/{tpl['db_acc']}" - elif tpl['db_name'] == "AlphaFoldDB": - link_url = f"https://alphafold.ebi.ac.uk/entry/{tpl['db_acc']}" - else: - link_url = None - print(f"URLs for {tpl['db_name']} NOT SUPPORTED YET") - if link_url: - tpl_text = f"{tpl['db_name']}: {_make_url(tpl['db_acc'], link_url)}" - else: - tpl_text = f"{tpl['db_name']}: {tpl['db_acc']}" - tpl_td[did] = { - "tpl_text": tpl_text, - "tpl_chains_label": [], - "tpl_chains_auth": [], - "tpl_chains_all_label": True, - "tpl_non_poly_ids": [] - } - # collect chain names - if "tpl_label_asym_id" in tpl: - # if here it is guaranteed to be non-empty - tpl_td[did]["tpl_chains_label"].append(tpl["tpl_label_asym_id"]) - else: - # if any missing, we set all to False and fall back to auth - tpl_td[did]["tpl_chains_all_label"] = False - if tpl["tpl_auth_asym_id"]: - # only add non empty ones - tpl_td[did]["tpl_chains_auth"].append(tpl["tpl_auth_asym_id"]) - # collect info on non poly if available (prefer short comp. ID) - if "non_poly_comp_id" in tpl: - tpl_td[did]["tpl_non_poly_ids"].append(tpl["non_poly_comp_id"]) - elif "non_poly_details" in tpl: - tpl_td[did]["tpl_non_poly_ids"].append(tpl["non_poly_details"]) - # turn into text - item_strings = [] - for tpl in tpl_td.values(): - item = tpl["tpl_text"] - if tpl["tpl_chains_all_label"] and tpl["tpl_chains_label"]: - chain_ids = sorted(set(tpl['tpl_chains_label'])) - item += f"; chains (label_asym_id): {', '.join(chain_ids)}" - elif tpl["tpl_chains_auth"]: - chain_ids = sorted(set(tpl['tpl_chains_auth'])) - item += f"; chains (auth_asym_id): {', '.join(chain_ids)}" - if tpl["tpl_non_poly_ids"]: - np_ids = sorted(set(tpl['tpl_non_poly_ids'])) - item += f"; non-polymers: {', '.join(np_ids)}" - item_strings.append(item) - # and into a paragraph... - if item_strings: - list_top = f"The following templates were used:" - return _make_paragraph(_make_list(list_top, item_strings)) - else: - return "" - -def _get_protocol_steps_text(block): - # do it - item_strings = [] - table = block.find("_ma_protocol_step.", ["step_id", "method_type", "?details"]) - for row in table: - item = f"Step {row.str(0)} - {row.str(1)}" - if row.has(2) and row.str(2): - item += f" : {row.str(2)}" - item_strings.append(item) - # and into a paragraph... - if item_strings: - return _make_paragraph(_make_multiline_text(item_strings)) - else: - return "" - -def _get_qa_acc_text(block): - # get QA part (can reuse if already used elsewhere) - qa_global, qa_local, qa_local_pairwise = _fetch_qa_data(block) - # parse accompanying data - file_contents = block.find_values("_ma_entry_associated_files.file_content") - has_single_zip_file = len(file_contents) == 1 and \ - file_contents.str(0) == "archive with multiple files" - if has_single_zip_file: - # override with data from other block - file_contents = block.find_values("_ma_associated_archive_file_details.file_content") - has_loc_pw_in_acc = any(True for v in file_contents \ - if gemmi.cif.as_string(v) == "local pairwise QA scores") - # put together text - text = "" - # text for QA - item = "" - if len(qa_global) > 1: - score_strings = [f"{v['name']} of {v['value']}" for v in qa_global] - item = f"The model has the following global model confidence scores:" \ - f" {', '.join(score_strings)}." - elif len(qa_global) == 1: - item = f"The model has a global model confidence score " \ - f"({qa_global[0]['name']}) of {qa_global[0]['value']}." - if item: - text += _make_paragraph(item) - # lots of options for local QA string - item = "" - qa_local_names = ", ".join([v["name"] for v in qa_local]) - qa_loc_pw_names = ", ".join([v["name"] for v in qa_local_pairwise]) - if qa_local_names and qa_loc_pw_names and has_loc_pw_in_acc: - item = f"Local per-residue model confidence scores ({qa_local_names}) " \ - f"are available in the model mmCIF file " \ - f"and local per-residue-pair scores ({qa_loc_pw_names}) " \ - f"in the accompanying data download." - elif qa_local_names and qa_loc_pw_names and not has_loc_pw_in_acc: - item = f"Local per-residue model confidence scores ({qa_local_names}) " \ - f"and local per-residue-pair scores ({qa_loc_pw_names}) " \ - f"are available in the model mmCIF file." - elif qa_local_names and not qa_loc_pw_names: - item = f"Local per-residue model confidence scores ({qa_local_names}) " \ - f"are available in the model mmCIF file." - elif not qa_local_names and qa_loc_pw_names and has_loc_pw_in_acc: - item = f"Local per-residue-pair model confidence scores ({qa_loc_pw_names}) " \ - f"are available in the accompanying data download." - elif not qa_local_names and qa_loc_pw_names and not has_loc_pw_in_acc: - item = f"Local per-residue-pair model confidence scores ({qa_loc_pw_names}) " \ - f"are available in the model mmCIF file." - if item: - text += _make_paragraph(item) - # list files in accompanying data (if any) - if has_single_zip_file: - table = block.find("_ma_associated_archive_file_details.", - ["file_path", "?file_content", "?description"]) - else: - # NOTE: aimed to work legacy-style for Baker-models but should be obsoleted - # -> can replace below with "table = None" in future - table = block.find("_ma_entry_associated_files.", - ["file_url", "?file_content", "?details"]) - if table: - list_top = "Files in accompanying data:" - list_items = [] - for row in table: - item = f"{row.str(0)}" - if row.has(1) and row.str(1): - item += f" ({row.str(1)})" - if row.has(2) and row.str(2): - item += f": {row.str(2)}" - list_items.append(item) - text += _make_paragraph(_make_list(list_top, list_items)) - # conclude with standard pointer to ModelCIF file - model_cif_link = _make_url( - "ModelCIF format", - "https://mmcif.wwpdb.org/dictionaries/mmcif_ma.dic/Index/" - ) - text += _make_paragraph( - f"Full details are available in {model_cif_link}" \ - f"in the model mmCIF file." - ) - return text -################################################################################ - -# full parsing of file -def _process_file(file_path): - print(f"ModelCIF->MA for {file_path}") - doc = gemmi.cif.read(file_path) - block = doc.sole_block() - print('-'*80) - print(f"TITLE: {_get_title_text(block)}") - print('-'*80) - print(f"OVERVIEW:\n{'-'*80}") - print(_get_overview_text(block)) - print('-'*80) - print(f"MATERIAL:\n{'-'*80}") - material_text = _get_entity_text(block) \ - + _get_sw_text(block) \ - + _get_ref_db_text(block) \ - + _get_tpl_text(block) - print(material_text) - print('-'*80) - print(f"PROCEDURE:\n{'-'*80}") - procedure_text = _get_protocol_steps_text(block) \ - + _get_qa_acc_text(block) - print(procedure_text) - print('-'*80) - -def _main(): - # get file to process - if len(sys.argv) == 2: - file_path = sys.argv[1] - _process_file(file_path) - else: - print("USAGE: python test_modelCIF_MA.py [CIF-FILE]") - -if __name__ == "__main__": - _main() diff --git a/projects/cancer-PPI-domains/README.md b/projects/cancer-PPI-domains/README.md new file mode 100644 index 0000000000000000000000000000000000000000..c3a4cf694576886f839a47f11eef59ef0e428145 --- /dev/null +++ b/projects/cancer-PPI-domains/README.md @@ -0,0 +1,23 @@ +# Modelling of Spongilla lacustris proteome with functional annotations + +[Link to project in ModelArchive](https://modelarchive.org/doi/10.5452/ma-t3vr3) (incl. background on project itself) + +Setup: +- Domains of interacting proteins extracted from full length proteins (sequences from UniProtKB) +- Models generated using sequences of domains which can have discontinuous mapping to full length sequence +- Same protocol used as in [model set for core eukaryotic protein complexes](https://www.modelarchive.org/doi/10.5452/ma-bak-cepc) + - Paired multiple sequence alignment (MSA) generated for each dimer + - Model using AlphaFold ("model 3" parameters; pTM monomer version) with a 200 residue gap between the two chains, without templates and without model relaxation +- Input from them: + - one zip file with all the PDB files (no b-factor values, residue numbers matching position in UniProtKB sequence) + - one zip file with all the extra files (1 fasta file for alignment, 1 npz file with pLDDT, PAE and contact probabilities) + - a CSV file with description and UniProtKB links for each protein + +Special features here: +- Custom MSA generation with intermediate result in accompanying data +- PAE and contact probabilities only kept for inter-chain residue-pairs +- Author provided residue numbers kept as auth_seq_id +- Mapping to most recent UniProtKB sequence generated, checked and stored as fasta files (ModelCIF file only has covered range with respect to the originally used sequence) + +Content: +- translate2modelcif.py : script to do conversion; compatible with Docker setup from [ma-wilkins-import](https://git.scicore.unibas.ch/schwede/ma-wilkins-import) (and script based on code there) diff --git a/projects/cancer-PPI-domains/translate2modelcif.py b/projects/cancer-PPI-domains/translate2modelcif.py new file mode 100644 index 0000000000000000000000000000000000000000..f5076cd6c684f277c2bb713f0d40a12e19a4253b --- /dev/null +++ b/projects/cancer-PPI-domains/translate2modelcif.py @@ -0,0 +1,1106 @@ +#! /usr/local/bin/ost +"""Translate models from Jing Zhang from PDB + extra data into ModelCIF.""" + +# EXAMPLES for running: +""" +GT test setup: +ost scripts/translate2modelcif.py ./pdbs ./accompanying_data \ + ./modelarchive_submission.csv ./modelcif +# DO ALL +ost scripts/translate2modelcif.py ./pdbs ./accompanying_data \ + ./modelarchive_submission.csv ./modelcif --compress > script_out.txt +""" + +import argparse +import datetime +import gzip +import os +import shutil +import sys +import zipfile + +from timeit import default_timer as timer +import numpy as np +import requests +import ujson as json + +import ihm +import ihm.citations +import modelcif +import modelcif.associated +import modelcif.dumper +import modelcif.model +import modelcif.protocol +import modelcif.reference + +import pandas as pd +from ost import io, seq + +# global cache +up_cache = {} + +def _parse_args(): + """Parse command line arguments.""" + parser = argparse.ArgumentParser( + formatter_class=argparse.RawDescriptionHelpFormatter, + description=__doc__, + ) + + parser.add_argument( + "model_dir", + type=str, + metavar="<MODEL DIR>", + help="Directory with models to be translated.", + ) + parser.add_argument( + "accompanying_data_dir", + type=str, + metavar="<ACC. DIR>", + help="Directory with zip files containing accompanying data.", + ) + parser.add_argument( + "metadata_file", + type=str, + metavar="<METADATA FILE>", + help="Path to CSV file with metadata.", + ) + parser.add_argument( + "out_dir", + type=str, + metavar="<OUTPUT DIR>", + help="Path to directory to store results.", + ) + parser.add_argument( + "--compress", + default=False, + action="store_true", + help="Compress ModelCIF file with gzip " + "(note that QA file is zipped either way).", + ) + opts = parser.parse_args() + + # check that model dir exists + if opts.model_dir.endswith("/"): + opts.model_dir = opts.model_dir[:-1] + if not os.path.exists(opts.model_dir): + _abort_msg(f"Model directory '{opts.model_dir}' does not exist.") + if not os.path.isdir(opts.model_dir): + _abort_msg(f"Path '{opts.model_dir}' does not point to a directory.") + # check that acc. dir exists + if opts.accompanying_data_dir.endswith("/"): + opts.accompanying_data_dir = opts.accompanying_data_dir[:-1] + if not os.path.exists(opts.accompanying_data_dir): + _abort_msg(f"Model directory '{opts.accompanying_data_dir}' does not exist.") + if not os.path.isdir(opts.accompanying_data_dir): + _abort_msg(f"Path '{opts.accompanying_data_dir}' does not point to a directory.") + # check metadata_file + if not os.path.exists(opts.metadata_file): + _abort_msg(f"Metadata file '{opts.metadata_file}' does not exist.") + if not os.path.isfile(opts.metadata_file): + _abort_msg(f"Path '{opts.metadata_file}' does not point to a file.") + # check out_dir + if opts.out_dir.endswith("/"): + opts.out_dir = opts.out_dir[:-1] + if not os.path.exists(opts.out_dir): + os.makedirs(opts.out_dir) + if not os.path.isdir(opts.out_dir): + _abort_msg(f"Path '{opts.out_dir}' does not point to a directory.") + return opts + + +# pylint: disable=too-few-public-methods +class _GlobalPLDDT(modelcif.qa_metric.Global, modelcif.qa_metric.PLDDT): + """Predicted accuracy according to the CA-only lDDT in [0,100]""" + + name = "pLDDT" + software = None + + +class _LocalPLDDT(modelcif.qa_metric.Local, modelcif.qa_metric.PLDDT): + """Predicted accuracy according to the CA-only lDDT in [0,100]""" + + name = "pLDDT" + software = None + + +class _PAE(modelcif.qa_metric.MetricType): + """Predicted aligned error (in Angstroms)""" + + type = "PAE" + other_details = None + + +class _LocalPairwisePAE(modelcif.qa_metric.LocalPairwise, _PAE): + """Predicted aligned error (in Angstroms)""" + + name = "PAE" + software = None + + +class _ContactProb(modelcif.qa_metric.MetricType): + """Contact probability of a pairwise interaction in [0,1]""" + + type = "contact probability" + other_details = None + + +class _LocalPairwiseCP(modelcif.qa_metric.LocalPairwise, _ContactProb): + """Contact probability of a pairwise interaction in [0,1]""" + + name = "contact probability" + software = None + + +# pylint: enable=too-few-public-methods + + +class _OST2ModelCIF(modelcif.model.AbInitioModel): + """Map OST entity elements to ihm.model""" + + def __init__(self, *args, **kwargs): + """Initialise a model""" + for i in ["ost_entity", "asym", "scores_json"]: + if i not in kwargs: + raise TypeError(f"Required keyword argument '{i}' not found.") + self.ost_entity = kwargs.pop("ost_entity") + self.asym = kwargs.pop("asym") + self.scores_json = kwargs.pop("scores_json") + # need reverse mapping from chain name + res num to seq. id + self.seq_id_map = { + ch.name: { + res.number.num: idx+1 for idx, res in enumerate(ch.residues) + } for ch in self.ost_entity.chains + } + # self.seq_id_map = { + # ch_id: {v: k for k, v in asym_unit.auth_seq_id_map.items()} \ + # for ch_id, asym_unit in self.asym.items() + # } + # fetch plddts for all residues (for mapping) + self.res_bfactors = { + r.qualified_name: self.scores_json["plddt"][i] \ + for i, r in enumerate(self.ost_entity.residues) + } + + super().__init__(*args, **kwargs) + + def get_atoms(self): + # note we blindly replace b-factors here! + for atm in self.ost_entity.atoms: + yield modelcif.model.Atom( + asym_unit=self.asym[atm.chain.name], + seq_id=self.seq_id_map[atm.chain.name][atm.residue.number.num], + atom_id=atm.name, + type_symbol=atm.element, + x=atm.pos[0], + y=atm.pos[1], + z=atm.pos[2], + het=atm.is_hetatom, + biso=self.res_bfactors[atm.residue.qualified_name], + occupancy=atm.occupancy, + ) + + def add_scores(self): + """Add QA metrics from AF2 scores.""" + # global scores + self.qa_metrics.append( + _GlobalPLDDT(np.mean(self.scores_json["plddt"])) + ) + + # local scores + lpae = [] + lcp = [] + i = 0 + for chn_idx, chn_i in enumerate(self.ost_entity.chains): + for res_i in chn_i.residues: + # local pLDDT + seq_id_i = self.seq_id_map[chn_i.name][res_i.number.num] + asym_i = self.asym[chn_i.name].residue(seq_id_i) + self.qa_metrics.append( + _LocalPLDDT(asym_i, self.scores_json["plddt"][i]) + ) + + # per-residue scores + # NOTE: only off diagonal stored (i.e. chain A with chain B) + j = 0 + for chn_j in self.ost_entity.chains[chn_idx+1:]: + for res_j in chn_j.residues: + seq_id_j = self.seq_id_map[chn_j.name][res_j.number.num] + asym_j = self.asym[chn_j.name].residue(seq_id_j) + pae_ij = self.scores_json["pae"][i][j] + lpae.append( + _LocalPairwisePAE(asym_i, asym_j, pae_ij) + ) + cp_ij = self.scores_json["contact_prob"][i][j] + lcp.append( + _LocalPairwiseCP(asym_i, asym_j, round(cp_ij, 3)) + ) + j += 1 + + i += 1 + + self.qa_metrics.extend(lpae) + self.qa_metrics.extend(lcp) + + +def _abort_msg(msg, exit_code=1): + """Write error message and exit with exit_code.""" + print(f"{msg}\nAborting.", file=sys.stderr) + sys.exit(exit_code) + + +def _warn_msg(msg): + """Write a warning message to stdout.""" + print(f"WARNING: {msg}") + + +def _check_file(file_path): + """Make sure a file exists and is actually a file.""" + if not os.path.exists(file_path): + _abort_msg(f"File not found: '{file_path}'.") + if not os.path.isfile(file_path): + _abort_msg(f"File path does not point to file: '{file_path}'.") + + +def _get_audit_authors(): + """Return the list of authors that produced this model.""" + return ( + "Zhang, J.", + "Pei, J.", + "Durham, J.", + "Bos, T.", + "Cong, Q.", + ) + + +def _get_metadata(metadata_file): + """Read csv file with metedata and prepare for next steps.""" + # NEEDS LOTS OF CLEANUP!! + # -> ASSUMED "A" always chain A + df_in = pd.read_csv(metadata_file) + cols = None + mdl_part_txt = " This model is part of" + mdl_af_txt = "Model generated using AlphaFold2" + for idx, row in df_in.iterrows(): + if row[0].startswith("#"): + continue + elif cols is None: + cols = list(row[~row.isna()]) + df = pd.DataFrame(columns=cols) + else: + row_data = [row[0]] + # fix overview entry (ASSUME "A" is always chain 1) + # -> any ',' in oevreview was split into columns + # -> also new-lines missing between lines + # -> and need to remove "This model is part of ..." text + ch1_idx = row.to_list().index("A") + overview = ",".join(row[1:ch1_idx]) + mdl_af_idx = overview.index(mdl_af_txt) + mdl_rel_idx = overview.index(mdl_part_txt) + assert mdl_af_idx < mdl_rel_idx + ov_fixed = overview[:mdl_af_idx] + "\n\n" \ + + overview[mdl_af_idx:mdl_rel_idx] + row_data.append(ov_fixed) + data_end_idx = ch1_idx + len(cols) - 2 + assert data_end_idx <= len(row) + assert not any(row[ch1_idx:data_end_idx].isna()) + row_data.extend(row[ch1_idx:data_end_idx]) + df.loc[idx] = row_data + # sanity checks + assert len(set(df["model id"])) == len(df["model id"]) + assert all(df.alignment_file.str.endswith(".fas")) + return df.set_index("model id") + + +def _get_modeling_description(): + """Fixed text for model creation.""" + return "Model using AlphaFold ('model 3' parameters; pTM monomer version)" \ + " with a 200 residue gap between the two chains, without templates" \ + " and without model relaxation" + +def _get_protocol_steps_and_software(): + """Create the list of protocol steps with software and parameters used.""" + protocol = [] + # MSA step + step = { + "method_type": "coevolution MSA", + "name": None, + "details": "Create paired MSAs for the dimers", + } + step["input"] = "target_sequences" + step["output"] = "MSA" + step["software"] = [] + step["software_parameters"] = {} + protocol.append(step) + + # modelling step + step = { + "method_type": "modeling", + "name": None, + "details": _get_modeling_description(), + } + # get input data + # Must refer to data already in the JSON, so we try keywords + step["input"] = "target_sequences_and_MSA" + # get output data + # Must refer to existing data, so we try keywords + step["output"] = "model" + # get software + step["software"] = [ + { + "name": "AlphaFold", + "classification": "model building", + "description": "Structure prediction", + "citation": ihm.citations.alphafold2, + "location": "https://github.com/deepmind/alphafold", + "type": "package", + "version": "2.0.0", + }] + step["software_parameters"] = {} + protocol.append(step) + + return protocol + + +def _get_title(gene_name_infos): + """Get a title for this modelling experiment.""" + ranged_gene_names = [f"{gn} ({start_pos}-{end_pos})" + for gn, start_pos, end_pos in gene_name_infos] + return f"Predicted interaction between {' and '.join(ranged_gene_names)}" + + +def _get_model_group_name(): + """Get a name for a model group.""" + return None + + +def _get_sequence(chn): + """Get the sequence out of an OST chain incl. '-' for gaps in resnums.""" + # initialise + lst_rn = chn.residues[0].number.num + idx = 1 + sqe = chn.residues[0].one_letter_code + + for res in chn.residues[idx:]: + lst_rn += 1 + while lst_rn != res.number.num: + sqe += "-" + lst_rn += 1 + sqe += res.one_letter_code + return sqe + + +def _check_sequence(up_ac, sequence): + """Verify sequence to only contain standard olc.""" + ns_aa_pos = [] # positions of non-standard amino acids + for i, res in enumerate(sequence): + if res not in "ACDEFGHIKLMNPQRSTVWY": + if res == "U": + _warn_msg( + f"Selenocysteine found at position {i+1} of entry " + + f"'{up_ac}', this residue may be missing in the " + + "model." + ) + ns_aa_pos.append(i) + continue + raise RuntimeError( + "Non-standard aa found in UniProtKB sequence " + + f"for entry '{up_ac}': {res}, position {i+1}" + ) + return ns_aa_pos + + +def _get_n_parse_up_entry(up_ac, up_url): + """Get data for an UniProtKB entry and parse it.""" + # This is a simple parser for UniProtKB txt format, instead of breaking it + # up into multiple functions, we just allow many many branches & statements, + # here. + # pylint: disable=too-many-branches,too-many-statements + data = {} + data["up_organism"] = "" + data["up_sequence"] = "" + data["up_ac"] = up_ac + rspns = requests.get(up_url, timeout=180) + for line in rspns.iter_lines(decode_unicode=True): + if line.startswith("ID "): + sline = line.split() + if len(sline) != 5: + _abort_msg(f"Unusual UniProtKB ID line found:\n'{line}'") + data["up_id"] = sline[1] + elif line.startswith("OX NCBI_TaxID="): + # Following strictly the UniProtKB format: 'OX NCBI_TaxID=<ID>;' + data["up_ncbi_taxid"] = line[len("OX NCBI_TaxID=") : -1] + data["up_ncbi_taxid"] = data["up_ncbi_taxid"].split("{")[0].strip() + elif line.startswith("OS "): + if line[-1] == ".": + data["up_organism"] += line[len("OS ") : -1] + else: + data["up_organism"] += line[len("OS ") : -1] + " " + elif line.startswith("SQ "): + sline = line.split() + if len(sline) != 8: + _abort_msg(f"Unusual UniProtKB SQ line found:\n'{line}'") + data["up_seqlen"] = int(sline[2]) + data["up_crc64"] = sline[6] + elif line.startswith(" "): + sline = line.split() + if len(sline) > 6: + _abort_msg( + "Unusual UniProtKB sequence data line " + + f"found:\n'{line}'" + ) + data["up_sequence"] += "".join(sline) + elif line.startswith("RP "): + if "ISOFORM" in line.upper(): + RuntimeError( + f"First ISOFORM found for '{up_ac}', needs " + "handling." + ) + elif line.startswith("DT "): + # 2012-10-03 + dt_flds = line[len("DT ") :].split(", ") + if dt_flds[1].upper().startswith("SEQUENCE VERSION "): + data["up_last_mod"] = datetime.datetime.strptime( + dt_flds[0], "%d-%b-%Y" + ) + elif dt_flds[1].upper().startswith("ENTRY VERSION "): + data["up_entry_version"] = dt_flds[1][len("ENTRY VERSION ") :] + if data["up_entry_version"][-1] == ".": + data["up_entry_version"] = data["up_entry_version"][:-1] + data["up_entry_version"] = int(data["up_entry_version"]) + elif line.startswith("GN Name="): + data["up_gn"] = line[len("GN Name=") :].split(";")[0] + data["up_gn"] = data["up_gn"].split("{")[0].strip() + + # we have not seen isoforms in the data set, yet, so we just set them to '.' + data["up_isoform"] = None + + if "up_gn" not in data: + _warn_msg( + f"No gene name found for UniProtKB entry '{up_ac}', using " + + "UniProtKB AC instead." + ) + data["up_gn"] = up_ac + if "up_last_mod" not in data: + _abort_msg(f"No sequence version found for UniProtKB entry '{up_ac}'.") + if "up_crc64" not in data: + _abort_msg(f"No CRC64 value found for UniProtKB entry '{up_ac}'.") + if len(data["up_sequence"]) == 0: + _abort_msg(f"No sequence found for UniProtKB entry '{up_ac}'.") + # check that sequence length and CRC64 is correct + if data["up_seqlen"] != len(data["up_sequence"]): + _abort_msg( + "Sequence length of SQ line and sequence data differ for " + + f"UniProtKB entry '{up_ac}': {data['up_seqlen']} != " + + f"{len(data['up_sequence'])}" + ) + data["up_ns_aa"] = _check_sequence(data["up_ac"], data["up_sequence"]) + + if "up_id" not in data: + _abort_msg(f"No ID found for UniProtKB entry '{up_ac}'.") + if "up_ncbi_taxid" not in data: + _abort_msg(f"No NCBI taxonomy ID found for UniProtKB entry '{up_ac}'.") + if len(data["up_organism"]) == 0: + _abort_msg(f"No organism species found for UniProtKB entry '{up_ac}'.") + return data + + +def _fetch_upkb_entry(up_ac): + """Get an UniProtKB entry.""" + return _get_n_parse_up_entry( + up_ac, f"https://rest.uniprot.org/uniprotkb/{up_ac}.txt" + ) + + +def _fetch_unisave_entry(up_ac, version): + """Get an UniSave entry, in contrast to an UniProtKB entry, that allows us + to specify a version.""" + return _get_n_parse_up_entry( + up_ac, + f"https://rest.uniprot.org/unisave/{up_ac}?format=txt&" + + f"versions={version}", + ) + + +def _build_and_check_up_aln(up_data, up_start, up_end, ch_seq): + # return: aln (UP (name: "up_ac|0-based-offset"), CH) if 100% match, + # None else + # up_start and up_end expected to be ready for 0-indexed slicing + # ch_seq expected to contain gaps to cover same length as up_end - up_start + if up_end > len(up_data["up_sequence"]): + # skip UP seq. versions with meaningless lengths + return None + s_up = seq.CreateSequence(f"{up_data['up_ac']}|{up_start}", + up_data["up_sequence"][up_start:up_end]) + s_ch = seq.CreateSequence("ch_seq", ch_seq) + aln = seq.CreateAlignment(s_up, s_ch) + seq_id = seq.alg.SequenceIdentity(aln) # ignores gaps + if seq_id < 100: + return None + else: + return aln + +def _build_and_cut_up_aln(up_data, ch_seq): + # return: aln (UP (name: "up_ac|0-based-offset"), CH) + # cut to remove terminal gaps in CH + s_ch = seq.CreateSequence("ch_seq", ch_seq) + s_up = seq.CreateSequence("up_seq", up_data["up_sequence"]) + aln = seq.alg.SemiGlobalAlign(s_up, s_ch, seq.alg.BLOSUM62)[0] + # cut to part covered by model and rename + offset = aln.sequences[1].first_non_gap + aln.Cut(0, aln.sequences[1].first_non_gap) + aln.Cut(aln.sequences[1].last_non_gap + 1, len(aln)) + aln.SetSequenceName(0, f"{up_data['up_ac']}|{offset}") + return aln + +def _get_upkb_for_sequence(label, up_ac, up_start, up_end, ch_seq, up_id, + up_cache={}): + # check length + if len(ch_seq) != up_end - up_start: + raise RuntimeError(f"BAD RES. COUNT FOR {label}") + # return matching up_data and aln to latest UP + up_data = up_cache.get(up_ac, None) + if up_data is None: + up_data = _fetch_upkb_entry(up_ac) + aln = _build_and_check_up_aln(up_data, up_start, up_end, ch_seq) + if aln is None: + # keep original version in cache and check other versions until hit + up_cache[up_ac + "-latest"] = up_data + while aln is None: + if up_data["up_entry_version"] > 1: + up_data = _fetch_unisave_entry( + up_ac, up_data["up_entry_version"] - 1 + ) + aln = _build_and_check_up_aln(up_data, up_start, up_end, ch_seq) + else: + raise RuntimeError( + f"Sequences not equal from file: {ch_seq}, from UniProtKB: " + f"{up_data['up_sequence']} ({label}), checked entire entry " + "history." + ) + # check UP ID + if up_id != up_data["up_id"]: + raise RuntimeError(f"UP ID MISMATCH for {label}; {up_id} vs {up_data['up_id']}") + # keep cached for matched data + up_cache[up_ac] = up_data + # align to latest sequence if needed + if up_ac + "-latest" in up_cache: + aln = _build_and_cut_up_aln(up_cache[up_ac + "-latest"], ch_seq) + seq_id = seq.alg.SequenceIdentity(aln) # ignores gaps + if len(aln) != up_end - up_start or seq_id < 95: + raise RuntimeError( + f"Failed to align {label} to latest {up_ac}!" + f" Lengths {len(aln)} vs {up_end - up_start};" + f" seq. id {seq_id}." + ) + return up_data, aln + + +def _get_entities(pdb_file, up_infos): + """Gather data for the mmCIF (target) entities.""" + # up_infos as dict {ch_name: (up_ac, up_start_idx, up_end_idx, up_id)} + # -> [up_start_idx:up_end_idx] meant to be for slicing up_sequence + entities = [] + _check_file(pdb_file) + ost_ent = io.LoadPDB(pdb_file) + # check assumption of dimer + if ost_ent.chain_count != len(up_infos): + raise RuntimeError(f"UNEXPECTED CHAIN COUNT IN {pdb_file}") + # check assumption that none of the PDB files have bfactors + unique_b_factors = sorted(set(a.b_factor for a in ost_ent.atoms)) + if unique_b_factors != [0.0]: + raise RuntimeError(f"B-FACTORS SPOTTED IN {pdb_file}: " + f"{unique_b_factors}") + already_seen = [] + for chn in ost_ent.chains: + cif_ent = {} + ch_label = f"{pdb_file}|CH-{chn.name}" + up_ac, up_start_idx, up_end_idx, up_id = up_infos[chn.name] + up_key = (up_ac, up_start_idx, up_end_idx) + sqe_no_gaps = "".join([res.one_letter_code for res in chn.residues]) + sqe_gaps = _get_sequence(chn) + try: + e_idx = already_seen.index(up_key) + except ValueError: + pass + else: + if sqe_no_gaps != entities[e_idx]["pdb_sequence"]: + _abort_msg( + "Sequences are different for two chains of the same " + "UniProtKB AC. This case is not implemented, yet." + ) + entities[e_idx]["pdb_chain_id"].append(chn.name) + continue + already_seen.append(up_key) + # note: upkb is for matching seq. version, aln is for latest seq. + upkb, up_aln = _get_upkb_for_sequence( + ch_label, up_ac, up_start_idx, up_end_idx, sqe_gaps, + up_id, up_cache + ) + cif_ent["pdb_sequence"] = sqe_no_gaps + cif_ent["pdb_seqlen"] = len(sqe_no_gaps) + cif_ent["pdb_chain_id"] = [chn.name] + cif_ent["description"] = ( + f"{upkb['up_organism']} {upkb['up_gn']} ({upkb['up_ac']}; " + f"{up_start_idx + 1} - {up_end_idx})" + ) + cif_ent["up_aln"] = up_aln + # 1-indexed positions for closed interval + cif_ent["up_start_pos"] = up_start_idx + 1 + cif_ent["up_end_pos"] = up_end_idx + # alignment didn't check starting position in UP + if chn.residues[0].number.num != cif_ent["up_start_pos"]: + print(f"UNEXPECTED STARTING RESNUM IN {ch_label}") + # mapping between seq_id and auth_seq_id + # -> assume same for all chains of this entity + # (trivial here as hetero-dimer) + cif_ent["auth_seq_id_map"] = { + idx+1: res.number.num for idx, res in enumerate(chn.residues) + } + cif_ent.update(upkb) + entities.append(cif_ent) + return entities, ost_ent + + +def _get_scores(data, acc_path, cp_name, aln_name): + """Check that all files needed to process this model are present.""" + _check_file(acc_path) + with zipfile.ZipFile(acc_path) as zf: + if len(zf.namelist()) > 2: + print(f"TOO MANY FILES IN ACC {acc_path}") + if cp_name not in zf.namelist(): + raise RuntimeError(f"MISSING NPZ FILE {acc_path}") + if aln_name not in zf.namelist(): + raise RuntimeError(f"MISSING ALN FILE {acc_path}") + aln_data = zf.open(aln_name).read() + # NOTE: this also checks that all sequences in FASTA have same length + aln = io.AlignmentFromString(aln_data, "fasta") + cp_data = np.load(zf.open(cp_name)) + # check aln data + # -> should match combined length of gapless chain sequences + combined_seq = "".join(trg_ent["pdb_sequence"] \ + for trg_ent in data["target_entities"]) + if str(aln.sequences[0]) != combined_seq: + raise RuntimeError(f"BAD ALN SEQ {acc_path}") + # if aln.sequence_count < 10: + # print("SHALLOW ALN", acc_path, aln.sequence_count) + # # not an issue really, just curious + # check cp data + # -> expected pLDDT vector and PAE/CP matrices + # -> expected to either have one off diagonal or full matrix + seq_lens = [trg_ent["pdb_seqlen"] for trg_ent in data["target_entities"]] + assert len(seq_lens) == 2 # only dimers supported here + sum_lens = sum(seq_lens) + exp_shape_offdiag = (seq_lens[0], seq_lens[1]) + exp_shape_full = (sum_lens, sum_lens) + if len(cp_data) != 3: + print(f"UNEXPECTED NUMBER OF ITEMS IN NPZ FILE {acc_path}") + if "contact_prob" not in cp_data: + raise RuntimeError(f"MISSING CP IN NPZ FILE {acc_path}") + cp_matrix = cp_data["contact_prob"] + if "predicted_aligned_error" not in cp_data: + raise RuntimeError(f"MISSING PAE IN NPZ FILE {acc_path}") + pae_matrix = cp_data["predicted_aligned_error"] + if cp_matrix.shape == exp_shape_full: + # cut matrices + cp_matrix = cp_matrix[:seq_lens[0], seq_lens[0]:] + pae_matrix = pae_matrix[:seq_lens[0], seq_lens[0]:] + elif cp_matrix.shape != exp_shape_offdiag: + raise RuntimeError(f"BAD SHAPE OF CP DATA {acc_path}") + if pae_matrix.shape != cp_matrix.shape: + raise RuntimeError(f"BAD SHAPE OF PAE DATA {acc_path}") + if "plddt" not in cp_data: + raise RuntimeError(f"MISSING PLDDT IN NPZ FILE {acc_path}") + elif cp_data["plddt"].shape != (sum_lens, ): + raise RuntimeError(f"BAD SHAPE OF PLDDT DATA {acc_path}") + # update data + data["plddt"] = cp_data["plddt"] + data["pae"] = pae_matrix + data["contact_prob"] = cp_matrix + data["aln_data"] = aln_data + + +def _get_modelcif_entities(target_ents, asym_units, system): + """Create ModelCIF entities and asymmetric units.""" + for cif_ent in target_ents: + mdlcif_ent = modelcif.Entity( + # NOTE: here pdb_sequence is what has actually been modelled + # -> compared to UP this contains gaps! + cif_ent["pdb_sequence"], + description=cif_ent["description"], + source=ihm.source.Natural( + ncbi_taxonomy_id=cif_ent["up_ncbi_taxid"], + scientific_name=cif_ent["up_organism"], + ), + references=[ + modelcif.reference.UniProt( + cif_ent["up_id"], + cif_ent["up_ac"], + align_begin=cif_ent["up_start_pos"], + align_end=cif_ent["up_end_pos"], + isoform=cif_ent["up_isoform"], + ncbi_taxonomy_id=cif_ent["up_ncbi_taxid"], + organism_scientific=cif_ent["up_organism"], + sequence_version_date=cif_ent["up_last_mod"], + sequence_crc64=cif_ent["up_crc64"], + ) + ], + ) + for pdb_chain_id in cif_ent["pdb_chain_id"]: + asym_units[pdb_chain_id] = modelcif.AsymUnit( + mdlcif_ent, auth_seq_id_map=cif_ent["auth_seq_id_map"] + ) + system.target_entities.append(mdlcif_ent) + + +def _get_assoc_aln_file(fle_path): + """Generate a modelcif.associated.File object pointing to FASTA formatted + file containing MSA. + """ + cfile = modelcif.associated.File( + fle_path, + details="Paired MSAs" + ) + cfile.file_format = "fasta" + cfile.file_content = "multiple sequence alignments" + return cfile + + +def _get_associated_files(entry_id, mdl_name, add_files): + """Create entry for associated files.""" + # extract local pairwise into extra file + ac_file = f"{mdl_name}_local_pairwise_qa.cif" + arc_files = [ + modelcif.associated.LocalPairwiseQAScoresFile( + ac_file, + categories=["_ma_qa_metric_local_pairwise"], + copy_categories=["_ma_qa_metric"], + entry_id=entry_id, + entry_details="This file is an associated file consisting " + + "of local pairwise QA metrics. This is a partial mmCIF " + + "file and can be validated by merging with the main " + + "mmCIF file containing the model coordinates and other " + + "associated data.", + details="Predicted aligned error and contact probability", + ) + ] + # add any extra files if needed + if add_files: + arc_files.extend(add_files) + # package all into zip file + return modelcif.associated.Repository( + "", + [modelcif.associated.ZipFile(f"{mdl_name}.zip", files=arc_files)], + ) + # NOTE: by convention MA expects zip file with same name as model-cif + + +def _assemble_modelcif_software(soft_dict): + """Create a modelcif.Software instance from dictionary.""" + return modelcif.Software( + soft_dict["name"], + soft_dict["classification"], + soft_dict["description"], + soft_dict["location"], + soft_dict["type"], + soft_dict["version"], + citation=soft_dict["citation"], + ) + + +def _get_modelcif_protocol_software(js_step): + """Assemble software entries for a ModelCIF protocol step.""" + if js_step["software"]: + if len(js_step["software"]) == 1: + sftwre = _assemble_modelcif_software(js_step["software"][0]) + else: + sftwre = [] + for sft in js_step["software"]: + sftwre.append(_assemble_modelcif_software(sft)) + sftwre = modelcif.SoftwareGroup(elements=sftwre) + if js_step["software_parameters"]: + params = [] + for key, val in js_step["software_parameters"].items(): + params.append(modelcif.SoftwareParameter(key, val)) + if isinstance(sftwre, modelcif.SoftwareGroup): + sftwre.parameters = params + else: + sftwre = modelcif.SoftwareGroup( + elements=(sftwre,), parameters=params + ) + return sftwre + return None + + +def _get_modelcif_protocol_data(data_label, target_entities, aln_data, model): + """Assemble data for a ModelCIF protocol step.""" + if data_label == "target_sequences": + data = modelcif.data.DataGroup(target_entities) + elif data_label == "MSA": + data = aln_data + elif data_label == "target_sequences_and_MSA": + data = modelcif.data.DataGroup(target_entities) + data.append(aln_data) + elif data_label == "model": + data = model + else: + raise RuntimeError(f"Unknown protocol data: '{data_label}'") + return data + + +def _get_modelcif_protocol(protocol_steps, target_entities, aln_data, model): + """Create the protocol for the ModelCIF file.""" + protocol = modelcif.protocol.Protocol() + for js_step in protocol_steps: + sftwre = _get_modelcif_protocol_software(js_step) + input_data = _get_modelcif_protocol_data( + js_step["input"], target_entities, aln_data, model + ) + output_data = _get_modelcif_protocol_data( + js_step["output"], target_entities, aln_data, model + ) + + protocol.steps.append( + modelcif.protocol.Step( + input_data=input_data, + output_data=output_data, + name=js_step["name"], + details=js_step["details"], + software=sftwre, + ) + ) + protocol.steps[-1].method_type = js_step["method_type"] + return protocol + + +def _compress_cif_file(cif_file): + """Compress cif file and delete original.""" + with open(cif_file, "rb") as f_in: + with gzip.open(cif_file + ".gz", "wb") as f_out: + shutil.copyfileobj(f_in, f_out) + os.remove(cif_file) + + +def _package_associated_files(repo): + """Compress associated files into single zip file and delete original.""" + # zip settings tested for good speed vs compression + for archive in repo.files: + with zipfile.ZipFile(archive.path, "w", zipfile.ZIP_BZIP2) as cif_zip: + for zfile in archive.files: + cif_zip.write(zfile.path, arcname=zfile.path) + os.remove(zfile.path) + + +def _store_as_modelcif( + data_json, ost_ent, out_dir, mdl_name, compress, add_files +): + """Mix all the data into a ModelCIF file.""" + print(" generating ModelCIF objects...", end="") + pstart = timer() + # create system to gather all the data + system = modelcif.System( + title=data_json["title"], + id=data_json["mdl_id"].upper(), + model_details=data_json["model_details"], + ) + + # add primary citation (HC here but could also fetch via from_pubmed_id) + system.citations.append(ihm.Citation( + pmid="36261849", + title="Computed cancer interactome explains the effects of somatic " + "mutations in cancers.", + journal="Protein Sci", + volume=31, + page_range="e4479", + year=2022, + authors=['Zhang, J.', 'Pei, J.', 'Durham, J.', 'Bos, T.', 'Cong, Q.'], + doi="10.1002/pro.4479", + is_primary=True, + )) + + # create target entities, references, source, asymmetric units & assembly + # create an asymmetric unit and an entity per target sequence + asym_units = {} + _get_modelcif_entities( + data_json["target_entities"], + asym_units, + system, + ) + + # audit_authors + system.authors.extend(data_json["audit_authors"]) + + # set up the model to produce coordinates + mdl_list_name = "Model 3" # fixed set of params used here + model = _OST2ModelCIF( + assembly=modelcif.Assembly(asym_units.values()), + asym=asym_units, + ost_entity=ost_ent, + scores_json=data_json, + name=mdl_list_name, + ) + print(f" ({timer()-pstart:.2f}s)") + print(" processing QA scores...", end="", flush=True) + pstart = timer() + model.add_scores() + print(f" ({timer()-pstart:.2f}s)") + + system.model_groups.append( + modelcif.model.ModelGroup([model], name=data_json["model_group_name"]) + ) + + # handle additional files + system.repositories.append( + _get_associated_files(system.id, mdl_name, add_files) + ) + + # prepare aln_data info + aln_files = [f for f in add_files \ + if f.file_content == "multiple sequence alignments"] + assert len(aln_files) == 1 # no support for multiple one atm + aln_file_name = aln_files[0].path + aln_data = modelcif.data.Data( + "Paired MSA for the dimer", + f"MSA stored as {aln_file_name} in accompanying data" + ) + + system.protocols.append( + _get_modelcif_protocol( + data_json["protocol"], + system.target_entities, + aln_data, + model, + ) + ) + + # write modelcif System to file + print(" write to disk...", end="", flush=True) + pstart = timer() + # NOTE: this will dump PAE on path provided in add_scores + # -> hence we cheat by changing path and back while being exception-safe... + # -> also we need to write aln file to have it in zip file with rest + oldpwd = os.getcwd() + os.chdir(out_dir) + mdl_fle = f"{mdl_name}.cif" + try: + with open(mdl_fle, "w", encoding="ascii") as mmcif_fh: + modelcif.dumper.write(mmcif_fh, [system]) + with open(aln_file_name, "wb") as fh: + fh.write(data_json["aln_data"]) + _package_associated_files(system.repositories[0]) + if compress: + _compress_cif_file(mdl_fle) + mdl_fle += ".gz" + # also output alignments to latest UP + for cif_ent in data_json["target_entities"]: + ch_names = "-".join(chn for chn in cif_ent["pdb_chain_id"]) + up_aln_file_name = f"{mdl_name}-UP-ALN-{ch_names}.fasta" + io.SaveAlignment(cif_ent["up_aln"], up_aln_file_name) + finally: + os.chdir(oldpwd) + print(f" ({timer()-pstart:.2f}s)") + return os.path.join(out_dir, mdl_fle) + + +def _create_interaction_json(): + """Create a dictionary (mimicking JSON) that contains data which is the same + for all models.""" + data = {} + data["audit_authors"] = _get_audit_authors() + data["protocol"] = _get_protocol_steps_and_software() + return data + + +def _create_model_json(data, pdb_file, metadata): + """Create a dictionary (mimicking JSON) that contains all the data.""" + up_infos = { + metadata[f"chain{ch_idx}"]: ( + metadata[f"chain{ch_idx}_UniProtAC"], + int(metadata[f"chain{ch_idx}_startPosi"]) - 1, + int(metadata[f"chain{ch_idx}_endPosi"]), + metadata[f"chain{ch_idx}_UniProtKB"], + ) for ch_idx in [1, 2] + } + data["target_entities"], ost_ent = _get_entities(pdb_file, up_infos) + gns = [(i["up_gn"], i["up_start_pos"], i["up_end_pos"]) \ + for i in data["target_entities"]] + data["title"] = _get_title(gns) + data["model_details"] = metadata.overview + data["model_group_name"] = _get_model_group_name() + return ost_ent + + +def _translate2modelcif(mdl_id, metadata, opts): + """Convert a PDB file with its accompanying data to ModelCIF.""" + pdb_fle = os.path.join(opts.model_dir, mdl_id + ".pdb") + acc_path = os.path.join(opts.accompanying_data_dir, + mdl_id + "_accompanying_data.zip") + + # gather data into JSON-like structure + print(" preparing data...", end="") + pstart = timer() + + mdlcf_json = _create_interaction_json() + mdlcf_json["mdl_id"] = mdl_id + + ost_ent = _create_model_json(mdlcf_json, pdb_fle, metadata) + + # read quality scores from JSON file + _get_scores( + mdlcf_json, acc_path, + metadata.contact_probility_file, + metadata.alignment_file + ) + print(f" ({timer()-pstart:.2f}s)") + add_files = [_get_assoc_aln_file(metadata.alignment_file)] + mdl_path = _store_as_modelcif( + mdlcf_json, + ost_ent, + opts.out_dir, + mdl_id, + opts.compress, + add_files, + ) + # check if result can be read and has expected seq. + ent = io.LoadMMCIF(mdl_path) + exp_seqs = [trg_ent["pdb_sequence"] \ + for trg_ent in mdlcf_json["target_entities"]] + assert ent.chain_count == len(exp_seqs), f"Bad chain count {mdl_id}" + ent_seq = "".join(res.one_letter_code for res in ent.residues) + assert ent_seq == "".join(exp_seqs), f"Bad seq. {mdl_id}" + + +def _main(): + """Run as script.""" + opts = _parse_args() + + # parse/fetch global data + metadata_full = _get_metadata(opts.metadata_file) + if opts.compress: + cifext = "cif.gz" + else: + cifext = "cif" + print(f"Working on {opts.metadata_file}...") + + # iterate models + # TEST: selected models + # for mdl_id in ["O00329-D1_P27986-D2", "O14602_P47813"]: + for mdl_id in ["O00329-D1_P27986-D2", "O14602_P47813", + "O75376-D12_Q14995-D5", "Q8NFD5-D13_Q92925-D2", + "P20248-D2_Q09472-D14", "O14744-D1_Q9Y618-D10", + "O00257-D2_Q6W2J9-D8"]: + metadata = metadata_full.loc[mdl_id] + # for mdl_id, metadata in metadata.iterrows(): + if os.path.exists(os.path.join(opts.out_dir, f"{mdl_id}.{cifext}")): + print(f" {mdl_id} already done...") + continue + print(f" translating {mdl_id}...") + pdb_start = timer() + _translate2modelcif(mdl_id, metadata, opts) + print(f" ... done with {mdl_id} ({timer()-pdb_start:.2f}s).") + + print(f"... done with {opts.metadata_file}.") + + +if __name__ == "__main__": + _main() + +# LocalWords: aa pdb diff --git a/pyproject.toml b/pyproject.toml index f3328b597187d9a324fbb8a743f5c6c173f72977..33018daba193de3ac421d4ea6d153a058b7b6719 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -8,7 +8,7 @@ reports='no' # A comma-separated list of package or module names from where C extensions may # be loaded. Extensions are loading into the active Python interpreter and may # run arbitrary code -extension-pkg-allow-list='rapidjson +extension-pkg-allow-list='rapidjson' [tool.pylint.FORMAT] max-line-length=80 diff --git a/validation/Dockerfile b/validation/Dockerfile index 7ec976fa46679088e7ac4d19cf6cd89245a48892..3f20534318c3205616c989434554e9fb5b4e537f 100644 --- a/validation/Dockerfile +++ b/validation/Dockerfile @@ -29,6 +29,7 @@ LABEL vendor3="Biozentrum - University of Basel (biozentrum.unibas.ch)" ## Install the RCSB CPP Dict Suite (only the binaries we need) WORKDIR ${SRC_DIR} +COPY requirements.txt ${SRC_DIR} RUN set -e pipefail; \ export DICT_PACK_SRC_DIR="${SRC_DIR}/cpp-dict-pack.git"; \ apk update; \ @@ -56,6 +57,7 @@ RUN set -e pipefail; \ /usr/local/bin/python -m pip install --upgrade pip; \ /usr/local/bin/python -m pip install mmcif==${VERSION_PY_MMCIF} \ python-rapidjson; \ + /usr/local/bin/python -m pip install -r requirements.txt; \ # ## Clean up/ remove unnecessary stuff apk del abuild binutils bison build-base cmake flex git gcc \ diff --git a/validation/requirements.txt b/validation/requirements.txt new file mode 100644 index 0000000000000000000000000000000000000000..a5f0a8bb8d844b3fb52fb55f783610e4dc860b75 --- /dev/null +++ b/validation/requirements.txt @@ -0,0 +1,2 @@ +python-rapidjson==1.9 +validators==0.20.0 diff --git a/validation/validate-mmcif-file.py b/validation/validate-mmcif-file.py index ad9fab4f9d35ba78aa461b657725d04f3db7b0fc..f5aa7bfabe0d42b9a4b72d45233eea46fa35b1c4 100755 --- a/validation/validate-mmcif-file.py +++ b/validation/validate-mmcif-file.py @@ -20,7 +20,9 @@ import sys import tempfile import zipfile +from validators import url as is_url import rapidjson as json +import requests from mmcif.api.DataCategory import DataCategory @@ -215,12 +217,51 @@ def _get_entry_id(cif_datablock, entry_id_map, datablock_idx): entry_id_map[row[eidx]] = datablock_idx +def _download_file(file_url): + """Download a file into a temporary file. Mark for deletion on + termination""" + rspns = requests.get(file_url, stream=True, timeout=600) + if rspns.status_code != 200: + raise RuntimeError(f"File not found by URL '{file_url}'.") + + dlf = tempfile.TemporaryFile() + for chunk in rspns.iter_content(chunk_size=1024): + dlf.write(chunk) + dlf.seek(0) + + return dlf + + +def _get_assoc_obj(file_or_url, assoc_dir): + """Get a path to an associated file. Will download from internet if path + is a URL. Downloaded files are automatically hooked up for deletion after + the script terminates.""" + if assoc_dir is None or not os.path.exists( + os.path.join(assoc_dir, file_or_url) + ): + if is_url(file_or_url): + return _download_file(file_or_url) + + raise RuntimeError( + "Associated file path does not point to actual file or URL: " + + f"'{assoc_dir}/{file_or_url}'" + ) + + return os.path.join(assoc_dir, file_or_url) + + def _unzip_arc_cif(arc_file, cif_file, assoc_dir): """Extract a cif file from a ZIP archive.""" assoc_data = [] - with zipfile.ZipFile(os.path.join(assoc_dir, arc_file)) as arc_zip: + assoc_obj = _get_assoc_obj(arc_file, assoc_dir) + with zipfile.ZipFile(assoc_obj) as arc_zip: with TextIOWrapper(arc_zip.open(cif_file), encoding="utf-8") as cif_fh: assoc_data = _read_mmcif(cif_fh) + # in case assoc_obj is a temporary file, we need to close + try: + assoc_obj.close() + except AttributeError: + pass return assoc_data @@ -256,6 +297,9 @@ def _get_associated_files(model_cif_file, assoc_dir): ) if row[idxs["file_format"]] != "cif": continue + # this should be easy to make reading URLs, using + # _get_assoc_obj(row[idxs["file_url"]], assoc_dir) but for now + # I have not seen the use case (no web server at hand for testing) data = _read_mmcif(os.path.join(assoc_dir, row[idxs["file_url"]])) assoc_files.append((data, row[idxs["entry_id"]])) # make sure entry_id is matching in associated file!