🎨 Update av

This commit is contained in:
Daniel 2023-07-03 21:16:38 +08:00
parent 4041c509f6
commit 919cd04c8a
No known key found for this signature in database
GPG key ID: 86211BA83DF03017
2 changed files with 13 additions and 21 deletions

View file

@ -58,7 +58,6 @@ func filterRows(ret *av.AttributeView) {
} }
} }
} }
colIndexes = util.RemoveDuplicatedElem(colIndexes)
var rows []*av.Row var rows []*av.Row
for _, row := range ret.Rows { for _, row := range ret.Rows {
@ -84,32 +83,37 @@ func filterRows(ret *av.AttributeView) {
func sortRows(ret *av.AttributeView) { func sortRows(ret *av.AttributeView) {
if 0 < len(ret.Sorts) { if 0 < len(ret.Sorts) {
var colIndexes []int type ColIndexSort struct {
Index int
Order av.SortOrder
}
var colIndexSorts []*ColIndexSort
for _, s := range ret.Sorts { for _, s := range ret.Sorts {
for i, c := range ret.Columns { for i, c := range ret.Columns {
if c.ID == s.Column { if c.ID == s.Column {
colIndexes = append(colIndexes, i) colIndexSorts = append(colIndexSorts, &ColIndexSort{Index: i, Order: s.Order})
break break
} }
} }
} }
colIndexes = util.RemoveDuplicatedElem(colIndexes)
sort.Slice(ret.Rows, func(i, j int) bool { sort.Slice(ret.Rows, func(i, j int) bool {
for _, index := range colIndexes { for _, colIndexSort := range colIndexSorts {
c := ret.Columns[index] c := ret.Columns[colIndexSort.Index]
if c.Type == av.ColumnTypeBlock { if c.Type == av.ColumnTypeBlock {
continue continue
} }
result := ret.Rows[i].Cells[index].Value.Compare(ret.Rows[j].Cells[index].Value) result := ret.Rows[i].Cells[colIndexSort.Index].Value.Compare(ret.Rows[j].Cells[colIndexSort.Index].Value)
if 0 == result { if 0 == result {
continue continue
} }
if 0 > result { if colIndexSort.Order == av.SortOrderAsc {
return true return 0 > result
} }
return 0 < result
} }
return false return false
}) })

View file

@ -24,18 +24,6 @@ import (
"github.com/88250/lute/html" "github.com/88250/lute/html"
) )
// RemoveDuplicatedElem removes the duplicated elements from the slice.
func RemoveDuplicatedElem(slice []int) (ret []int) {
allKeys := make(map[int]bool)
for _, item := range slice {
if _, value := allKeys[item]; !value {
allKeys[item] = true
ret = append(ret, item)
}
}
return
}
// InsertElem inserts a new element value at the specified index position. // InsertElem inserts a new element value at the specified index position.
// 0 <= index <= len(a) // 0 <= index <= len(a)
func InsertElem[T any](ret []T, index int, value T) []T { func InsertElem[T any](ret []T, index int, value T) []T {