From c145cd2a9522d089cfcbe463095549d9e2e2e472 Mon Sep 17 00:00:00 2001 From: Daniel <845765@qq.com> Date: Mon, 9 Jun 2025 22:30:00 +0800 Subject: [PATCH] :art: Database gallery view https://github.com/siyuan-note/siyuan/issues/10414 --- kernel/av/layout_gallery.go | 2 +- kernel/model/attribute_view.go | 30 ++++++++++++++++++++++++++++++ kernel/model/transaction.go | 2 ++ 3 files changed, 33 insertions(+), 1 deletion(-) diff --git a/kernel/av/layout_gallery.go b/kernel/av/layout_gallery.go index 762441614..b3e09e68f 100644 --- a/kernel/av/layout_gallery.go +++ b/kernel/av/layout_gallery.go @@ -24,7 +24,7 @@ type LayoutGallery struct { CoverFrom CoverFrom `json:"coverFrom"` // 封面来源,0:无,1:内容图,2:资源字段 CoverFromAssetKeyID string `json:"coverFromAssetKeyId,omitempty"` // 资源字段 ID,CoverFrom 为 2 时有效 - CardSize CardSize `json:"cardSize"` // 卡片大小 + CardSize CardSize `json:"cardSize"` // 卡片大小,0:小卡片,1:中卡片,2:大卡片 FitImage bool `json:"fitImage"` // 是否适应图片大小 ShowIcon bool `json:"showIcon"` // 是否显示图标 WrapField bool `json:"wrapField"` // 是否换行字段 diff --git a/kernel/model/attribute_view.go b/kernel/model/attribute_view.go index 56b9bc6dd..a6c0191c7 100644 --- a/kernel/model/attribute_view.go +++ b/kernel/model/attribute_view.go @@ -44,6 +44,36 @@ import ( "github.com/xrash/smetrics" ) +func (tx *Transaction) doSetAttrViewCardSize(operation *Operation) (ret *TxErr) { + err := setAttrViewCardSize(operation) + if err != nil { + return &TxErr{code: TxErrWriteAttributeView, id: operation.AvID, msg: err.Error()} + } + return +} + +func setAttrViewCardSize(operation *Operation) (err error) { + attrView, err := av.ParseAttributeView(operation.AvID) + if err != nil { + return + } + + view, err := getAttrViewViewByBlockID(attrView, operation.BlockID) + if err != nil { + return + } + + switch view.LayoutType { + case av.LayoutTypeTable: + return + case av.LayoutTypeGallery: + view.Gallery.CardSize = av.CardSize(operation.Data.(float64)) + } + + err = av.SaveAttributeView(attrView) + return +} + func (tx *Transaction) doSetAttrViewCoverFromAssetKeyID(operation *Operation) (ret *TxErr) { err := setAttrViewCoverFromAssetKeyID(operation) if err != nil { diff --git a/kernel/model/transaction.go b/kernel/model/transaction.go index d4d17785b..8569fc0ee 100644 --- a/kernel/model/transaction.go +++ b/kernel/model/transaction.go @@ -282,6 +282,8 @@ func performTx(tx *Transaction) (ret *TxErr) { ret = tx.doSetAttrViewCoverFrom(op) case "setAttrViewCoverFromAssetKeyID": ret = tx.doSetAttrViewCoverFromAssetKeyID(op) + case "setAttrViewCardSize": + ret = tx.doSetAttrViewCardSize(op) } if nil != ret {