mirror of
https://github.com/unidoc/unioffice.git
synced 2025-05-14 19:29:48 +08:00

* update license and terms * Fixes * Create ACKNOWLEDGEMENTS.md * Update ACKNOWLEDGEMENTS.md * Revert go.mod changes and remove go1.11 tests
208 lines
5.2 KiB
Go
208 lines
5.2 KiB
Go
// Copyright 2020 FoxyUtils ehf. All rights reserved.
|
|
//
|
|
// DO NOT EDIT: generated by unioffice ECMA-376 generator
|
|
//
|
|
// Use of this software package and source code is governed by the terms of the
|
|
// UniDoc End User License Agreement (EULA) that is available at:
|
|
// https://unidoc.io/eula/
|
|
// A trial license code for evaluation can be obtained at https://unidoc.io website.
|
|
|
|
package wml
|
|
|
|
import (
|
|
"encoding/xml"
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"github.com/unidoc/unioffice/schema/soo/ofc/sharedTypes"
|
|
)
|
|
|
|
type CT_Border struct {
|
|
// Border Style
|
|
ValAttr ST_Border
|
|
// Border Color
|
|
ColorAttr *ST_HexColor
|
|
// Border Theme Color
|
|
ThemeColorAttr ST_ThemeColor
|
|
// Border Theme Color Tint
|
|
ThemeTintAttr *string
|
|
// Border Theme Color Shade
|
|
ThemeShadeAttr *string
|
|
// Border Width
|
|
SzAttr *uint64
|
|
// Border Spacing Measurement
|
|
SpaceAttr *uint64
|
|
// Border Shadow
|
|
ShadowAttr *sharedTypes.ST_OnOff
|
|
// Create Frame Effect
|
|
FrameAttr *sharedTypes.ST_OnOff
|
|
}
|
|
|
|
func NewCT_Border() *CT_Border {
|
|
ret := &CT_Border{}
|
|
ret.ValAttr = ST_Border(1)
|
|
return ret
|
|
}
|
|
|
|
func (m *CT_Border) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
|
|
attr, err := m.ValAttr.MarshalXMLAttr(xml.Name{Local: "w:val"})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
start.Attr = append(start.Attr, attr)
|
|
if m.ColorAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:color"},
|
|
Value: fmt.Sprintf("%v", *m.ColorAttr)})
|
|
}
|
|
if m.ThemeColorAttr != ST_ThemeColorUnset {
|
|
attr, err := m.ThemeColorAttr.MarshalXMLAttr(xml.Name{Local: "w:themeColor"})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
start.Attr = append(start.Attr, attr)
|
|
}
|
|
if m.ThemeTintAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:themeTint"},
|
|
Value: fmt.Sprintf("%v", *m.ThemeTintAttr)})
|
|
}
|
|
if m.ThemeShadeAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:themeShade"},
|
|
Value: fmt.Sprintf("%v", *m.ThemeShadeAttr)})
|
|
}
|
|
if m.SzAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:sz"},
|
|
Value: fmt.Sprintf("%v", *m.SzAttr)})
|
|
}
|
|
if m.SpaceAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:space"},
|
|
Value: fmt.Sprintf("%v", *m.SpaceAttr)})
|
|
}
|
|
if m.ShadowAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:shadow"},
|
|
Value: fmt.Sprintf("%v", *m.ShadowAttr)})
|
|
}
|
|
if m.FrameAttr != nil {
|
|
start.Attr = append(start.Attr, xml.Attr{Name: xml.Name{Local: "w:frame"},
|
|
Value: fmt.Sprintf("%v", *m.FrameAttr)})
|
|
}
|
|
e.EncodeToken(start)
|
|
e.EncodeToken(xml.EndElement{Name: start.Name})
|
|
return nil
|
|
}
|
|
|
|
func (m *CT_Border) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
|
|
// initialize to default
|
|
m.ValAttr = ST_Border(1)
|
|
for _, attr := range start.Attr {
|
|
if attr.Name.Local == "val" {
|
|
m.ValAttr.UnmarshalXMLAttr(attr)
|
|
continue
|
|
}
|
|
if attr.Name.Local == "color" {
|
|
parsed, err := ParseUnionST_HexColor(attr.Value)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.ColorAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "themeColor" {
|
|
m.ThemeColorAttr.UnmarshalXMLAttr(attr)
|
|
continue
|
|
}
|
|
if attr.Name.Local == "themeTint" {
|
|
parsed, err := attr.Value, error(nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.ThemeTintAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "themeShade" {
|
|
parsed, err := attr.Value, error(nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.ThemeShadeAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "sz" {
|
|
parsed, err := strconv.ParseUint(attr.Value, 10, 64)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.SzAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "space" {
|
|
parsed, err := strconv.ParseUint(attr.Value, 10, 64)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.SpaceAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "shadow" {
|
|
parsed, err := ParseUnionST_OnOff(attr.Value)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.ShadowAttr = &parsed
|
|
continue
|
|
}
|
|
if attr.Name.Local == "frame" {
|
|
parsed, err := ParseUnionST_OnOff(attr.Value)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
m.FrameAttr = &parsed
|
|
continue
|
|
}
|
|
}
|
|
// skip any extensions we may find, but don't support
|
|
for {
|
|
tok, err := d.Token()
|
|
if err != nil {
|
|
return fmt.Errorf("parsing CT_Border: %s", err)
|
|
}
|
|
if el, ok := tok.(xml.EndElement); ok && el.Name == start.Name {
|
|
break
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Validate validates the CT_Border and its children
|
|
func (m *CT_Border) Validate() error {
|
|
return m.ValidateWithPath("CT_Border")
|
|
}
|
|
|
|
// ValidateWithPath validates the CT_Border and its children, prefixing error messages with path
|
|
func (m *CT_Border) ValidateWithPath(path string) error {
|
|
if m.ValAttr == ST_BorderUnset {
|
|
return fmt.Errorf("%s/ValAttr is a mandatory field", path)
|
|
}
|
|
if err := m.ValAttr.ValidateWithPath(path + "/ValAttr"); err != nil {
|
|
return err
|
|
}
|
|
if m.ColorAttr != nil {
|
|
if err := m.ColorAttr.ValidateWithPath(path + "/ColorAttr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if err := m.ThemeColorAttr.ValidateWithPath(path + "/ThemeColorAttr"); err != nil {
|
|
return err
|
|
}
|
|
if m.ShadowAttr != nil {
|
|
if err := m.ShadowAttr.ValidateWithPath(path + "/ShadowAttr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if m.FrameAttr != nil {
|
|
if err := m.FrameAttr.ValidateWithPath(path + "/FrameAttr"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|