streamlit-nightly 1.43.2.dev20250307__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.
Files changed (563) hide show
  1. streamlit/__init__.py +306 -0
  2. streamlit/__main__.py +20 -0
  3. streamlit/auth_util.py +218 -0
  4. streamlit/cli_util.py +105 -0
  5. streamlit/column_config.py +56 -0
  6. streamlit/commands/__init__.py +13 -0
  7. streamlit/commands/echo.py +126 -0
  8. streamlit/commands/execution_control.py +238 -0
  9. streamlit/commands/experimental_query_params.py +169 -0
  10. streamlit/commands/logo.py +189 -0
  11. streamlit/commands/navigation.py +385 -0
  12. streamlit/commands/page_config.py +311 -0
  13. streamlit/components/__init__.py +13 -0
  14. streamlit/components/lib/__init__.py +13 -0
  15. streamlit/components/lib/local_component_registry.py +84 -0
  16. streamlit/components/types/__init__.py +13 -0
  17. streamlit/components/types/base_component_registry.py +99 -0
  18. streamlit/components/types/base_custom_component.py +150 -0
  19. streamlit/components/v1/__init__.py +31 -0
  20. streamlit/components/v1/component_arrow.py +141 -0
  21. streamlit/components/v1/component_registry.py +130 -0
  22. streamlit/components/v1/components.py +38 -0
  23. streamlit/components/v1/custom_component.py +243 -0
  24. streamlit/config.py +1513 -0
  25. streamlit/config_option.py +311 -0
  26. streamlit/config_util.py +177 -0
  27. streamlit/connections/__init__.py +28 -0
  28. streamlit/connections/base_connection.py +174 -0
  29. streamlit/connections/snowflake_connection.py +562 -0
  30. streamlit/connections/snowpark_connection.py +213 -0
  31. streamlit/connections/sql_connection.py +425 -0
  32. streamlit/connections/util.py +97 -0
  33. streamlit/cursor.py +210 -0
  34. streamlit/dataframe_util.py +1416 -0
  35. streamlit/delta_generator.py +602 -0
  36. streamlit/delta_generator_singletons.py +204 -0
  37. streamlit/deprecation_util.py +209 -0
  38. streamlit/development.py +21 -0
  39. streamlit/elements/__init__.py +13 -0
  40. streamlit/elements/alert.py +234 -0
  41. streamlit/elements/arrow.py +962 -0
  42. streamlit/elements/balloons.py +47 -0
  43. streamlit/elements/bokeh_chart.py +133 -0
  44. streamlit/elements/code.py +114 -0
  45. streamlit/elements/deck_gl_json_chart.py +546 -0
  46. streamlit/elements/dialog_decorator.py +267 -0
  47. streamlit/elements/doc_string.py +558 -0
  48. streamlit/elements/empty.py +130 -0
  49. streamlit/elements/exception.py +331 -0
  50. streamlit/elements/form.py +354 -0
  51. streamlit/elements/graphviz_chart.py +150 -0
  52. streamlit/elements/heading.py +302 -0
  53. streamlit/elements/html.py +105 -0
  54. streamlit/elements/iframe.py +191 -0
  55. streamlit/elements/image.py +196 -0
  56. streamlit/elements/json.py +139 -0
  57. streamlit/elements/layouts.py +879 -0
  58. streamlit/elements/lib/__init__.py +13 -0
  59. streamlit/elements/lib/built_in_chart_utils.py +1157 -0
  60. streamlit/elements/lib/color_util.py +263 -0
  61. streamlit/elements/lib/column_config_utils.py +542 -0
  62. streamlit/elements/lib/column_types.py +2188 -0
  63. streamlit/elements/lib/dialog.py +147 -0
  64. streamlit/elements/lib/dicttools.py +154 -0
  65. streamlit/elements/lib/event_utils.py +37 -0
  66. streamlit/elements/lib/file_uploader_utils.py +66 -0
  67. streamlit/elements/lib/form_utils.py +77 -0
  68. streamlit/elements/lib/image_utils.py +441 -0
  69. streamlit/elements/lib/js_number.py +105 -0
  70. streamlit/elements/lib/mutable_status_container.py +183 -0
  71. streamlit/elements/lib/options_selector_utils.py +250 -0
  72. streamlit/elements/lib/pandas_styler_utils.py +274 -0
  73. streamlit/elements/lib/policies.py +194 -0
  74. streamlit/elements/lib/streamlit_plotly_theme.py +207 -0
  75. streamlit/elements/lib/subtitle_utils.py +176 -0
  76. streamlit/elements/lib/utils.py +250 -0
  77. streamlit/elements/map.py +508 -0
  78. streamlit/elements/markdown.py +277 -0
  79. streamlit/elements/media.py +793 -0
  80. streamlit/elements/metric.py +301 -0
  81. streamlit/elements/plotly_chart.py +546 -0
  82. streamlit/elements/progress.py +156 -0
  83. streamlit/elements/pyplot.py +194 -0
  84. streamlit/elements/snow.py +47 -0
  85. streamlit/elements/spinner.py +113 -0
  86. streamlit/elements/text.py +76 -0
  87. streamlit/elements/toast.py +98 -0
  88. streamlit/elements/vega_charts.py +1984 -0
  89. streamlit/elements/widgets/__init__.py +13 -0
  90. streamlit/elements/widgets/audio_input.py +310 -0
  91. streamlit/elements/widgets/button.py +1123 -0
  92. streamlit/elements/widgets/button_group.py +1008 -0
  93. streamlit/elements/widgets/camera_input.py +263 -0
  94. streamlit/elements/widgets/chat.py +647 -0
  95. streamlit/elements/widgets/checkbox.py +352 -0
  96. streamlit/elements/widgets/color_picker.py +265 -0
  97. streamlit/elements/widgets/data_editor.py +983 -0
  98. streamlit/elements/widgets/file_uploader.py +486 -0
  99. streamlit/elements/widgets/multiselect.py +338 -0
  100. streamlit/elements/widgets/number_input.py +545 -0
  101. streamlit/elements/widgets/radio.py +407 -0
  102. streamlit/elements/widgets/select_slider.py +437 -0
  103. streamlit/elements/widgets/selectbox.py +366 -0
  104. streamlit/elements/widgets/slider.py +880 -0
  105. streamlit/elements/widgets/text_widgets.py +628 -0
  106. streamlit/elements/widgets/time_widgets.py +970 -0
  107. streamlit/elements/write.py +574 -0
  108. streamlit/emojis.py +34 -0
  109. streamlit/env_util.py +61 -0
  110. streamlit/error_util.py +105 -0
  111. streamlit/errors.py +452 -0
  112. streamlit/external/__init__.py +13 -0
  113. streamlit/external/langchain/__init__.py +23 -0
  114. streamlit/external/langchain/streamlit_callback_handler.py +406 -0
  115. streamlit/file_util.py +247 -0
  116. streamlit/git_util.py +173 -0
  117. streamlit/hello/__init__.py +13 -0
  118. streamlit/hello/animation_demo.py +82 -0
  119. streamlit/hello/dataframe_demo.py +71 -0
  120. streamlit/hello/hello.py +37 -0
  121. streamlit/hello/mapping_demo.py +114 -0
  122. streamlit/hello/plotting_demo.py +55 -0
  123. streamlit/hello/streamlit_app.py +55 -0
  124. streamlit/hello/utils.py +28 -0
  125. streamlit/logger.py +130 -0
  126. streamlit/material_icon_names.py +25 -0
  127. streamlit/navigation/__init__.py +13 -0
  128. streamlit/navigation/page.py +302 -0
  129. streamlit/net_util.py +125 -0
  130. streamlit/platform.py +33 -0
  131. streamlit/proto/Alert_pb2.py +29 -0
  132. streamlit/proto/Alert_pb2.pyi +90 -0
  133. streamlit/proto/AppPage_pb2.py +27 -0
  134. streamlit/proto/AppPage_pb2.pyi +64 -0
  135. streamlit/proto/ArrowNamedDataSet_pb2.py +28 -0
  136. streamlit/proto/ArrowNamedDataSet_pb2.pyi +57 -0
  137. streamlit/proto/ArrowVegaLiteChart_pb2.py +29 -0
  138. streamlit/proto/ArrowVegaLiteChart_pb2.pyi +84 -0
  139. streamlit/proto/Arrow_pb2.py +33 -0
  140. streamlit/proto/Arrow_pb2.pyi +188 -0
  141. streamlit/proto/AudioInput_pb2.py +28 -0
  142. streamlit/proto/AudioInput_pb2.pyi +58 -0
  143. streamlit/proto/Audio_pb2.py +27 -0
  144. streamlit/proto/Audio_pb2.pyi +58 -0
  145. streamlit/proto/AuthRedirect_pb2.py +27 -0
  146. streamlit/proto/AuthRedirect_pb2.pyi +41 -0
  147. streamlit/proto/AutoRerun_pb2.py +27 -0
  148. streamlit/proto/AutoRerun_pb2.pyi +45 -0
  149. streamlit/proto/BackMsg_pb2.py +29 -0
  150. streamlit/proto/BackMsg_pb2.pyi +105 -0
  151. streamlit/proto/Balloons_pb2.py +27 -0
  152. streamlit/proto/Balloons_pb2.pyi +43 -0
  153. streamlit/proto/Block_pb2.py +53 -0
  154. streamlit/proto/Block_pb2.pyi +322 -0
  155. streamlit/proto/BokehChart_pb2.py +27 -0
  156. streamlit/proto/BokehChart_pb2.pyi +49 -0
  157. streamlit/proto/ButtonGroup_pb2.py +36 -0
  158. streamlit/proto/ButtonGroup_pb2.pyi +169 -0
  159. streamlit/proto/Button_pb2.py +27 -0
  160. streamlit/proto/Button_pb2.pyi +71 -0
  161. streamlit/proto/CameraInput_pb2.py +28 -0
  162. streamlit/proto/CameraInput_pb2.pyi +58 -0
  163. streamlit/proto/ChatInput_pb2.py +31 -0
  164. streamlit/proto/ChatInput_pb2.pyi +111 -0
  165. streamlit/proto/Checkbox_pb2.py +30 -0
  166. streamlit/proto/Checkbox_pb2.pyi +90 -0
  167. streamlit/proto/ClientState_pb2.py +30 -0
  168. streamlit/proto/ClientState_pb2.pyi +90 -0
  169. streamlit/proto/Code_pb2.py +27 -0
  170. streamlit/proto/Code_pb2.pyi +55 -0
  171. streamlit/proto/ColorPicker_pb2.py +28 -0
  172. streamlit/proto/ColorPicker_pb2.pyi +67 -0
  173. streamlit/proto/Common_pb2.py +51 -0
  174. streamlit/proto/Common_pb2.pyi +293 -0
  175. streamlit/proto/Components_pb2.py +35 -0
  176. streamlit/proto/Components_pb2.pyi +172 -0
  177. streamlit/proto/DataFrame_pb2.py +56 -0
  178. streamlit/proto/DataFrame_pb2.pyi +397 -0
  179. streamlit/proto/DateInput_pb2.py +28 -0
  180. streamlit/proto/DateInput_pb2.pyi +83 -0
  181. streamlit/proto/DeckGlJsonChart_pb2.py +29 -0
  182. streamlit/proto/DeckGlJsonChart_pb2.pyi +102 -0
  183. streamlit/proto/Delta_pb2.py +31 -0
  184. streamlit/proto/Delta_pb2.pyi +74 -0
  185. streamlit/proto/DocString_pb2.py +29 -0
  186. streamlit/proto/DocString_pb2.pyi +93 -0
  187. streamlit/proto/DownloadButton_pb2.py +27 -0
  188. streamlit/proto/DownloadButton_pb2.pyi +70 -0
  189. streamlit/proto/Element_pb2.py +78 -0
  190. streamlit/proto/Element_pb2.pyi +312 -0
  191. streamlit/proto/Empty_pb2.py +27 -0
  192. streamlit/proto/Empty_pb2.pyi +36 -0
  193. streamlit/proto/Exception_pb2.py +27 -0
  194. streamlit/proto/Exception_pb2.pyi +72 -0
  195. streamlit/proto/Favicon_pb2.py +27 -0
  196. streamlit/proto/Favicon_pb2.pyi +40 -0
  197. streamlit/proto/FileUploader_pb2.py +28 -0
  198. streamlit/proto/FileUploader_pb2.pyi +78 -0
  199. streamlit/proto/ForwardMsg_pb2.py +53 -0
  200. streamlit/proto/ForwardMsg_pb2.pyi +293 -0
  201. streamlit/proto/GitInfo_pb2.py +29 -0
  202. streamlit/proto/GitInfo_pb2.pyi +83 -0
  203. streamlit/proto/GraphVizChart_pb2.py +27 -0
  204. streamlit/proto/GraphVizChart_pb2.pyi +53 -0
  205. streamlit/proto/Heading_pb2.py +27 -0
  206. streamlit/proto/Heading_pb2.pyi +56 -0
  207. streamlit/proto/Html_pb2.py +27 -0
  208. streamlit/proto/Html_pb2.pyi +42 -0
  209. streamlit/proto/IFrame_pb2.py +27 -0
  210. streamlit/proto/IFrame_pb2.pyi +59 -0
  211. streamlit/proto/Image_pb2.py +29 -0
  212. streamlit/proto/Image_pb2.pyi +84 -0
  213. streamlit/proto/Json_pb2.py +27 -0
  214. streamlit/proto/Json_pb2.pyi +53 -0
  215. streamlit/proto/LabelVisibilityMessage_pb2.py +29 -0
  216. streamlit/proto/LabelVisibilityMessage_pb2.pyi +68 -0
  217. streamlit/proto/LinkButton_pb2.py +27 -0
  218. streamlit/proto/LinkButton_pb2.pyi +58 -0
  219. streamlit/proto/Logo_pb2.py +27 -0
  220. streamlit/proto/Logo_pb2.pyi +51 -0
  221. streamlit/proto/Markdown_pb2.py +29 -0
  222. streamlit/proto/Markdown_pb2.pyi +86 -0
  223. streamlit/proto/Metric_pb2.py +32 -0
  224. streamlit/proto/Metric_pb2.pyi +101 -0
  225. streamlit/proto/MetricsEvent_pb2.py +30 -0
  226. streamlit/proto/MetricsEvent_pb2.pyi +200 -0
  227. streamlit/proto/MultiSelect_pb2.py +28 -0
  228. streamlit/proto/MultiSelect_pb2.pyi +81 -0
  229. streamlit/proto/NamedDataSet_pb2.py +28 -0
  230. streamlit/proto/NamedDataSet_pb2.pyi +59 -0
  231. streamlit/proto/Navigation_pb2.py +30 -0
  232. streamlit/proto/Navigation_pb2.pyi +84 -0
  233. streamlit/proto/NewSession_pb2.py +51 -0
  234. streamlit/proto/NewSession_pb2.pyi +481 -0
  235. streamlit/proto/NumberInput_pb2.py +30 -0
  236. streamlit/proto/NumberInput_pb2.pyi +121 -0
  237. streamlit/proto/PageConfig_pb2.py +33 -0
  238. streamlit/proto/PageConfig_pb2.pyi +126 -0
  239. streamlit/proto/PageInfo_pb2.py +27 -0
  240. streamlit/proto/PageInfo_pb2.pyi +43 -0
  241. streamlit/proto/PageLink_pb2.py +27 -0
  242. streamlit/proto/PageLink_pb2.pyi +63 -0
  243. streamlit/proto/PageNotFound_pb2.py +27 -0
  244. streamlit/proto/PageNotFound_pb2.pyi +42 -0
  245. streamlit/proto/PageProfile_pb2.py +31 -0
  246. streamlit/proto/PageProfile_pb2.pyi +127 -0
  247. streamlit/proto/PagesChanged_pb2.py +28 -0
  248. streamlit/proto/PagesChanged_pb2.pyi +48 -0
  249. streamlit/proto/ParentMessage_pb2.py +27 -0
  250. streamlit/proto/ParentMessage_pb2.pyi +46 -0
  251. streamlit/proto/PlotlyChart_pb2.py +31 -0
  252. streamlit/proto/PlotlyChart_pb2.pyi +131 -0
  253. streamlit/proto/Progress_pb2.py +27 -0
  254. streamlit/proto/Progress_pb2.pyi +43 -0
  255. streamlit/proto/Radio_pb2.py +28 -0
  256. streamlit/proto/Radio_pb2.pyi +84 -0
  257. streamlit/proto/RootContainer_pb2.py +27 -0
  258. streamlit/proto/RootContainer_pb2.pyi +56 -0
  259. streamlit/proto/Selectbox_pb2.py +28 -0
  260. streamlit/proto/Selectbox_pb2.pyi +80 -0
  261. streamlit/proto/SessionEvent_pb2.py +28 -0
  262. streamlit/proto/SessionEvent_pb2.pyi +62 -0
  263. streamlit/proto/SessionStatus_pb2.py +27 -0
  264. streamlit/proto/SessionStatus_pb2.pyi +57 -0
  265. streamlit/proto/Skeleton_pb2.py +29 -0
  266. streamlit/proto/Skeleton_pb2.pyi +71 -0
  267. streamlit/proto/Slider_pb2.py +32 -0
  268. streamlit/proto/Slider_pb2.pyi +142 -0
  269. streamlit/proto/Snow_pb2.py +27 -0
  270. streamlit/proto/Snow_pb2.pyi +43 -0
  271. streamlit/proto/Spinner_pb2.py +27 -0
  272. streamlit/proto/Spinner_pb2.pyi +49 -0
  273. streamlit/proto/TextArea_pb2.py +28 -0
  274. streamlit/proto/TextArea_pb2.pyi +80 -0
  275. streamlit/proto/TextInput_pb2.py +30 -0
  276. streamlit/proto/TextInput_pb2.pyi +107 -0
  277. streamlit/proto/Text_pb2.py +27 -0
  278. streamlit/proto/Text_pb2.pyi +46 -0
  279. streamlit/proto/TimeInput_pb2.py +28 -0
  280. streamlit/proto/TimeInput_pb2.pyi +74 -0
  281. streamlit/proto/Toast_pb2.py +27 -0
  282. streamlit/proto/Toast_pb2.pyi +45 -0
  283. streamlit/proto/VegaLiteChart_pb2.py +29 -0
  284. streamlit/proto/VegaLiteChart_pb2.pyi +71 -0
  285. streamlit/proto/Video_pb2.py +31 -0
  286. streamlit/proto/Video_pb2.pyi +117 -0
  287. streamlit/proto/WidgetStates_pb2.py +31 -0
  288. streamlit/proto/WidgetStates_pb2.pyi +126 -0
  289. streamlit/proto/__init__.py +15 -0
  290. streamlit/proto/openmetrics_data_model_pb2.py +60 -0
  291. streamlit/proto/openmetrics_data_model_pb2.pyi +522 -0
  292. streamlit/py.typed +0 -0
  293. streamlit/runtime/__init__.py +50 -0
  294. streamlit/runtime/app_session.py +982 -0
  295. streamlit/runtime/caching/__init__.py +98 -0
  296. streamlit/runtime/caching/cache_data_api.py +665 -0
  297. streamlit/runtime/caching/cache_errors.py +142 -0
  298. streamlit/runtime/caching/cache_resource_api.py +527 -0
  299. streamlit/runtime/caching/cache_type.py +33 -0
  300. streamlit/runtime/caching/cache_utils.py +523 -0
  301. streamlit/runtime/caching/cached_message_replay.py +290 -0
  302. streamlit/runtime/caching/hashing.py +637 -0
  303. streamlit/runtime/caching/legacy_cache_api.py +169 -0
  304. streamlit/runtime/caching/storage/__init__.py +29 -0
  305. streamlit/runtime/caching/storage/cache_storage_protocol.py +239 -0
  306. streamlit/runtime/caching/storage/dummy_cache_storage.py +60 -0
  307. streamlit/runtime/caching/storage/in_memory_cache_storage_wrapper.py +145 -0
  308. streamlit/runtime/caching/storage/local_disk_cache_storage.py +223 -0
  309. streamlit/runtime/connection_factory.py +436 -0
  310. streamlit/runtime/context.py +280 -0
  311. streamlit/runtime/credentials.py +364 -0
  312. streamlit/runtime/forward_msg_cache.py +296 -0
  313. streamlit/runtime/forward_msg_queue.py +240 -0
  314. streamlit/runtime/fragment.py +477 -0
  315. streamlit/runtime/media_file_manager.py +234 -0
  316. streamlit/runtime/media_file_storage.py +143 -0
  317. streamlit/runtime/memory_media_file_storage.py +181 -0
  318. streamlit/runtime/memory_session_storage.py +77 -0
  319. streamlit/runtime/memory_uploaded_file_manager.py +138 -0
  320. streamlit/runtime/metrics_util.py +486 -0
  321. streamlit/runtime/pages_manager.py +165 -0
  322. streamlit/runtime/runtime.py +792 -0
  323. streamlit/runtime/runtime_util.py +106 -0
  324. streamlit/runtime/script_data.py +46 -0
  325. streamlit/runtime/scriptrunner/__init__.py +38 -0
  326. streamlit/runtime/scriptrunner/exec_code.py +159 -0
  327. streamlit/runtime/scriptrunner/magic.py +273 -0
  328. streamlit/runtime/scriptrunner/magic_funcs.py +32 -0
  329. streamlit/runtime/scriptrunner/script_cache.py +89 -0
  330. streamlit/runtime/scriptrunner/script_runner.py +756 -0
  331. streamlit/runtime/scriptrunner_utils/__init__.py +19 -0
  332. streamlit/runtime/scriptrunner_utils/exceptions.py +48 -0
  333. streamlit/runtime/scriptrunner_utils/script_requests.py +307 -0
  334. streamlit/runtime/scriptrunner_utils/script_run_context.py +287 -0
  335. streamlit/runtime/secrets.py +534 -0
  336. streamlit/runtime/session_manager.py +394 -0
  337. streamlit/runtime/state/__init__.py +41 -0
  338. streamlit/runtime/state/common.py +191 -0
  339. streamlit/runtime/state/query_params.py +205 -0
  340. streamlit/runtime/state/query_params_proxy.py +218 -0
  341. streamlit/runtime/state/safe_session_state.py +138 -0
  342. streamlit/runtime/state/session_state.py +772 -0
  343. streamlit/runtime/state/session_state_proxy.py +153 -0
  344. streamlit/runtime/state/widgets.py +135 -0
  345. streamlit/runtime/stats.py +109 -0
  346. streamlit/runtime/uploaded_file_manager.py +148 -0
  347. streamlit/runtime/websocket_session_manager.py +167 -0
  348. streamlit/source_util.py +98 -0
  349. streamlit/static/favicon.png +0 -0
  350. streamlit/static/index.html +61 -0
  351. streamlit/static/static/css/index.Bmkmz40k.css +1 -0
  352. streamlit/static/static/css/index.DpJG_94W.css +1 -0
  353. streamlit/static/static/css/index.DzuxGC_t.css +1 -0
  354. streamlit/static/static/js/FileDownload.esm.Bp9m5jrx.js +1 -0
  355. streamlit/static/static/js/FileHelper.D_3pbilj.js +5 -0
  356. streamlit/static/static/js/FormClearHelper.Ct2rwLXo.js +1 -0
  357. streamlit/static/static/js/Hooks.BKdzj5MJ.js +1 -0
  358. streamlit/static/static/js/InputInstructions.DB3QGNJP.js +1 -0
  359. streamlit/static/static/js/ProgressBar.D40A5xc2.js +2 -0
  360. streamlit/static/static/js/RenderInPortalIfExists.DLUCooTN.js +1 -0
  361. streamlit/static/static/js/Toolbar.BiGGIQun.js +1 -0
  362. streamlit/static/static/js/UploadFileInfo.C-jY39rj.js +1 -0
  363. streamlit/static/static/js/base-input.CQBQT24M.js +4 -0
  364. streamlit/static/static/js/checkbox.Buj8gd_M.js +9 -0
  365. streamlit/static/static/js/createDownloadLinkElement.DZMwyjvU.js +1 -0
  366. streamlit/static/static/js/createSuper.CesK3I23.js +1 -0
  367. streamlit/static/static/js/data-grid-overlay-editor.B69OOFM4.js +1 -0
  368. streamlit/static/static/js/downloader.BZQhlBNT.js +1 -0
  369. streamlit/static/static/js/es6.D9Zhqujy.js +2 -0
  370. streamlit/static/static/js/iframeResizer.contentWindow.CAzcBpCC.js +1 -0
  371. streamlit/static/static/js/index.08vcOOvb.js +1 -0
  372. streamlit/static/static/js/index.0uqKfJUS.js +1 -0
  373. streamlit/static/static/js/index.B02M5u69.js +203 -0
  374. streamlit/static/static/js/index.B7mcZKMx.js +1 -0
  375. streamlit/static/static/js/index.BAQDHFA_.js +1 -0
  376. streamlit/static/static/js/index.BI60cMVr.js +2 -0
  377. streamlit/static/static/js/index.BLug2inK.js +1 -0
  378. streamlit/static/static/js/index.BM6TMY8g.js +2 -0
  379. streamlit/static/static/js/index.BZ9p1t7G.js +1 -0
  380. streamlit/static/static/js/index.BZqa87a1.js +2 -0
  381. streamlit/static/static/js/index.BcsRUzZZ.js +1 -0
  382. streamlit/static/static/js/index.BgVMiY_P.js +197 -0
  383. streamlit/static/static/js/index.BtuGy7By.js +6 -0
  384. streamlit/static/static/js/index.BuDuBmrs.js +1 -0
  385. streamlit/static/static/js/index.BvXU2oKV.js +1 -0
  386. streamlit/static/static/js/index.BxcwPacT.js +73 -0
  387. streamlit/static/static/js/index.CWX8KB81.js +1 -0
  388. streamlit/static/static/js/index.CXzZTo_q.js +1 -0
  389. streamlit/static/static/js/index.CcRWp_KL.js +1 -0
  390. streamlit/static/static/js/index.Cd-_xe55.js +3 -0
  391. streamlit/static/static/js/index.CdG2PXln.js +4537 -0
  392. streamlit/static/static/js/index.CjXvXmcP.js +1 -0
  393. streamlit/static/static/js/index.D1HZENZx.js +776 -0
  394. streamlit/static/static/js/index.D21Efo64.js +1617 -0
  395. streamlit/static/static/js/index.D9WgGVBx.js +7 -0
  396. streamlit/static/static/js/index.DEcsHtvb.js +12 -0
  397. streamlit/static/static/js/index.DFeMfr_K.js +1 -0
  398. streamlit/static/static/js/index.DHFBoItz.js +1 -0
  399. streamlit/static/static/js/index.D_PrBKnJ.js +3 -0
  400. streamlit/static/static/js/index.DmuRkekN.js +3855 -0
  401. streamlit/static/static/js/index.Do6eY8sf.js +1 -0
  402. streamlit/static/static/js/index.Dz3lP2P-.js +1 -0
  403. streamlit/static/static/js/index.Dz_UqF-s.js +1 -0
  404. streamlit/static/static/js/index.GkSUsPhJ.js +1 -0
  405. streamlit/static/static/js/index.H1U1IC_d.js +3 -0
  406. streamlit/static/static/js/index.g6p_4DPr.js +1 -0
  407. streamlit/static/static/js/index.g9x_GKss.js +1 -0
  408. streamlit/static/static/js/index.zo9jm08y.js +1 -0
  409. streamlit/static/static/js/input.DnaFglHq.js +2 -0
  410. streamlit/static/static/js/inputUtils.CQWz5UKz.js +1 -0
  411. streamlit/static/static/js/memory.Crb9x4-F.js +1 -0
  412. streamlit/static/static/js/mergeWith.ouAz0sK3.js +1 -0
  413. streamlit/static/static/js/number-overlay-editor._UaN-O48.js +9 -0
  414. streamlit/static/static/js/possibleConstructorReturn.CtGjGFHz.js +1 -0
  415. streamlit/static/static/js/sandbox.CBybYOhV.js +1 -0
  416. streamlit/static/static/js/sprintf.D7DtBTRn.js +1 -0
  417. streamlit/static/static/js/textarea.Cb_uJt5U.js +2 -0
  418. streamlit/static/static/js/threshold.DjX0wlsa.js +1 -0
  419. streamlit/static/static/js/timepicker.DKT7pfoF.js +4 -0
  420. streamlit/static/static/js/timer.CAwTRJ_g.js +1 -0
  421. streamlit/static/static/js/toConsumableArray.05Ikp13-.js +3 -0
  422. streamlit/static/static/js/uniqueId.D2FMWUEI.js +1 -0
  423. streamlit/static/static/js/useBasicWidgetState.urnZLANY.js +1 -0
  424. streamlit/static/static/js/useOnInputChange.BOKIIdJ1.js +1 -0
  425. streamlit/static/static/js/value.CgPGBV_l.js +1 -0
  426. streamlit/static/static/js/withFullScreenWrapper.C_N8J0Xx.js +1 -0
  427. streamlit/static/static/media/KaTeX_AMS-Regular.BQhdFMY1.woff2 +0 -0
  428. streamlit/static/static/media/KaTeX_AMS-Regular.DMm9YOAa.woff +0 -0
  429. streamlit/static/static/media/KaTeX_AMS-Regular.DRggAlZN.ttf +0 -0
  430. streamlit/static/static/media/KaTeX_Caligraphic-Bold.ATXxdsX0.ttf +0 -0
  431. streamlit/static/static/media/KaTeX_Caligraphic-Bold.BEiXGLvX.woff +0 -0
  432. streamlit/static/static/media/KaTeX_Caligraphic-Bold.Dq_IR9rO.woff2 +0 -0
  433. streamlit/static/static/media/KaTeX_Caligraphic-Regular.CTRA-rTL.woff +0 -0
  434. streamlit/static/static/media/KaTeX_Caligraphic-Regular.Di6jR-x-.woff2 +0 -0
  435. streamlit/static/static/media/KaTeX_Caligraphic-Regular.wX97UBjC.ttf +0 -0
  436. streamlit/static/static/media/KaTeX_Fraktur-Bold.BdnERNNW.ttf +0 -0
  437. streamlit/static/static/media/KaTeX_Fraktur-Bold.BsDP51OF.woff +0 -0
  438. streamlit/static/static/media/KaTeX_Fraktur-Bold.CL6g_b3V.woff2 +0 -0
  439. streamlit/static/static/media/KaTeX_Fraktur-Regular.CB_wures.ttf +0 -0
  440. streamlit/static/static/media/KaTeX_Fraktur-Regular.CTYiF6lA.woff2 +0 -0
  441. streamlit/static/static/media/KaTeX_Fraktur-Regular.Dxdc4cR9.woff +0 -0
  442. streamlit/static/static/media/KaTeX_Main-Bold.Cx986IdX.woff2 +0 -0
  443. streamlit/static/static/media/KaTeX_Main-Bold.Jm3AIy58.woff +0 -0
  444. streamlit/static/static/media/KaTeX_Main-Bold.waoOVXN0.ttf +0 -0
  445. streamlit/static/static/media/KaTeX_Main-BoldItalic.DxDJ3AOS.woff2 +0 -0
  446. streamlit/static/static/media/KaTeX_Main-BoldItalic.DzxPMmG6.ttf +0 -0
  447. streamlit/static/static/media/KaTeX_Main-BoldItalic.SpSLRI95.woff +0 -0
  448. streamlit/static/static/media/KaTeX_Main-Italic.3WenGoN9.ttf +0 -0
  449. streamlit/static/static/media/KaTeX_Main-Italic.BMLOBm91.woff +0 -0
  450. streamlit/static/static/media/KaTeX_Main-Italic.NWA7e6Wa.woff2 +0 -0
  451. streamlit/static/static/media/KaTeX_Main-Regular.B22Nviop.woff2 +0 -0
  452. streamlit/static/static/media/KaTeX_Main-Regular.Dr94JaBh.woff +0 -0
  453. streamlit/static/static/media/KaTeX_Main-Regular.ypZvNtVU.ttf +0 -0
  454. streamlit/static/static/media/KaTeX_Math-BoldItalic.B3XSjfu4.ttf +0 -0
  455. streamlit/static/static/media/KaTeX_Math-BoldItalic.CZnvNsCZ.woff2 +0 -0
  456. streamlit/static/static/media/KaTeX_Math-BoldItalic.iY-2wyZ7.woff +0 -0
  457. streamlit/static/static/media/KaTeX_Math-Italic.DA0__PXp.woff +0 -0
  458. streamlit/static/static/media/KaTeX_Math-Italic.flOr_0UB.ttf +0 -0
  459. streamlit/static/static/media/KaTeX_Math-Italic.t53AETM-.woff2 +0 -0
  460. streamlit/static/static/media/KaTeX_SansSerif-Bold.CFMepnvq.ttf +0 -0
  461. streamlit/static/static/media/KaTeX_SansSerif-Bold.D1sUS0GD.woff2 +0 -0
  462. streamlit/static/static/media/KaTeX_SansSerif-Bold.DbIhKOiC.woff +0 -0
  463. streamlit/static/static/media/KaTeX_SansSerif-Italic.C3H0VqGB.woff2 +0 -0
  464. streamlit/static/static/media/KaTeX_SansSerif-Italic.DN2j7dab.woff +0 -0
  465. streamlit/static/static/media/KaTeX_SansSerif-Italic.YYjJ1zSn.ttf +0 -0
  466. streamlit/static/static/media/KaTeX_SansSerif-Regular.BNo7hRIc.ttf +0 -0
  467. streamlit/static/static/media/KaTeX_SansSerif-Regular.CS6fqUqJ.woff +0 -0
  468. streamlit/static/static/media/KaTeX_SansSerif-Regular.DDBCnlJ7.woff2 +0 -0
  469. streamlit/static/static/media/KaTeX_Script-Regular.C5JkGWo-.ttf +0 -0
  470. streamlit/static/static/media/KaTeX_Script-Regular.D3wIWfF6.woff2 +0 -0
  471. streamlit/static/static/media/KaTeX_Script-Regular.D5yQViql.woff +0 -0
  472. streamlit/static/static/media/KaTeX_Size1-Regular.C195tn64.woff +0 -0
  473. streamlit/static/static/media/KaTeX_Size1-Regular.Dbsnue_I.ttf +0 -0
  474. streamlit/static/static/media/KaTeX_Size1-Regular.mCD8mA8B.woff2 +0 -0
  475. streamlit/static/static/media/KaTeX_Size2-Regular.B7gKUWhC.ttf +0 -0
  476. streamlit/static/static/media/KaTeX_Size2-Regular.Dy4dx90m.woff2 +0 -0
  477. streamlit/static/static/media/KaTeX_Size2-Regular.oD1tc_U0.woff +0 -0
  478. streamlit/static/static/media/KaTeX_Size3-Regular.CTq5MqoE.woff +0 -0
  479. streamlit/static/static/media/KaTeX_Size3-Regular.DgpXs0kz.ttf +0 -0
  480. streamlit/static/static/media/KaTeX_Size4-Regular.BF-4gkZK.woff +0 -0
  481. streamlit/static/static/media/KaTeX_Size4-Regular.DWFBv043.ttf +0 -0
  482. streamlit/static/static/media/KaTeX_Size4-Regular.Dl5lxZxV.woff2 +0 -0
  483. streamlit/static/static/media/KaTeX_Typewriter-Regular.C0xS9mPB.woff +0 -0
  484. streamlit/static/static/media/KaTeX_Typewriter-Regular.CO6r4hn1.woff2 +0 -0
  485. streamlit/static/static/media/KaTeX_Typewriter-Regular.D3Ib7_Hf.ttf +0 -0
  486. streamlit/static/static/media/MaterialSymbols-Rounded.DcZbplWk.woff2 +0 -0
  487. streamlit/static/static/media/SourceCodePro-Bold.CFEfr7-q.woff2 +0 -0
  488. streamlit/static/static/media/SourceCodePro-BoldItalic.C-LkFXxa.woff2 +0 -0
  489. streamlit/static/static/media/SourceCodePro-Italic.CxFOx7N-.woff2 +0 -0
  490. streamlit/static/static/media/SourceCodePro-Regular.CBOlD63d.woff2 +0 -0
  491. streamlit/static/static/media/SourceCodePro-SemiBold.CFHwW3Wd.woff2 +0 -0
  492. streamlit/static/static/media/SourceCodePro-SemiBoldItalic.Cg2yRu82.woff2 +0 -0
  493. streamlit/static/static/media/SourceSansPro-Bold.-6c9oR8J.woff2 +0 -0
  494. streamlit/static/static/media/SourceSansPro-BoldItalic.DmM_grLY.woff2 +0 -0
  495. streamlit/static/static/media/SourceSansPro-Italic.I1ipWe7Q.woff2 +0 -0
  496. streamlit/static/static/media/SourceSansPro-Regular.DZLUzqI4.woff2 +0 -0
  497. streamlit/static/static/media/SourceSansPro-SemiBold.sKQIyTMz.woff2 +0 -0
  498. streamlit/static/static/media/SourceSansPro-SemiBoldItalic.C0wP0icr.woff2 +0 -0
  499. streamlit/static/static/media/SourceSerifPro-Bold.8TUnKj4x.woff2 +0 -0
  500. streamlit/static/static/media/SourceSerifPro-BoldItalic.CBVO7Ve7.woff2 +0 -0
  501. streamlit/static/static/media/SourceSerifPro-Italic.DkFgL2HZ.woff2 +0 -0
  502. streamlit/static/static/media/SourceSerifPro-Regular.CNJNET2S.woff2 +0 -0
  503. streamlit/static/static/media/SourceSerifPro-SemiBold.CHyh9GC5.woff2 +0 -0
  504. streamlit/static/static/media/SourceSerifPro-SemiBoldItalic.CBtz8sWN.woff2 +0 -0
  505. streamlit/static/static/media/balloon-0.Czj7AKwE.png +0 -0
  506. streamlit/static/static/media/balloon-1.CNvFFrND.png +0 -0
  507. streamlit/static/static/media/balloon-2.DTvC6B1t.png +0 -0
  508. streamlit/static/static/media/balloon-3.CgSk4tbL.png +0 -0
  509. streamlit/static/static/media/balloon-4.mbtFrzxf.png +0 -0
  510. streamlit/static/static/media/balloon-5.CSwkUfRA.png +0 -0
  511. streamlit/static/static/media/fireworks.B4d-_KUe.gif +0 -0
  512. streamlit/static/static/media/flake-0.DgWaVvm5.png +0 -0
  513. streamlit/static/static/media/flake-1.B2r5AHMK.png +0 -0
  514. streamlit/static/static/media/flake-2.BnWSExPC.png +0 -0
  515. streamlit/static/static/media/snowflake.JU2jBHL8.svg +11 -0
  516. streamlit/string_util.py +203 -0
  517. streamlit/temporary_directory.py +56 -0
  518. streamlit/testing/__init__.py +13 -0
  519. streamlit/testing/v1/__init__.py +17 -0
  520. streamlit/testing/v1/app_test.py +1050 -0
  521. streamlit/testing/v1/element_tree.py +2083 -0
  522. streamlit/testing/v1/local_script_runner.py +180 -0
  523. streamlit/testing/v1/util.py +53 -0
  524. streamlit/time_util.py +75 -0
  525. streamlit/type_util.py +460 -0
  526. streamlit/url_util.py +122 -0
  527. streamlit/user_info.py +519 -0
  528. streamlit/util.py +72 -0
  529. streamlit/vendor/__init__.py +0 -0
  530. streamlit/vendor/pympler/__init__.py +0 -0
  531. streamlit/vendor/pympler/asizeof.py +2869 -0
  532. streamlit/version.py +18 -0
  533. streamlit/watcher/__init__.py +28 -0
  534. streamlit/watcher/event_based_path_watcher.py +406 -0
  535. streamlit/watcher/folder_black_list.py +82 -0
  536. streamlit/watcher/local_sources_watcher.py +233 -0
  537. streamlit/watcher/path_watcher.py +185 -0
  538. streamlit/watcher/polling_path_watcher.py +124 -0
  539. streamlit/watcher/util.py +207 -0
  540. streamlit/web/__init__.py +13 -0
  541. streamlit/web/bootstrap.py +353 -0
  542. streamlit/web/cache_storage_manager_config.py +38 -0
  543. streamlit/web/cli.py +369 -0
  544. streamlit/web/server/__init__.py +26 -0
  545. streamlit/web/server/app_static_file_handler.py +93 -0
  546. streamlit/web/server/authlib_tornado_integration.py +60 -0
  547. streamlit/web/server/browser_websocket_handler.py +246 -0
  548. streamlit/web/server/component_request_handler.py +116 -0
  549. streamlit/web/server/media_file_handler.py +141 -0
  550. streamlit/web/server/oauth_authlib_routes.py +176 -0
  551. streamlit/web/server/oidc_mixin.py +108 -0
  552. streamlit/web/server/routes.py +295 -0
  553. streamlit/web/server/server.py +479 -0
  554. streamlit/web/server/server_util.py +161 -0
  555. streamlit/web/server/stats_request_handler.py +95 -0
  556. streamlit/web/server/upload_file_request_handler.py +137 -0
  557. streamlit/web/server/websocket_headers.py +56 -0
  558. streamlit_nightly-1.43.2.dev20250307.data/scripts/streamlit.cmd +16 -0
  559. streamlit_nightly-1.43.2.dev20250307.dist-info/METADATA +207 -0
  560. streamlit_nightly-1.43.2.dev20250307.dist-info/RECORD +563 -0
  561. streamlit_nightly-1.43.2.dev20250307.dist-info/WHEEL +5 -0
  562. streamlit_nightly-1.43.2.dev20250307.dist-info/entry_points.txt +2 -0
  563. streamlit_nightly-1.43.2.dev20250307.dist-info/top_level.txt +1 -0
