silverbullet/plug-api/syscalls/editor.ts

226 lines
5.7 KiB
TypeScript

import type { UploadFile } from "../types.ts";
import { syscall } from "../syscall.ts";
import type { PageRef } from "../lib/page_ref.ts";
import type { FilterOption } from "../../lib/web.ts";
export function getCurrentPage(): Promise<string> {
return syscall("editor.getCurrentPage");
}
export function setPage(newName: string): Promise<void> {
return syscall("editor.setPage", newName);
}
export function getText(): Promise<string> {
return syscall("editor.getText");
}
/**
* This updates the editor text, but in a minimal-diff way:
* it compares the current editor text with the new text, and only sends the changes to the editor, thereby preserving cursor location
*/
export function setText(newText: string): Promise<void> {
return syscall("editor.setText", newText);
}
export function getCursor(): Promise<number> {
return syscall("editor.getCursor");
}
export function getSelection(): Promise<{ from: number; to: number }> {
return syscall("editor.getSelection");
}
export function setSelection(from: number, to: number): Promise<void> {
return syscall("editor.setSelection", from, to);
}
export function save(): Promise<void> {
return syscall("editor.save");
}
export function navigate(
pageRef: PageRef,
replaceState = false,
newWindow = false,
): Promise<void> {
return syscall("editor.navigate", pageRef, replaceState, newWindow);
}
export function openPageNavigator(
mode: "page" | "meta" | "all" = "page",
): Promise<void> {
return syscall("editor.openPageNavigator", mode);
}
export function openCommandPalette(): Promise<void> {
return syscall("editor.openCommandPalette");
}
export function reloadPage(): Promise<void> {
return syscall("editor.reloadPage");
}
export function reloadUI(): Promise<void> {
return syscall("editor.reloadUI");
}
export function reloadSettingsAndCommands(): Promise<void> {
return syscall("editor.reloadSettingsAndCommands");
}
export function openUrl(url: string, existingWindow = false): Promise<void> {
return syscall("editor.openUrl", url, existingWindow);
}
/**
* This is calling the `go()` method from the History Web API.
* @param delta Position in history to move to relative to the current page,
* where a negative value moves backwards, and positive forwards
*/
export function goHistory(delta: number): Promise<void> {
return syscall("editor.goHistory", delta);
}
// Force the client to download the file in dataUrl with filename as file name
export function downloadFile(filename: string, dataUrl: string): Promise<void> {
return syscall("editor.downloadFile", filename, dataUrl);
}
export function uploadFile(
accept?: string,
capture?: string,
): Promise<UploadFile> {
return syscall("editor.uploadFile", accept, capture);
}
export function flashNotification(
message: string,
type: "info" | "error" = "info",
): Promise<void> {
return syscall("editor.flashNotification", message, type);
}
export function filterBox(
label: string,
options: FilterOption[],
helpText = "",
placeHolder = "",
): Promise<FilterOption | undefined> {
return syscall("editor.filterBox", label, options, helpText, placeHolder);
}
export function showPanel(
id: "lhs" | "rhs" | "bhs" | "modal",
mode: number,
html: string,
script = "",
): Promise<void> {
return syscall("editor.showPanel", id, mode, html, script);
}
export function hidePanel(
id: "lhs" | "rhs" | "bhs" | "modal",
): Promise<void> {
return syscall("editor.hidePanel", id);
}
export function insertAtPos(text: string, pos: number): Promise<void> {
return syscall("editor.insertAtPos", text, pos);
}
export function replaceRange(
from: number,
to: number,
text: string,
): Promise<void> {
return syscall("editor.replaceRange", from, to, text);
}
export function moveCursor(pos: number, center = false): Promise<void> {
return syscall("editor.moveCursor", pos, center);
}
export function moveCursorToLine(
line: number,
column = 1,
center = false,
): Promise<void> {
return syscall("editor.moveCursorToLine", line, column, center);
}
export function insertAtCursor(text: string): Promise<void> {
return syscall("editor.insertAtCursor", text);
}
export function dispatch(change: any): Promise<void> {
return syscall("editor.dispatch", change);
}
export function prompt(
message: string,
defaultValue = "",
): Promise<string | undefined> {
return syscall("editor.prompt", message, defaultValue);
}
export function confirm(
message: string,
): Promise<boolean> {
return syscall("editor.confirm", message);
}
export function getUiOption(key: string): Promise<any> {
return syscall("editor.getUiOption", key);
}
export function setUiOption(key: string, value: any): Promise<void> {
return syscall("editor.setUiOption", key, value);
}
// Vim specific
export function vimEx(exCommand: string): Promise<any> {
return syscall("editor.vimEx", exCommand);
}
// Folding
export function fold(): Promise<void> {
return syscall("editor.fold");
}
export function unfold(): Promise<void> {
return syscall("editor.unfold");
}
export function toggleFold(): Promise<void> {
return syscall("editor.toggleFold");
}
export function foldAll(): Promise<void> {
return syscall("editor.foldAll");
}
export function unfoldAll(): Promise<void> {
return syscall("editor.unfoldAll");
}
// Undo/redo
export function undo(): Promise<void> {
return syscall("editor.undo");
}
export function redo(): Promise<void> {
return syscall("editor.redo");
}
export function openSearchPanel(): Promise<void> {
return syscall("editor.openSearchPanel");
}
export function copyToClipboard(data: string | Blob): Promise<void> {
return syscall("editor.copyToClipboard", data);
}
export function deleteLine(): Promise<void> {
return syscall("editor.deleteLine");
}