rui_orig/columnSeparator.go

194 lines
5.1 KiB
Go
Raw Normal View History

2021-09-07 17:36:50 +03:00
package rui
import (
"fmt"
"strings"
)
// ColumnSeparatorProperty is the interface of a view separator data
type ColumnSeparatorProperty interface {
Properties
fmt.Stringer
2022-05-22 12:54:02 +03:00
stringWriter
// ViewBorder returns column separator description in a form of ViewBorder
2021-09-07 17:36:50 +03:00
ViewBorder(session Session) ViewBorder
2021-09-07 17:36:50 +03:00
cssValue(session Session) string
}
type columnSeparatorProperty struct {
2024-11-13 12:56:39 +03:00
dataProperty
2021-09-07 17:36:50 +03:00
}
2022-07-26 18:36:00 +03:00
func newColumnSeparatorProperty(value any) ColumnSeparatorProperty {
2021-09-07 17:36:50 +03:00
if value == nil {
separator := new(columnSeparatorProperty)
2024-11-13 12:56:39 +03:00
separator.init()
2021-09-07 17:36:50 +03:00
return separator
}
switch value := value.(type) {
case ColumnSeparatorProperty:
return value
case DataObject:
separator := new(columnSeparatorProperty)
2024-11-13 12:56:39 +03:00
separator.init()
for _, tag := range []PropertyName{Style, Width, ColorTag} {
if val, ok := value.PropertyValue(string(tag)); ok && val != "" {
propertiesSet(separator, tag, value)
2021-09-07 17:36:50 +03:00
}
}
return separator
case ViewBorder:
separator := new(columnSeparatorProperty)
2024-11-13 12:56:39 +03:00
separator.init()
separator.properties = map[PropertyName]any{
Style: value.Style,
Width: value.Width,
ColorTag: value.Color,
2021-09-07 17:36:50 +03:00
}
return separator
}
invalidPropertyValue(Border, value)
return nil
}
2024-12-05 20:15:39 +03:00
// NewColumnSeparatorProperty creates the new ColumnSeparatorProperty.
2024-10-21 18:37:35 +03:00
//
2024-12-05 20:15:39 +03:00
// The following properties can be used:
// - "style" (Style) - Determines the line style (type is int). Valid values: 0 (NoneLine), 1 (SolidLine), 2 (DashedLine), 3 (DottedLine), or 4 (DoubleLine);
// - "color" (ColorTag) - Determines the line color (type is [Color]);
// - "width" (Width) - Determines the line thickness (type is [SizeUnit]).
func NewColumnSeparatorProperty(params Params) ColumnSeparatorProperty {
2021-09-07 17:36:50 +03:00
separator := new(columnSeparatorProperty)
2024-11-13 12:56:39 +03:00
separator.init()
2021-09-07 17:36:50 +03:00
if params != nil {
2024-11-13 12:56:39 +03:00
for _, tag := range []PropertyName{Style, Width, ColorTag} {
2021-09-07 17:36:50 +03:00
if value, ok := params[tag]; ok && value != nil {
separator.Set(tag, value)
}
}
}
return separator
}
2024-12-05 20:15:39 +03:00
// NewColumnSeparator creates the new ColumnSeparatorProperty.
//
// Arguments:
// - style - determines the line style. Valid values: 0 [NoneLine], 1 [SolidLine], 2 [DashedLine], 3 [DottedLine], or 4 [DoubleLine];
// - color - determines the line color;
// - width - determines the line thickness.
func NewColumnSeparator(style int, color Color, width SizeUnit) ColumnSeparatorProperty {
return NewColumnSeparatorProperty(Params{
Width: width,
Style: style,
ColorTag: color,
})
}
2024-11-13 12:56:39 +03:00
func (separator *columnSeparatorProperty) init() {
separator.dataProperty.init()
separator.normalize = normalizeVolumnSeparatorTag
separator.set = columnSeparatorSet
2024-11-13 12:56:39 +03:00
separator.supportedProperties = []PropertyName{Style, Width, ColorTag}
}
func normalizeVolumnSeparatorTag(tag PropertyName) PropertyName {
tag = defaultNormalize(tag)
2021-09-07 17:36:50 +03:00
switch tag {
case ColumnSeparatorStyle, "separator-style":
return Style
case ColumnSeparatorWidth, "separator-width":
return Width
case ColumnSeparatorColor, "separator-color":
return ColorTag
2021-09-07 17:36:50 +03:00
}
return tag
}
2022-05-22 12:54:02 +03:00
func (separator *columnSeparatorProperty) writeString(buffer *strings.Builder, indent string) {
buffer.WriteString("_{ ")
comma := false
2024-11-13 12:56:39 +03:00
for _, tag := range []PropertyName{Style, Width, ColorTag} {
2021-09-07 17:36:50 +03:00
if value, ok := separator.properties[tag]; ok {
2022-05-22 12:54:02 +03:00
if comma {
buffer.WriteString(", ")
}
2024-11-13 12:56:39 +03:00
buffer.WriteString(string(tag))
2022-05-22 12:54:02 +03:00
buffer.WriteString(" = ")
writePropertyValue(buffer, BorderStyle, value, indent)
comma = true
2021-09-07 17:36:50 +03:00
}
}
2022-05-22 12:54:02 +03:00
buffer.WriteString(" }")
2021-09-07 17:36:50 +03:00
}
func (separator *columnSeparatorProperty) String() string {
2022-05-22 12:54:02 +03:00
return runStringWriter(separator)
2021-09-07 17:36:50 +03:00
}
2024-11-13 12:56:39 +03:00
func getColumnSeparatorProperty(properties Properties) ColumnSeparatorProperty {
if val := properties.getRaw(ColumnSeparator); val != nil {
if separator, ok := val.(ColumnSeparatorProperty); ok {
return separator
}
2021-09-07 17:36:50 +03:00
}
return nil
}
func (separator *columnSeparatorProperty) ViewBorder(session Session) ViewBorder {
style, _ := valueToEnum(separator.getRaw(Style), BorderStyle, session, NoneLine)
width, _ := sizeProperty(separator, Width, session)
color, _ := colorProperty(separator, ColorTag, session)
2021-09-07 17:36:50 +03:00
return ViewBorder{
Style: style,
Width: width,
Color: color,
}
}
func (separator *columnSeparatorProperty) cssValue(session Session) string {
value := separator.ViewBorder(session)
buffer := allocStringBuilder()
defer freeStringBuilder(buffer)
if value.Width.Type != Auto && value.Width.Type != SizeInFraction &&
(value.Width.Value > 0 || value.Width.Type == SizeFunction) {
buffer.WriteString(value.Width.cssString("", session))
2021-09-07 17:36:50 +03:00
}
styles := enumProperties[BorderStyle].cssValues
if value.Style > 0 && value.Style < len(styles) {
if buffer.Len() > 0 {
buffer.WriteRune(' ')
}
buffer.WriteString(styles[value.Style])
}
if value.Color != 0 {
if buffer.Len() > 0 {
buffer.WriteRune(' ')
}
buffer.WriteString(value.Color.cssString())
}
return buffer.String()
}
func columnSeparatorSet(properties Properties, tag PropertyName, value any) []PropertyName {
if tag == Style {
return setEnumProperty(properties, Style, value, enumProperties[BorderStyle].values)
}
return propertiesSet(properties, tag, value)
}