Cmd/Ctrl-click now opens page in new window
parent
540af411a0
commit
bef2c4c62b
|
@ -33,8 +33,9 @@ export function navigate(
|
||||||
name: string,
|
name: string,
|
||||||
pos?: string | number,
|
pos?: string | number,
|
||||||
replaceState = false,
|
replaceState = false,
|
||||||
|
newWindow = false,
|
||||||
): Promise<void> {
|
): Promise<void> {
|
||||||
return syscall("editor.navigate", name, pos, replaceState);
|
return syscall("editor.navigate", name, pos, replaceState, newWindow);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function reloadPage(): Promise<void> {
|
export function reloadPage(): Promise<void> {
|
||||||
|
|
|
@ -10,7 +10,10 @@ function patchUrl(url: string): string {
|
||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
|
|
||||||
async function actionClickOrActionEnter(mdTree: ParseTree | null) {
|
async function actionClickOrActionEnter(
|
||||||
|
mdTree: ParseTree | null,
|
||||||
|
inNewWindow = false,
|
||||||
|
) {
|
||||||
if (!mdTree) {
|
if (!mdTree) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -28,7 +31,7 @@ async function actionClickOrActionEnter(mdTree: ParseTree | null) {
|
||||||
if (!pageLink) {
|
if (!pageLink) {
|
||||||
pageLink = await editor.getCurrentPage();
|
pageLink = await editor.getCurrentPage();
|
||||||
}
|
}
|
||||||
await editor.navigate(pageLink, pos);
|
await editor.navigate(pageLink, pos, false, inNewWindow);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case "URL":
|
case "URL":
|
||||||
|
@ -61,13 +64,13 @@ export async function linkNavigate() {
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function clickNavigate(event: ClickEvent) {
|
export async function clickNavigate(event: ClickEvent) {
|
||||||
// Navigate by default, don't navigate when Ctrl or Cmd is held
|
// Navigate by default, don't navigate when Alt is held
|
||||||
if (event.ctrlKey || event.metaKey) {
|
if (event.altKey) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const mdTree = await markdown.parseMarkdown(await editor.getText());
|
const mdTree = await markdown.parseMarkdown(await editor.getText());
|
||||||
const newNode = nodeAtPos(mdTree, event.pos);
|
const newNode = nodeAtPos(mdTree, event.pos);
|
||||||
await actionClickOrActionEnter(newNode);
|
await actionClickOrActionEnter(newNode, event.ctrlKey || event.metaKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function navigateCommand(cmdDef: any) {
|
export async function navigateCommand(cmdDef: any) {
|
||||||
|
|
|
@ -604,10 +604,23 @@ export class Editor {
|
||||||
this.editorView!.focus();
|
this.editorView!.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
async navigate(name: string, pos?: number | string, replaceState = false) {
|
async navigate(
|
||||||
|
name: string,
|
||||||
|
pos?: number | string,
|
||||||
|
replaceState = false,
|
||||||
|
newWindow = false,
|
||||||
|
) {
|
||||||
if (!name) {
|
if (!name) {
|
||||||
name = this.indexPage;
|
name = this.indexPage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (newWindow) {
|
||||||
|
const win = window.open(`${location.origin}/${name}`, "_blank");
|
||||||
|
if (win) {
|
||||||
|
win.focus();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
await this.pageNavigator.navigate(name, pos, replaceState);
|
await this.pageNavigator.navigate(name, pos, replaceState);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,8 +48,9 @@ export function editorSyscalls(editor: Editor): SysCallMapping {
|
||||||
name: string,
|
name: string,
|
||||||
pos: number | string,
|
pos: number | string,
|
||||||
replaceState = false,
|
replaceState = false,
|
||||||
|
newWindow = false,
|
||||||
) => {
|
) => {
|
||||||
await editor.navigate(name, pos, replaceState);
|
await editor.navigate(name, pos, replaceState, newWindow);
|
||||||
},
|
},
|
||||||
"editor.reloadPage": async () => {
|
"editor.reloadPage": async () => {
|
||||||
await editor.reloadPage();
|
await editor.reloadPage();
|
||||||
|
|
Loading…
Reference in New Issue