solara-ui 1.31.0__py2.py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- prefix/etc/jupyter/jupyter_notebook_config.d/solara.json +7 -0
- prefix/etc/jupyter/jupyter_server_config.d/solara.json +7 -0
- solara/__init__.py +124 -0
- solara/__main__.py +734 -0
- solara/alias.py +6 -0
- solara/autorouting.py +546 -0
- solara/cache.py +303 -0
- solara/checks.html +71 -0
- solara/checks.py +224 -0
- solara/comm.py +28 -0
- solara/components/__init__.py +59 -0
- solara/components/alert.py +155 -0
- solara/components/applayout.py +393 -0
- solara/components/button.py +85 -0
- solara/components/card.py +87 -0
- solara/components/checkbox.py +50 -0
- solara/components/code_highlight_css.py +11 -0
- solara/components/code_highlight_css.vue +63 -0
- solara/components/columns.py +159 -0
- solara/components/component_vue.py +110 -0
- solara/components/cross_filter.py +335 -0
- solara/components/dataframe.py +546 -0
- solara/components/datatable.py +221 -0
- solara/components/datatable.vue +175 -0
- solara/components/details.py +21 -0
- solara/components/download.vue +35 -0
- solara/components/echarts.py +75 -0
- solara/components/echarts.vue +128 -0
- solara/components/figure_altair.py +39 -0
- solara/components/file_browser.py +182 -0
- solara/components/file_download.py +199 -0
- solara/components/file_drop.py +139 -0
- solara/components/file_drop.vue +83 -0
- solara/components/file_list_widget.vue +78 -0
- solara/components/head.py +27 -0
- solara/components/head_tag.py +49 -0
- solara/components/head_tag.vue +60 -0
- solara/components/image.py +173 -0
- solara/components/input.py +436 -0
- solara/components/link.py +55 -0
- solara/components/markdown.py +378 -0
- solara/components/markdown_editor.py +25 -0
- solara/components/markdown_editor.vue +362 -0
- solara/components/matplotlib.py +74 -0
- solara/components/meta.py +47 -0
- solara/components/misc.py +333 -0
- solara/components/pivot_table.py +258 -0
- solara/components/pivot_table.vue +158 -0
- solara/components/progress.py +47 -0
- solara/components/select.py +182 -0
- solara/components/select.vue +27 -0
- solara/components/slider.py +442 -0
- solara/components/slider_date.vue +56 -0
- solara/components/spinner-solara.vue +105 -0
- solara/components/spinner.py +30 -0
- solara/components/sql_code.py +33 -0
- solara/components/sql_code.vue +128 -0
- solara/components/style.py +105 -0
- solara/components/switch.py +68 -0
- solara/components/tab_navigation.py +37 -0
- solara/components/title.py +90 -0
- solara/components/title.vue +38 -0
- solara/components/togglebuttons.py +200 -0
- solara/components/tooltip.py +61 -0
- solara/datatypes.py +143 -0
- solara/express.py +241 -0
- solara/hooks/__init__.py +4 -0
- solara/hooks/dataframe.py +99 -0
- solara/hooks/misc.py +263 -0
- solara/hooks/use_reactive.py +129 -0
- solara/hooks/use_thread.py +129 -0
- solara/kitchensink.py +8 -0
- solara/lab/__init__.py +34 -0
- solara/lab/components/__init__.py +6 -0
- solara/lab/components/chat.py +203 -0
- solara/lab/components/confirmation_dialog.py +163 -0
- solara/lab/components/cross_filter.py +7 -0
- solara/lab/components/input_date.py +298 -0
- solara/lab/components/menu.py +181 -0
- solara/lab/components/menu.vue +38 -0
- solara/lab/components/tabs.py +274 -0
- solara/lab/components/theming.py +98 -0
- solara/lab/components/theming.vue +72 -0
- solara/lab/hooks/__init__.py +0 -0
- solara/lab/hooks/dataframe.py +12 -0
- solara/lab/toestand.py +3 -0
- solara/lab/utils/__init__.py +2 -0
- solara/lab/utils/cookies.py +5 -0
- solara/lab/utils/dataframe.py +115 -0
- solara/lab/utils/headers.py +5 -0
- solara/layout.py +44 -0
- solara/lifecycle.py +46 -0
- solara/minisettings.py +133 -0
- solara/py.typed +0 -0
- solara/reactive.py +93 -0
- solara/routing.py +268 -0
- solara/scope/__init__.py +88 -0
- solara/scope/types.py +55 -0
- solara/server/__init__.py +0 -0
- solara/server/app.py +491 -0
- solara/server/assets/custom.css +1 -0
- solara/server/assets/custom.js +1 -0
- solara/server/assets/favicon.png +0 -0
- solara/server/assets/favicon.svg +5 -0
- solara/server/assets/style.css +1665 -0
- solara/server/assets/theme-dark.css +437 -0
- solara/server/assets/theme-light.css +420 -0
- solara/server/assets/theme.js +3 -0
- solara/server/cdn_helper.py +77 -0
- solara/server/esm.py +69 -0
- solara/server/fastapi.py +5 -0
- solara/server/flask.py +286 -0
- solara/server/jupyter/__init__.py +2 -0
- solara/server/jupyter/cdn_handler.py +28 -0
- solara/server/jupyter/server_extension.py +29 -0
- solara/server/jupytertools.py +46 -0
- solara/server/kernel.py +338 -0
- solara/server/kernel_context.py +357 -0
- solara/server/patch.py +552 -0
- solara/server/reload.py +242 -0
- solara/server/server.py +456 -0
- solara/server/settings.py +215 -0
- solara/server/shell.py +251 -0
- solara/server/starlette.py +601 -0
- solara/server/static/ansi.js +270 -0
- solara/server/static/highlight-dark.css +82 -0
- solara/server/static/highlight.css +43 -0
- solara/server/static/main-vuetify.js +260 -0
- solara/server/static/main.js +163 -0
- solara/server/static/solara_bootstrap.py +129 -0
- solara/server/static/sun.svg +23 -0
- solara/server/static/webworker.js +42 -0
- solara/server/telemetry.py +212 -0
- solara/server/templates/index.html.j2 +1 -0
- solara/server/templates/loader-plain.css +11 -0
- solara/server/templates/loader-plain.html +20 -0
- solara/server/templates/loader-solara.css +111 -0
- solara/server/templates/loader-solara.html +40 -0
- solara/server/templates/plain.html +82 -0
- solara/server/templates/solara.html.j2 +446 -0
- solara/server/threaded.py +75 -0
- solara/server/utils.py +30 -0
- solara/server/websocket.py +45 -0
- solara/settings.py +56 -0
- solara/tasks.py +837 -0
- solara/template/button.py +16 -0
- solara/template/markdown.py +42 -0
- solara/template/portal/.flake8 +6 -0
- solara/template/portal/.pre-commit-config.yaml +28 -0
- solara/template/portal/LICENSE +21 -0
- solara/template/portal/Procfile +7 -0
- solara/template/portal/mypy.ini +3 -0
- solara/template/portal/pyproject.toml +26 -0
- solara/template/portal/solara_portal/__init__.py +4 -0
- solara/template/portal/solara_portal/components/__init__.py +2 -0
- solara/template/portal/solara_portal/components/article.py +28 -0
- solara/template/portal/solara_portal/components/data.py +28 -0
- solara/template/portal/solara_portal/components/header.py +6 -0
- solara/template/portal/solara_portal/components/layout.py +6 -0
- solara/template/portal/solara_portal/content/articles/equis-in-vidi.md +85 -0
- solara/template/portal/solara_portal/content/articles/substiterat-vati.md +70 -0
- solara/template/portal/solara_portal/data.py +60 -0
- solara/template/portal/solara_portal/pages/__init__.py +67 -0
- solara/template/portal/solara_portal/pages/article/__init__.py +26 -0
- solara/template/portal/solara_portal/pages/tabular.py +29 -0
- solara/template/portal/solara_portal/pages/viz/__init__.py +70 -0
- solara/template/portal/solara_portal/pages/viz/overview.py +14 -0
- solara/test/__init__.py +0 -0
- solara/test/pytest_plugin.py +697 -0
- solara/toestand.py +772 -0
- solara/util.py +308 -0
- solara/website/__init__.py +0 -0
- solara/website/assets/custom.css +468 -0
- solara/website/assets/images/logo-small.png +0 -0
- solara/website/assets/images/logo.svg +17 -0
- solara/website/assets/images/logo_white.svg +50 -0
- solara/website/assets/theme.js +8 -0
- solara/website/components/__init__.py +5 -0
- solara/website/components/algolia.vue +24 -0
- solara/website/components/algolia_api.vue +187 -0
- solara/website/components/docs.py +118 -0
- solara/website/components/header.py +72 -0
- solara/website/components/hero.py +15 -0
- solara/website/components/mailchimp.py +12 -0
- solara/website/components/mailchimp.vue +47 -0
- solara/website/components/markdown.py +30 -0
- solara/website/components/notebook.py +171 -0
- solara/website/pages/__init__.py +575 -0
- solara/website/pages/apps/__init__.py +16 -0
- solara/website/pages/apps/authorization/__init__.py +119 -0
- solara/website/pages/apps/authorization/admin.py +12 -0
- solara/website/pages/apps/authorization/users.py +12 -0
- solara/website/pages/apps/jupyter-dashboard-1.py +116 -0
- solara/website/pages/apps/layout-demo.py +40 -0
- solara/website/pages/apps/multipage/__init__.py +38 -0
- solara/website/pages/apps/multipage/page1.py +26 -0
- solara/website/pages/apps/multipage/page2.py +34 -0
- solara/website/pages/apps/scatter.py +136 -0
- solara/website/pages/apps/scrolling.py +63 -0
- solara/website/pages/apps/tutorial-streamlit.py +18 -0
- solara/website/pages/changelog/__init__.py +8 -0
- solara/website/pages/changelog/changelog.md +204 -0
- solara/website/pages/contact/__init__.py +8 -0
- solara/website/pages/contact/contact.md +17 -0
- solara/website/pages/doc_use_download.py +85 -0
- solara/website/pages/documentation/__init__.py +184 -0
- solara/website/pages/documentation/advanced/__init__.py +9 -0
- solara/website/pages/documentation/advanced/content/00-overview.md +1 -0
- solara/website/pages/documentation/advanced/content/10-howto/00-overview.md +6 -0
- solara/website/pages/documentation/advanced/content/10-howto/10-multipage.md +196 -0
- solara/website/pages/documentation/advanced/content/10-howto/20-layout.md +125 -0
- solara/website/pages/documentation/advanced/content/10-howto/30-testing.md +162 -0
- solara/website/pages/documentation/advanced/content/10-howto/31-debugging.md +69 -0
- solara/website/pages/documentation/advanced/content/10-howto/40-embed.md +49 -0
- solara/website/pages/documentation/advanced/content/10-howto/50-ipywidget_libraries.md +124 -0
- solara/website/pages/documentation/advanced/content/15-reference/00-overview.md +3 -0
- solara/website/pages/documentation/advanced/content/15-reference/40-static_files.md +31 -0
- solara/website/pages/documentation/advanced/content/15-reference/41-asset-files.md +36 -0
- solara/website/pages/documentation/advanced/content/15-reference/60-static-site-generation.md +59 -0
- solara/website/pages/documentation/advanced/content/15-reference/70-search.md +34 -0
- solara/website/pages/documentation/advanced/content/15-reference/80-reloading.md +34 -0
- solara/website/pages/documentation/advanced/content/15-reference/90-notebook-support.md +7 -0
- solara/website/pages/documentation/advanced/content/15-reference/95-caching.md +148 -0
- solara/website/pages/documentation/advanced/content/20-understanding/00-introduction.md +10 -0
- solara/website/pages/documentation/advanced/content/20-understanding/05-ipywidgets.md +35 -0
- solara/website/pages/documentation/advanced/content/20-understanding/06-ipyvuetify.md +42 -0
- solara/website/pages/documentation/advanced/content/20-understanding/10-reacton.md +28 -0
- solara/website/pages/documentation/advanced/content/20-understanding/12-reacton-basics.md +108 -0
- solara/website/pages/documentation/advanced/content/20-understanding/15-anatomy.md +23 -0
- solara/website/pages/documentation/advanced/content/20-understanding/17-rules-of-hooks.md +7 -0
- solara/website/pages/documentation/advanced/content/20-understanding/18-containers.md +166 -0
- solara/website/pages/documentation/advanced/content/20-understanding/20-solara.md +18 -0
- solara/website/pages/documentation/advanced/content/20-understanding/40-routing.md +240 -0
- solara/website/pages/documentation/advanced/content/20-understanding/50-solara-server.md +97 -0
- solara/website/pages/documentation/advanced/content/20-understanding/60-voila.md +12 -0
- solara/website/pages/documentation/advanced/content/30-enterprise/00-overview.md +1 -0
- solara/website/pages/documentation/advanced/content/30-enterprise/10-oauth.md +171 -0
- solara/website/pages/documentation/advanced/content/40-development/00-overview.md +0 -0
- solara/website/pages/documentation/advanced/content/40-development/01-contribute.md +45 -0
- solara/website/pages/documentation/advanced/content/40-development/10-setup.md +76 -0
- solara/website/pages/documentation/api/__init__.py +19 -0
- solara/website/pages/documentation/api/cross_filter/__init__.py +9 -0
- solara/website/pages/documentation/api/cross_filter/cross_filter_dataframe.py +23 -0
- solara/website/pages/documentation/api/cross_filter/cross_filter_report.py +22 -0
- solara/website/pages/documentation/api/cross_filter/cross_filter_select.py +22 -0
- solara/website/pages/documentation/api/cross_filter/cross_filter_slider.py +22 -0
- solara/website/pages/documentation/api/hooks/__init__.py +9 -0
- solara/website/pages/documentation/api/hooks/use_cross_filter.py +25 -0
- solara/website/pages/documentation/api/hooks/use_dark_effective.py +12 -0
- solara/website/pages/documentation/api/hooks/use_effect.md +43 -0
- solara/website/pages/documentation/api/hooks/use_effect.py +9 -0
- solara/website/pages/documentation/api/hooks/use_exception.py +33 -0
- solara/website/pages/documentation/api/hooks/use_memo.md +16 -0
- solara/website/pages/documentation/api/hooks/use_memo.py +9 -0
- solara/website/pages/documentation/api/hooks/use_previous.py +33 -0
- solara/website/pages/documentation/api/hooks/use_reactive.py +16 -0
- solara/website/pages/documentation/api/hooks/use_state.py +10 -0
- solara/website/pages/documentation/api/hooks/use_state_or_update.py +69 -0
- solara/website/pages/documentation/api/hooks/use_thread.md +58 -0
- solara/website/pages/documentation/api/hooks/use_thread.py +44 -0
- solara/website/pages/documentation/api/hooks/use_trait_observe.py +12 -0
- solara/website/pages/documentation/api/routing/__init__.py +9 -0
- solara/website/pages/documentation/api/routing/generate_routes.py +10 -0
- solara/website/pages/documentation/api/routing/generate_routes_directory.py +10 -0
- solara/website/pages/documentation/api/routing/resolve_path.py +35 -0
- solara/website/pages/documentation/api/routing/route.py +31 -0
- solara/website/pages/documentation/api/routing/use_route.py +80 -0
- solara/website/pages/documentation/api/routing/use_router.py +16 -0
- solara/website/pages/documentation/api/utilities/__init__.py +9 -0
- solara/website/pages/documentation/api/utilities/component_vue.py +10 -0
- solara/website/pages/documentation/api/utilities/computed.py +16 -0
- solara/website/pages/documentation/api/utilities/display.py +16 -0
- solara/website/pages/documentation/api/utilities/get_kernel_id.py +16 -0
- solara/website/pages/documentation/api/utilities/get_session_id.py +16 -0
- solara/website/pages/documentation/api/utilities/memoize.py +35 -0
- solara/website/pages/documentation/api/utilities/on_kernel_start.py +27 -0
- solara/website/pages/documentation/api/utilities/reactive.py +16 -0
- solara/website/pages/documentation/api/utilities/widget.py +104 -0
- solara/website/pages/documentation/components/__init__.py +12 -0
- solara/website/pages/documentation/components/advanced/__init__.py +9 -0
- solara/website/pages/documentation/components/advanced/link.py +27 -0
- solara/website/pages/documentation/components/advanced/meta.py +20 -0
- solara/website/pages/documentation/components/advanced/style.py +45 -0
- solara/website/pages/documentation/components/common.py +9 -0
- solara/website/pages/documentation/components/data/__init__.py +9 -0
- solara/website/pages/documentation/components/data/dataframe.py +44 -0
- solara/website/pages/documentation/components/data/pivot_table.py +81 -0
- solara/website/pages/documentation/components/enterprise/__init__.py +9 -0
- solara/website/pages/documentation/components/enterprise/avatar.py +24 -0
- solara/website/pages/documentation/components/enterprise/avatar_menu.py +25 -0
- solara/website/pages/documentation/components/input/__init__.py +9 -0
- solara/website/pages/documentation/components/input/button.py +23 -0
- solara/website/pages/documentation/components/input/checkbox.py +10 -0
- solara/website/pages/documentation/components/input/file_browser.py +32 -0
- solara/website/pages/documentation/components/input/file_drop.py +76 -0
- solara/website/pages/documentation/components/input/input.py +19 -0
- solara/website/pages/documentation/components/input/select.py +22 -0
- solara/website/pages/documentation/components/input/slider.py +29 -0
- solara/website/pages/documentation/components/input/switch.py +10 -0
- solara/website/pages/documentation/components/input/togglebuttons.py +21 -0
- solara/website/pages/documentation/components/lab/__init__.py +9 -0
- solara/website/pages/documentation/components/lab/chat.py +109 -0
- solara/website/pages/documentation/components/lab/confirmation_dialog.py +55 -0
- solara/website/pages/documentation/components/lab/cookies_headers.py +48 -0
- solara/website/pages/documentation/components/lab/input_date.py +20 -0
- solara/website/pages/documentation/components/lab/menu.py +22 -0
- solara/website/pages/documentation/components/lab/tab.py +25 -0
- solara/website/pages/documentation/components/lab/tabs.py +45 -0
- solara/website/pages/documentation/components/lab/task.py +11 -0
- solara/website/pages/documentation/components/lab/theming.py +72 -0
- solara/website/pages/documentation/components/lab/use_task.py +11 -0
- solara/website/pages/documentation/components/layout/__init__.py +9 -0
- solara/website/pages/documentation/components/layout/app_bar.py +16 -0
- solara/website/pages/documentation/components/layout/app_bar_title.py +16 -0
- solara/website/pages/documentation/components/layout/app_layout.py +24 -0
- solara/website/pages/documentation/components/layout/card.py +15 -0
- solara/website/pages/documentation/components/layout/card_actions.py +16 -0
- solara/website/pages/documentation/components/layout/column.py +30 -0
- solara/website/pages/documentation/components/layout/columns.py +27 -0
- solara/website/pages/documentation/components/layout/columns_responsive.py +68 -0
- solara/website/pages/documentation/components/layout/griddraggable.py +62 -0
- solara/website/pages/documentation/components/layout/gridfixed.py +21 -0
- solara/website/pages/documentation/components/layout/hbox.py +18 -0
- solara/website/pages/documentation/components/layout/row.py +30 -0
- solara/website/pages/documentation/components/layout/sidebar.py +24 -0
- solara/website/pages/documentation/components/layout/vbox.py +19 -0
- solara/website/pages/documentation/components/output/__init__.py +9 -0
- solara/website/pages/documentation/components/output/file_download.py +11 -0
- solara/website/pages/documentation/components/output/html.py +21 -0
- solara/website/pages/documentation/components/output/image.py +11 -0
- solara/website/pages/documentation/components/output/markdown.py +57 -0
- solara/website/pages/documentation/components/output/markdown_editor.py +51 -0
- solara/website/pages/documentation/components/output/sql_code.py +85 -0
- solara/website/pages/documentation/components/output/tooltip.py +11 -0
- solara/website/pages/documentation/components/page/__init__.py +9 -0
- solara/website/pages/documentation/components/page/head.py +18 -0
- solara/website/pages/documentation/components/page/title.py +27 -0
- solara/website/pages/documentation/components/status/__init__.py +9 -0
- solara/website/pages/documentation/components/status/error.py +40 -0
- solara/website/pages/documentation/components/status/info.py +40 -0
- solara/website/pages/documentation/components/status/progress.py +10 -0
- solara/website/pages/documentation/components/status/spinner.py +11 -0
- solara/website/pages/documentation/components/status/success.py +40 -0
- solara/website/pages/documentation/components/status/warning.py +47 -0
- solara/website/pages/documentation/components/viz/__init__.py +9 -0
- solara/website/pages/documentation/components/viz/altair.py +42 -0
- solara/website/pages/documentation/components/viz/echarts.py +75 -0
- solara/website/pages/documentation/components/viz/matplotlib.py +30 -0
- solara/website/pages/documentation/components/viz/plotly.py +63 -0
- solara/website/pages/documentation/components/viz/plotly_express.py +41 -0
- solara/website/pages/documentation/examples/__init__.py +52 -0
- solara/website/pages/documentation/examples/ai/__init__.py +11 -0
- solara/website/pages/documentation/examples/ai/chatbot.py +95 -0
- solara/website/pages/documentation/examples/ai/tokenizer.py +107 -0
- solara/website/pages/documentation/examples/basics/__init__.py +10 -0
- solara/website/pages/documentation/examples/basics/sine.py +28 -0
- solara/website/pages/documentation/examples/fullscreen/__init__.py +10 -0
- solara/website/pages/documentation/examples/fullscreen/authorization.py +3 -0
- solara/website/pages/documentation/examples/fullscreen/layout_demo.py +3 -0
- solara/website/pages/documentation/examples/fullscreen/multipage.py +3 -0
- solara/website/pages/documentation/examples/fullscreen/scatter.py +3 -0
- solara/website/pages/documentation/examples/fullscreen/scrolling.py +3 -0
- solara/website/pages/documentation/examples/fullscreen/tutorial_streamlit.py +3 -0
- solara/website/pages/documentation/examples/general/__init__.py +10 -0
- solara/website/pages/documentation/examples/general/custom_storage.py +70 -0
- solara/website/pages/documentation/examples/general/deploy_model.py +115 -0
- solara/website/pages/documentation/examples/general/live_update.py +38 -0
- solara/website/pages/documentation/examples/general/login_oauth.py +81 -0
- solara/website/pages/documentation/examples/general/mycard.vue +58 -0
- solara/website/pages/documentation/examples/general/pokemon_search.py +51 -0
- solara/website/pages/documentation/examples/general/vue_component.py +50 -0
- solara/website/pages/documentation/examples/ipycanvas.py +49 -0
- solara/website/pages/documentation/examples/libraries/__init__.py +10 -0
- solara/website/pages/documentation/examples/libraries/altair.py +64 -0
- solara/website/pages/documentation/examples/libraries/bqplot.py +39 -0
- solara/website/pages/documentation/examples/libraries/ipyleaflet.py +33 -0
- solara/website/pages/documentation/examples/libraries/ipyleaflet_advanced.py +66 -0
- solara/website/pages/documentation/examples/utilities/__init__.py +10 -0
- solara/website/pages/documentation/examples/utilities/calculator.py +157 -0
- solara/website/pages/documentation/examples/utilities/countdown_timer.py +64 -0
- solara/website/pages/documentation/examples/utilities/todo.py +196 -0
- solara/website/pages/documentation/examples/visualization/__init__.py +6 -0
- solara/website/pages/documentation/examples/visualization/annotator.py +69 -0
- solara/website/pages/documentation/examples/visualization/linked_views.py +84 -0
- solara/website/pages/documentation/examples/visualization/plotly.py +44 -0
- solara/website/pages/documentation/faq/__init__.py +12 -0
- solara/website/pages/documentation/faq/content/99-faq.md +76 -0
- solara/website/pages/documentation/getting_started/__init__.py +9 -0
- solara/website/pages/documentation/getting_started/content/00-quickstart.md +89 -0
- solara/website/pages/documentation/getting_started/content/01-introduction.md +125 -0
- solara/website/pages/documentation/getting_started/content/02-installing.md +134 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/00-overview.md +14 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/10_data_science.py +13 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/20-web-app.md +89 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/30-ipywidgets.md +124 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/40-streamlit.md +146 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/50-dash.md +144 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/60-jupyter-dashboard-part1.py +64 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/SF_crime_sample.csv.gz +0 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/_data_science.ipynb +445 -0
- solara/website/pages/documentation/getting_started/content/04-tutorials/_jupyter_dashboard_1.ipynb +1000 -0
- solara/website/pages/documentation/getting_started/content/05-fundamentals/00-overview.md +11 -0
- solara/website/pages/documentation/getting_started/content/05-fundamentals/10-components.md +223 -0
- solara/website/pages/documentation/getting_started/content/05-fundamentals/50-state-management.md +88 -0
- solara/website/pages/documentation/getting_started/content/07-deploying/00-overview.md +7 -0
- solara/website/pages/documentation/getting_started/content/07-deploying/10-self-hosted.md +273 -0
- solara/website/pages/documentation/getting_started/content/07-deploying/20-cloud-hosted.md +80 -0
- solara/website/pages/documentation/getting_started/content/80-what-is-lab.md +7 -0
- solara/website/pages/documentation/getting_started/content/90-troubleshoot.md +26 -0
- solara/website/pages/docutils.py +38 -0
- solara/website/pages/showcase/__init__.py +105 -0
- solara/website/pages/showcase/domino_code_assist.py +60 -0
- solara/website/pages/showcase/planeto_tessa.py +19 -0
- solara/website/pages/showcase/solara_dev.py +54 -0
- solara/website/pages/showcase/solarathon_2023_team_2.py +22 -0
- solara/website/pages/showcase/solarathon_2023_team_4.py +22 -0
- solara/website/pages/showcase/solarathon_2023_team_5.py +23 -0
- solara/website/pages/showcase/solarathon_2023_team_6.py +34 -0
- solara/website/pages/showcase/wanderlust.py +27 -0
- solara/website/public/beach.jpeg +0 -0
- solara/website/public/logo.svg +6 -0
- solara/website/public/social/discord.svg +1 -0
- solara/website/public/social/github.svg +1 -0
- solara/website/public/social/twitter.svg +3 -0
- solara/website/public/success.html +25 -0
- solara/website/templates/index.html.j2 +117 -0
- solara/website/utils.py +51 -0
- solara/widgets/__init__.py +1 -0
- solara/widgets/vue/gridlayout.vue +110 -0
- solara/widgets/vue/html.vue +4 -0
- solara/widgets/vue/navigator.vue +104 -0
- solara/widgets/vue/vegalite.vue +115 -0
- solara/widgets/widgets.py +66 -0
- solara_ui-1.31.0.data/data/etc/jupyter/jupyter_notebook_config.d/solara.json +7 -0
- solara_ui-1.31.0.data/data/etc/jupyter/jupyter_server_config.d/solara.json +7 -0
- solara_ui-1.31.0.dist-info/METADATA +158 -0
- solara_ui-1.31.0.dist-info/RECORD +439 -0
- solara_ui-1.31.0.dist-info/WHEEL +5 -0
- solara_ui-1.31.0.dist-info/licenses/LICENSE +21 -0
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
html,
|
|
2
|
+
body {
|
|
3
|
+
height: 100vh;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
@keyframes spin {
|
|
8
|
+
0% {
|
|
9
|
+
transform: rotate(0deg);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
100% {
|
|
13
|
+
transform: rotate(359deg);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
@keyframes oscillate {
|
|
18
|
+
0% {
|
|
19
|
+
transform: scale(0.8);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
50% {
|
|
23
|
+
transform: scale(1.0);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
100% {
|
|
27
|
+
transform: scale(0.8);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
#sun-spinner1 {
|
|
32
|
+
animation: spin 6s linear infinite;
|
|
33
|
+
padding: 10px;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
#sun-spinner2 {
|
|
37
|
+
animation: spin 2s cubic-bezier(.79, .14, .15, .86) infinite;
|
|
38
|
+
padding: 10px;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
#sun-spinner-container {
|
|
42
|
+
animation: oscillate 2s linear infinite;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
@keyframes bounce-in {
|
|
46
|
+
0% {
|
|
47
|
+
transform: scale(0);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
100% {
|
|
51
|
+
transform: scale(1);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
@keyframes bounce-out {
|
|
56
|
+
0% {
|
|
57
|
+
transform: translateZ(0) scale(1);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
100% {
|
|
61
|
+
transform: translateZ(0) scale(50);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.solara-transition-enter-active {
|
|
66
|
+
transition: opacity 0.5s ease;
|
|
67
|
+
/* animation: bounce-in 0.5s ease; */
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.solara-transition-leave-active {
|
|
71
|
+
transition: opacity 0.5s ease;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.solara-transition-leave-active .solara-loader {
|
|
75
|
+
animation: bounce-out 0.5s ease;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
.solara-transition-leave-active #sun-spinner-container {
|
|
79
|
+
animation: unset;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.solara-transition-leave-active h1 {
|
|
83
|
+
visibility: hidden;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
.solara-transition-enter,
|
|
87
|
+
.solara-transition-leave-to {
|
|
88
|
+
opacity: 0;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
#sun-spinner-container {
|
|
92
|
+
overflow: hidden;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
#loader-container {
|
|
96
|
+
width: 100vw;
|
|
97
|
+
height: 100vh;
|
|
98
|
+
position: absolute;
|
|
99
|
+
margin: 0;
|
|
100
|
+
padding: 0;
|
|
101
|
+
z-index: 998;
|
|
102
|
+
display: flex;
|
|
103
|
+
align-items: center;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
#loader {
|
|
107
|
+
position: absolute;
|
|
108
|
+
text-align: center;
|
|
109
|
+
z-index: 1000;
|
|
110
|
+
overflow: hidden;
|
|
111
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
{% raw -%}
|
|
2
|
+
<transition name="solara-transition" :duration="{ enter: 500, leave: 500 }">
|
|
3
|
+
<div v-if="loading" id="loader-container">
|
|
4
|
+
<v-container id="loader" key="loader" class="solara-loader" fluid>
|
|
5
|
+
<v-row>
|
|
6
|
+
<v-col>
|
|
7
|
+
<div id="sun-spinner-container">
|
|
8
|
+
<!-- <img id="sun-spinner" height="100px" src="static/assets/favicon.svg" /> -->
|
|
9
|
+
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
10
|
+
xmlns:svgjs="http://svgjs.com/svgjs" width="65" height="65"><svg width="65" height="65"
|
|
11
|
+
viewBox="0 0 65 65" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
12
|
+
<path id="sun-spinner1" style="transform-origin: center;"
|
|
13
|
+
d="M57.11 30.64L61.47 17.87L48.7 13.51L42.76 1.39999L30.65 7.34999L17.87 2.97999L13.51 15.75L1.40002 21.7L7.35002 33.81L2.99002 46.58L15.76 50.94L21.71 63.06L33.82 57.11L46.59 61.47L50.95 48.7L63.06 42.75L57.11 30.64ZM54.26 34.39L34.39 54.26C33.19 55.46 31.25 55.46 30.05 54.26L10.2 34.4C9.00002 33.2 9.00002 31.26 10.2 30.07L30.06 10.2C31.26 8.99999 33.2 8.99999 34.4 10.2L54.27 30.07C55.47 31.27 55.47 33.21 54.27 34.4L54.26 34.39Z"
|
|
14
|
+
fill="#FFCF64"></path>
|
|
15
|
+
<path id="sun-spinner2" style="transform-origin: center;"
|
|
16
|
+
d="M53.62 19.42L51.65 6.07L38.3 8.04L27.46 0L19.42 10.84L6.07 12.82L8.04 26.17L0 37L10.84 45.04L12.81 58.39L26.16 56.42L37 64.46L45.04 53.62L58.39 51.64L56.42 38.29L64.46 27.45L53.62 19.4V19.42ZM52.8 24.06L44.24 50.82C43.72 52.43 42 53.32 40.39 52.81L13.63 44.25C12.02 43.74 11.13 42.01 11.64 40.4L20.21 13.64C20.72 12.03 22.45 11.14 24.06 11.65L50.82 20.21C52.43 20.72 53.32 22.45 52.81 24.06H52.8Z"
|
|
17
|
+
fill="#FF8C3E"></path>
|
|
18
|
+
</svg>
|
|
19
|
+
</svg>
|
|
20
|
+
|
|
21
|
+
</div>
|
|
22
|
+
<h1>{{ loading_text }}</h1>
|
|
23
|
+
|
|
24
|
+
</v-col>
|
|
25
|
+
</v-row>
|
|
26
|
+
</v-container>
|
|
27
|
+
<div style="right: 50px; bottom: 10px; position: absolute;">
|
|
28
|
+
<b>Made with <a href="https://solara.dev">Solara</a></b>
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
31
|
+
<div v-else>
|
|
32
|
+
<jupyter-widget-mount-point mount-id="solara-main">
|
|
33
|
+
A widget with mount-id="solara-main" should go here
|
|
34
|
+
</jupyter-widget-mount-point>
|
|
35
|
+
<div style="position: absolute; right: 0px; bottom: 0px; padding: 10px;">
|
|
36
|
+
<b>This website runs on <a href="https://solara.dev">Solara</a></b>
|
|
37
|
+
</div>
|
|
38
|
+
</div>
|
|
39
|
+
</transition>
|
|
40
|
+
{% endraw -%}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html>
|
|
3
|
+
|
|
4
|
+
<head>
|
|
5
|
+
<!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.6.10/vue.min.js"></script>
|
|
6
|
+
<script src="https://cdn.jsdelivr.net/npm/vuetify@2.2.26/dist/vuetify.min.js"></script> -->
|
|
7
|
+
<!-- <link href="https://cdn.jsdelivr.net/npm/vuetify@2.2.26/dist/vuetify.min.css" rel="stylesheet"> -->
|
|
8
|
+
<link href='https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900|Material+Icons' rel="stylesheet">
|
|
9
|
+
<link href='https://cdn.materialdesignicons.com/4.9.95/css/materialdesignicons.min.css' rel="stylesheet">
|
|
10
|
+
<link href="/static/highlight.css" rel="stylesheet">
|
|
11
|
+
</link>
|
|
12
|
+
<link href="/static/style.css" rel="stylesheet">
|
|
13
|
+
</link>
|
|
14
|
+
|
|
15
|
+
<link href="/solara/static/index.css" rel="stylesheet">
|
|
16
|
+
</link>
|
|
17
|
+
<link href="/solara/static/theme-light.css" rel="stylesheet">
|
|
18
|
+
</link>
|
|
19
|
+
<link rel="icon"
|
|
20
|
+
href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>☀️</text></svg>">
|
|
21
|
+
<title>Hello from Solara ☀️</title>
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
<script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.3.4/require.js" crossorigin="anonymous">
|
|
25
|
+
</script>
|
|
26
|
+
<script src="/static/main.js">
|
|
27
|
+
</script>
|
|
28
|
+
<link rel='stylesheet' href='//cdn.jsdelivr.net/npm/hack-font@3.3.0/build/web/hack-subset.css'>
|
|
29
|
+
|
|
30
|
+
<script id="jupyter-config-data" type="application/json">
|
|
31
|
+
{
|
|
32
|
+
"baseUrl": "/jupyter",
|
|
33
|
+
"kernelId": "1234"
|
|
34
|
+
}
|
|
35
|
+
</script>
|
|
36
|
+
|
|
37
|
+
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css"
|
|
38
|
+
integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
|
39
|
+
<link>
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
<style>
|
|
43
|
+
html,
|
|
44
|
+
body {
|
|
45
|
+
height: 100vh;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.ipywidgets-server-contents-container {
|
|
49
|
+
height: 95vh;
|
|
50
|
+
padding-top: 5vh;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
#result {
|
|
54
|
+
margin-top: auto;
|
|
55
|
+
margin-bottom: auto;
|
|
56
|
+
}
|
|
57
|
+
</style>
|
|
58
|
+
</head>
|
|
59
|
+
|
|
60
|
+
<body>
|
|
61
|
+
<div id="content" style="display: flex; flex: 1 1 auto; align-items: left; justify-content: left;">
|
|
62
|
+
Loading... widget should appear here soon
|
|
63
|
+
</div>
|
|
64
|
+
</body>
|
|
65
|
+
<script>
|
|
66
|
+
requirejs.config({ baseUrl: '{{base_url}}voila/', waitSeconds: 30 });
|
|
67
|
+
|
|
68
|
+
// Loading classic notebook extensions.
|
|
69
|
+
{% for ext in resources.nbextensions -%}
|
|
70
|
+
requirejs(["{{base_url}}voila/nbextensions/{{ ext }}.js"],
|
|
71
|
+
function () {
|
|
72
|
+
console.log("Loaded classic notebook extension \"{{ ext }}\".");
|
|
73
|
+
},
|
|
74
|
+
function () {
|
|
75
|
+
console.error("Failed to load classic notebook extension \"{{ ext }}\".");
|
|
76
|
+
}
|
|
77
|
+
);
|
|
78
|
+
{% endfor %}
|
|
79
|
+
solaraMount("{{model_id}}")
|
|
80
|
+
</script>
|
|
81
|
+
|
|
82
|
+
</html>
|
|
@@ -0,0 +1,446 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html>
|
|
3
|
+
|
|
4
|
+
<head>
|
|
5
|
+
<title>{{title}}</title>
|
|
6
|
+
<meta charset="utf-8">
|
|
7
|
+
{{ pre_rendered_metas | safe }}
|
|
8
|
+
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, minimal-ui">
|
|
9
|
+
<link rel="icon" type="image/png" sizes="any" href="{{root_path}}/static/assets/favicon.png">
|
|
10
|
+
<link rel="icon" type="image/svg+xml" href="{{root_path}}/static/assets/favicon.svg">
|
|
11
|
+
|
|
12
|
+
{% block header %}
|
|
13
|
+
|
|
14
|
+
{{ pre_rendered_css | safe }}
|
|
15
|
+
{% if vue3 == True %}
|
|
16
|
+
<link href="{{cdn}}/@widgetti/solara-vuetify3-app@5.0.2/dist/main{{ipywidget_major_version}}.css" rel="stylesheet" class="solara-template-css"></link>
|
|
17
|
+
{% else %}
|
|
18
|
+
<link href="{{cdn}}/@widgetti/solara-vuetify-app@10.0.2/dist/main{{ipywidget_major_version}}.css" rel="stylesheet" class="solara-template-css"></link>
|
|
19
|
+
{% endif %}
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
{% if assets.fontawesome_enabled == True %}
|
|
23
|
+
<link rel="stylesheet" href="{{cdn}}{{assets.fontawesome_path}}" type="text/css">
|
|
24
|
+
{% endif %}
|
|
25
|
+
{{ resources.include_css("/static/highlight.css") }}
|
|
26
|
+
{{ resources.include_css("/static/highlight-dark.css") }}
|
|
27
|
+
{{ resources.include_css("/static/assets/style.css") }}
|
|
28
|
+
<style id="jupyter-theme-css" class="solara-template-css">
|
|
29
|
+
</style>
|
|
30
|
+
{{ resources.include_css("/static/assets/custom.css") }}
|
|
31
|
+
|
|
32
|
+
<script id="jupyter-config-data" type="application/json">
|
|
33
|
+
{
|
|
34
|
+
"baseUrl": "{{root_path}}/",
|
|
35
|
+
"kernelId": "1234"
|
|
36
|
+
}
|
|
37
|
+
</script>
|
|
38
|
+
<style class="solara-template-css">
|
|
39
|
+
{% include "loader-"~theme.loader~".css" %}
|
|
40
|
+
</style>
|
|
41
|
+
<!-- Include Vuetify background colours so static html from SSG renders the right general colour theme
|
|
42
|
+
before first render. We remove these after Vue takes over rendering to avoid collisions -->
|
|
43
|
+
<style id="pre-render-theme">
|
|
44
|
+
.theme--light .v-sheet {
|
|
45
|
+
background-color: #fff;
|
|
46
|
+
border-color: #fff;
|
|
47
|
+
color: rgba(0,0,0,.87)
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.theme--dark .v-sheet {
|
|
51
|
+
background-color: #1e1e1e;
|
|
52
|
+
border-color: #1e1e1e;
|
|
53
|
+
color: #fff
|
|
54
|
+
}
|
|
55
|
+
</style>
|
|
56
|
+
{% endblock header %}
|
|
57
|
+
</head>
|
|
58
|
+
{% raw -%}
|
|
59
|
+
<script type="x-template" id="vue-app-template" style="display: none">
|
|
60
|
+
<v-app :key="forceUpdateTrigger" :class="loadingPage ? 'solara-page-loading' : ''">
|
|
61
|
+
<v-progress-linear :style="{visibility: (kernelBusyLong && isMounted) ? 'visible' : 'hidden'}" indeterminate
|
|
62
|
+
absolute></v-progress-linear>
|
|
63
|
+
<v-alert v-if="needsRefresh || cancelAutoRefresh" type="warning" border="left"
|
|
64
|
+
style="position: absolute; right: 0px; z-index: 100; left: 0px;">
|
|
65
|
+
App is disconnected, and may not function properly. Please refresh the page.
|
|
66
|
+
</v-alert>
|
|
67
|
+
{% endraw -%}
|
|
68
|
+
{# {% include "transition-domino.html" %} #}
|
|
69
|
+
{% include "loader-" ~ theme.loader ~ ".html" %}
|
|
70
|
+
<v-overlay style="z-index: 100002;" :value="(connectionStatus != 'connected') & wasConnected">
|
|
71
|
+
<v-progress-circular indeterminate size="128" style="text-align: center;">Server
|
|
72
|
+
disconnected.</v-progress-circular>
|
|
73
|
+
</v-overlay>
|
|
74
|
+
|
|
75
|
+
<v-dialog v-model="needsRefresh" width="500">
|
|
76
|
+
<v-card>
|
|
77
|
+
<v-card-title class="text-h5 grey lighten-2">Please refresh the page</v-card-title>
|
|
78
|
+
|
|
79
|
+
{% if production %}
|
|
80
|
+
<v-card-text>
|
|
81
|
+
Could not restore session. Please refresh.
|
|
82
|
+
</v-card-text>
|
|
83
|
+
{% else %}
|
|
84
|
+
<v-card-text>
|
|
85
|
+
{% raw -%}
|
|
86
|
+
Could not restore session. Will refresh in {{autoRefreshCount}} seconds.
|
|
87
|
+
{% endraw -%}
|
|
88
|
+
</v-card-text>
|
|
89
|
+
{% endif %}
|
|
90
|
+
|
|
91
|
+
<v-divider></v-divider>
|
|
92
|
+
|
|
93
|
+
<v-card-actions>
|
|
94
|
+
<v-spacer></v-spacer>
|
|
95
|
+
<v-btn color="secondary" text @click="reload()">
|
|
96
|
+
Refresh now
|
|
97
|
+
</v-btn>
|
|
98
|
+
<v-btn color="primary" text @click="setCancelAutoRefresh()">
|
|
99
|
+
Cancel
|
|
100
|
+
</v-btn>
|
|
101
|
+
</v-card-actions>
|
|
102
|
+
</v-card>
|
|
103
|
+
</v-dialog>
|
|
104
|
+
{% raw -%}
|
|
105
|
+
|
|
106
|
+
<v-menu v-if="debug && solaraDebugMessages && solaraDebugMessages.length" offset-y top
|
|
107
|
+
:close-on-content-click="false">
|
|
108
|
+
<template v-slot:activator="{ on }">
|
|
109
|
+
<v-btn text v-on="on" style="position: fixed; bottom: 8px; right: 8px">
|
|
110
|
+
<span style="color: red">{{ solaraDebugMessages.length }}</span>
|
|
111
|
+
<v-icon right large color="red">mdi-bug-outline</v-icon>
|
|
112
|
+
</v-btn>
|
|
113
|
+
</template>
|
|
114
|
+
<v-sheet class="pa-2" style="overflow: auto; max-height: 80vh">
|
|
115
|
+
<div style="display: flex" v-for="message in solaraDebugMessages" :key="message.cell" class="pa-2">
|
|
116
|
+
<div style="width: 50px">[{{ message.cell }}]</div>
|
|
117
|
+
<div v-if="message.traceback" class="jp-RenderedText jp-OutputArea-output"
|
|
118
|
+
data-mime-type="application/vnd.jupyter.stderr">
|
|
119
|
+
<pre v-html="message.traceback" class="pa-2"></pre>
|
|
120
|
+
</div>
|
|
121
|
+
<pre v-else><span :style="message.name === 'stderr' ? 'background-color: var(--jp-rendermime-error-background)' : ''"
|
|
122
|
+
class="pa-2"
|
|
123
|
+
>{{ message.text }}</span>
|
|
124
|
+
</pre>
|
|
125
|
+
</div>
|
|
126
|
+
<div class="d-flex justify-end">
|
|
127
|
+
<v-tooltip top>
|
|
128
|
+
<template v-slot:activator="{ on, attrs }">
|
|
129
|
+
<v-btn icon v-bind="attrs" v-on="on" @click="solaraDebugMessages = []">
|
|
130
|
+
<v-icon>mdi-trash-can-outline</v-icon>
|
|
131
|
+
</v-btn>
|
|
132
|
+
</template>
|
|
133
|
+
<span>Clear messages</span>
|
|
134
|
+
</v-tooltip>
|
|
135
|
+
</div>
|
|
136
|
+
</v-sheet>
|
|
137
|
+
</v-menu>
|
|
138
|
+
|
|
139
|
+
<!-- <v-menu v-if="debug && outputMessages && outputMessages.length" offset-y top
|
|
140
|
+
:close-on-content-click="false">
|
|
141
|
+
<template v-slot:activator="{ on }">
|
|
142
|
+
<v-btn text v-on="on" style="position: fixed; top: 8px; right: 8px">
|
|
143
|
+
<span style="color: #333">{{ outputMessages.length }}</span>
|
|
144
|
+
<v-icon right large color="#333">mdi-information-outline</v-icon>
|
|
145
|
+
</v-btn>
|
|
146
|
+
</template>
|
|
147
|
+
<v-sheet class="pa-2" style="overflow: auto; max-height: 80vh">
|
|
148
|
+
<div style="display: flex" v-for="message in outputMessages" :key="message.cell" class="pa-2">
|
|
149
|
+
<div style="width: 50px">[{{ message.cell }}]</div>
|
|
150
|
+
<div v-if="message.traceback" class="jp-RenderedText jp-OutputArea-output"
|
|
151
|
+
data-mime-type="application/vnd.jupyter.stderr">
|
|
152
|
+
<pre v-html="message.traceback" class="pa-2"></pre>
|
|
153
|
+
</div>
|
|
154
|
+
<pre v-else><span :style="message.name === 'stderr' ? 'background-color: var(--jp-rendermime-error-background)' : ''"
|
|
155
|
+
class="pa-2"
|
|
156
|
+
>{{ message.text }}</span>
|
|
157
|
+
</pre>
|
|
158
|
+
</div>
|
|
159
|
+
<div class="d-flex justify-end">
|
|
160
|
+
<v-tooltip top>
|
|
161
|
+
<template v-slot:activator="{ on, attrs }">
|
|
162
|
+
<v-btn icon v-bind="attrs" v-on="on" @click="outputMessages = []">
|
|
163
|
+
<v-icon>mdi-trash-can-outline</v-icon>
|
|
164
|
+
</v-btn>
|
|
165
|
+
</template>
|
|
166
|
+
<span>Clear messages</span>
|
|
167
|
+
</v-tooltip>
|
|
168
|
+
</div>
|
|
169
|
+
</v-sheet>
|
|
170
|
+
</v-menu> -->
|
|
171
|
+
</v-app>
|
|
172
|
+
</script>
|
|
173
|
+
{% endraw -%}
|
|
174
|
+
|
|
175
|
+
<body data-base-url="{{root_path}}/static/">
|
|
176
|
+
{% if perform_check %}
|
|
177
|
+
<iframe src="https://solara.dev/static/public/success.html?system=solara&check=html&version={{solara_version}}" style="display: none"></iframe>
|
|
178
|
+
{% endif %}
|
|
179
|
+
{% if theme.variant == "auto" %}
|
|
180
|
+
{% endif %}
|
|
181
|
+
{% if theme.variant == "light" %}
|
|
182
|
+
<div id="app" class="v-application v-application--is-ltr theme--light" data-app="true">
|
|
183
|
+
{% elif theme.variant == "dark" %}
|
|
184
|
+
<div id="app" class="v-application v-application--is-ltr theme--dark" data-app="true">
|
|
185
|
+
{% endif %}
|
|
186
|
+
{{ pre_rendered_html|safe }}
|
|
187
|
+
{# next div is used in ssg code to see if vue took over rendering #}
|
|
188
|
+
<div id="pre-rendered-html-present" style="display: none"></div>
|
|
189
|
+
</div>
|
|
190
|
+
<script>
|
|
191
|
+
var theme = {{ theme | tojson | safe }}
|
|
192
|
+
function getThemeVariant() {
|
|
193
|
+
if (localStorage.getItem(':solara:theme.variant')) {
|
|
194
|
+
return JSON.parse(localStorage.getItem(':solara:theme.variant'))
|
|
195
|
+
}
|
|
196
|
+
return theme.variant;
|
|
197
|
+
}
|
|
198
|
+
if (localStorage.getItem(':solara:theme.variant')) {
|
|
199
|
+
theme.variant = JSON.parse(localStorage.getItem(':solara:theme.variant'))
|
|
200
|
+
}
|
|
201
|
+
function prefersDarkScheme() {
|
|
202
|
+
return window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches
|
|
203
|
+
}
|
|
204
|
+
function inDarkMode() {
|
|
205
|
+
if (getThemeVariant() == 'auto') {
|
|
206
|
+
return prefersDarkScheme();
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
return getThemeVariant() == 'dark';
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
// Init theme
|
|
213
|
+
let appContainer = document.getElementById('app');
|
|
214
|
+
if (inDarkMode()) {
|
|
215
|
+
appContainer.classList.remove('theme--light');
|
|
216
|
+
appContainer.classList.add('theme--dark');
|
|
217
|
+
} else {
|
|
218
|
+
appContainer.classList.remove('theme--dark');
|
|
219
|
+
appContainer.classList.add('theme--light');
|
|
220
|
+
}
|
|
221
|
+
</script>
|
|
222
|
+
{% block after_pre_rendered_html %}{% endblock %}
|
|
223
|
+
{% if vue3 == True %}
|
|
224
|
+
<link href="{{cdn}}/@widgetti/solara-vuetify3-app@5.0.2/dist/fonts.css" rel="stylesheet"></link>
|
|
225
|
+
{% if production %}
|
|
226
|
+
<script src="{{cdn}}/@widgetti/solara-vuetify3-app@5.0.2/dist/solara-vuetify-app{{ipywidget_major_version}}.min.js"></script>
|
|
227
|
+
{% else %}
|
|
228
|
+
<script src="{{cdn}}/@widgetti/solara-vuetify3-app@5.0.2/dist/solara-vuetify-app{{ipywidget_major_version}}.js"></script>
|
|
229
|
+
{% endif %}
|
|
230
|
+
{% else %}
|
|
231
|
+
<link href="{{cdn}}/@widgetti/solara-vuetify-app@10.0.2/dist/fonts.css" rel="stylesheet" fetchpriority="low"></link>
|
|
232
|
+
{% if production %}
|
|
233
|
+
<script src="{{cdn}}/@widgetti/solara-vuetify-app@10.0.2/dist/solara-vuetify-app{{ipywidget_major_version}}.min.js"></script>
|
|
234
|
+
{% else %}
|
|
235
|
+
<script src="{{cdn}}/@widgetti/solara-vuetify-app@10.0.2/dist/solara-vuetify-app{{ipywidget_major_version}}.js"></script>
|
|
236
|
+
{% endif %}
|
|
237
|
+
{% endif %}
|
|
238
|
+
<script>
|
|
239
|
+
solara.rootPath = {{ root_path | tojson | safe}};
|
|
240
|
+
console.log("rootPath", solara.rootPath);
|
|
241
|
+
|
|
242
|
+
async function changeThemeCSS(theme) {
|
|
243
|
+
let css = await fetch(`${solara.rootPath}/static/assets/theme-${theme}.css`).then(r => r.text());
|
|
244
|
+
document.getElementById('jupyter-theme-css').innerHTML = css;
|
|
245
|
+
}
|
|
246
|
+
changeThemeCSS(inDarkMode() ? 'dark' : 'light');
|
|
247
|
+
</script>
|
|
248
|
+
|
|
249
|
+
{{ resources.include_js("/static/assets/custom.js") }}
|
|
250
|
+
{{ resources.include_js("/static/assets/theme.js") }}
|
|
251
|
+
|
|
252
|
+
<script src="{{cdn}}/requirejs@2.3.6/require.js" crossorigin="anonymous">
|
|
253
|
+
</script>
|
|
254
|
+
{{ resources.include_js("/static/main-vuetify.js") }}
|
|
255
|
+
{{ resources.include_js("/static/ansi.js") }}
|
|
256
|
+
|
|
257
|
+
<script>
|
|
258
|
+
solara.production = {{ production | tojson | safe }};
|
|
259
|
+
const themeVariants = ['light', 'dark', 'auto']
|
|
260
|
+
solara.preRendered = {{ pre_rendered_html | safe | length | tojson }} > 0
|
|
261
|
+
</script>
|
|
262
|
+
|
|
263
|
+
<script>
|
|
264
|
+
window.solara.browser_platform = false;
|
|
265
|
+
{% if platform == "emscripten" %}
|
|
266
|
+
window.solara.browser_platform = true;
|
|
267
|
+
{% endif %}
|
|
268
|
+
var debug = true;
|
|
269
|
+
|
|
270
|
+
var appComponent = {
|
|
271
|
+
// if we do prerendering, keep it unmounted, and mount
|
|
272
|
+
// when loading becomes false
|
|
273
|
+
el: solara.preRendered ? null : '#app' ,
|
|
274
|
+
template: '#vue-app-template',
|
|
275
|
+
created() {
|
|
276
|
+
const original_$forceUpdate = this.$forceUpdate.bind(this);
|
|
277
|
+
this.$forceUpdate = (() => {
|
|
278
|
+
this.forceUpdateTrigger += 1;
|
|
279
|
+
original_$forceUpdate();
|
|
280
|
+
});
|
|
281
|
+
},
|
|
282
|
+
mounted() {
|
|
283
|
+
document.querySelector('#app').removeAttribute("style");
|
|
284
|
+
// listen to change in preferred color scheme (e.g if choosing dark in OSX)
|
|
285
|
+
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', event => {
|
|
286
|
+
this.$vuetify.theme.dark = inDarkMode();
|
|
287
|
+
});
|
|
288
|
+
document.getElementById('pre-render-theme').remove();
|
|
289
|
+
},
|
|
290
|
+
methods: {
|
|
291
|
+
stateReset() {
|
|
292
|
+
console.log('reset')
|
|
293
|
+
msg = { "type": "state_reset", "reason": "user command" }
|
|
294
|
+
wsWatchdog.send(JSON.stringify(msg))
|
|
295
|
+
},
|
|
296
|
+
setCancelAutoRefresh() {
|
|
297
|
+
this.needsRefresh = false;
|
|
298
|
+
this.cancelAutoRefresh = true;
|
|
299
|
+
},
|
|
300
|
+
reload() {
|
|
301
|
+
location.reload();
|
|
302
|
+
},
|
|
303
|
+
},
|
|
304
|
+
watch: {
|
|
305
|
+
kernelBusy: function (value) {
|
|
306
|
+
if(this._lastBusyTimer) {
|
|
307
|
+
clearTimeout(this._lastBusyTimer)
|
|
308
|
+
}
|
|
309
|
+
if(value) {
|
|
310
|
+
this._lastBusyTimer = setTimeout(() => {
|
|
311
|
+
this.kernelBusyLong = value;
|
|
312
|
+
}, 300);
|
|
313
|
+
} else {
|
|
314
|
+
this.kernelBusyLong = value;
|
|
315
|
+
}
|
|
316
|
+
},
|
|
317
|
+
loading: function (value) {
|
|
318
|
+
// if preRendered, the app is not mounted yet
|
|
319
|
+
// so we mount it when loading becomes false
|
|
320
|
+
if (solara.preRendered && !this.mounted) {
|
|
321
|
+
this.isMounted = true;
|
|
322
|
+
this.$mount("#app")
|
|
323
|
+
} else {
|
|
324
|
+
this.isMounted = true;
|
|
325
|
+
}
|
|
326
|
+
},
|
|
327
|
+
needsRefresh: function (value) {
|
|
328
|
+
if (this.needsRefresh && !this.cancelAutoRefresh && !solara.production) {
|
|
329
|
+
console.log('value for needRefresh', value);
|
|
330
|
+
setTimeout(() => {
|
|
331
|
+
console.log('this.autoRefreshCount', this.autoRefreshCount)
|
|
332
|
+
this.autoRefreshCount = this.autoRefreshCount - 1;
|
|
333
|
+
}, 1000);
|
|
334
|
+
}
|
|
335
|
+
},
|
|
336
|
+
autoRefreshCount: function (value) {
|
|
337
|
+
console.log('value for autoRefreshCount', value);
|
|
338
|
+
if (value == 0) {
|
|
339
|
+
if (!this.cancelAutoRefresh)
|
|
340
|
+
this.reload();
|
|
341
|
+
} else if (value > 0) {
|
|
342
|
+
setTimeout(() => {
|
|
343
|
+
console.log('this.autoRefreshCount!', this.autoRefreshCount)
|
|
344
|
+
this.autoRefreshCount = this.autoRefreshCount - 1;
|
|
345
|
+
}, 1000);
|
|
346
|
+
}
|
|
347
|
+
},
|
|
348
|
+
'$vuetify.theme.dark': function (value) {
|
|
349
|
+
if ( value ) {
|
|
350
|
+
this.changeThemeCSS('dark');
|
|
351
|
+
appContainer.classList.remove('theme--light');
|
|
352
|
+
appContainer.classList.add('theme--dark');
|
|
353
|
+
} else {
|
|
354
|
+
this.changeThemeCSS('light');
|
|
355
|
+
appContainer.classList.remove('theme--dark');
|
|
356
|
+
appContainer.classList.add('theme--light');
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
},
|
|
360
|
+
data() {
|
|
361
|
+
return {
|
|
362
|
+
forceUpdateTrigger: 0,
|
|
363
|
+
loading_text: "Loading resources",
|
|
364
|
+
loadingPercentage: -1,
|
|
365
|
+
loading: true,
|
|
366
|
+
title: "No title",
|
|
367
|
+
solaraDebugMessages: [],
|
|
368
|
+
outputMessages: [],
|
|
369
|
+
theme: theme,
|
|
370
|
+
debug: debug,
|
|
371
|
+
connectionStatus: null,
|
|
372
|
+
wasConnected: false,
|
|
373
|
+
needsRefresh: false,
|
|
374
|
+
cancelAutoRefresh: false,
|
|
375
|
+
autoRefreshCount: 3,
|
|
376
|
+
kernelBusy: false,
|
|
377
|
+
isMounted: false,
|
|
378
|
+
loadingPage: false,
|
|
379
|
+
_lastBusyTimer: null,
|
|
380
|
+
kernelBusyLong: false,
|
|
381
|
+
// outputMessages: [{ name: 'stderr', text: 'lala' }],
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
};
|
|
385
|
+
const vue3 = Vue.version.startsWith('3');
|
|
386
|
+
if(vue3) {
|
|
387
|
+
var app = Vue.createApp(appComponent).use(vuetifyPlugin)
|
|
388
|
+
.component("jupyter-widget-mount-point", jupyterWidgetMountPoint)
|
|
389
|
+
.mount('#app');
|
|
390
|
+
|
|
391
|
+
} else {
|
|
392
|
+
Vue.component('jupyter-widget-mount-point', jupyterWidgetMountPoint);
|
|
393
|
+
Vue.use(Vuetify);
|
|
394
|
+
var app = new Vue({
|
|
395
|
+
vuetify: new Vuetify({
|
|
396
|
+
theme: {
|
|
397
|
+
dark: inDarkMode(),
|
|
398
|
+
themes: vuetifyThemes,
|
|
399
|
+
},
|
|
400
|
+
}),
|
|
401
|
+
...appComponent,
|
|
402
|
+
});
|
|
403
|
+
}
|
|
404
|
+
// Loading classic notebook extensions.
|
|
405
|
+
{% if 'jupyter-vuetify/extension' in resources.nbextensions -%}
|
|
406
|
+
window.enable_nbextensions = true;
|
|
407
|
+
{% endif -%}
|
|
408
|
+
nbextensionHashes = {{ resources.nbextensions_hashes | tojson | safe }};
|
|
409
|
+
requirejs.config({
|
|
410
|
+
baseUrl: '{{root_path}}/static/',
|
|
411
|
+
waitSeconds: 3000,
|
|
412
|
+
map: {
|
|
413
|
+
'*': {
|
|
414
|
+
{% if 'jupyter-vue/extension' in resources.nbextensions -%}
|
|
415
|
+
'jupyter-vue': 'nbextensions/jupyter-vue/nodeps',
|
|
416
|
+
{% endif -%}
|
|
417
|
+
{% if 'jupyter-vuetify/extension' in resources.nbextensions -%}
|
|
418
|
+
'jupyter-vuetify': 'nbextensions/jupyter-vuetify/nodeps',
|
|
419
|
+
{% endif -%}
|
|
420
|
+
},
|
|
421
|
+
},
|
|
422
|
+
// Add cache busting to the urlArgs to ensure latest versions of nbextensions are loaded
|
|
423
|
+
urlArgs: function (id, url) {
|
|
424
|
+
const extensionName = id.replace("/static/nbextensions/", "").replace(".js", "");
|
|
425
|
+
if (nbextensionHashes[extensionName] !== undefined) {
|
|
426
|
+
// Check if the url already has a query string, if so, append the hash as an additional parameter
|
|
427
|
+
return (url.indexOf('?') === -1 ? '?' : '&') + nbextensionHashes[extensionName];
|
|
428
|
+
} else {
|
|
429
|
+
return '';
|
|
430
|
+
}
|
|
431
|
+
},
|
|
432
|
+
});
|
|
433
|
+
requirejs([
|
|
434
|
+
{% for ext in resources.nbextensions if ext != 'jupyter-vuetify/extension' and ext != 'jupyter-vue/extension' -%}
|
|
435
|
+
"{{root_path}}/static/nbextensions/{{ ext }}.js",
|
|
436
|
+
{% endfor %}
|
|
437
|
+
]);
|
|
438
|
+
(async function () {
|
|
439
|
+
await Promise.all([
|
|
440
|
+
solaraInit('solara-main')
|
|
441
|
+
]);
|
|
442
|
+
})();
|
|
443
|
+
|
|
444
|
+
</script>
|
|
445
|
+
|
|
446
|
+
</html>
|