Added "type" argument to flashNotification (to distinguish between error and info)

website
Zef Hemel 2022-07-14 13:32:28 +02:00
parent d57a9e79de
commit a8274d225c
6 changed files with 51 additions and 21 deletions

View File

@ -41,8 +41,11 @@ export function openUrl(url: string): Promise<void> {
return syscall("editor.openUrl", url);
}
export function flashNotification(message: string): Promise<void> {
return syscall("editor.flashNotification", message);
export function flashNotification(
message: string,
type: "info" | "error" = "info"
): Promise<void> {
return syscall("editor.flashNotification", message, type);
}
export function filterBox(

View File

@ -39,9 +39,14 @@ export function TopBar({
{prettyName(pageName)}
</span>
{notifications.length > 0 && (
<div className="status">
<div className="notifications">
{notifications.map((notification) => (
<div key={notification.id}>{notification.message}</div>
<div
key={notification.id}
className={`notification-${notification.type}`}
>
{notification.message}
</div>
))}
</div>
)}

View File

@ -272,22 +272,26 @@ export class Editor {
});
}
flashNotification(message: string) {
flashNotification(message: string, type: "info" | "error" = "info") {
let id = Math.floor(Math.random() * 1000000);
this.viewDispatch({
type: "show-notification",
notification: {
id: id,
message: message,
id,
type,
message,
date: new Date(),
},
});
setTimeout(() => {
this.viewDispatch({
type: "dismiss-notification",
id: id,
});
}, 2000);
setTimeout(
() => {
this.viewDispatch({
type: "dismiss-notification",
id: id,
});
},
type === "info" ? 2000 : 5000
);
}
filterBox(
@ -334,7 +338,10 @@ export class Editor {
.then(def.run)
.catch((e: any) => {
console.error(e);
this.flashNotification(`Error running command: ${e.message}`);
this.flashNotification(
`Error running command: ${e.message}`,
"error"
);
});
return true;
},

View File

@ -76,18 +76,28 @@ body {
display: flex;
flex-direction: row;
.status {
.notifications {
position: absolute;
font-family: "iA-Mono";
bottom: 45px;
left: 5px;
right: 5px;
background-color: rgb(187, 221, 247);
border: rgb(41, 41, 41) 1px solid;
border-radius: 5px;
padding: 3px;
font-size: 15px;
z-index: 100;
> div {
padding: 3px;
margin-bottom: 3px;
border-radius: 5px;
border: rgb(41, 41, 41) 1px solid;
}
.notification-info {
background-color: rgb(187, 221, 247);
}
.notification-error {
background-color: rgb(255, 84, 84);
}
}
.current-page {

View File

@ -55,8 +55,12 @@ export function editorSyscalls(editor: Editor): SysCallMapping {
win.focus();
}
},
"editor.flashNotification": (ctx, message: string) => {
editor.flashNotification(message);
"editor.flashNotification": (
ctx,
message: string,
type: "error" | "info" = "info"
) => {
editor.flashNotification(message, type);
},
"editor.filterBox": (
ctx,

View File

@ -6,6 +6,7 @@ export const slashCommandRegexp = /\/[\w\-]*/;
export type Notification = {
id: number;
message: string;
type: "info" | "error";
date: Date;
};