2024-03-16 22:29:24 +08:00
|
|
|
import { Manifest } from "../lib/manifest.ts";
|
2024-07-14 17:29:43 +08:00
|
|
|
import { PageDecoration, PageMeta } from "../plug-api/types.ts";
|
2024-03-16 22:29:24 +08:00
|
|
|
import { AppCommand } from "../lib/command.ts";
|
2024-02-09 04:00:45 +08:00
|
|
|
import { defaultSettings } from "$common/settings.ts";
|
2024-03-16 22:29:24 +08:00
|
|
|
import {
|
|
|
|
ActionButton,
|
2024-07-13 20:55:35 +08:00
|
|
|
EmojiConfig,
|
2024-03-16 22:29:24 +08:00
|
|
|
FilterOption,
|
|
|
|
Notification,
|
|
|
|
PanelMode,
|
|
|
|
Shortcut,
|
|
|
|
} from "$lib/web.ts";
|
2024-02-06 21:07:38 +08:00
|
|
|
|
2022-12-15 20:23:49 +08:00
|
|
|
export type BuiltinSettings = {
|
|
|
|
indexPage: string;
|
2023-12-27 15:14:57 +08:00
|
|
|
shortcuts?: Shortcut[];
|
2024-07-20 01:08:49 +08:00
|
|
|
useSmartQuotes?: boolean;
|
2024-03-28 04:21:12 +08:00
|
|
|
maximumAttachmentSize?: number;
|
2024-07-23 22:49:27 +08:00
|
|
|
// Open the last page that was open when the app was closed
|
|
|
|
pwaOpenLastPage?: boolean;
|
|
|
|
// UI visuals
|
|
|
|
hideEditButton?: boolean;
|
|
|
|
hideSyncButton?: boolean;
|
2024-01-25 18:42:36 +08:00
|
|
|
actionButtons: ActionButton[];
|
2024-07-14 17:29:43 +08:00
|
|
|
pageDecorations?: PageDecoration[];
|
2023-05-29 15:53:49 +08:00
|
|
|
// Format: compatible with docker ignore
|
|
|
|
spaceIgnore?: string;
|
2024-02-06 21:07:38 +08:00
|
|
|
emoji?: EmojiConfig;
|
2024-07-23 22:49:27 +08:00
|
|
|
// DEPRECATED: Use space styles instead
|
|
|
|
customStyles?: string | string[];
|
|
|
|
// DEPRECATED: Use shortcuts instead
|
|
|
|
plugOverrides?: Record<string, Partial<Manifest>>;
|
|
|
|
// NOTE: Bit niche, maybe delete at some point?
|
|
|
|
defaultLinkStyle?: string;
|
2022-12-15 20:23:49 +08:00
|
|
|
};
|
|
|
|
|
2022-09-30 22:59:57 +08:00
|
|
|
export type PanelConfig = {
|
|
|
|
mode?: PanelMode;
|
|
|
|
html?: string;
|
|
|
|
script?: string;
|
|
|
|
};
|
|
|
|
|
2022-03-20 16:56:28 +08:00
|
|
|
export type AppViewState = {
|
|
|
|
currentPage?: string;
|
2023-01-16 18:28:59 +08:00
|
|
|
currentPageMeta?: PageMeta;
|
2024-01-25 18:42:36 +08:00
|
|
|
allPages: PageMeta[];
|
|
|
|
|
2022-09-06 22:21:33 +08:00
|
|
|
isLoading: boolean;
|
2024-02-07 16:33:47 +08:00
|
|
|
isMobile: boolean;
|
2022-03-20 16:56:28 +08:00
|
|
|
showPageNavigator: boolean;
|
|
|
|
showCommandPalette: boolean;
|
2023-01-04 23:37:09 +08:00
|
|
|
showCommandPaletteContext?: string;
|
2022-03-31 20:28:07 +08:00
|
|
|
unsavedChanges: boolean;
|
2023-08-16 17:40:31 +08:00
|
|
|
syncFailures: number; // Reset everytime a sync succeeds
|
2023-06-15 02:58:08 +08:00
|
|
|
progressPerc?: number;
|
2022-09-30 22:59:57 +08:00
|
|
|
panels: { [key: string]: PanelConfig };
|
2022-03-20 16:56:28 +08:00
|
|
|
commands: Map<string, AppCommand>;
|
|
|
|
notifications: Notification[];
|
2022-05-16 21:09:36 +08:00
|
|
|
recentCommands: Map<string, Date>;
|
2022-04-13 20:46:52 +08:00
|
|
|
|
2024-01-25 18:42:36 +08:00
|
|
|
settings: BuiltinSettings;
|
|
|
|
|
2022-12-21 21:55:24 +08:00
|
|
|
uiOptions: {
|
|
|
|
vimMode: boolean;
|
|
|
|
darkMode: boolean;
|
|
|
|
forcedROMode: boolean;
|
2024-02-23 06:28:47 +08:00
|
|
|
customStyles?: string;
|
2022-12-21 21:55:24 +08:00
|
|
|
};
|
|
|
|
|
2024-01-21 02:16:07 +08:00
|
|
|
// Page navigator mode
|
2024-07-19 23:06:40 +08:00
|
|
|
pageNavigatorMode: "page" | "meta" | "all";
|
2024-01-21 02:16:07 +08:00
|
|
|
|
2022-12-21 23:08:51 +08:00
|
|
|
// Filter box
|
2022-04-13 20:46:52 +08:00
|
|
|
showFilterBox: boolean;
|
2022-04-21 17:46:33 +08:00
|
|
|
filterBoxLabel: string;
|
2022-04-13 20:46:52 +08:00
|
|
|
filterBoxPlaceHolder: string;
|
|
|
|
filterBoxOptions: FilterOption[];
|
|
|
|
filterBoxHelpText: string;
|
|
|
|
filterBoxOnSelect: (option: FilterOption | undefined) => void;
|
2022-12-21 23:08:51 +08:00
|
|
|
|
|
|
|
// Prompt
|
|
|
|
showPrompt: boolean;
|
|
|
|
promptMessage?: string;
|
|
|
|
promptDefaultValue?: string;
|
|
|
|
promptCallback?: (value: string | undefined) => void;
|
|
|
|
|
|
|
|
// Confirm
|
|
|
|
showConfirm: boolean;
|
|
|
|
confirmMessage?: string;
|
|
|
|
confirmCallback?: (value: boolean) => void;
|
2022-03-20 16:56:28 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
export const initialViewState: AppViewState = {
|
2022-09-06 22:21:33 +08:00
|
|
|
isLoading: false,
|
2022-03-20 16:56:28 +08:00
|
|
|
showPageNavigator: false,
|
|
|
|
showCommandPalette: false,
|
2024-01-21 02:16:07 +08:00
|
|
|
pageNavigatorMode: "page",
|
2022-03-31 20:28:07 +08:00
|
|
|
unsavedChanges: false,
|
2023-08-16 17:40:31 +08:00
|
|
|
syncFailures: 0,
|
2022-12-21 21:55:24 +08:00
|
|
|
uiOptions: {
|
|
|
|
vimMode: false,
|
|
|
|
darkMode: false,
|
|
|
|
forcedROMode: false,
|
|
|
|
},
|
2024-02-07 16:33:47 +08:00
|
|
|
isMobile: false,
|
2022-09-30 22:59:57 +08:00
|
|
|
panels: {
|
|
|
|
lhs: {},
|
|
|
|
rhs: {},
|
|
|
|
bhs: {},
|
|
|
|
modal: {},
|
|
|
|
},
|
2024-01-25 18:42:36 +08:00
|
|
|
settings: defaultSettings,
|
2023-05-24 02:53:53 +08:00
|
|
|
allPages: [],
|
2022-03-20 16:56:28 +08:00
|
|
|
commands: new Map(),
|
2022-05-16 21:09:36 +08:00
|
|
|
recentCommands: new Map(),
|
2022-03-20 16:56:28 +08:00
|
|
|
notifications: [],
|
2022-04-13 20:46:52 +08:00
|
|
|
showFilterBox: false,
|
|
|
|
filterBoxHelpText: "",
|
2022-04-21 17:46:33 +08:00
|
|
|
filterBoxLabel: "",
|
2022-04-13 20:46:52 +08:00
|
|
|
filterBoxOnSelect: () => {},
|
|
|
|
filterBoxOptions: [],
|
|
|
|
filterBoxPlaceHolder: "",
|
2022-12-21 23:08:51 +08:00
|
|
|
|
|
|
|
showPrompt: false,
|
|
|
|
showConfirm: false,
|
2022-03-20 16:56:28 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
export type Action =
|
2022-05-17 17:53:17 +08:00
|
|
|
| { type: "page-loaded"; meta: PageMeta }
|
2022-09-06 22:21:33 +08:00
|
|
|
| { type: "page-loading"; name: string }
|
2022-03-31 20:28:07 +08:00
|
|
|
| { type: "page-changed" }
|
|
|
|
| { type: "page-saved" }
|
2023-08-16 17:40:31 +08:00
|
|
|
| { type: "sync-change"; syncSuccess: boolean }
|
2024-07-13 20:55:35 +08:00
|
|
|
| { type: "update-current-page-meta"; meta: PageMeta }
|
2023-12-22 22:55:50 +08:00
|
|
|
| { type: "update-page-list"; allPages: PageMeta[] }
|
2024-01-25 18:42:36 +08:00
|
|
|
| { type: "settings-loaded"; settings: BuiltinSettings }
|
2024-07-19 23:06:40 +08:00
|
|
|
| { type: "start-navigate"; mode: "page" | "meta" | "all" }
|
2022-03-20 16:56:28 +08:00
|
|
|
| { type: "stop-navigate" }
|
2022-05-07 00:55:04 +08:00
|
|
|
| {
|
2022-10-10 20:50:21 +08:00
|
|
|
type: "update-commands";
|
|
|
|
commands: Map<string, AppCommand>;
|
|
|
|
}
|
2022-04-21 17:46:33 +08:00
|
|
|
| { type: "show-palette"; context?: string }
|
2022-03-20 16:56:28 +08:00
|
|
|
| { type: "hide-palette" }
|
|
|
|
| { type: "show-notification"; notification: Notification }
|
2022-03-28 21:25:05 +08:00
|
|
|
| { type: "dismiss-notification"; id: number }
|
2022-09-30 22:59:57 +08:00
|
|
|
| {
|
2022-10-10 20:50:21 +08:00
|
|
|
type: "show-panel";
|
|
|
|
id: "rhs" | "lhs" | "bhs" | "modal";
|
|
|
|
config: PanelConfig;
|
|
|
|
}
|
2022-09-30 22:59:57 +08:00
|
|
|
| { type: "hide-panel"; id: string }
|
2022-05-16 21:09:36 +08:00
|
|
|
| { type: "command-run"; command: string }
|
2022-04-13 20:46:52 +08:00
|
|
|
| {
|
2022-10-10 20:50:21 +08:00
|
|
|
type: "show-filterbox";
|
|
|
|
options: FilterOption[];
|
|
|
|
placeHolder: string;
|
|
|
|
helpText: string;
|
|
|
|
label: string;
|
|
|
|
onSelect: (option: FilterOption | undefined) => void;
|
|
|
|
}
|
2022-09-16 20:26:47 +08:00
|
|
|
| { type: "hide-filterbox" }
|
2022-12-21 23:08:51 +08:00
|
|
|
| {
|
|
|
|
type: "show-prompt";
|
|
|
|
message: string;
|
|
|
|
defaultValue: string;
|
|
|
|
callback: (value: string | undefined) => void;
|
|
|
|
}
|
|
|
|
| { type: "hide-prompt" }
|
|
|
|
| {
|
|
|
|
type: "show-confirm";
|
|
|
|
message: string;
|
|
|
|
callback: (value: boolean) => void;
|
|
|
|
}
|
|
|
|
| { type: "hide-confirm" }
|
2023-06-15 02:58:08 +08:00
|
|
|
| { type: "set-ui-option"; key: string; value: any }
|
|
|
|
| { type: "set-progress"; progressPerc?: number };
|