Implement editor.uploadFile syscall (#570)
* Implement editor.attachFile syscall * Refactor attachFile to uploadFile returns a promise with an UploadFile now * Fix style * Reject promise with errors * Another code style fix --------- Co-authored-by: prcrst <p-github@prcr.st>pull/573/head
parent
9b89330ec9
commit
ae1561ac90
|
@ -1,4 +1,5 @@
|
|||
import type { FilterOption } from "../../web/types.ts";
|
||||
import { UploadFile } from "../types.ts";
|
||||
import { syscall } from "./syscall.ts";
|
||||
|
||||
export function getCurrentPage(): Promise<string> {
|
||||
|
@ -55,6 +56,10 @@ 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",
|
||||
|
|
|
@ -140,3 +140,8 @@ export type LintDiagnostic = {
|
|||
severity: "error" | "warning" | "info" | "hint";
|
||||
message: string;
|
||||
};
|
||||
|
||||
export type UploadFile = {
|
||||
name: string;
|
||||
content: Uint8Array;
|
||||
}
|
|
@ -12,6 +12,7 @@ import {
|
|||
} from "../deps.ts";
|
||||
import { SysCallMapping } from "../../plugos/system.ts";
|
||||
import type { FilterOption } from "../types.ts";
|
||||
import { UploadFile } from "../../plug-api/types.ts";
|
||||
|
||||
export function editorSyscalls(editor: Client): SysCallMapping {
|
||||
const syscalls: SysCallMapping = {
|
||||
|
@ -61,6 +62,46 @@ export function editorSyscalls(editor: Client): SysCallMapping {
|
|||
link.download = filename;
|
||||
link.click();
|
||||
},
|
||||
"editor.uploadFile": (
|
||||
_ctx,
|
||||
accept?: string,
|
||||
capture?: string
|
||||
): Promise<UploadFile> => {
|
||||
return new Promise<UploadFile>((resolve, reject) => {
|
||||
const input = document.createElement("input");
|
||||
input.type = "file";
|
||||
if (accept) {
|
||||
input.accept = accept;
|
||||
}
|
||||
if (capture) {
|
||||
input.capture = capture;
|
||||
}
|
||||
|
||||
input.onchange = () => {
|
||||
const file = input.files?.item(0);
|
||||
if (!file) {
|
||||
reject(new Error("No file found"));
|
||||
} else {
|
||||
var reader = new FileReader();
|
||||
reader.readAsArrayBuffer(file);
|
||||
reader.onloadend = async (evt) => {
|
||||
if (evt.target?.readyState == FileReader.DONE) {
|
||||
const arrayBuffer = evt.target.result;
|
||||
resolve({
|
||||
name: file.name,
|
||||
content: new Uint8Array(await file.arrayBuffer())
|
||||
});
|
||||
}
|
||||
};
|
||||
reader.onabort = (e) => { reject(e) };
|
||||
reader.onerror = (e) => { reject(e) };
|
||||
}
|
||||
}
|
||||
input.onabort = (e) => { reject(e) };
|
||||
|
||||
input.click();
|
||||
});
|
||||
},
|
||||
"editor.flashNotification": (
|
||||
_ctx,
|
||||
message: string,
|
||||
|
|
Loading…
Reference in New Issue