本文整理匯總了TypeScript中@nteract/types.NotebookModel.getIn方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript NotebookModel.getIn方法的具體用法?TypeScript NotebookModel.getIn怎麽用?TypeScript NotebookModel.getIn使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類@nteract/types.NotebookModel
的用法示例。
在下文中一共展示了NotebookModel.getIn方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: changeCellType
function changeCellType(
state: NotebookModel,
action: actionTypes.ChangeCellType
): RecordOf<DocumentRecordProps> {
const id = action.payload.id ? action.payload.id : state.cellFocused;
if (!id) {
return state;
}
const { to } = action.payload;
const cell = state.getIn(["notebook", "cellMap", id]);
const from = cell.cell_type;
// NOOP, since we're already that cell type
if (from === to) {
return state;
}
let nextState = state;
// from === "code"
if (from === "code") {
nextState = cleanCellTransient(
state
.deleteIn(["notebook", "cellMap", id, "execution_count"])
.deleteIn(["notebook", "cellMap", id, "outputs"]),
id
);
}
switch (to) {
case "code":
return nextState.setIn(
["notebook", "cellMap", id],
makeCodeCell({
source: cell.source
})
);
case "markdown":
return nextState.setIn(
["notebook", "cellMap", id],
makeMarkdownCell({
source: cell.source
})
);
case "raw":
return nextState.setIn(
["notebook", "cellMap", id],
makeRawCell({
source: cell.source
})
);
}
// If we didn't match on the `to`, we should change nothing as we don't implement
// other cell types (as there aren't any)
return state;
}
示例2: updateDisplay
function updateDisplay(
state: NotebookModel,
action: actionTypes.UpdateDisplay
): RecordOf<DocumentRecordProps> {
const { content } = action.payload;
if (!(content && content.transient && content.transient.display_id)) {
return state;
}
const displayID = content.transient.display_id;
const keyPaths: KeyPaths = state.getIn([
"transient",
"keyPathsForDisplays",
displayID
]);
const updatedContent = {
data: createFrozenMediaBundle(content.data),
metadata: fromJS(content.metadata || {})
};
return keyPaths.reduce(
(currState: NotebookModel, kp: KeyPath) =>
currState.updateIn(kp, output => {
return output.merge(updatedContent);
}),
state
);
}
示例3: updateDisplay
function updateDisplay(
state: NotebookModel,
action: actionTypes.UpdateDisplay
) {
const { content } = action.payload;
if (!(content && content.transient && content.transient.display_id)) {
return state;
}
const displayID = content.transient.display_id;
const keyPaths: KeyPaths = state.getIn([
"transient",
"keyPathsForDisplays",
displayID
]);
const updatedContent = {
data: createImmutableMimeBundle(content.data),
metadata: Immutable.fromJS(content.metadata || {})
};
return keyPaths.reduce(
(currState: NotebookModel, kp: KeyPath) =>
// $FlowFixMe: gnarly one we need to FIXME
currState.updateIn(kp, output => {
return output.merge(updatedContent);
}),
state
);
}
示例4: copyCell
function copyCell(state: NotebookModel, action: actionTypes.CopyCell) {
let id = action.payload.id || state.cellFocused;
const cell = state.getIn(["notebook", "cellMap", id]);
if (!cell) {
return state;
}
return state.set("copied", cell);
}
示例5: focusPreviousCellEditor
function focusPreviousCellEditor(
state: NotebookModel,
action: actionTypes.FocusPreviousCellEditor
): RecordOf<DocumentRecordProps> {
const cellOrder: List<CellId> = state.getIn(["notebook", "cellOrder"]);
const curIndex = cellOrder.findIndex(
(id: CellId) => id === action.payload.id
);
const nextIndex = Math.max(0, curIndex - 1);
return state.set("editorFocused", cellOrder.get(nextIndex));
}
示例6: focusPreviousCell
function focusPreviousCell(
state: NotebookModel,
action: actionTypes.FocusPreviousCell
): NotebookModel {
const cellOrder = state.getIn(["notebook", "cellOrder"]);
const curIndex = cellOrder.findIndex(
(id: CellId) => id === action.payload.id
);
const nextIndex = Math.max(0, curIndex - 1);
return state.set("cellFocused", cellOrder.get(nextIndex));
}
示例7: toggleCellInputVisibility
function toggleCellInputVisibility(
state: NotebookModel,
action: actionTypes.ToggleCellInputVisibility
): RecordOf<DocumentRecordProps> {
const id = action.payload.id ? action.payload.id : state.cellFocused;
if (!id) {
return state;
}
return state.setIn(
["notebook", "cellMap", id, "metadata", "inputHidden"],
!state.getIn(["notebook", "cellMap", id, "metadata", "inputHidden"])
);
}
示例8: toggleCellOutputVisibility
function toggleCellOutputVisibility(
state: NotebookModel,
action: actionTypes.ToggleCellOutputVisibility
) {
const id = action.payload.id ? action.payload.id : state.cellFocused;
if (!id) {
return state;
}
return state.setIn(
["notebook", "cellMap", id, "metadata", "outputHidden"],
!state.getIn(["notebook", "cellMap", id, "metadata", "outputHidden"])
);
}
示例9: focusNextCell
function focusNextCell(
state: NotebookModel,
action: actionTypes.FocusNextCell
): RecordOf<DocumentRecordProps> {
const cellOrder = state.getIn(["notebook", "cellOrder"]);
const id = action.payload.id ? action.payload.id : state.get("cellFocused");
// If for some reason we neither have an ID here or a focused cell, we just
// keep the state consistent
if (!id) {
return state;
}
const curIndex = cellOrder.findIndex((foundId: CellId) => id === foundId);
const curCellType = state.getIn(["notebook", "cellMap", id, "cell_type"]);
const nextIndex = curIndex + 1;
// When at the end, create a new cell
if (nextIndex >= cellOrder.size) {
if (!action.payload.createCellIfUndefined) {
return state;
}
const cellId: string = uuid();
const cell = curCellType === "code" ? emptyCodeCell : emptyMarkdownCell;
const notebook: ImmutableNotebook = state.get("notebook");
return state
.set("cellFocused", cellId)
.set("notebook", insertCellAt(notebook, cell, cellId, nextIndex));
}
// When in the middle of the notebook document, move to the next cell
return state.set("cellFocused", cellOrder.get(nextIndex));
}
示例10: clearOutputs
function clearOutputs(state: NotebookModel, action: actionTypes.ClearOutputs) {
const id = action.payload.id ? action.payload.id : state.cellFocused;
if (!id) {
return state;
}
const type = state.getIn(["notebook", "cellMap", id, "cell_type"]);
const cleanedState = cleanCellTransient(state, id);
if (type === "code") {
return cleanedState
.setIn(["notebook", "cellMap", id, "outputs"], Immutable.List())
.setIn(["notebook", "cellMap", id, "execution_count"], null);
}
return cleanedState;
}