inspect-ai 0.3.62__py3-none-any.whl → 0.3.63__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 (415) hide show
  1. inspect_ai/_cli/main.py +1 -1
  2. inspect_ai/_cli/trace.py +8 -0
  3. inspect_ai/_display/core/active.py +2 -3
  4. inspect_ai/_eval/eval.py +4 -4
  5. inspect_ai/_eval/evalset.py +6 -6
  6. inspect_ai/_eval/task/run.py +3 -0
  7. inspect_ai/_util/hash.py +1 -1
  8. inspect_ai/_view/www/.vscode/extensions.json +3 -0
  9. inspect_ai/_view/www/.vscode/settings.json +8 -0
  10. inspect_ai/_view/www/App.css +92 -29
  11. inspect_ai/_view/www/dist/assets/index.css +16637 -14676
  12. inspect_ai/_view/www/dist/assets/index.js +58897 -51440
  13. inspect_ai/_view/www/dist/index.html +1 -1
  14. inspect_ai/_view/www/index.html +2 -2
  15. inspect_ai/_view/www/log-schema.json +1 -0
  16. inspect_ai/_view/www/package.json +22 -4
  17. inspect_ai/_view/www/postcss.config.cjs +8 -9
  18. inspect_ai/_view/www/src/{App.mjs → App.tsx} +355 -365
  19. inspect_ai/_view/www/src/AppErrorBoundary.tsx +47 -0
  20. inspect_ai/_view/www/src/api/api-browser.ts +2 -2
  21. inspect_ai/_view/www/src/api/api-http.ts +3 -5
  22. inspect_ai/_view/www/src/api/api-vscode.ts +6 -6
  23. inspect_ai/_view/www/src/api/client-api.ts +4 -4
  24. inspect_ai/_view/www/src/api/index.ts +4 -4
  25. inspect_ai/_view/www/src/api/{Types.ts → types.ts} +25 -9
  26. inspect_ai/_view/www/src/appearance/colors.ts +9 -0
  27. inspect_ai/_view/www/src/appearance/fonts.ts +39 -0
  28. inspect_ai/_view/www/src/appearance/icons.ts +100 -0
  29. inspect_ai/_view/www/src/appearance/{Styles.mjs → styles.ts} +2 -32
  30. inspect_ai/_view/www/src/components/AnsiDisplay.tsx +198 -0
  31. inspect_ai/_view/www/src/components/AsciinemaPlayer.tsx +86 -0
  32. inspect_ai/_view/www/src/components/Card.css +60 -0
  33. inspect_ai/_view/www/src/components/Card.tsx +109 -0
  34. inspect_ai/_view/www/src/components/CopyButton.module.css +11 -0
  35. inspect_ai/_view/www/src/components/CopyButton.tsx +58 -0
  36. inspect_ai/_view/www/src/components/DownloadButton.css +4 -0
  37. inspect_ai/_view/www/src/components/DownloadButton.tsx +25 -0
  38. inspect_ai/_view/www/src/components/DownloadPanel.css +10 -0
  39. inspect_ai/_view/www/src/components/DownloadPanel.tsx +30 -0
  40. inspect_ai/_view/www/src/components/EmptyPanel.css +12 -0
  41. inspect_ai/_view/www/src/components/EmptyPanel.tsx +15 -0
  42. inspect_ai/_view/www/src/components/ErrorPanel.css +37 -0
  43. inspect_ai/_view/www/src/components/ErrorPanel.tsx +39 -0
  44. inspect_ai/_view/www/src/components/ExpandablePanel.css +40 -0
  45. inspect_ai/_view/www/src/components/ExpandablePanel.tsx +115 -0
  46. inspect_ai/_view/www/src/components/FindBand.css +49 -0
  47. inspect_ai/_view/www/src/components/FindBand.tsx +130 -0
  48. inspect_ai/_view/www/src/components/HumanBaselineView.css +41 -0
  49. inspect_ai/_view/www/src/components/HumanBaselineView.tsx +162 -0
  50. inspect_ai/_view/www/src/components/JsonPanel.css +20 -0
  51. inspect_ai/_view/www/src/components/JsonPanel.tsx +82 -0
  52. inspect_ai/_view/www/src/components/LabeledValue.css +20 -0
  53. inspect_ai/_view/www/src/components/LabeledValue.tsx +41 -0
  54. inspect_ai/_view/www/src/components/LargeModal.module.css +54 -0
  55. inspect_ai/_view/www/src/components/LargeModal.tsx +199 -0
  56. inspect_ai/_view/www/src/components/LightboxCarousel.css +95 -0
  57. inspect_ai/_view/www/src/components/LightboxCarousel.tsx +132 -0
  58. inspect_ai/_view/www/src/components/MarkdownDiv.css +3 -0
  59. inspect_ai/_view/www/src/components/MarkdownDiv.tsx +133 -0
  60. inspect_ai/_view/www/src/components/MessageBand.css +43 -0
  61. inspect_ai/_view/www/src/components/MessageBand.tsx +39 -0
  62. inspect_ai/_view/www/src/components/MorePopOver.tsx +67 -0
  63. inspect_ai/_view/www/src/components/NavPills.module.css +18 -0
  64. inspect_ai/_view/www/src/components/NavPills.tsx +99 -0
  65. inspect_ai/_view/www/src/components/ProgressBar.module.css +37 -0
  66. inspect_ai/_view/www/src/components/ProgressBar.tsx +22 -0
  67. inspect_ai/_view/www/src/components/TabSet.module.css +40 -0
  68. inspect_ai/_view/www/src/components/TabSet.tsx +200 -0
  69. inspect_ai/_view/www/src/components/ToolButton.css +3 -0
  70. inspect_ai/_view/www/src/components/ToolButton.tsx +27 -0
  71. inspect_ai/_view/www/src/components/VirtualList.module.css +19 -0
  72. inspect_ai/_view/www/src/components/VirtualList.tsx +292 -0
  73. inspect_ai/_view/www/src/{index.js → index.tsx} +45 -19
  74. inspect_ai/_view/www/src/{log → logfile}/remoteLogFile.ts +3 -7
  75. inspect_ai/_view/www/src/{utils/remoteZipFile.mjs → logfile/remoteZipFile.ts} +86 -80
  76. inspect_ai/_view/www/src/metadata/MetaDataGrid.tsx +83 -0
  77. inspect_ai/_view/www/src/metadata/MetaDataView.module.css +35 -0
  78. inspect_ai/_view/www/src/metadata/MetaDataView.tsx +95 -0
  79. inspect_ai/_view/www/src/metadata/MetadataGrid.module.css +15 -0
  80. inspect_ai/_view/www/src/metadata/RenderedContent.module.css +12 -0
  81. inspect_ai/_view/www/src/{components/RenderedContent/RenderedContent.mjs → metadata/RenderedContent.tsx} +92 -73
  82. inspect_ai/_view/www/src/metadata/types.ts +18 -0
  83. inspect_ai/_view/www/src/plan/DatasetDetailView.module.css +3 -0
  84. inspect_ai/_view/www/src/plan/DatasetDetailView.tsx +37 -0
  85. inspect_ai/_view/www/src/plan/DetailStep.module.css +9 -0
  86. inspect_ai/_view/www/src/plan/DetailStep.tsx +31 -0
  87. inspect_ai/_view/www/src/plan/PlanCard.tsx +28 -0
  88. inspect_ai/_view/www/src/plan/PlanDetailView.module.css +48 -0
  89. inspect_ai/_view/www/src/plan/PlanDetailView.tsx +309 -0
  90. inspect_ai/_view/www/src/plan/ScorerDetailView.module.css +3 -0
  91. inspect_ai/_view/www/src/plan/ScorerDetailView.tsx +30 -0
  92. inspect_ai/_view/www/src/plan/SolverDetailView.module.css +15 -0
  93. inspect_ai/_view/www/src/plan/SolverDetailView.tsx +32 -0
  94. inspect_ai/_view/www/src/samples/InlineSampleDisplay.module.css +8 -0
  95. inspect_ai/_view/www/src/samples/InlineSampleDisplay.tsx +53 -0
  96. inspect_ai/_view/www/src/samples/SampleDialog.tsx +122 -0
  97. inspect_ai/_view/www/src/samples/SampleDisplay.module.css +29 -0
  98. inspect_ai/_view/www/src/samples/SampleDisplay.tsx +326 -0
  99. inspect_ai/_view/www/src/samples/SampleSummaryView.module.css +24 -0
  100. inspect_ai/_view/www/src/samples/SampleSummaryView.tsx +175 -0
  101. inspect_ai/_view/www/src/samples/SamplesTools.tsx +60 -0
  102. inspect_ai/_view/www/src/samples/chat/ChatMessage.module.css +29 -0
  103. inspect_ai/_view/www/src/samples/chat/ChatMessage.tsx +76 -0
  104. inspect_ai/_view/www/src/samples/chat/ChatMessageRenderer.tsx +60 -0
  105. inspect_ai/_view/www/src/samples/chat/ChatMessageRow.module.css +9 -0
  106. inspect_ai/_view/www/src/samples/chat/ChatMessageRow.tsx +57 -0
  107. inspect_ai/_view/www/src/samples/chat/ChatView.tsx +46 -0
  108. inspect_ai/_view/www/src/samples/chat/ChatViewVirtualList.module.css +4 -0
  109. inspect_ai/_view/www/src/samples/chat/ChatViewVirtualList.tsx +58 -0
  110. inspect_ai/_view/www/src/samples/chat/MessageContent.module.css +4 -0
  111. inspect_ai/_view/www/src/samples/chat/MessageContent.tsx +143 -0
  112. inspect_ai/_view/www/src/samples/chat/MessageContents.module.css +3 -0
  113. inspect_ai/_view/www/src/samples/chat/MessageContents.tsx +131 -0
  114. inspect_ai/_view/www/src/samples/chat/messages.ts +112 -0
  115. inspect_ai/_view/www/src/samples/chat/tools/ToolCallView.tsx +145 -0
  116. inspect_ai/_view/www/src/samples/chat/tools/ToolInput.module.css +14 -0
  117. inspect_ai/_view/www/src/samples/chat/tools/ToolInput.tsx +86 -0
  118. inspect_ai/_view/www/src/samples/chat/tools/ToolOutput.module.css +19 -0
  119. inspect_ai/_view/www/src/samples/chat/tools/ToolOutput.tsx +53 -0
  120. inspect_ai/_view/www/src/samples/chat/tools/ToolTitle.module.css +4 -0
  121. inspect_ai/_view/www/src/samples/chat/tools/ToolTitle.tsx +18 -0
  122. inspect_ai/_view/www/src/samples/chat/tools/tool.ts +107 -0
  123. inspect_ai/_view/www/src/samples/descriptor/samplesDescriptor.tsx +363 -0
  124. inspect_ai/_view/www/src/samples/descriptor/score/BooleanScoreDescriptor.module.css +22 -0
  125. inspect_ai/_view/www/src/samples/descriptor/score/BooleanScoreDescriptor.tsx +26 -0
  126. inspect_ai/_view/www/src/samples/descriptor/score/CategoricalScoreDescriptor.tsx +18 -0
  127. inspect_ai/_view/www/src/samples/descriptor/score/NumericScoreDescriptor.tsx +27 -0
  128. inspect_ai/_view/www/src/samples/descriptor/score/ObjectScoreDescriptor.module.css +18 -0
  129. inspect_ai/_view/www/src/samples/descriptor/score/ObjectScoreDescriptor.tsx +71 -0
  130. inspect_ai/_view/www/src/samples/descriptor/score/OtherScoreDescriptor.tsx +20 -0
  131. inspect_ai/_view/www/src/samples/descriptor/score/PassFailScoreDescriptor.module.css +28 -0
  132. inspect_ai/_view/www/src/samples/descriptor/score/PassFailScoreDescriptor.tsx +81 -0
  133. inspect_ai/_view/www/src/samples/descriptor/score/ScoreDescriptor.tsx +99 -0
  134. inspect_ai/_view/www/src/samples/descriptor/types.ts +55 -0
  135. inspect_ai/_view/www/src/samples/error/FlatSampleErrorView.module.css +19 -0
  136. inspect_ai/_view/www/src/samples/error/FlatSampleErrorView.tsx +22 -0
  137. inspect_ai/_view/www/src/samples/error/SampleErrorView.module.css +17 -0
  138. inspect_ai/_view/www/src/samples/error/SampleErrorView.tsx +31 -0
  139. inspect_ai/_view/www/src/samples/error/error.ts +15 -0
  140. inspect_ai/_view/www/src/samples/list/SampleFooter.module.css +9 -0
  141. inspect_ai/_view/www/src/samples/list/SampleFooter.tsx +14 -0
  142. inspect_ai/_view/www/src/samples/list/SampleHeader.module.css +13 -0
  143. inspect_ai/_view/www/src/samples/list/SampleHeader.tsx +36 -0
  144. inspect_ai/_view/www/src/samples/list/SampleList.module.css +11 -0
  145. inspect_ai/_view/www/src/samples/list/SampleList.tsx +247 -0
  146. inspect_ai/_view/www/src/samples/list/SampleRow.module.css +33 -0
  147. inspect_ai/_view/www/src/samples/list/SampleRow.tsx +98 -0
  148. inspect_ai/_view/www/src/samples/list/SampleSeparator.module.css +6 -0
  149. inspect_ai/_view/www/src/samples/list/SampleSeparator.tsx +24 -0
  150. inspect_ai/_view/www/src/samples/sample-tools/EpochFilter.module.css +9 -0
  151. inspect_ai/_view/www/src/samples/sample-tools/EpochFilter.tsx +51 -0
  152. inspect_ai/_view/www/src/samples/sample-tools/SelectScorer.module.css +16 -0
  153. inspect_ai/_view/www/src/samples/sample-tools/SelectScorer.tsx +173 -0
  154. inspect_ai/_view/www/src/samples/sample-tools/SortFilter.module.css +9 -0
  155. inspect_ai/_view/www/src/samples/sample-tools/SortFilter.tsx +182 -0
  156. inspect_ai/_view/www/src/samples/{tools/filters.mjs → sample-tools/filters.ts} +86 -81
  157. inspect_ai/_view/www/src/samples/sample-tools/sample-filter/SampleFilter.module.css +16 -0
  158. inspect_ai/_view/www/src/samples/sample-tools/sample-filter/SampleFilter.tsx +288 -0
  159. inspect_ai/_view/www/src/samples/sample-tools/sample-filter/completions.ts +346 -0
  160. inspect_ai/_view/www/src/samples/sample-tools/sample-filter/language.ts +19 -0
  161. inspect_ai/_view/www/src/samples/sample-tools/sample-filter/tokenize.ts +97 -0
  162. inspect_ai/_view/www/src/samples/{SampleLimit.mjs → sampleLimit.ts} +3 -6
  163. inspect_ai/_view/www/src/samples/scores/SampleScoreView.module.css +53 -0
  164. inspect_ai/_view/www/src/samples/scores/SampleScoreView.tsx +168 -0
  165. inspect_ai/_view/www/src/samples/scores/SampleScores.module.css +5 -0
  166. inspect_ai/_view/www/src/samples/scores/SampleScores.tsx +37 -0
  167. inspect_ai/_view/www/src/samples/transcript/ApprovalEventView.tsx +66 -0
  168. inspect_ai/_view/www/src/samples/transcript/ErrorEventView.tsx +51 -0
  169. inspect_ai/_view/www/src/samples/transcript/InfoEventView.module.css +3 -0
  170. inspect_ai/_view/www/src/samples/transcript/InfoEventView.tsx +54 -0
  171. inspect_ai/_view/www/src/samples/transcript/InputEventView.tsx +48 -0
  172. inspect_ai/_view/www/src/samples/transcript/LoggerEventView.module.css +6 -0
  173. inspect_ai/_view/www/src/samples/transcript/LoggerEventView.tsx +36 -0
  174. inspect_ai/_view/www/src/samples/transcript/ModelEventView.module.css +43 -0
  175. inspect_ai/_view/www/src/samples/transcript/ModelEventView.tsx +223 -0
  176. inspect_ai/_view/www/src/samples/transcript/SampleInitEventView.module.css +23 -0
  177. inspect_ai/_view/www/src/samples/transcript/SampleInitEventView.tsx +108 -0
  178. inspect_ai/_view/www/src/samples/transcript/SampleLimitEventView.tsx +75 -0
  179. inspect_ai/_view/www/src/samples/transcript/SampleTranscript.tsx +22 -0
  180. inspect_ai/_view/www/src/samples/transcript/ScoreEventView.module.css +15 -0
  181. inspect_ai/_view/www/src/samples/transcript/ScoreEventView.tsx +100 -0
  182. inspect_ai/_view/www/src/samples/transcript/StepEventView.tsx +171 -0
  183. inspect_ai/_view/www/src/samples/transcript/SubtaskEventView.module.css +19 -0
  184. inspect_ai/_view/www/src/samples/transcript/SubtaskEventView.tsx +133 -0
  185. inspect_ai/_view/www/src/samples/transcript/ToolEventView.module.css +10 -0
  186. inspect_ai/_view/www/src/samples/transcript/ToolEventView.tsx +91 -0
  187. inspect_ai/_view/www/src/samples/transcript/TranscriptView.module.css +49 -0
  188. inspect_ai/_view/www/src/samples/transcript/TranscriptView.tsx +449 -0
  189. inspect_ai/_view/www/src/samples/transcript/event/EventNav.module.css +5 -0
  190. inspect_ai/_view/www/src/samples/transcript/event/EventNav.tsx +43 -0
  191. inspect_ai/_view/www/src/samples/transcript/event/EventNavs.module.css +3 -0
  192. inspect_ai/_view/www/src/samples/transcript/event/EventNavs.tsx +38 -0
  193. inspect_ai/_view/www/src/samples/transcript/event/EventPanel.module.css +25 -0
  194. inspect_ai/_view/www/src/samples/transcript/event/EventPanel.tsx +190 -0
  195. inspect_ai/_view/www/src/samples/transcript/event/EventRow.module.css +13 -0
  196. inspect_ai/_view/www/src/samples/transcript/event/EventRow.tsx +32 -0
  197. inspect_ai/_view/www/src/samples/transcript/event/EventSection.module.css +8 -0
  198. inspect_ai/_view/www/src/samples/transcript/event/EventSection.tsx +29 -0
  199. inspect_ai/_view/www/src/samples/transcript/state/StateDiffView.tsx +67 -0
  200. inspect_ai/_view/www/src/samples/transcript/state/StateEventRenderers.tsx +274 -0
  201. inspect_ai/_view/www/src/samples/transcript/state/StateEventRenders.module.css +10 -0
  202. inspect_ai/_view/www/src/samples/transcript/state/StateEventView.module.css +9 -0
  203. inspect_ai/_view/www/src/samples/transcript/state/{StateEventView.mjs → StateEventView.tsx} +148 -110
  204. inspect_ai/_view/www/src/samples/transcript/types.ts +58 -0
  205. inspect_ai/_view/www/src/types/log.d.ts +1 -0
  206. inspect_ai/_view/www/src/types/prism.d.ts +11 -0
  207. inspect_ai/_view/www/src/types.ts +71 -0
  208. inspect_ai/_view/www/src/usage/ModelTokenTable.tsx +22 -0
  209. inspect_ai/_view/www/src/usage/ModelUsagePanel.module.css +24 -0
  210. inspect_ai/_view/www/src/usage/ModelUsagePanel.tsx +95 -0
  211. inspect_ai/_view/www/src/usage/TokenTable.module.css +17 -0
  212. inspect_ai/_view/www/src/usage/TokenTable.tsx +91 -0
  213. inspect_ai/_view/www/src/usage/UsageCard.module.css +15 -0
  214. inspect_ai/_view/www/src/usage/UsageCard.tsx +67 -0
  215. inspect_ai/_view/www/src/utils/attachments.ts +42 -0
  216. inspect_ai/_view/www/src/utils/{Base64.mjs → base64.ts} +1 -6
  217. inspect_ai/_view/www/src/{components/Browser.mjs → utils/browser.ts} +0 -1
  218. inspect_ai/_view/www/src/utils/debugging.ts +28 -0
  219. inspect_ai/_view/www/src/utils/dom.ts +30 -0
  220. inspect_ai/_view/www/src/utils/format.ts +194 -0
  221. inspect_ai/_view/www/src/utils/git.ts +7 -0
  222. inspect_ai/_view/www/src/utils/html.ts +6 -0
  223. inspect_ai/_view/www/src/utils/http.ts +14 -0
  224. inspect_ai/_view/www/src/utils/{Path.mjs → path.ts} +2 -9
  225. inspect_ai/_view/www/src/utils/{Print.mjs → print.ts} +34 -26
  226. inspect_ai/_view/www/src/utils/queue.ts +51 -0
  227. inspect_ai/_view/www/src/utils/sync.ts +114 -0
  228. inspect_ai/_view/www/src/utils/{Type.mjs → type.ts} +3 -6
  229. inspect_ai/_view/www/src/utils/vscode.ts +13 -0
  230. inspect_ai/_view/www/src/workspace/WorkSpace.tsx +324 -0
  231. inspect_ai/_view/www/src/workspace/WorkSpaceView.module.css +33 -0
  232. inspect_ai/_view/www/src/workspace/WorkSpaceView.tsx +160 -0
  233. inspect_ai/_view/www/src/workspace/error/TaskErrorPanel.module.css +3 -0
  234. inspect_ai/_view/www/src/workspace/error/TaskErrorPanel.tsx +28 -0
  235. inspect_ai/_view/www/src/workspace/navbar/Navbar.module.css +54 -0
  236. inspect_ai/_view/www/src/workspace/navbar/Navbar.tsx +68 -0
  237. inspect_ai/_view/www/src/workspace/navbar/PrimaryBar.module.css +52 -0
  238. inspect_ai/_view/www/src/workspace/navbar/PrimaryBar.tsx +113 -0
  239. inspect_ai/_view/www/src/workspace/navbar/ResultsPanel.module.css +67 -0
  240. inspect_ai/_view/www/src/workspace/navbar/ResultsPanel.tsx +156 -0
  241. inspect_ai/_view/www/src/workspace/navbar/SecondaryBar.module.css +28 -0
  242. inspect_ai/_view/www/src/workspace/navbar/SecondaryBar.tsx +222 -0
  243. inspect_ai/_view/www/src/workspace/navbar/StatusPanel.module.css +14 -0
  244. inspect_ai/_view/www/src/workspace/navbar/StatusPanel.tsx +61 -0
  245. inspect_ai/_view/www/src/workspace/sidebar/EvalStatus.module.css +15 -0
  246. inspect_ai/_view/www/src/workspace/sidebar/EvalStatus.tsx +71 -0
  247. inspect_ai/_view/www/src/workspace/sidebar/LogDirectoryTitleView.module.css +5 -0
  248. inspect_ai/_view/www/src/workspace/sidebar/LogDirectoryTitleView.tsx +56 -0
  249. inspect_ai/_view/www/src/workspace/sidebar/Sidebar.module.css +68 -0
  250. inspect_ai/_view/www/src/workspace/sidebar/Sidebar.tsx +85 -0
  251. inspect_ai/_view/www/src/workspace/sidebar/SidebarLogEntry.module.css +29 -0
  252. inspect_ai/_view/www/src/workspace/sidebar/SidebarLogEntry.tsx +95 -0
  253. inspect_ai/_view/www/src/workspace/sidebar/SidebarScoreView.module.css +23 -0
  254. inspect_ai/_view/www/src/workspace/sidebar/SidebarScoreView.tsx +41 -0
  255. inspect_ai/_view/www/src/workspace/sidebar/SidebarScoresView.module.css +35 -0
  256. inspect_ai/_view/www/src/workspace/sidebar/SidebarScoresView.tsx +61 -0
  257. inspect_ai/_view/www/src/workspace/tabs/InfoTab.tsx +80 -0
  258. inspect_ai/_view/www/src/workspace/tabs/JsonTab.module.css +5 -0
  259. inspect_ai/_view/www/src/workspace/tabs/JsonTab.tsx +46 -0
  260. inspect_ai/_view/www/src/workspace/tabs/SamplesTab.tsx +204 -0
  261. inspect_ai/_view/www/src/workspace/tabs/grouping.ts +195 -0
  262. inspect_ai/_view/www/src/workspace/tabs/types.ts +19 -0
  263. inspect_ai/_view/www/src/workspace/types.ts +10 -0
  264. inspect_ai/_view/www/tsconfig.json +23 -9
  265. inspect_ai/_view/www/vite.config.js +8 -17
  266. inspect_ai/_view/www/yarn.lock +627 -556
  267. inspect_ai/dataset/_dataset.py +36 -0
  268. inspect_ai/dataset/_sources/csv.py +8 -0
  269. inspect_ai/dataset/_sources/file.py +4 -0
  270. inspect_ai/dataset/_sources/hf.py +11 -1
  271. inspect_ai/dataset/_sources/json.py +8 -0
  272. inspect_ai/log/_log.py +3 -6
  273. inspect_ai/log/_message.py +1 -1
  274. inspect_ai/log/_recorders/json.py +5 -7
  275. inspect_ai/model/_call_tools.py +2 -1
  276. inspect_ai/model/_providers/anthropic.py +3 -3
  277. inspect_ai/model/_providers/openai_o1.py +3 -5
  278. inspect_ai/model/_providers/openrouter.py +86 -0
  279. inspect_ai/model/_providers/providers.py +11 -0
  280. inspect_ai/scorer/_answer.py +7 -7
  281. inspect_ai/scorer/_classification.py +34 -18
  282. inspect_ai/scorer/_common.py +2 -8
  283. inspect_ai/solver/_multiple_choice.py +24 -9
  284. inspect_ai/tool/__init__.py +2 -0
  285. inspect_ai/tool/{beta → _tools}/_computer/_computer.py +2 -5
  286. inspect_ai/tool/_tools/_computer/_resources/tool/__init__.py +0 -0
  287. inspect_ai/tool/{beta → _tools}/_computer/_resources/tool/_x11_client.py +1 -1
  288. inspect_ai/tool/_tools/_computer/_resources/tool/requirements.txt +0 -0
  289. inspect_ai/tool/_tools/_execute.py +8 -2
  290. inspect_ai/tool/beta.py +3 -0
  291. inspect_ai/util/_sandbox/docker/docker.py +32 -85
  292. inspect_ai/util/_sandbox/self_check.py +124 -16
  293. {inspect_ai-0.3.62.dist-info → inspect_ai-0.3.63.dist-info}/METADATA +2 -1
  294. inspect_ai-0.3.63.dist-info/RECORD +618 -0
  295. inspect_ai/_view/www/src/Register.mjs +0 -3
  296. inspect_ai/_view/www/src/Types.mjs +0 -38
  297. inspect_ai/_view/www/src/appearance/Colors.mjs +0 -27
  298. inspect_ai/_view/www/src/appearance/Fonts.mjs +0 -66
  299. inspect_ai/_view/www/src/appearance/Icons.mjs +0 -240
  300. inspect_ai/_view/www/src/components/AnsiDisplay.mjs +0 -184
  301. inspect_ai/_view/www/src/components/AppErrorBoundary.mjs +0 -34
  302. inspect_ai/_view/www/src/components/AsciiCinemaPlayer.mjs +0 -74
  303. inspect_ai/_view/www/src/components/Card.mjs +0 -126
  304. inspect_ai/_view/www/src/components/ChatView.mjs +0 -441
  305. inspect_ai/_view/www/src/components/CopyButton.mjs +0 -48
  306. inspect_ai/_view/www/src/components/Dialog.mjs +0 -61
  307. inspect_ai/_view/www/src/components/DownloadButton.mjs +0 -15
  308. inspect_ai/_view/www/src/components/DownloadPanel.mjs +0 -29
  309. inspect_ai/_view/www/src/components/EmptyPanel.mjs +0 -23
  310. inspect_ai/_view/www/src/components/ErrorPanel.mjs +0 -66
  311. inspect_ai/_view/www/src/components/ExpandablePanel.mjs +0 -136
  312. inspect_ai/_view/www/src/components/FindBand.mjs +0 -157
  313. inspect_ai/_view/www/src/components/HumanBaselineView.mjs +0 -168
  314. inspect_ai/_view/www/src/components/JsonPanel.mjs +0 -61
  315. inspect_ai/_view/www/src/components/LabeledValue.mjs +0 -32
  316. inspect_ai/_view/www/src/components/LargeModal.mjs +0 -190
  317. inspect_ai/_view/www/src/components/LightboxCarousel.mjs +0 -217
  318. inspect_ai/_view/www/src/components/MarkdownDiv.mjs +0 -118
  319. inspect_ai/_view/www/src/components/MessageBand.mjs +0 -48
  320. inspect_ai/_view/www/src/components/MessageContent.mjs +0 -111
  321. inspect_ai/_view/www/src/components/MetaDataGrid.mjs +0 -92
  322. inspect_ai/_view/www/src/components/MetaDataView.mjs +0 -109
  323. inspect_ai/_view/www/src/components/MorePopOver.mjs +0 -50
  324. inspect_ai/_view/www/src/components/NavPills.mjs +0 -63
  325. inspect_ai/_view/www/src/components/ProgressBar.mjs +0 -51
  326. inspect_ai/_view/www/src/components/RenderedContent/ChatMessageRenderer.mjs +0 -54
  327. inspect_ai/_view/www/src/components/RenderedContent/Types.mjs +0 -19
  328. inspect_ai/_view/www/src/components/TabSet.mjs +0 -184
  329. inspect_ai/_view/www/src/components/ToolButton.mjs +0 -16
  330. inspect_ai/_view/www/src/components/Tools.mjs +0 -376
  331. inspect_ai/_view/www/src/components/VirtualList.mjs +0 -280
  332. inspect_ai/_view/www/src/components/ansi-output.js +0 -932
  333. inspect_ai/_view/www/src/json/JsonTab.mjs +0 -48
  334. inspect_ai/_view/www/src/log-reader/Log-Reader.mjs +0 -25
  335. inspect_ai/_view/www/src/log-reader/Native-Log-Reader.mjs +0 -13
  336. inspect_ai/_view/www/src/log-reader/Open-AI-Log-Reader.mjs +0 -263
  337. inspect_ai/_view/www/src/navbar/Navbar.mjs +0 -418
  338. inspect_ai/_view/www/src/navbar/SecondaryBar.mjs +0 -175
  339. inspect_ai/_view/www/src/plan/PlanCard.mjs +0 -418
  340. inspect_ai/_view/www/src/samples/SampleDialog.mjs +0 -123
  341. inspect_ai/_view/www/src/samples/SampleDisplay.mjs +0 -516
  342. inspect_ai/_view/www/src/samples/SampleError.mjs +0 -99
  343. inspect_ai/_view/www/src/samples/SampleList.mjs +0 -427
  344. inspect_ai/_view/www/src/samples/SampleScoreView.mjs +0 -172
  345. inspect_ai/_view/www/src/samples/SampleScores.mjs +0 -34
  346. inspect_ai/_view/www/src/samples/SampleTranscript.mjs +0 -20
  347. inspect_ai/_view/www/src/samples/SamplesDescriptor.mjs +0 -771
  348. inspect_ai/_view/www/src/samples/SamplesTab.mjs +0 -399
  349. inspect_ai/_view/www/src/samples/SamplesTools.mjs +0 -64
  350. inspect_ai/_view/www/src/samples/tools/EpochFilter.mjs +0 -38
  351. inspect_ai/_view/www/src/samples/tools/SampleFilter.mjs +0 -756
  352. inspect_ai/_view/www/src/samples/tools/SelectScorer.mjs +0 -141
  353. inspect_ai/_view/www/src/samples/tools/SortFilter.mjs +0 -151
  354. inspect_ai/_view/www/src/samples/transcript/ApprovalEventView.mjs +0 -71
  355. inspect_ai/_view/www/src/samples/transcript/ErrorEventView.mjs +0 -44
  356. inspect_ai/_view/www/src/samples/transcript/EventPanel.mjs +0 -271
  357. inspect_ai/_view/www/src/samples/transcript/EventRow.mjs +0 -46
  358. inspect_ai/_view/www/src/samples/transcript/EventSection.mjs +0 -33
  359. inspect_ai/_view/www/src/samples/transcript/InfoEventView.mjs +0 -59
  360. inspect_ai/_view/www/src/samples/transcript/InputEventView.mjs +0 -44
  361. inspect_ai/_view/www/src/samples/transcript/LoggerEventView.mjs +0 -32
  362. inspect_ai/_view/www/src/samples/transcript/ModelEventView.mjs +0 -216
  363. inspect_ai/_view/www/src/samples/transcript/SampleInitEventView.mjs +0 -107
  364. inspect_ai/_view/www/src/samples/transcript/SampleLimitEventView.mjs +0 -74
  365. inspect_ai/_view/www/src/samples/transcript/ScoreEventView.mjs +0 -100
  366. inspect_ai/_view/www/src/samples/transcript/StepEventView.mjs +0 -187
  367. inspect_ai/_view/www/src/samples/transcript/SubtaskEventView.mjs +0 -133
  368. inspect_ai/_view/www/src/samples/transcript/ToolEventView.mjs +0 -88
  369. inspect_ai/_view/www/src/samples/transcript/TranscriptView.mjs +0 -459
  370. inspect_ai/_view/www/src/samples/transcript/Types.mjs +0 -44
  371. inspect_ai/_view/www/src/samples/transcript/state/StateDiffView.mjs +0 -53
  372. inspect_ai/_view/www/src/samples/transcript/state/StateEventRenderers.mjs +0 -254
  373. inspect_ai/_view/www/src/sidebar/Sidebar.mjs +0 -418
  374. inspect_ai/_view/www/src/usage/ModelTokenTable.mjs +0 -72
  375. inspect_ai/_view/www/src/usage/UsageCard.mjs +0 -159
  376. inspect_ai/_view/www/src/utils/Format.mjs +0 -260
  377. inspect_ai/_view/www/src/utils/Git.mjs +0 -12
  378. inspect_ai/_view/www/src/utils/Html.mjs +0 -21
  379. inspect_ai/_view/www/src/utils/attachments.mjs +0 -31
  380. inspect_ai/_view/www/src/utils/debugging.mjs +0 -23
  381. inspect_ai/_view/www/src/utils/http.mjs +0 -18
  382. inspect_ai/_view/www/src/utils/queue.mjs +0 -67
  383. inspect_ai/_view/www/src/utils/sync.mjs +0 -101
  384. inspect_ai/_view/www/src/workspace/TaskErrorPanel.mjs +0 -17
  385. inspect_ai/_view/www/src/workspace/WorkSpace.mjs +0 -516
  386. inspect_ai/tool/beta/__init__.py +0 -5
  387. inspect_ai-0.3.62.dist-info/RECORD +0 -481
  388. /inspect_ai/{tool/beta/_computer/_resources/tool/__init__.py → _view/www/src/components/MorePopOver.css} +0 -0
  389. /inspect_ai/_view/www/src/{constants.mjs → constants.ts} +0 -0
  390. /inspect_ai/{tool/beta/_computer/_resources/tool/requirements.txt → _view/www/src/workspace/tabs/InfoTab.module.css} +0 -0
  391. /inspect_ai/tool/{beta → _tools}/_computer/__init__.py +0 -0
  392. /inspect_ai/tool/{beta → _tools}/_computer/_common.py +0 -0
  393. /inspect_ai/tool/{beta → _tools}/_computer/_computer_split.py +0 -0
  394. /inspect_ai/tool/{beta → _tools}/_computer/_resources/Dockerfile +0 -0
  395. /inspect_ai/tool/{beta → _tools}/_computer/_resources/README.md +0 -0
  396. /inspect_ai/tool/{beta → _tools}/_computer/_resources/entrypoint/entrypoint.sh +0 -0
  397. /inspect_ai/tool/{beta → _tools}/_computer/_resources/entrypoint/novnc_startup.sh +0 -0
  398. /inspect_ai/tool/{beta → _tools}/_computer/_resources/entrypoint/x11vnc_startup.sh +0 -0
  399. /inspect_ai/tool/{beta → _tools}/_computer/_resources/entrypoint/xfce_startup.sh +0 -0
  400. /inspect_ai/tool/{beta → _tools}/_computer/_resources/entrypoint/xvfb_startup.sh +0 -0
  401. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/.config/Code/User/globalStorage/state.vscdb +0 -0
  402. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/.config/Code/User/settings.json +0 -0
  403. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/.config/xfce4/xfconf/xfce-perchannel-xml/xfce4-panel.xml +0 -0
  404. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/.config/xfce4/xfconf/xfce-perchannel-xml/xfce4-screensaver.xml +0 -0
  405. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/Desktop/Firefox Web Browser.desktop +0 -0
  406. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/Desktop/Terminal.desktop +0 -0
  407. /inspect_ai/tool/{beta → _tools}/_computer/_resources/image_home_dir/Desktop/Visual Studio Code.desktop +0 -0
  408. /inspect_ai/tool/{beta → _tools}/_computer/_resources/tool/_logger.py +0 -0
  409. /inspect_ai/tool/{beta → _tools}/_computer/_resources/tool/_run.py +0 -0
  410. /inspect_ai/tool/{beta → _tools}/_computer/_resources/tool/_tool_result.py +0 -0
  411. /inspect_ai/tool/{beta → _tools}/_computer/_resources/tool/computer_tool.py +0 -0
  412. {inspect_ai-0.3.62.dist-info → inspect_ai-0.3.63.dist-info}/LICENSE +0 -0
  413. {inspect_ai-0.3.62.dist-info → inspect_ai-0.3.63.dist-info}/WHEEL +0 -0
  414. {inspect_ai-0.3.62.dist-info → inspect_ai-0.3.63.dist-info}/entry_points.txt +0 -0
  415. {inspect_ai-0.3.62.dist-info → inspect_ai-0.3.63.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,199 @@
1
+ import clsx from "clsx";
2
+ import { ProgressBar } from "./ProgressBar";
3
+
4
+ import { ReactNode, UIEvent, useCallback, useEffect, useRef } from "react";
5
+ import styles from "./LargeModal.module.css";
6
+
7
+ export interface ModalTool {
8
+ label: string;
9
+ icon: string;
10
+ onClick: () => void;
11
+ enabled: boolean;
12
+ }
13
+
14
+ export interface ModalTools {
15
+ left: ModalTool[];
16
+ right: ModalTool[];
17
+ }
18
+
19
+ interface LargeModalProps {
20
+ id?: string;
21
+ title?: string;
22
+ detail: string;
23
+ detailTools?: ModalTools;
24
+ showProgress: boolean;
25
+ footer?: React.ReactNode;
26
+ visible: boolean;
27
+ onkeyup: (e: any) => void;
28
+ onHide: () => void;
29
+ scrollRef: React.RefObject<HTMLDivElement | null>;
30
+ initialScrollPositionRef: React.RefObject<number>;
31
+ setInitialScrollPosition: (position: number) => void;
32
+ children: ReactNode;
33
+ }
34
+
35
+ export const LargeModal: React.FC<LargeModalProps> = ({
36
+ id,
37
+ title,
38
+ detail,
39
+ detailTools,
40
+ children,
41
+ footer,
42
+ onkeyup,
43
+ visible,
44
+ onHide,
45
+ showProgress,
46
+ initialScrollPositionRef,
47
+ setInitialScrollPosition,
48
+ scrollRef,
49
+ }) => {
50
+ // The footer
51
+ const modalFooter = footer ? (
52
+ <div className={"modal-footer"}>{footer}</div>
53
+ ) : (
54
+ ""
55
+ );
56
+
57
+ // Support restoring the scroll position
58
+ // but only do this for the first time that the children are set
59
+ scrollRef = scrollRef || useRef(null);
60
+ useEffect(() => {
61
+ if (scrollRef.current) {
62
+ setTimeout(() => {
63
+ if (
64
+ scrollRef.current &&
65
+ initialScrollPositionRef.current &&
66
+ scrollRef.current.scrollTop !== initialScrollPositionRef?.current
67
+ ) {
68
+ scrollRef.current.scrollTop = initialScrollPositionRef.current;
69
+ }
70
+ }, 0);
71
+ }
72
+ }, []);
73
+
74
+ const onScroll = useCallback(
75
+ (e: UIEvent<HTMLDivElement>) => {
76
+ setInitialScrollPosition(e.currentTarget.scrollTop);
77
+ },
78
+ [setInitialScrollPosition],
79
+ );
80
+
81
+ // Capture header elements
82
+ const headerEls = [];
83
+ // The title
84
+ headerEls.push(
85
+ <div className={clsx("modal-title", "text-size-smaller", styles.title)}>
86
+ {title || ""}
87
+ </div>,
88
+ );
89
+
90
+ // A centered text element with tools to the left and right
91
+ if (detail) {
92
+ headerEls.push(
93
+ <div className={styles.detail}>
94
+ {detailTools?.left
95
+ ? detailTools.left.map((tool) => {
96
+ return <TitleTool {...tool} />;
97
+ })
98
+ : ""}
99
+ <div className={clsx("text-size-smaller", styles.detailText)}>
100
+ <div>{detail}</div>
101
+ </div>
102
+
103
+ {detailTools?.right
104
+ ? detailTools.right.map((tool) => {
105
+ return <TitleTool {...tool} />;
106
+ })
107
+ : ""}
108
+ </div>,
109
+ );
110
+ }
111
+
112
+ // The close 'x'
113
+ headerEls.push(
114
+ <button
115
+ type="button"
116
+ className={clsx(
117
+ "btn",
118
+ "btn-close-large-dialog",
119
+ "text-size-larger",
120
+ styles.close,
121
+ )}
122
+ onClick={onHide}
123
+ aria-label="Close"
124
+ >
125
+ <HtmlEntity html={"&times;"} />
126
+ </button>,
127
+ );
128
+
129
+ return (
130
+ <div
131
+ id={id}
132
+ className={clsx(
133
+ "modal",
134
+ styles.modal,
135
+ !visible ? styles.hidden : undefined,
136
+ )}
137
+ role="dialog"
138
+ onKeyUp={onkeyup}
139
+ tabIndex={visible ? 0 : undefined}
140
+ >
141
+ <div
142
+ className={clsx(
143
+ "modal-dialog",
144
+ "modal-dialog-scrollable",
145
+ styles.modalBody,
146
+ )}
147
+ role="document"
148
+ >
149
+ <div className={clsx("modal-content", styles.content)}>
150
+ <div className={clsx("modal-header", styles.header)}>{headerEls}</div>
151
+ <ProgressBar animating={showProgress} />
152
+ <div className={"modal-body"} ref={scrollRef} onScroll={onScroll}>
153
+ {children}
154
+ </div>
155
+ {modalFooter}
156
+ </div>
157
+ </div>
158
+ </div>
159
+ );
160
+ };
161
+
162
+ interface HtmlEntityProps {
163
+ html: string;
164
+ }
165
+
166
+ const HtmlEntity: React.FC<HtmlEntityProps> = ({ html }) => (
167
+ <span dangerouslySetInnerHTML={{ __html: html }} />
168
+ );
169
+
170
+ interface TitleToolProps {
171
+ label: string;
172
+ icon: string;
173
+ enabled: boolean;
174
+ onClick: () => void;
175
+ }
176
+
177
+ const TitleTool: React.FC<TitleToolProps> = ({
178
+ label,
179
+ icon,
180
+ enabled,
181
+ onClick,
182
+ }) => {
183
+ return (
184
+ <button
185
+ type="button"
186
+ className={clsx(
187
+ "btn",
188
+ "btn-outline",
189
+ "text-size-small",
190
+ styles.titleTool,
191
+ )}
192
+ aria-label={label}
193
+ onClick={onClick}
194
+ disabled={!enabled}
195
+ >
196
+ <i className={icon} />
197
+ </button>
198
+ );
199
+ };
@@ -0,0 +1,95 @@
1
+ .carousel-thumbs {
2
+ display: grid;
3
+ grid-template-columns: auto auto auto auto;
4
+ }
5
+
6
+ .carousel-thumb {
7
+ background: black;
8
+ color: white;
9
+ padding: 4em 0;
10
+ border: 0;
11
+ margin: 5px;
12
+ cursor: pointer;
13
+ text-align: center;
14
+ }
15
+
16
+ .carousel-play-icon {
17
+ font-size: 4em;
18
+ }
19
+
20
+ .lightbox-overlay {
21
+ position: fixed;
22
+ top: 0;
23
+ left: 0;
24
+ width: 100vw;
25
+ height: 100vh;
26
+ background: rgba(0, 0, 0, 0.8);
27
+ display: flex;
28
+ align-items: center;
29
+ justify-content: center;
30
+ z-index: 9998;
31
+ }
32
+
33
+ .lightbox-content.open,
34
+ .lightbox-overlay.open {
35
+ opacity: 1;
36
+ visibility: visible;
37
+ }
38
+
39
+ .lightbox-content.closed,
40
+ .lightbox-overlay.closed {
41
+ opacity: 0;
42
+ visibility: hidden;
43
+ }
44
+
45
+ .lightbox-button-close-wrapper {
46
+ position: absolute;
47
+ top: 10px;
48
+ right: 10px;
49
+ }
50
+
51
+ .lightbox-button-close {
52
+ border: none;
53
+ background: none;
54
+ color: #fff;
55
+ font-size: 3em;
56
+ font-weight: 500;
57
+ cursor: pointer;
58
+ padding-left: 1em;
59
+ padding-bottom: 1em;
60
+ z-index: 10000;
61
+ }
62
+
63
+ .lightbox-preview-button {
64
+ position: absolute;
65
+ top: 50%;
66
+ transform: translateY(-50%);
67
+ background: none;
68
+ color: #fff;
69
+ border: none;
70
+ padding: 0.5em;
71
+ font-size: 3em;
72
+ cursor: pointer;
73
+ z-index: 9999;
74
+ }
75
+
76
+ .lightbox-preview-button.next {
77
+ left: 10px;
78
+ }
79
+
80
+ .lightbox-preview-button.prev {
81
+ right: 10px;
82
+ }
83
+
84
+ .lightbox-content {
85
+ max-width: 90%;
86
+ max-height: 90%;
87
+ display: flex;
88
+ align-items: center;
89
+ justify-content: center;
90
+ position: relative;
91
+ transition:
92
+ opacity 0.3s ease,
93
+ visibility 0.3s ease;
94
+ z-index: 9999;
95
+ }
@@ -0,0 +1,132 @@
1
+ import clsx from "clsx";
2
+ import { useCallback, useEffect, useState } from "react";
3
+ import { ApplicationIcons } from "../appearance/icons";
4
+ import "./LightboxCarousel.css";
5
+
6
+ interface Slide {
7
+ label: string;
8
+ render: () => React.ReactNode;
9
+ }
10
+
11
+ interface LightboxCarouselProps {
12
+ slides: Slide[];
13
+ }
14
+
15
+ /**
16
+ * LightboxCarousel component provides a carousel with lightbox functionality.
17
+ */
18
+ export const LightboxCarousel: React.FC<LightboxCarouselProps> = ({
19
+ slides,
20
+ }) => {
21
+ const [isOpen, setIsOpen] = useState(false);
22
+ const [showOverlay, setShowOverlay] = useState(false);
23
+ const [currentIndex, setCurrentIndex] = useState(0);
24
+
25
+ const openLightbox = (index: number) => {
26
+ setCurrentIndex(index);
27
+ setShowOverlay(true);
28
+
29
+ // Slight delay before setting isOpen so the fade-in starts from opacity: 0
30
+ setTimeout(() => setIsOpen(true), 10);
31
+ };
32
+
33
+ const closeLightbox = () => {
34
+ setIsOpen(false);
35
+ };
36
+
37
+ // Remove the overlay from the DOM after fade-out completes
38
+ useEffect(() => {
39
+ if (!isOpen && showOverlay) {
40
+ const timer = setTimeout(() => {
41
+ setShowOverlay(false);
42
+ }, 300); // match your transition duration
43
+ return () => clearTimeout(timer);
44
+ }
45
+ }, [isOpen, showOverlay]);
46
+
47
+ const showNext = useCallback(() => {
48
+ setCurrentIndex((prev) => {
49
+ return (prev + 1) % slides.length;
50
+ });
51
+ }, [slides]);
52
+
53
+ const showPrev = useCallback(() => {
54
+ setCurrentIndex((prev) => (prev - 1 + slides.length) % slides.length);
55
+ }, [slides]);
56
+
57
+ // Keyboard Navigation
58
+ useEffect(() => {
59
+ if (!isOpen) return;
60
+ const handleKeyUp = (e: KeyboardEvent) => {
61
+ if (e.key === "Escape") {
62
+ closeLightbox();
63
+ } else if (e.key === "ArrowRight") {
64
+ showNext();
65
+ } else if (e.key === "ArrowLeft") {
66
+ showPrev();
67
+ }
68
+ e.preventDefault();
69
+ e.stopPropagation();
70
+ };
71
+ window.addEventListener("keyup", handleKeyUp, true);
72
+ return () => window.removeEventListener("keyup", handleKeyUp);
73
+ }, [isOpen, showNext, showPrev]);
74
+
75
+ return (
76
+ <div className="lightbox-carousel-container">
77
+ <div className="carousel-thumbs">
78
+ {slides.map((slide, index) => {
79
+ return (
80
+ <div
81
+ key={index}
82
+ className="carousel-thumb"
83
+ onClick={() => openLightbox(index)}
84
+ >
85
+ <div>{slide.label}</div>
86
+ <div>
87
+ <i
88
+ className={clsx(ApplicationIcons.play, "carousel-play-icon")}
89
+ />
90
+ </div>
91
+ </div>
92
+ );
93
+ })}
94
+ </div>
95
+ {showOverlay && (
96
+ <div className={clsx("lightbox-overlay", isOpen ? "open" : "closed")}>
97
+ <div className={"lightbox-button-close-wrapper"}>
98
+ <button className={"lightbox-button-close"} onClick={closeLightbox}>
99
+ <i className={ApplicationIcons.close}></i>
100
+ </button>
101
+ </div>
102
+ {slides.length > 1 ? (
103
+ <button
104
+ className={"lightbox-preview-button prev"}
105
+ onClick={showPrev}
106
+ >
107
+ <i className={ApplicationIcons.previous}></i>
108
+ </button>
109
+ ) : (
110
+ ""
111
+ )}
112
+ {slides.length > 1 ? (
113
+ <button
114
+ className={"lightbox-preview-button next"}
115
+ onClick={showNext}
116
+ >
117
+ <i className={ApplicationIcons.next} />
118
+ </button>
119
+ ) : (
120
+ ""
121
+ )}
122
+ <div
123
+ key={`carousel-slide-${currentIndex}`}
124
+ className={clsx("lightbox-content", isOpen ? "open" : "closed")}
125
+ >
126
+ {slides[currentIndex].render()}
127
+ </div>
128
+ </div>
129
+ )}
130
+ </div>
131
+ );
132
+ };
@@ -0,0 +1,3 @@
1
+ .markdown-ordered-list-item {
2
+ margin-bottom: 0.2em;
3
+ }
@@ -0,0 +1,133 @@
1
+ import clsx from "clsx";
2
+ import markdownit from "markdown-it";
3
+ import React from "react";
4
+ import "./MarkdownDiv.css";
5
+
6
+ interface MarkdownDivProps {
7
+ markdown: string;
8
+ style?: React.CSSProperties;
9
+ className?: string | string[];
10
+ }
11
+
12
+ export const MarkdownDiv = React.forwardRef<HTMLDivElement, MarkdownDivProps>(
13
+ ({ markdown, style, className }, ref) => {
14
+ // Escape all tags
15
+ const escaped = markdown ? escape(markdown) : "";
16
+
17
+ // Pre-render any text that isn't handled by markdown
18
+ const preRendered = preRenderText(escaped);
19
+
20
+ const protectedText = protectMarkdown(preRendered);
21
+
22
+ let renderedHtml = protectedText;
23
+ try {
24
+ const md = markdownit({
25
+ breaks: true,
26
+ html: true,
27
+ });
28
+ renderedHtml = md.render(protectedText);
29
+ } catch (ex) {
30
+ console.log("Unable to markdown render content");
31
+ console.error(ex);
32
+ }
33
+
34
+ const unescaped = unprotectMarkdown(renderedHtml);
35
+
36
+ // For `code` tags, reverse the escaping if we can
37
+ const withCode = unescapeCodeHtmlEntities(unescaped);
38
+
39
+ // Return the rendered markdown
40
+ const markup = { __html: withCode };
41
+
42
+ return (
43
+ <div
44
+ ref={ref}
45
+ dangerouslySetInnerHTML={markup}
46
+ style={style}
47
+ className={clsx(className, "markdown-content")}
48
+ />
49
+ );
50
+ },
51
+ );
52
+
53
+ const kLetterListPattern = /^([a-zA-Z][).]\s.*?)$/gm;
54
+ const kCommonmarkReferenceLinkPattern = /\[([^\]]*)\]: (?!http)(.*)/g;
55
+
56
+ const preRenderText = (txt: string): string => {
57
+ // eslint-disable-next-line no-misleading-character-class
58
+ txt = txt.replace(/^[\u200B\u200C\u200D\u200E\u200F\uFEFF]/, "");
59
+
60
+ // Special handling for ordered lists that look like
61
+ // multiple choice (e.g. a), b), c), d) etc..)
62
+ return txt.replaceAll(
63
+ kLetterListPattern,
64
+ "<p class='markdown-ordered-list-item'>$1</p>",
65
+ );
66
+ };
67
+
68
+ const protectMarkdown = (txt: string): string => {
69
+ // Special handling for commonmark like reference links which might
70
+ // look like:
71
+ // [alias]: http://www.google.com
72
+ // but text like:
73
+ // [expert]: answer
74
+ // Also fools this
75
+ return txt.replaceAll(
76
+ kCommonmarkReferenceLinkPattern,
77
+ "(open:767A125E)$1(close:767A125E) $2 ",
78
+ );
79
+ };
80
+
81
+ const unprotectMarkdown = (txt: string): string => {
82
+ txt = txt.replaceAll("(open:767A125E)", "[");
83
+ txt = txt.replaceAll("(close:767A125E)", "]");
84
+ return txt;
85
+ };
86
+
87
+ const escape = (content: string): string => {
88
+ return content.replace(/[<>&'"]/g, (c: string): string => {
89
+ switch (c) {
90
+ case "<":
91
+ return "&lt;";
92
+ case ">":
93
+ return "&gt;";
94
+ case "&":
95
+ return "&amp;";
96
+ case "'":
97
+ return "&apos;";
98
+ case '"':
99
+ return "&quot;";
100
+ default:
101
+ throw new Error("Matched a value that isn't replaceable");
102
+ }
103
+ });
104
+ };
105
+
106
+ function unescapeCodeHtmlEntities(str: string): string {
107
+ const htmlEntities: Record<string, string> = {
108
+ "&lt;": "<",
109
+ "&gt;": ">",
110
+ "&amp;": "&",
111
+ "&#x5C;": "\\",
112
+ "&quot;": '"',
113
+ };
114
+
115
+ return str.replace(
116
+ /(<code[^>]*>)([\s\S]*?)(<\/code>)/gi,
117
+ (
118
+ _match: string,
119
+ starttag: string,
120
+ content: string,
121
+ endtag: string,
122
+ ): string => {
123
+ return (
124
+ starttag +
125
+ content.replace(
126
+ /&(?:amp|lt|gt|quot|#39|#x2F|#x5C|#96);/g,
127
+ (entity: string): string => htmlEntities[entity] || entity,
128
+ ) +
129
+ endtag
130
+ );
131
+ },
132
+ );
133
+ }
@@ -0,0 +1,43 @@
1
+ .message-band {
2
+ grid-template-columns: max-content auto max-content;
3
+ align-items: center;
4
+ column-gap: 0.5em;
5
+ font-size: var(--inspect-font-size-small);
6
+ border-bottom: solid 1px var(--bs-light-border-subtle);
7
+ padding: 0.3em 1em;
8
+ display: grid;
9
+ }
10
+
11
+ .message-band.hidden {
12
+ display: none;
13
+ }
14
+
15
+ .message-band.info {
16
+ background-color: var(--bs-light);
17
+ }
18
+
19
+ .message-band.warning {
20
+ background-color: var(--bs-warning-bg-subtle);
21
+ color: var(--bs-warning-text-emphasis);
22
+ }
23
+
24
+ .message-band.error {
25
+ background-color: var(--bs-error-bg-subtle);
26
+ color: var(--bs-error-text-emphasis);
27
+ }
28
+
29
+ .message-band-btn {
30
+ font-size: var(--inspect-font-size-title-secondary);
31
+ margin: 0;
32
+ padding: 0;
33
+ height: var(--inspect-font-size-title-secondary);
34
+ line-height: var(--inspect-font-size-title-secondary);
35
+ }
36
+
37
+ .message-band-btn.error {
38
+ color: var(--bs-error-text-emphasis);
39
+ }
40
+
41
+ .message-band-btn.warning {
42
+ color: var(--bs-warning-text-emphasis);
43
+ }
@@ -0,0 +1,39 @@
1
+ import { clsx } from "clsx";
2
+
3
+ import { ApplicationIcons } from "../appearance/icons";
4
+ import "./MessageBand.css";
5
+
6
+ interface MessageBandProps {
7
+ message: string;
8
+ hidden: boolean;
9
+ setHidden: (hidden: boolean) => void;
10
+ type: "info" | "warning" | "error";
11
+ }
12
+
13
+ export const MessageBand: React.FC<MessageBandProps> = ({
14
+ message,
15
+ hidden,
16
+ setHidden,
17
+ type,
18
+ }) => {
19
+ const className: string[] = [type];
20
+ if (hidden) {
21
+ className.push("hidden");
22
+ }
23
+
24
+ return (
25
+ <div className={clsx("message-band", className)}>
26
+ <i className={ApplicationIcons.logging[type]} />
27
+ {message}
28
+ <button
29
+ className={clsx("btn", "message-band-btn", type)}
30
+ title="Close"
31
+ onClick={() => {
32
+ setHidden(true);
33
+ }}
34
+ >
35
+ <i className={ApplicationIcons.close}></i>
36
+ </button>
37
+ </div>
38
+ );
39
+ };
@@ -0,0 +1,67 @@
1
+ import { Popover } from "bootstrap";
2
+ import React, { useEffect, useRef } from "react";
3
+ import "./MorePopover.css";
4
+
5
+ interface MorePopoverProps {
6
+ title: string;
7
+ customClass?: string;
8
+ children: React.ReactNode;
9
+ }
10
+
11
+ export const MorePopover: React.FC<MorePopoverProps> = ({
12
+ title,
13
+ customClass,
14
+ children,
15
+ }) => {
16
+ const popoverRef = useRef<HTMLAnchorElement>(null);
17
+ const contentRef = useRef<HTMLDivElement>(null);
18
+
19
+ useEffect(() => {
20
+ if (!popoverRef.current || !contentRef.current) return;
21
+
22
+ const contentEl = contentRef.current;
23
+ const popOverContent = document.createElement("div");
24
+
25
+ // Clone children into popover content
26
+ Array.from(contentEl.childNodes).forEach((child) =>
27
+ popOverContent.appendChild(child.cloneNode(true)),
28
+ );
29
+
30
+ // Initialize Bootstrap popover
31
+ new Popover(popoverRef.current, {
32
+ content: popOverContent,
33
+ title,
34
+ html: true,
35
+ customClass,
36
+ trigger: "focus",
37
+ });
38
+
39
+ // Cleanup on unmount
40
+ return () => {
41
+ if (popoverRef.current) {
42
+ const popoverInstance = Popover.getInstance(popoverRef.current);
43
+ if (popoverInstance) {
44
+ popoverInstance.dispose();
45
+ }
46
+ }
47
+ };
48
+ }, [title, customClass]);
49
+
50
+ return (
51
+ <>
52
+ <a
53
+ ref={popoverRef}
54
+ tabIndex={0}
55
+ className="more-popover-button btn"
56
+ role="button"
57
+ data-bs-toggle="popover"
58
+ data-bs-trigger="focus"
59
+ >
60
+ <i className="more-icon" />
61
+ </a>
62
+ <div ref={contentRef} className="more-popover-content">
63
+ {children}
64
+ </div>
65
+ </>
66
+ );
67
+ };