diff --git a/app/src/menus/commonMenuItem.ts b/app/src/menus/commonMenuItem.ts index 85c28afe7..a1c101527 100644 --- a/app/src/menus/commonMenuItem.ts +++ b/app/src/menus/commonMenuItem.ts @@ -722,6 +722,17 @@ export const exportMd = (id: string) => { openByMobile(response.data.zip); }); } + }, { + label: "EPUB", + click: () => { + const msgId = showMessage(window.siyuan.languages.exporting, -1); + fetchPost("/api/export/exportEPUB", { + id, + }, response => { + hideMessage(msgId); + openByMobile(response.data.zip); + }); + } }, ] } diff --git a/kernel/api/export.go b/kernel/api/export.go index c4ca4acbd..458310ac8 100644 --- a/kernel/api/export.go +++ b/kernel/api/export.go @@ -31,6 +31,23 @@ import ( "github.com/siyuan-note/siyuan/kernel/util" ) +func exportEPUB(c *gin.Context) { + ret := gulu.Ret.NewResult() + defer c.JSON(http.StatusOK, ret) + + arg, ok := util.JsonArg(c, ret) + if !ok { + return + } + + id := arg["id"].(string) + name, zipPath := model.ExportPandocConvertZip(id, "epub", ".epub") + ret.Data = map[string]interface{}{ + "name": name, + "zip": zipPath, + } +} + func exportRTF(c *gin.Context) { ret := gulu.Ret.NewResult() defer c.JSON(http.StatusOK, ret) diff --git a/kernel/api/router.go b/kernel/api/router.go index 22b5fe39d..ffd934bd5 100644 --- a/kernel/api/router.go +++ b/kernel/api/router.go @@ -253,6 +253,7 @@ func ServeAPI(ginServer *gin.Engine) { ginServer.Handle("POST", "/api/export/exportMediaWiki", model.CheckAuth, exportMediaWiki) ginServer.Handle("POST", "/api/export/exportODT", model.CheckAuth, exportODT) ginServer.Handle("POST", "/api/export/exportRTF", model.CheckAuth, exportRTF) + ginServer.Handle("POST", "/api/export/exportEPUB", model.CheckAuth, exportEPUB) ginServer.Handle("POST", "/api/import/importStdMd", model.CheckAuth, model.CheckReadonly, importStdMd) ginServer.Handle("POST", "/api/import/importData", model.CheckAuth, model.CheckReadonly, importData)