// Copyright 2017 Baliance. All rights reserved. // // Use of this source code is governed by the terms of the Affero GNU General // Public License version 3.0 as published by the Free Software Foundation and // appearing in the file LICENSE included in the packaging of this file. A // commercial license can be purchased by contacting sales@baliance.com. package spreadsheetml import ( "encoding/xml" "fmt" "log" "strconv" ) type CT_SheetPr struct { // Synch Horizontal SyncHorizontalAttr *bool // Synch Vertical SyncVerticalAttr *bool // Synch Reference SyncRefAttr *string // Transition Formula Evaluation TransitionEvaluationAttr *bool // Transition Formula Entry TransitionEntryAttr *bool // Published PublishedAttr *bool // Code Name CodeNameAttr *string // Filter Mode FilterModeAttr *bool // Enable Conditional Formatting Calculations EnableFormatConditionsCalculationAttr *bool // Sheet Tab Color TabColor *CT_Color // Outline Properties OutlinePr *CT_OutlinePr // Page Setup Properties PageSetUpPr *CT_PageSetUpPr } func NewCT_SheetPr() *CT_SheetPr { ret := &CT_SheetPr{} return ret } func (m *CT_SheetPr) MarshalXML(e *xml.Encoder, start xml.StartElement) error { if m == nil { return nil } if m.SyncHorizontalAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "syncHorizontal"}, Value: fmt.Sprintf("%v", *m.SyncHorizontalAttr)}) } if m.SyncVerticalAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "syncVertical"}, Value: fmt.Sprintf("%v", *m.SyncVerticalAttr)}) } if m.SyncRefAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "syncRef"}, Value: fmt.Sprintf("%v", *m.SyncRefAttr)}) } if m.TransitionEvaluationAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "transitionEvaluation"}, Value: fmt.Sprintf("%v", *m.TransitionEvaluationAttr)}) } if m.TransitionEntryAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "transitionEntry"}, Value: fmt.Sprintf("%v", *m.TransitionEntryAttr)}) } if m.PublishedAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "published"}, Value: fmt.Sprintf("%v", *m.PublishedAttr)}) } if m.CodeNameAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "codeName"}, Value: fmt.Sprintf("%v", *m.CodeNameAttr)}) } if m.FilterModeAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "filterMode"}, Value: fmt.Sprintf("%v", *m.FilterModeAttr)}) } if m.EnableFormatConditionsCalculationAttr != nil { start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "enableFormatConditionsCalculation"}, Value: fmt.Sprintf("%v", *m.EnableFormatConditionsCalculationAttr)}) } e.EncodeToken(start) start.Attr = nil if m.TabColor != nil { setabColor := xml.StartElement{Name: xml.Name{Local: "x:tabColor"}} e.EncodeElement(m.TabColor, setabColor) } if m.OutlinePr != nil { seoutlinePr := xml.StartElement{Name: xml.Name{Local: "x:outlinePr"}} e.EncodeElement(m.OutlinePr, seoutlinePr) } if m.PageSetUpPr != nil { sepageSetUpPr := xml.StartElement{Name: xml.Name{Local: "x:pageSetUpPr"}} e.EncodeElement(m.PageSetUpPr, sepageSetUpPr) } e.EncodeToken(xml.EndElement{Name: start.Name}) return nil } func (m *CT_SheetPr) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error { // initialize to default for _, attr := range start.Attr { if attr.Name.Local == "syncHorizontal" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.SyncHorizontalAttr = &parsed } if attr.Name.Local == "syncVertical" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.SyncVerticalAttr = &parsed } if attr.Name.Local == "syncRef" { parsed, err := attr.Value, error(nil) if err != nil { return err } m.SyncRefAttr = &parsed } if attr.Name.Local == "transitionEvaluation" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.TransitionEvaluationAttr = &parsed } if attr.Name.Local == "transitionEntry" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.TransitionEntryAttr = &parsed } if attr.Name.Local == "published" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.PublishedAttr = &parsed } if attr.Name.Local == "codeName" { parsed, err := attr.Value, error(nil) if err != nil { return err } m.CodeNameAttr = &parsed } if attr.Name.Local == "filterMode" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.FilterModeAttr = &parsed } if attr.Name.Local == "enableFormatConditionsCalculation" { parsed, err := strconv.ParseBool(attr.Value) if err != nil { return err } m.EnableFormatConditionsCalculationAttr = &parsed } } lCT_SheetPr: for { tok, err := d.Token() if err != nil { return err } switch el := tok.(type) { case xml.StartElement: switch el.Name.Local { case "tabColor": m.TabColor = NewCT_Color() if err := d.DecodeElement(m.TabColor, &el); err != nil { return err } case "outlinePr": m.OutlinePr = NewCT_OutlinePr() if err := d.DecodeElement(m.OutlinePr, &el); err != nil { return err } case "pageSetUpPr": m.PageSetUpPr = NewCT_PageSetUpPr() if err := d.DecodeElement(m.PageSetUpPr, &el); err != nil { return err } default: log.Printf("skipping unsupported element %v", el.Name) if err := d.Skip(); err != nil { return err } } case xml.EndElement: break lCT_SheetPr case xml.CharData: } } return nil } func (m *CT_SheetPr) Validate() error { return m.ValidateWithPath("CT_SheetPr") } func (m *CT_SheetPr) ValidateWithPath(path string) error { if m.TabColor != nil { if err := m.TabColor.ValidateWithPath(path + "/TabColor"); err != nil { return err } } if m.OutlinePr != nil { if err := m.OutlinePr.ValidateWithPath(path + "/OutlinePr"); err != nil { return err } } if m.PageSetUpPr != nil { if err := m.PageSetUpPr.ValidateWithPath(path + "/PageSetUpPr"); err != nil { return err } } return nil }