@@ -0,0 +1,331 @@
1
+ # Copyright (c) Streamlit Inc. (2018-2022) Snowflake Inc. (2022-2025)
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ from __future__ import annotations
16
+
17
+ import os
18
+ import traceback
19
+ from typing import TYPE_CHECKING, Callable, Final, TypeVar, cast
20
+
21
+ from streamlit import config
22
+ from streamlit.errors import (
23
+ MarkdownFormattedException,
24
+ StreamlitAPIWarning,
25
+ )
26
+ from streamlit.logger import get_logger
27
+ from streamlit.proto.Exception_pb2 import Exception as ExceptionProto
28
+ from streamlit.runtime.metrics_util import gather_metrics
29
+ from streamlit.runtime.scriptrunner_utils.script_run_context import get_script_run_ctx
30
+
31
+ if TYPE_CHECKING:
32
+ from streamlit.delta_generator import DeltaGenerator
33
+
34
+ _LOGGER: Final = get_logger(__name__)
35
+
36
+ # When client.showErrorDetails is False, we show a generic warning in the
37
+ # frontend when we encounter an uncaught app exception.
38
+ _GENERIC_UNCAUGHT_EXCEPTION_TEXT: Final = "This app has encountered an error. The original error message is redacted to prevent data leaks. Full error details have been recorded in the logs (if you're on Streamlit Cloud, click on 'Manage app' in the lower right of your app)."
39
+
40
+
41
+ class ExceptionMixin:
42
+ @gather_metrics("exception")
43
+ def exception(self, exception: BaseException) -> DeltaGenerator:
44
+ """Display an exception.
45
+
46
+ Parameters
47
+ ----------
48
+ exception : Exception
49
+ The exception to display.
50
+
51
+ Example
52
+ -------
53
+ >>> import streamlit as st
54
+ >>>
55
+ >>> e = RuntimeError("This is an exception of type RuntimeError")
56
+ >>> st.exception(e)
57
+
58
+ """
59
+ return _exception(self.dg, exception)
60
+
61
+ @property
62
+ def dg(self) -> DeltaGenerator:
63
+ """Get our DeltaGenerator."""
64
+ return cast("DeltaGenerator", self)
65
+
66
+
67
+ # TODO(lawilby): confirm whether we want to track metrics here with lukasmasuch.
68
+ @gather_metrics("exception")
69
+ def _exception(
70
+ dg: DeltaGenerator,
71
+ exception: BaseException,
72
+ is_uncaught_app_exception: bool = False,
73
+ ) -> DeltaGenerator:
74
+ exception_proto = ExceptionProto()
75
+ marshall(exception_proto, exception, is_uncaught_app_exception)
76
+ return dg._enqueue("exception", exception_proto)
77
+
78
+
79
+ def marshall(
80
+ exception_proto: ExceptionProto,
81
+ exception: BaseException,
82
+ is_uncaught_app_exception: bool = False,
83
+ ) -> None:
84
+ """Marshalls an Exception.proto message.
85
+
86
+ Parameters
87
+ ----------
88
+ exception_proto : Exception.proto
89
+ The Exception protobuf to fill out.
90
+
91
+ exception : BaseException
92
+ The exception whose data we're extracting.
93
+
94
+ is_uncaught_app_exception: bool
95
+ The exception originates from an uncaught error during script execution.
96
+ """
97
+ is_markdown_exception = isinstance(exception, MarkdownFormattedException)
98
+
99
+ # Some exceptions (like UserHashError) have an alternate_name attribute so
100
+ # we can pretend to the user that the exception is called something else.
101
+ if getattr(exception, "alternate_name", None) is not None:
102
+ exception_proto.type = exception.alternate_name # type: ignore[attr-defined]
103
+ else:
104
+ exception_proto.type = type(exception).__name__
105
+
106
+ stack_trace = _get_stack_trace_str_list(exception)
107
+
108
+ exception_proto.stack_trace.extend(stack_trace)
109
+ exception_proto.is_warning = isinstance(exception, Warning)
110
+
111
+ try:
112
+ if isinstance(exception, SyntaxError):
113
+ # SyntaxErrors have additional fields (filename, text, lineno,
114
+ # offset) that we can use for a nicely-formatted message telling
115
+ # the user what to fix.
116
+ exception_proto.message = _format_syntax_error_message(exception)
117
+ else:
118
+ exception_proto.message = str(exception).strip()
119
+ exception_proto.message_is_markdown = is_markdown_exception
120
+
121
+ except Exception as str_exception:
122
+ # Sometimes the exception's __str__/__unicode__ method itself
123
+ # raises an error.
124
+ exception_proto.message = ""
125
+ _LOGGER.warning(
126
+ """
127
+
128
+ Streamlit was unable to parse the data from an exception in the user's script.
129
+ This is usually due to a bug in the Exception object itself. Here is some info
130
+ about that Exception object, so you can report a bug to the original author:
131
+
132
+ Exception type:
133
+ %s
134
+
135
+ Problem:
136
+ %s
137
+
138
+ Traceback:
139
+ %s
140
+
141
+ """,
142
+ type(exception).__name__,
143
+ str_exception,
144
+ "\n".join(_get_stack_trace_str_list(str_exception)),
145
+ )
146
+
147
+ if is_uncaught_app_exception:
148
+ show_error_details = config.get_option("client.showErrorDetails")
149
+
150
+ show_message = (
151
+ show_error_details == config.ShowErrorDetailsConfigOptions.FULL
152
+ or config.ShowErrorDetailsConfigOptions.is_true_variation(
153
+ show_error_details
154
+ )
155
+ )
156
+ # False is a legacy config option still in-use in community cloud. It is equivalent
157
+ # to "stacktrace".
158
+ show_trace = (
159
+ show_message
160
+ or show_error_details == config.ShowErrorDetailsConfigOptions.STACKTRACE
161
+ or config.ShowErrorDetailsConfigOptions.is_false_variation(
162
+ show_error_details
163
+ )
164
+ )
165
+ show_type = (
166
+ show_trace
167
+ or show_error_details == config.ShowErrorDetailsConfigOptions.TYPE
168
+ )
169
+
170
+ if not show_message:
171
+ exception_proto.message = _GENERIC_UNCAUGHT_EXCEPTION_TEXT
172
+ if not show_type:
173
+ exception_proto.ClearField("type")
174
+ else:
175
+ type_str = str(type(exception))
176
+ exception_proto.type = type_str.replace("<class '", "").replace("'>", "")
177
+ if not show_trace:
178
+ exception_proto.ClearField("stack_trace")
179
+
180
+
181
+ def _format_syntax_error_message(exception: SyntaxError) -> str:
182
+ """Returns a nicely formatted SyntaxError message that emulates
183
+ what the Python interpreter outputs, e.g.:
184
+
185
+ > File "raven.py", line 3
186
+ > st.write('Hello world!!'))
187
+ > ^
188
+ > SyntaxError: invalid syntax
189
+
190
+ """
191
+ if exception.text:
192
+ if exception.offset is not None:
193
+ caret_indent = " " * max(exception.offset - 1, 0)
194
+ else:
195
+ caret_indent = ""
196
+
197
+ return (
198
+ 'File "%(filename)s", line %(lineno)s\n'
199
+ " %(text)s\n"
200
+ " %(caret_indent)s^\n"
201
+ "%(errname)s: %(msg)s"
202
+ % {
203
+ "filename": exception.filename,
204
+ "lineno": exception.lineno,
205
+ "text": exception.text.rstrip(),
206
+ "caret_indent": caret_indent,
207
+ "errname": type(exception).__name__,
208
+ "msg": exception.msg,
209
+ }
210
+ )
211
+ # If a few edge cases, SyntaxErrors don't have all these nice fields. So we
212
+ # have a fall back here.
213
+ # Example edge case error message: encoding declaration in Unicode string
214
+ return str(exception)
215
+
216
+
217
+ def _get_stack_trace_str_list(exception: BaseException) -> list[str]:
218
+ """Get the stack trace for the given exception.
219
+
220
+ Parameters
221
+ ----------
222
+ exception : BaseException
223
+ The exception to extract the traceback from
224
+
225
+ Returns
226
+ -------
227
+ tuple of two string lists
228
+ The exception traceback as two lists of strings. The first represents the part
229
+ of the stack trace the users don't typically want to see, containing internal
230
+ Streamlit code. The second is whatever comes after the Streamlit stack trace,
231
+ which is usually what the user wants.
232
+
233
+ """
234
+ extracted_traceback: traceback.StackSummary | None = None
235
+ if isinstance(exception, StreamlitAPIWarning):
236
+ extracted_traceback = exception.tacked_on_stack
237
+ elif hasattr(exception, "__traceback__"):
238
+ extracted_traceback = traceback.extract_tb(exception.__traceback__)
239
+
240
+ # Format the extracted traceback and add it to the protobuf element.
241
+ if extracted_traceback is None:
242
+ trace_str_list = [
243
+ "Cannot extract the stack trace for this exception. "
244
+ "Try calling exception() within the `catch` block."
245
+ ]
246
+ else:
247
+ internal_frames, external_frames = _split_internal_streamlit_frames(
248
+ extracted_traceback
249
+ )
250
+
251
+ if external_frames:
252
+ trace_str_list = traceback.format_list(external_frames)
253
+ else:
254
+ trace_str_list = traceback.format_list(internal_frames)
255
+
256
+ trace_str_list = [item.strip() for item in trace_str_list]
257
+
258
+ return trace_str_list
259
+
260
+
261
+ def _is_in_package(file: str, package_path: str) -> bool:
262
+ """True if the given file is part of package_path."""
263
+ try:
264
+ common_prefix = os.path.commonprefix([os.path.realpath(file), package_path])
265
+ except ValueError:
266
+ # Raised if paths are on different drives.
267
+ return False
268
+
269
+ return common_prefix == package_path
270
+
271
+
272
+ def _split_internal_streamlit_frames(
273
+ extracted_tb: traceback.StackSummary,
274
+ ) -> tuple[list[traceback.FrameSummary], list[traceback.FrameSummary]]:
275
+ """Split the traceback into a Streamlit-internal part and an external part.
276
+
277
+ The internal part is everything up to (but excluding) the first frame belonging to
278
+ the user's code. The external part is everything else.
279
+
280
+ So if the stack looks like this:
281
+
282
+ 1. Streamlit frame
283
+ 2. Pandas frame
284
+ 3. Altair frame
285
+ 4. Streamlit frame
286
+ 5. User frame
287
+ 6. User frame
288
+ 7. Streamlit frame
289
+ 8. Matplotlib frame
290
+
291
+ ...then this should return 1-4 as the internal traceback and 5-8 as the external.
292
+
293
+ (Note that something like the example above is extremely unlikely to happen since
294
+ it's not like Altair is calling Streamlit code, but you get the idea.)
295
+ """
296
+
297
+ ctx = get_script_run_ctx()
298
+
299
+ if not ctx:
300
+ return [], list(extracted_tb)
301
+
302
+ package_path = os.path.join(os.path.realpath(str(ctx.main_script_parent)), "")
303
+
304
+ return _split_list(
305
+ extracted_tb,
306
+ split_point=lambda tb: _is_in_package(tb.filename, package_path),
307
+ )
308
+
309
+
310
+ T = TypeVar("T")
311
+
312
+
313
+ def _split_list(
314
+ orig_list: list[T], split_point: Callable[[T], bool]
315
+ ) -> tuple[list[T], list[T]]:
316
+ before: list[T] = []
317
+ after: list[T] = []
318
+
319
+ saw_split_point = False
320
+
321
+ for item in orig_list:
322
+ if not saw_split_point:
323
+ if split_point(item):
324
+ saw_split_point = True
325
+
326
+ if saw_split_point:
327
+ after.append(item)
328
+ else:
329
+ before.append(item)
330
+
331
+ return before, after
@@ -0,0 +1,354 @@
1
+ # Copyright (c) Streamlit Inc. (2018-2022) Snowflake Inc. (2022-2025)
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ from __future__ import annotations
15
+
16
+ import textwrap
17
+ from typing import TYPE_CHECKING, Literal, cast
18
+
19
+ from streamlit.elements.lib.form_utils import FormData, current_form_id, is_in_form
20
+ from streamlit.elements.lib.policies import (
21
+ check_cache_replay_rules,
22
+ check_session_state_rules,
23
+ )
24
+ from streamlit.errors import StreamlitAPIException
25
+ from streamlit.proto import Block_pb2
26
+ from streamlit.runtime.metrics_util import gather_metrics
27
+ from streamlit.runtime.scriptrunner import ScriptRunContext, get_script_run_ctx
28
+
29
+ if TYPE_CHECKING:
30
+ from streamlit.delta_generator import DeltaGenerator
31
+ from streamlit.runtime.state import WidgetArgs, WidgetCallback, WidgetKwargs
32
+
33
+
34
+ def _build_duplicate_form_message(user_key: str | None = None) -> str:
35
+ if user_key is not None:
36
+ message = textwrap.dedent(
37
+ f"""
38
+ There are multiple identical forms with `key='{user_key}'`.
39
+
40
+ To fix this, please make sure that the `key` argument is unique for
41
+ each `st.form` you create.
42
+ """
43
+ )
44
+ else:
45
+ message = textwrap.dedent(
46
+ """
47
+ There are multiple identical forms with the same generated key.
48
+
49
+ When a form is created, it's assigned an internal key based on
50
+ its structure. Multiple forms with an identical structure will
51
+ result in the same internal key, which causes this error.
52
+
53
+ To fix this error, please pass a unique `key` argument to
54
+ `st.form`.
55
+ """
56
+ )
57
+
58
+ return message.strip("\n")
59
+
60
+
61
+ class FormMixin:
62
+ @gather_metrics("form")
63
+ def form(
64
+ self,
65
+ key: str,
66
+ clear_on_submit: bool = False,
67
+ *,
68
+ enter_to_submit: bool = True,
69
+ border: bool = True,
70
+ ) -> DeltaGenerator:
71
+ """Create a form that batches elements together with a "Submit" button.
72
+
73
+ A form is a container that visually groups other elements and
74
+ widgets together, and contains a Submit button. When the form's
75
+ Submit button is pressed, all widget values inside the form will be
76
+ sent to Streamlit in a batch.
77
+
78
+ To add elements to a form object, you can use ``with`` notation
79
+ (preferred) or just call methods directly on the form. See
80
+ examples below.
81
+
82
+ Forms have a few constraints:
83
+
84
+ - Every form must contain a ``st.form_submit_button``.
85
+ - ``st.button`` and ``st.download_button`` cannot be added to a form.
86
+ - Forms can appear anywhere in your app (sidebar, columns, etc),
87
+ but they cannot be embedded inside other forms.
88
+ - Within a form, the only widget that can have a callback function is
89
+ ``st.form_submit_button``.
90
+
91
+ Parameters
92
+ ----------
93
+ key : str
94
+ A string that identifies the form. Each form must have its own
95
+ key. (This key is not displayed to the user in the interface.)
96
+ clear_on_submit : bool
97
+ If True, all widgets inside the form will be reset to their default
98
+ values after the user presses the Submit button. Defaults to False.
99
+ (Note that Custom Components are unaffected by this flag, and
100
+ will not be reset to their defaults on form submission.)
101
+ enter_to_submit : bool
102
+ Whether to submit the form when a user presses Enter while
103
+ interacting with a widget inside the form.
104
+
105
+ If this is ``True`` (default), pressing Enter while interacting
106
+ with a form widget is equivalent to clicking the first
107
+ ``st.form_submit_button`` in the form.
108
+
109
+ If this is ``False``, the user must click an
110
+ ``st.form_submit_button`` to submit the form.
111
+
112
+ If the first ``st.form_submit_button`` in the form is disabled,
113
+ the form will override submission behavior with
114
+ ``enter_to_submit=False``.
115
+
116
+ border : bool
117
+ Whether to show a border around the form. Defaults to True.
118
+
119
+ .. note::
120
+ Not showing a border can be confusing to viewers since interacting with a
121
+ widget in the form will do nothing. You should only remove the border if
122
+ there's another border (e.g. because of an expander) or the form is small
123
+ (e.g. just a text input and a submit button).
124
+
125
+ Examples
126
+ --------
127
+ Inserting elements using ``with`` notation:
128
+
129
+ >>> import streamlit as st
130
+ >>>
131
+ >>> with st.form("my_form"):
132
+ ... st.write("Inside the form")
133
+ ... slider_val = st.slider("Form slider")
134
+ ... checkbox_val = st.checkbox("Form checkbox")
135
+ ...
136
+ ... # Every form must have a submit button.
137
+ ... submitted = st.form_submit_button("Submit")
138
+ ... if submitted:
139
+ ... st.write("slider", slider_val, "checkbox", checkbox_val)
140
+ >>> st.write("Outside the form")
141
+
142
+ .. output::
143
+ https://doc-form1.streamlit.app/
144
+ height: 425px
145
+
146
+ Inserting elements out of order:
147
+
148
+ >>> import streamlit as st
149
+ >>>
150
+ >>> form = st.form("my_form")
151
+ >>> form.slider("Inside the form")
152
+ >>> st.slider("Outside the form")
153
+ >>>
154
+ >>> # Now add a submit button to the form:
155
+ >>> form.form_submit_button("Submit")
156
+
157
+ .. output::
158
+ https://doc-form2.streamlit.app/
159
+ height: 375px
160
+
161
+ """
162
+ if is_in_form(self.dg):
163
+ raise StreamlitAPIException("Forms cannot be nested in other forms.")
164
+
165
+ check_cache_replay_rules()
166
+ check_session_state_rules(default_value=None, key=key, writes_allowed=False)
167
+
168
+ # A form is uniquely identified by its key.
169
+ form_id = key
170
+
171
+ ctx = get_script_run_ctx()
172
+ if ctx is not None:
173
+ new_form_id = form_id not in ctx.form_ids_this_run
174
+ if new_form_id:
175
+ ctx.form_ids_this_run.add(form_id)
176
+ else:
177
+ raise StreamlitAPIException(_build_duplicate_form_message(key))
178
+
179
+ block_proto = Block_pb2.Block()
180
+ block_proto.form.form_id = form_id
181
+ block_proto.form.clear_on_submit = clear_on_submit
182
+ block_proto.form.enter_to_submit = enter_to_submit
183
+ block_proto.form.border = border
184
+ block_dg = self.dg._block(block_proto)
185
+
186
+ # Attach the form's button info to the newly-created block's
187
+ # DeltaGenerator.
188
+ block_dg._form_data = FormData(form_id)
189
+ return block_dg
190
+
191
+ @gather_metrics("form_submit_button")
192
+ def form_submit_button(
193
+ self,
194
+ label: str = "Submit",
195
+ help: str | None = None,
196
+ on_click: WidgetCallback | None = None,
197
+ args: WidgetArgs | None = None,
198
+ kwargs: WidgetKwargs | None = None,
199
+ *, # keyword-only arguments:
200
+ type: Literal["primary", "secondary", "tertiary"] = "secondary",
201
+ icon: str | None = None,
202
+ disabled: bool = False,
203
+ use_container_width: bool = False,
204
+ ) -> bool:
205
+ """Display a form submit button.
206
+
207
+ When this button is clicked, all widget values inside the form will be
208
+ sent from the user's browser to your Streamlit server in a batch.
209
+
210
+ Every form must have at least one ``st.form_submit_button``. An
211
+ ``st.form_submit_button`` cannot exist outside of a form.
212
+
213
+ For more information about forms, check out our `docs
214
+ <https://docs.streamlit.io/develop/concepts/architecture/forms>`_.
215
+
216
+ Parameters
217
+ ----------
218
+ label : str
219
+ A short label explaining to the user what this button is for. This
220
+ defaults to ``"Submit"``. The label can optionally contain
221
+ GitHub-flavored Markdown of the following types: Bold, Italics,
222
+ Strikethroughs, Inline Code, Links, and Images. Images display like
223
+ icons, with a max height equal to the font height.
224
+
225
+ Unsupported Markdown elements are unwrapped so only their children
226
+ (text contents) render. Display unsupported elements as literal
227
+ characters by backslash-escaping them. E.g.,
228
+ ``"1\\. Not an ordered list"``.
229
+
230
+ See the ``body`` parameter of |st.markdown|_ for additional,
231
+ supported Markdown directives.
232
+
233
+ .. |st.markdown| replace:: ``st.markdown``
234
+ .. _st.markdown: https://docs.streamlit.io/develop/api-reference/text/st.markdown
235
+ help : str or None
236
+ A tooltip that gets displayed when the button is hovered over. If
237
+ this is ``None`` (default), no tooltip is displayed.
238
+
239
+ The tooltip can optionally contain GitHub-flavored Markdown,
240
+ including the Markdown directives described in the ``body``
241
+ parameter of ``st.markdown``.
242
+ on_click : callable
243
+ An optional callback invoked when this button is clicked.
244
+ args : tuple
245
+ An optional tuple of args to pass to the callback.
246
+ kwargs : dict
247
+ An optional dict of kwargs to pass to the callback.
248
+ type : "primary", "secondary", or "tertiary"
249
+ An optional string that specifies the button type. This can be one
250
+ of the following:
251
+
252
+ - ``"primary"``: The button's background is the app's primary color
253
+ for additional emphasis.
254
+ - ``"secondary"`` (default): The button's background coordinates
255
+ with the app's background color for normal emphasis.
256
+ - ``"tertiary"``: The button is plain text without a border or
257
+ background for subtly.
258
+
259
+ icon : str or None
260
+ An optional emoji or icon to display next to the button label. If ``icon``
261
+ is ``None`` (default), no icon is displayed. If ``icon`` is a
262
+ string, the following options are valid:
263
+
264
+ - A single-character emoji. For example, you can set ``icon="🚨"``
265
+ or ``icon="🔥"``. Emoji short codes are not supported.
266
+
267
+ - An icon from the Material Symbols library (rounded style) in the
268
+ format ``":material/icon_name:"`` where "icon_name" is the name
269
+ of the icon in snake case.
270
+
271
+ For example, ``icon=":material/thumb_up:"`` will display the
272
+ Thumb Up icon. Find additional icons in the `Material Symbols \
273
+ <https://fonts.google.com/icons?icon.set=Material+Symbols&icon.style=Rounded>`_
274
+ font library.
275
+ disabled : bool
276
+ Whether to disable the button. If this is ``False`` (default), the
277
+ user can interact with the button. If this is ``True``, the button
278
+ is grayed-out and can't be clicked.
279
+
280
+ If the first ``st.form_submit_button`` in the form is disabled,
281
+ the form will override submission behavior with
282
+ ``enter_to_submit=False``.
283
+
284
+ use_container_width : bool
285
+ Whether to expand the button's width to fill its parent container.
286
+ If ``use_container_width`` is ``False`` (default), Streamlit sizes
287
+ the button to fit its contents. If ``use_container_width`` is
288
+ ``True``, the width of the button matches its parent container.
289
+
290
+ In both cases, if the contents of the button are wider than the
291
+ parent container, the contents will line wrap.
292
+
293
+ Returns
294
+ -------
295
+ bool
296
+ True if the button was clicked.
297
+ """
298
+ ctx = get_script_run_ctx()
299
+
300
+ # Checks whether the entered button type is one of the allowed options
301
+ if type not in ["primary", "secondary", "tertiary"]:
302
+ raise StreamlitAPIException(
303
+ 'The type argument to st.form_submit_button must be "primary", "secondary", or "tertiary". \n'
304
+ f'The argument passed was "{type}".'
305
+ )
306
+
307
+ return self._form_submit_button(
308
+ label=label,
309
+ help=help,
310
+ on_click=on_click,
311
+ args=args,
312
+ kwargs=kwargs,
313
+ type=type,
314
+ icon=icon,
315
+ disabled=disabled,
316
+ use_container_width=use_container_width,
317
+ ctx=ctx,
318
+ )
319
+
320
+ def _form_submit_button(
321
+ self,
322
+ label: str = "Submit",
323
+ help: str | None = None,
324
+ on_click: WidgetCallback | None = None,
325
+ args: WidgetArgs | None = None,
326
+ kwargs: WidgetKwargs | None = None,
327
+ *, # keyword-only arguments:
328
+ type: Literal["primary", "secondary", "tertiary"] = "secondary",
329
+ icon: str | None = None,
330
+ disabled: bool = False,
331
+ use_container_width: bool = False,
332
+ ctx: ScriptRunContext | None = None,
333
+ ) -> bool:
334
+ form_id = current_form_id(self.dg)
335
+ submit_button_key = f"FormSubmitter:{form_id}-{label}"
336
+ return self.dg._button(
337
+ label=label,
338
+ key=submit_button_key,
339
+ help=help,
340
+ is_form_submitter=True,
341
+ on_click=on_click,
342
+ args=args,
343
+ kwargs=kwargs,
344
+ type=type,
345
+ icon=icon,
346
+ disabled=disabled,
347
+ use_container_width=use_container_width,
348
+ ctx=ctx,
349
+ )
350
+
351
+ @property
352
+ def dg(self) -> DeltaGenerator:
353
+ """Get our DeltaGenerator."""
354
+ return cast("DeltaGenerator", self)