@marimo-team/frontend 0.23.6-dev1 → 0.23.6-dev11
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.
- package/dist/assets/{CellStatus-DKMrz26-.js → CellStatus-BasmzQBh.js} +1 -1
- package/dist/assets/{JsonOutput-02ehjjSC.js → JsonOutput-BQaSLDBi.js} +1 -1
- package/dist/assets/{MarimoErrorOutput-Dbk0HqOA.js → MarimoErrorOutput-Dm4hVwDq.js} +1 -1
- package/dist/assets/{RenderHTML-8cI8zL5y.js → RenderHTML-CA4tujDX.js} +1 -1
- package/dist/assets/{add-cell-with-ai-DfniMbLM.js → add-cell-with-ai-5QPp1nPl.js} +1 -1
- package/dist/assets/{add-connection-dialog-8ChtH4mo.js → add-connection-dialog-C3IbqmBw.js} +1 -1
- package/dist/assets/{agent-panel-jsnbrvBR.js → agent-panel-Dbk-1jxq.js} +1 -1
- package/dist/assets/{ai-model-dropdown-BFTnsrTP.js → ai-model-dropdown-DRqlfqFb.js} +1 -1
- package/dist/assets/{app-config-button-c_2rVezv.js → app-config-button-DyNQc93A.js} +1 -1
- package/dist/assets/{cell-editor-WSoKgacR.js → cell-editor-V8ybPnUa.js} +1 -1
- package/dist/assets/{cell-link-BRdZl0OJ.js → cell-link-8o8mCUzE.js} +1 -1
- package/dist/assets/{cells-CcBfzJ1Z.js → cells-Jdt48eTG.js} +47 -47
- package/dist/assets/{chat-display-NiFkPnNN.js → chat-display-D4A5J3ON.js} +1 -1
- package/dist/assets/{chat-panel-C6V6gxrr.js → chat-panel--TAJZjAo.js} +1 -1
- package/dist/assets/{chat-ui-BLiRBYhk.js → chat-ui-Dlmd_U56.js} +1 -1
- package/dist/assets/{column-preview-rDM8Q-wn.js → column-preview-B1oiFlur.js} +1 -1
- package/dist/assets/{command-palette-CUYBVGPU.js → command-palette-DcTyjGF4.js} +1 -1
- package/dist/assets/{common-CHmdPmWi.js → common-C6ZHulDM.js} +1 -1
- package/dist/assets/{components-HCInimq-.js → components-BiZUhizd.js} +1 -1
- package/dist/assets/{components-DVKf_7RU.js → components-Du9BBcZY.js} +1 -1
- package/dist/assets/{datasource-Czm_KBfK.js → datasource-BGCJgHn8.js} +1 -1
- package/dist/assets/{dependency-graph-panel-DPKylrlr.js → dependency-graph-panel-BFoJRcHv.js} +1 -1
- package/dist/assets/{documentation-panel-DZkIKuPv.js → documentation-panel-Bi7B6BDD.js} +1 -1
- package/dist/assets/{download-YUQiaxS9.js → download-q17GDjRk.js} +1 -1
- package/dist/assets/{edit-page-BiwFohnL.js → edit-page-CKzJ_Zmc.js} +3 -3
- package/dist/assets/{error-panel-C4UQHEjp.js → error-panel-Elx5tZAZ.js} +1 -1
- package/dist/assets/{file-explorer-panel-DEJtGGUp.js → file-explorer-panel-omTFPhXg.js} +1 -1
- package/dist/assets/{file-icons-CMxkj_kV.js → file-icons-D1lzcliR.js} +1 -1
- package/dist/assets/{floating-outline-BtNnv2IX.js → floating-outline-DVqXePmL.js} +1 -1
- package/dist/assets/{focus-CXQpR65O.js → focus-Bz1PGBQ2.js} +1 -1
- package/dist/assets/{form-EgPmt17c.js → form-CpNkZ10P.js} +1 -1
- package/dist/assets/{home-page-CaIONOO0.js → home-page-B6hZQb34.js} +1 -1
- package/dist/assets/{hooks-CZcajTLZ.js → hooks-lEn1DZw2.js} +1 -1
- package/dist/assets/{html-to-image-BHdf1t5J.js → html-to-image-BJDxFKbb.js} +1 -1
- package/dist/assets/{index-CL4WR8q8.js → index-Dyru2McE.js} +4 -4
- package/dist/assets/{kiosk-mode-vHMq9vr1.js → kiosk-mode-DlJLa7MP.js} +1 -1
- package/dist/assets/layout-DBhZTvp5.js +9 -0
- package/dist/assets/{logs-panel-DL9WeQsv.js → logs-panel--5x174b0.js} +1 -1
- package/dist/assets/{markdown-renderer-DmnGXdCp.js → markdown-renderer-9gIJjISB.js} +1 -1
- package/dist/assets/{name-cell-input-CHuLB3H7.js → name-cell-input-DUUJ7fdG.js} +1 -1
- package/dist/assets/{outline-panel-JaSUHnmD.js → outline-panel-B6y7CdzK.js} +1 -1
- package/dist/assets/{packages-panel-BB5_Iu2c.js → packages-panel-bTONt5Lb.js} +1 -1
- package/dist/assets/{panels-D4g3bUpO.js → panels-DLL43K0s.js} +1 -1
- package/dist/assets/{process-output-hJso9ugZ.js → process-output-TR8koJYc.js} +1 -1
- package/dist/assets/{radio-group-6t7ozlnG.js → radio-group-B0jYgGRE.js} +1 -1
- package/dist/assets/{readonly-python-code-JBCsN3-9.js → readonly-python-code-BNCBnJYH.js} +1 -1
- package/dist/assets/{reveal-component-BKMB17JT.js → reveal-component-Cfvv_aP0.js} +1 -1
- package/dist/assets/{run-page-BPM6GfJo.js → run-page-CPxLAWm8.js} +1 -1
- package/dist/assets/{scratchpad-panel-Cabu2odx.js → scratchpad-panel-DUSXJer8.js} +1 -1
- package/dist/assets/{session-panel-BAiIHm0d.js → session-panel-BAAW6R7U.js} +1 -1
- package/dist/assets/{snippets-panel-CQKr-OMs.js → snippets-panel-roW3_D4d.js} +1 -1
- package/dist/assets/{state-DCT6JLba.js → state-Bhut5iLD.js} +1 -1
- package/dist/assets/{state-DGoUR-mM.js → state-D5aL5woK.js} +1 -1
- package/dist/assets/{textarea-BI_mXP9w.js → textarea-DapfQSws.js} +1 -1
- package/dist/assets/{tracing-BF-ca60a.js → tracing-D3nIh6vh.js} +1 -1
- package/dist/assets/{tracing-panel-D1j7Fbvr.js → tracing-panel-B23uvwYc.js} +2 -2
- package/dist/assets/{useCellActionButton-CcXV09GQ.js → useCellActionButton-DrzG-_Bd.js} +1 -1
- package/dist/assets/{useDeleteCell-BVX9aH-t.js → useDeleteCell-CcnkgOq-.js} +1 -1
- package/dist/assets/{useDependencyPanelTab-CewdyAAy.js → useDependencyPanelTab-Dv04JzMr.js} +1 -1
- package/dist/assets/useNotebookActions-D6c9Rjb9.js +1 -0
- package/dist/assets/{useRunCells-CgXnbA14.js → useRunCells-BeRcytF8.js} +1 -1
- package/dist/assets/{useSplitCell-_Q2wQXsQ.js → useSplitCell-DSLPh_8D.js} +1 -1
- package/dist/index.html +22 -22
- package/package.json +1 -1
- package/src/components/slides/slide-form.tsx +43 -0
- package/src/core/cells/__tests__/apply-transaction.test.ts +193 -27
- package/src/core/cells/__tests__/cells.test.ts +99 -0
- package/src/core/cells/__tests__/document-changes.test.ts +14 -0
- package/src/core/cells/cells.ts +14 -1
- package/src/core/cells/document-changes.ts +17 -14
- package/dist/assets/layout-DNOqvNbP.js +0 -9
- package/dist/assets/useNotebookActions-CWpi-dx_.js +0 -1
package/src/core/cells/cells.ts
CHANGED
|
@@ -29,6 +29,7 @@ import { isErrorMime } from "../mime";
|
|
|
29
29
|
import type { CellConfig } from "../network/types";
|
|
30
30
|
import { isRtcEnabled } from "../rtc/state";
|
|
31
31
|
import { createDeepEqualAtom, store } from "../state/jotai";
|
|
32
|
+
import { isWasm } from "../wasm/utils";
|
|
32
33
|
import { prepareCellForExecution, transitionCell } from "./cell";
|
|
33
34
|
import { documentTransactionMiddleware } from "./document-changes";
|
|
34
35
|
import { CellId, SCRATCH_CELL_ID, SETUP_CELL_ID } from "./ids";
|
|
@@ -1032,8 +1033,20 @@ const {
|
|
|
1032
1033
|
setCells: (state, cells: CellData[]) => {
|
|
1033
1034
|
const cellData = Object.fromEntries(cells.map((cell) => [cell.id, cell]));
|
|
1034
1035
|
|
|
1036
|
+
// WASM has no server-side SessionView to replay outputs, so the
|
|
1037
|
+
// snapshot hydrated by notebookStateFromSession is the only source.
|
|
1038
|
+
const preserveSnapshot = isWasm();
|
|
1039
|
+
const runtimeFor = (cellId: CellId): CellRuntimeState => {
|
|
1040
|
+
if (!preserveSnapshot) {
|
|
1041
|
+
return createCellRuntimeState();
|
|
1042
|
+
}
|
|
1043
|
+
const prev = state.cellRuntime[cellId];
|
|
1044
|
+
const hasSnapshot =
|
|
1045
|
+
prev && (prev.output != null || prev.consoleOutputs.length > 0);
|
|
1046
|
+
return hasSnapshot ? prev : createCellRuntimeState();
|
|
1047
|
+
};
|
|
1035
1048
|
const cellRuntime = Object.fromEntries(
|
|
1036
|
-
cells.map((cell) => [cell.id,
|
|
1049
|
+
cells.map((cell) => [cell.id, runtimeFor(cell.id)]),
|
|
1037
1050
|
);
|
|
1038
1051
|
|
|
1039
1052
|
return withScratchCell({
|
|
@@ -156,10 +156,13 @@ function columnChanges(
|
|
|
156
156
|
for (const [cellId, newCol] of newColumns) {
|
|
157
157
|
const prevCol = prevColumns.get(cellId);
|
|
158
158
|
if (prevCol !== newCol) {
|
|
159
|
+
const cell = getCell(cellId, newState);
|
|
159
160
|
changes.push({
|
|
160
161
|
type: "set-config",
|
|
161
162
|
cellId: cellId,
|
|
162
163
|
column: newCol,
|
|
164
|
+
disabled: cell?.config.disabled ?? false,
|
|
165
|
+
hideCode: cell?.config.hide_code ?? false,
|
|
163
166
|
});
|
|
164
167
|
}
|
|
165
168
|
}
|
|
@@ -257,18 +260,21 @@ export function toDocumentChanges(
|
|
|
257
260
|
}
|
|
258
261
|
|
|
259
262
|
// updateCellConfig → set-config
|
|
260
|
-
//
|
|
261
|
-
//
|
|
262
|
-
// (from the action payload, not the full cell config).
|
|
263
|
+
// SetConfig is full-replacement: emit the cell's complete config from
|
|
264
|
+
// newState (which already merged the action's partial payload).
|
|
263
265
|
case "updateCellConfig": {
|
|
264
|
-
const { cellId
|
|
266
|
+
const { cellId } = action.payload;
|
|
267
|
+
const cell = getCell(cellId, newState);
|
|
268
|
+
if (!cell) {
|
|
269
|
+
return [];
|
|
270
|
+
}
|
|
265
271
|
return [
|
|
266
272
|
{
|
|
267
273
|
type: "set-config",
|
|
268
274
|
cellId: cellId,
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
275
|
+
column: cell.config.column ?? null,
|
|
276
|
+
disabled: cell.config.disabled ?? false,
|
|
277
|
+
hideCode: cell.config.hide_code ?? false,
|
|
272
278
|
},
|
|
273
279
|
];
|
|
274
280
|
}
|
|
@@ -538,18 +544,15 @@ export function fromDocumentChanges(
|
|
|
538
544
|
break;
|
|
539
545
|
|
|
540
546
|
// set-config → updateCellConfig
|
|
541
|
-
// Maps the change's camelCase hideCode back to CellConfig's snake_case
|
|
542
|
-
// hide_code. Only includes fields that are non-null (null means
|
|
543
|
-
// "not specified" on the wire, not "clear the value").
|
|
544
547
|
case "set-config":
|
|
545
548
|
actions.push({
|
|
546
549
|
type: "updateCellConfig",
|
|
547
550
|
payload: {
|
|
548
551
|
cellId: change.cellId,
|
|
549
552
|
config: {
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
+
column: change.column,
|
|
554
|
+
disabled: change.disabled,
|
|
555
|
+
hide_code: change.hideCode,
|
|
553
556
|
},
|
|
554
557
|
},
|
|
555
558
|
});
|
|
@@ -650,7 +653,7 @@ export function applyTransactionChanges(
|
|
|
650
653
|
) {
|
|
651
654
|
continue;
|
|
652
655
|
}
|
|
653
|
-
if (change.type === "set-config"
|
|
656
|
+
if (change.type === "set-config") {
|
|
654
657
|
hasColumnChange = true;
|
|
655
658
|
}
|
|
656
659
|
if (change.type === "create-cell" && change.config?.column != null) {
|