mirror of
https://github.com/siyuan-note/siyuan.git
synced 2025-12-18 07:30:12 +01:00
🎨 Supports multiple views for the database https://github.com/siyuan-note/siyuan/issues/9751
This commit is contained in:
parent
45a8c97e9f
commit
177ed1b67f
2 changed files with 48 additions and 0 deletions
|
|
@ -634,6 +634,49 @@ func getRowBlockValue(keyValues []*av.KeyValues) (ret *av.Value) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (tx *Transaction) doSortAttrViewView(operation *Operation) (ret *TxErr) {
|
||||||
|
avID := operation.AvID
|
||||||
|
attrView, err := av.ParseAttributeView(avID)
|
||||||
|
if nil != err {
|
||||||
|
logging.LogErrorf("parse attribute view [%s] failed: %s", operation.AvID, err)
|
||||||
|
return &TxErr{code: TxErrWriteAttributeView, id: operation.AvID, msg: err.Error()}
|
||||||
|
}
|
||||||
|
|
||||||
|
viewID := operation.ID
|
||||||
|
previewViewID := operation.PreviousID
|
||||||
|
|
||||||
|
if viewID == previewViewID {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
view := attrView.GetView(viewID)
|
||||||
|
if nil == view {
|
||||||
|
logging.LogErrorf("get view [%s] failed: %s", viewID, err)
|
||||||
|
return &TxErr{code: TxErrWriteAttributeView, id: viewID, msg: err.Error()}
|
||||||
|
}
|
||||||
|
|
||||||
|
if "" == previewViewID {
|
||||||
|
// 插入到第一个
|
||||||
|
attrView.Views = append([]*av.View{view}, attrView.Views...)
|
||||||
|
} else {
|
||||||
|
// 插入到 previewViewID 的后面
|
||||||
|
var index int
|
||||||
|
for i, v := range attrView.Views {
|
||||||
|
if v.ID == previewViewID {
|
||||||
|
index = i + 1
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
attrView.Views = util.InsertElem(attrView.Views, index, view)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err = av.SaveAttributeView(attrView); nil != err {
|
||||||
|
logging.LogErrorf("save attribute view [%s] failed: %s", avID, err)
|
||||||
|
return &TxErr{code: TxErrCodeWriteTree, msg: err.Error(), id: avID}
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
func (tx *Transaction) doRemoveAttrViewView(operation *Operation) (ret *TxErr) {
|
func (tx *Transaction) doRemoveAttrViewView(operation *Operation) (ret *TxErr) {
|
||||||
var err error
|
var err error
|
||||||
avID := operation.AvID
|
avID := operation.AvID
|
||||||
|
|
@ -657,6 +700,9 @@ func (tx *Transaction) doRemoveAttrViewView(operation *Operation) (ret *TxErr) {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if 0 > index {
|
||||||
|
index = 0
|
||||||
|
}
|
||||||
|
|
||||||
attrView.ViewID = attrView.Views[index].ID
|
attrView.ViewID = attrView.Views[index].ID
|
||||||
if err = av.SaveAttributeView(attrView); nil != err {
|
if err = av.SaveAttributeView(attrView); nil != err {
|
||||||
|
|
|
||||||
|
|
@ -252,6 +252,8 @@ func performTx(tx *Transaction) (ret *TxErr) {
|
||||||
ret = tx.doSetAttrViewViewIcon(op)
|
ret = tx.doSetAttrViewViewIcon(op)
|
||||||
case "duplicateAttrViewView":
|
case "duplicateAttrViewView":
|
||||||
ret = tx.doDuplicateAttrViewView(op)
|
ret = tx.doDuplicateAttrViewView(op)
|
||||||
|
case "sortAttrViewView":
|
||||||
|
ret = tx.doSortAttrViewView(op)
|
||||||
}
|
}
|
||||||
|
|
||||||
if nil != ret {
|
if nil != ret {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue