This closes #1416, support set row outline level to stream (#1422)

Co-authored-by: TlyupovBM <bajjzet.tlyupov@vseinstrumenti.ru>
pull/2/head
Bayzet Tlyupov 2 years ago committed by GitHub
parent 61fda0b1ca
commit ce4f7a25c9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -310,9 +310,10 @@ type Cell struct {
// RowOpts define the options for the set row, it can be used directly in // RowOpts define the options for the set row, it can be used directly in
// StreamWriter.SetRow to specify the style and properties of the row. // StreamWriter.SetRow to specify the style and properties of the row.
type RowOpts struct { type RowOpts struct {
Height float64 Height float64
Hidden bool Hidden bool
StyleID int StyleID int
OutlineLevel int
} }
// marshalAttrs prepare attributes of the row. // marshalAttrs prepare attributes of the row.
@ -328,6 +329,10 @@ func (r *RowOpts) marshalAttrs() (strings.Builder, error) {
err = ErrMaxRowHeight err = ErrMaxRowHeight
return attrs, err return attrs, err
} }
if r.OutlineLevel > 7 {
err = ErrOutlineLevel
return attrs, err
}
if r.StyleID > 0 { if r.StyleID > 0 {
attrs.WriteString(` s="`) attrs.WriteString(` s="`)
attrs.WriteString(strconv.Itoa(r.StyleID)) attrs.WriteString(strconv.Itoa(r.StyleID))
@ -338,6 +343,11 @@ func (r *RowOpts) marshalAttrs() (strings.Builder, error) {
attrs.WriteString(strconv.FormatFloat(r.Height, 'f', -1, 64)) attrs.WriteString(strconv.FormatFloat(r.Height, 'f', -1, 64))
attrs.WriteString(`" customHeight="1"`) attrs.WriteString(`" customHeight="1"`)
} }
if r.OutlineLevel > 0 {
attrs.WriteString(` outlineLevel="`)
attrs.WriteString(strconv.Itoa(r.OutlineLevel))
attrs.WriteString(`"`)
}
if r.Hidden { if r.Hidden {
attrs.WriteString(` hidden="1"`) attrs.WriteString(` hidden="1"`)
} }

@ -358,3 +358,31 @@ func TestStreamSetCellValFunc(t *testing.T) {
assert.NoError(t, sw.setCellValFunc(c, nil)) assert.NoError(t, sw.setCellValFunc(c, nil))
assert.NoError(t, sw.setCellValFunc(c, complex64(5+10i))) assert.NoError(t, sw.setCellValFunc(c, complex64(5+10i)))
} }
func TestStreamWriterOutlineLevel(t *testing.T) {
file := NewFile()
streamWriter, err := file.NewStreamWriter("Sheet1")
assert.NoError(t, err)
// Test set outlineLevel in row.
assert.NoError(t, streamWriter.SetRow("A1", nil, RowOpts{OutlineLevel: 1}))
assert.NoError(t, streamWriter.SetRow("A2", nil, RowOpts{OutlineLevel: 7}))
assert.ErrorIs(t, ErrOutlineLevel, streamWriter.SetRow("A3", nil, RowOpts{OutlineLevel: 8}))
assert.NoError(t, streamWriter.Flush())
// Save spreadsheet by the given path.
assert.NoError(t, file.SaveAs(filepath.Join("test", "TestStreamWriterSetRowOutlineLevel.xlsx")))
file, err = OpenFile(filepath.Join("test", "TestStreamWriterSetRowOutlineLevel.xlsx"))
assert.NoError(t, err)
level, err := file.GetRowOutlineLevel("Sheet1", 1)
assert.NoError(t, err)
assert.Equal(t, uint8(1), level)
level, err = file.GetRowOutlineLevel("Sheet1", 2)
assert.NoError(t, err)
assert.Equal(t, uint8(7), level)
level, err = file.GetRowOutlineLevel("Sheet1", 3)
assert.NoError(t, err)
assert.Equal(t, uint8(0), level)
assert.NoError(t, file.Close())
}

Loading…
Cancel
Save