123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267 |
- package excelize
- import (
- "fmt"
- "strings"
- )
- type DataValidationType int
- const (
- _DataValidationType = iota
- typeNone
- DataValidationTypeCustom
- DataValidationTypeDate
- DataValidationTypeDecimal
- typeList
- DataValidationTypeTextLeng
- DataValidationTypeTime
-
- DataValidationTypeWhole
- )
- const (
-
- dataValidationFormulaStrLen = 257
-
- dataValidationFormulaStrLenErr = "data validation must be 0-255 characters"
- )
- type DataValidationErrorStyle int
- const (
- _ DataValidationErrorStyle = iota
- DataValidationErrorStyleStop
- DataValidationErrorStyleWarning
- DataValidationErrorStyleInformation
- )
- const (
- styleStop = "stop"
- styleWarning = "warning"
- styleInformation = "information"
- )
- type DataValidationOperator int
- const (
- _DataValidationOperator = iota
- DataValidationOperatorBetween
- DataValidationOperatorEqual
- DataValidationOperatorGreaterThan
- DataValidationOperatorGreaterThanOrEqual
- DataValidationOperatorLessThan
- DataValidationOperatorLessThanOrEqual
- DataValidationOperatorNotBetween
- DataValidationOperatorNotEqual
- )
- func NewDataValidation(allowBlank bool) *DataValidation {
- return &DataValidation{
- AllowBlank: allowBlank,
- ShowErrorMessage: false,
- ShowInputMessage: false,
- }
- }
- func (dd *DataValidation) SetError(style DataValidationErrorStyle, title, msg string) {
- dd.Error = &msg
- dd.ErrorTitle = &title
- strStyle := styleStop
- switch style {
- case DataValidationErrorStyleStop:
- strStyle = styleStop
- case DataValidationErrorStyleWarning:
- strStyle = styleWarning
- case DataValidationErrorStyleInformation:
- strStyle = styleInformation
- }
- dd.ShowErrorMessage = true
- dd.ErrorStyle = &strStyle
- }
- func (dd *DataValidation) SetInput(title, msg string) {
- dd.ShowInputMessage = true
- dd.PromptTitle = &title
- dd.Prompt = &msg
- }
- func (dd *DataValidation) SetDropList(keys []string) error {
- formula := "\"" + strings.Join(keys, ",") + "\""
- if dataValidationFormulaStrLen < len(formula) {
- return fmt.Errorf(dataValidationFormulaStrLenErr)
- }
- dd.Formula1 = fmt.Sprintf("<formula1>%s</formula1>", formula)
- dd.Type = convDataValidationType(typeList)
- return nil
- }
- func (dd *DataValidation) SetRange(f1, f2 float64, t DataValidationType, o DataValidationOperator) error {
- formula1 := fmt.Sprintf("%f", f1)
- formula2 := fmt.Sprintf("%f", f2)
- if dataValidationFormulaStrLen+21 < len(dd.Formula1) || dataValidationFormulaStrLen+21 < len(dd.Formula2) {
- return fmt.Errorf(dataValidationFormulaStrLenErr)
- }
- dd.Formula1 = fmt.Sprintf("<formula1>%s</formula1>", formula1)
- dd.Formula2 = fmt.Sprintf("<formula2>%s</formula2>", formula2)
- dd.Type = convDataValidationType(t)
- dd.Operator = convDataValidationOperatior(o)
- return nil
- }
- func (dd *DataValidation) SetSqrefDropList(sqref string, isCurrentSheet bool) error {
- if isCurrentSheet {
- dd.Formula1 = fmt.Sprintf("<formula1>%s</formula1>", sqref)
- dd.Type = convDataValidationType(typeList)
- return nil
- }
- return fmt.Errorf("cross-sheet sqref cell are not supported")
- }
- func (dd *DataValidation) SetSqref(sqref string) {
- if dd.Sqref == "" {
- dd.Sqref = sqref
- } else {
- dd.Sqref = fmt.Sprintf("%s %s", dd.Sqref, sqref)
- }
- }
- func convDataValidationType(t DataValidationType) string {
- typeMap := map[DataValidationType]string{
- typeNone: "none",
- DataValidationTypeCustom: "custom",
- DataValidationTypeDate: "date",
- DataValidationTypeDecimal: "decimal",
- typeList: "list",
- DataValidationTypeTextLeng: "textLength",
- DataValidationTypeTime: "time",
- DataValidationTypeWhole: "whole",
- }
- return typeMap[t]
- }
- func convDataValidationOperatior(o DataValidationOperator) string {
- typeMap := map[DataValidationOperator]string{
- DataValidationOperatorBetween: "between",
- DataValidationOperatorEqual: "equal",
- DataValidationOperatorGreaterThan: "greaterThan",
- DataValidationOperatorGreaterThanOrEqual: "greaterThanOrEqual",
- DataValidationOperatorLessThan: "lessThan",
- DataValidationOperatorLessThanOrEqual: "lessThanOrEqual",
- DataValidationOperatorNotBetween: "notBetween",
- DataValidationOperatorNotEqual: "notEqual",
- }
- return typeMap[o]
- }
- func (f *File) AddDataValidation(sheet string, dv *DataValidation) error {
- ws, err := f.workSheetReader(sheet)
- if err != nil {
- return err
- }
- if nil == ws.DataValidations {
- ws.DataValidations = new(xlsxDataValidations)
- }
- ws.DataValidations.DataValidation = append(ws.DataValidations.DataValidation, dv)
- ws.DataValidations.Count = len(ws.DataValidations.DataValidation)
- return err
- }
- func (f *File) DeleteDataValidation(sheet, sqref string) error {
- ws, err := f.workSheetReader(sheet)
- if err != nil {
- return err
- }
- if ws.DataValidations == nil {
- return nil
- }
- dv := ws.DataValidations
- for i := 0; i < len(dv.DataValidation); i++ {
- if dv.DataValidation[i].Sqref == sqref {
- dv.DataValidation = append(dv.DataValidation[:i], dv.DataValidation[i+1:]...)
- i--
- }
- }
- dv.Count = len(dv.DataValidation)
- if dv.Count == 0 {
- ws.DataValidations = nil
- }
- return nil
- }
|