You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
1.9 KiB
Go
52 lines
1.9 KiB
Go
package xlsx
|
|
|
|
import (
|
|
"strconv"
|
|
"time"
|
|
)
|
|
|
|
// StreamCell holds the data, style and type of cell for streaming.
|
|
type StreamCell struct {
|
|
cellData string
|
|
cellStyle StreamStyle
|
|
cellType CellType
|
|
}
|
|
|
|
// NewStreamCell creates a new cell containing the given data with the given style and type.
|
|
func NewStreamCell(cellData string, cellStyle StreamStyle, cellType CellType) StreamCell {
|
|
return StreamCell{
|
|
cellData: cellData,
|
|
cellStyle: cellStyle,
|
|
cellType: cellType,
|
|
}
|
|
}
|
|
|
|
// NewStringStreamCell creates a new cell that holds string data, is of type string and uses general formatting.
|
|
func NewStringStreamCell(cellData string) StreamCell {
|
|
return NewStreamCell(cellData, StreamStyleDefaultString, CellTypeString)
|
|
}
|
|
|
|
// NewStyledStringStreamCell creates a new cell that holds a string and is styled according to the given style.
|
|
func NewStyledStringStreamCell(cellData string, cellStyle StreamStyle) StreamCell {
|
|
return NewStreamCell(cellData, cellStyle, CellTypeString)
|
|
}
|
|
|
|
// NewIntegerStreamCell creates a new cell that holds an integer value (represented as string),
|
|
// is formatted as a standard integer and is of type numeric.
|
|
func NewIntegerStreamCell(cellData int) StreamCell {
|
|
return NewStreamCell(strconv.Itoa(cellData), StreamStyleDefaultInteger, CellTypeNumeric)
|
|
}
|
|
|
|
// NewStyledIntegerStreamCell creates a new cell that holds an integer value (represented as string)
|
|
// and is styled according to the given style.
|
|
func NewStyledIntegerStreamCell(cellData int, cellStyle StreamStyle) StreamCell {
|
|
return NewStreamCell(strconv.Itoa(cellData), cellStyle, CellTypeNumeric)
|
|
}
|
|
|
|
// NewDateStreamCell creates a new cell that holds a date value and is formatted as dd-mm-yyyy
|
|
// and is of type numeric.
|
|
func NewDateStreamCell(t time.Time) StreamCell {
|
|
excelTime := TimeToExcelTime(t, false)
|
|
return NewStreamCell(strconv.Itoa(int(excelTime)), StreamStyleDefaultDate, CellTypeNumeric)
|
|
}
|