|
@@ -19,6 +19,8 @@ package api
|
|
|
import (
|
|
|
"errors"
|
|
|
"net/http"
|
|
|
+ "path"
|
|
|
+ "strings"
|
|
|
|
|
|
"github.com/88250/gulu"
|
|
|
"github.com/88250/lute"
|
|
@@ -30,6 +32,59 @@ import (
|
|
|
"github.com/siyuan-note/siyuan/kernel/util"
|
|
|
)
|
|
|
|
|
|
+func appendDailyNoteBlock(c *gin.Context) {
|
|
|
+ ret := gulu.Ret.NewResult()
|
|
|
+ defer c.JSON(http.StatusOK, ret)
|
|
|
+
|
|
|
+ arg, ok := util.JsonArg(c, ret)
|
|
|
+ if !ok {
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ data := arg["data"].(string)
|
|
|
+ dataType := arg["dataType"].(string)
|
|
|
+ boxID := arg["notebook"].(string)
|
|
|
+ if util.InvalidIDPattern(boxID, ret) {
|
|
|
+ return
|
|
|
+ }
|
|
|
+ if "markdown" == dataType {
|
|
|
+ luteEngine := util.NewLute()
|
|
|
+ var err error
|
|
|
+ data, err = dataBlockDOM(data, luteEngine)
|
|
|
+ if nil != err {
|
|
|
+ ret.Code = -1
|
|
|
+ ret.Msg = "data block DOM failed: " + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ p, _, err := model.CreateDailyNote(boxID)
|
|
|
+ if nil != err {
|
|
|
+ ret.Code = -1
|
|
|
+ ret.Msg = "create daily note failed: " + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ parentID := strings.TrimSuffix(path.Base(p), ".sy")
|
|
|
+ transactions := []*model.Transaction{
|
|
|
+ {
|
|
|
+ DoOperations: []*model.Operation{
|
|
|
+ {
|
|
|
+ Action: "appendInsert",
|
|
|
+ Data: data,
|
|
|
+ ParentID: parentID,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ model.PerformTransactions(&transactions)
|
|
|
+ model.WaitForWritingFiles()
|
|
|
+
|
|
|
+ ret.Data = transactions
|
|
|
+ broadcastTransactions(transactions)
|
|
|
+}
|
|
|
+
|
|
|
func unfoldBlock(c *gin.Context) {
|
|
|
ret := gulu.Ret.NewResult()
|
|
|
defer c.JSON(http.StatusOK, ret)
|