mirror of https://github.com/anoshenko/rui.git
416 lines
20 KiB
Go
416 lines
20 KiB
Go
package rui
|
||
|
||
// Constants for various specific properties of a views
|
||
const (
|
||
// Visible - default value of the view Visibility property: View is visible
|
||
Visible = 0
|
||
|
||
// Invisible - value of the view Visibility property: View is invisible but takes place
|
||
Invisible = 1
|
||
|
||
// Gone - value of the view Visibility property: View is invisible and does not take place
|
||
Gone = 2
|
||
|
||
// OverflowHidden - value of the view "overflow" property:
|
||
// Content is clipped if necessary to fit the padding box. No scrollbars are provided,
|
||
// and no support for allowing the user to scroll (such as by dragging or using a scroll wheel) is allowed.
|
||
// The content can be scrolled programmatically, so the element is still a scroll container.
|
||
OverflowHidden = 0
|
||
|
||
// OverflowVisible - value of the view "overflow" property:
|
||
// Content is not clipped and may be rendered outside the padding box.
|
||
OverflowVisible = 1
|
||
|
||
// OverflowScroll - value of the view "overflow" property:
|
||
// Content is clipped if necessary to fit the padding box. Browsers always display scrollbars whether or
|
||
// not any content is actually clipped, preventing scrollbars from appearing or disappearing as content changes.
|
||
OverflowScroll = 2
|
||
|
||
// OverflowAuto - value of the view "overflow" property:
|
||
// Depends on the browser user agent. If content fits inside the padding box, it looks the same as OverflowVisible,
|
||
// but still establishes a new block formatting context. Desktop browsers provide scrollbars if content overflows.
|
||
OverflowAuto = 3
|
||
|
||
// NoneTextTransform - not transform text
|
||
NoneTextTransform = 0
|
||
|
||
// CapitalizeTextTransform - capitalize text
|
||
CapitalizeTextTransform = 1
|
||
|
||
// LowerCaseTextTransform - transform text to lower case
|
||
LowerCaseTextTransform = 2
|
||
|
||
// UpperCaseTextTransform - transform text to upper case
|
||
UpperCaseTextTransform = 3
|
||
|
||
// HorizontalTopToBottom - content flows horizontally from left to right, vertically from top to bottom.
|
||
// The next horizontal line is positioned below the previous line.
|
||
HorizontalTopToBottom = 0
|
||
|
||
// HorizontalBottomToTop - content flows horizontally from left to right, vertically from bottom to top.
|
||
// The next horizontal line is positioned above the previous line.
|
||
HorizontalBottomToTop = 1
|
||
|
||
// VerticalRightToLeft - content flows vertically from top to bottom, horizontally from right to left.
|
||
// The next vertical line is positioned to the left of the previous line.
|
||
VerticalRightToLeft = 2
|
||
|
||
// VerticalLeftToRight - content flows vertically from top to bottom, horizontally from left to right.
|
||
// The next vertical line is positioned to the right of the previous line.
|
||
VerticalLeftToRight = 3
|
||
|
||
// MixedTextOrientation - rotates the characters of horizontal scripts 90° clockwise.
|
||
// Lays out the characters of vertical scripts naturally. Default value.
|
||
MixedTextOrientation = 0
|
||
|
||
// UprightTextOrientation - lays out the characters of horizontal scripts naturally (upright),
|
||
// as well as the glyphs for vertical scripts. Note that this keyword causes all characters
|
||
// to be considered as left-to-right: the used value of "text-direction" is forced to be "left-to-right".
|
||
UprightTextOrientation = 1
|
||
|
||
// SystemTextDirection - direction of a text and other elements defined by system. This is the default value.
|
||
SystemTextDirection = 0
|
||
|
||
// LeftToRightDirection - text and other elements go from left to right.
|
||
LeftToRightDirection = 1
|
||
|
||
//RightToLeftDirection - text and other elements go from right to left.
|
||
RightToLeftDirection = 2
|
||
|
||
// ThinFont - the value of "text-weight" property: the thin (hairline) text weight
|
||
ThinFont = 1
|
||
|
||
// ExtraLightFont - the value of "text-weight" property: the extra light (ultra light) text weight
|
||
ExtraLightFont = 2
|
||
|
||
// LightFont - the value of "text-weight" property: the light text weight
|
||
LightFont = 3
|
||
|
||
// NormalFont - the value of "text-weight" property (default value): the normal text weight
|
||
NormalFont = 4
|
||
|
||
// MediumFont - the value of "text-weight" property: the medium text weight
|
||
MediumFont = 5
|
||
|
||
// SemiBoldFont - the value of "text-weight" property: the semi bold (demi bold) text weight
|
||
SemiBoldFont = 6
|
||
|
||
// BoldFont - the value of "text-weight" property: the bold text weight
|
||
BoldFont = 7
|
||
|
||
// ExtraBoldFont - the value of "text-weight" property: the extra bold (ultra bold) text weight
|
||
ExtraBoldFont = 8
|
||
|
||
// BlackFont - the value of "text-weight" property: the black (heavy) text weight
|
||
BlackFont = 9
|
||
|
||
// TopAlign - top vertical-align for the "vertical-align" property
|
||
TopAlign = 0
|
||
|
||
// BottomAlign - bottom vertical-align for the "vertical-align" property
|
||
BottomAlign = 1
|
||
|
||
// LeftAlign - the left horizontal-align for the "horizontal-align" property
|
||
LeftAlign = 0
|
||
|
||
// RightAlign - the right horizontal-align for the "horizontal-align" property
|
||
RightAlign = 1
|
||
|
||
// CenterAlign - the center horizontal/vertical-align for the "horizontal-align"/"vertical-align" property
|
||
CenterAlign = 2
|
||
|
||
// StretchAlign - the stretch horizontal/vertical-align for the "horizontal-align"/"vertical-align" property
|
||
StretchAlign = 3
|
||
|
||
// JustifyAlign - the justify text align for "text-align" property
|
||
JustifyAlign = 3
|
||
|
||
// BaselineAlign - the baseline cell-vertical-align for the "cell-vertical-align" property
|
||
BaselineAlign = 4
|
||
|
||
// WhiteSpaceNormal - sequences of white space are collapsed. Newline characters in the source
|
||
// are handled the same as other white space. Lines are broken as necessary to fill line boxes.
|
||
WhiteSpaceNormal = 0
|
||
|
||
// WhiteSpaceNowrap - collapses white space as for normal, but suppresses line breaks (text wrapping)
|
||
// within the source.
|
||
WhiteSpaceNowrap = 1
|
||
|
||
// WhiteSpacePre - sequences of white space are preserved. Lines are only broken at newline
|
||
// characters in the source and at <br> elements.
|
||
WhiteSpacePre = 2
|
||
|
||
// WhiteSpacePreWrap - Sequences of white space are preserved. Lines are broken at newline
|
||
// characters, at <br>, and as necessary to fill line boxes.
|
||
WhiteSpacePreWrap = 3
|
||
|
||
// WhiteSpacePreLine - sequences of white space are collapsed. Lines are broken at newline characters,
|
||
// at <br>, and as necessary to fill line boxes.
|
||
WhiteSpacePreLine = 4
|
||
|
||
// WhiteSpaceBreakSpaces - the behavior is identical to that of WhiteSpacePreWrap, except that:
|
||
// * Any sequence of preserved white space always takes up space, including at the end of the line.
|
||
// * A line breaking opportunity exists after every preserved white space character, including between white space characters.
|
||
// * Such preserved spaces take up space and do not hang, and thus affect the box’s intrinsic sizes (min-content size and max-content size).
|
||
WhiteSpaceBreakSpaces = 5
|
||
|
||
// WordBreakNormal - use the default line break rule.
|
||
WordBreakNormal = 0
|
||
|
||
// WordBreakAll - to prevent overflow, word breaks should be inserted between any two characters
|
||
// (excluding Chinese/Japanese/Korean text).
|
||
WordBreakAll = 1
|
||
|
||
// WordBreakKeepAll - word breaks should not be used for Chinese/Japanese/Korean (CJK) text.
|
||
// Non-CJK text behavior is the same as for normal.
|
||
WordBreakKeepAll = 2
|
||
|
||
// WordBreakWord - when the block boundaries are exceeded, the remaining whole words can be split
|
||
// in an arbitrary place, unless a more suitable place for the line break is found.
|
||
WordBreakWord = 3
|
||
|
||
// TextOverflowClip - truncate the text at the limit of the content area, therefore the truncation
|
||
// can happen in the middle of a character.
|
||
TextOverflowClip = 0
|
||
|
||
// TextOverflowEllipsis - display an ellipsis ('…', U+2026 HORIZONTAL ELLIPSIS) to represent clipped text.
|
||
// The ellipsis is displayed inside the content area, decreasing the amount of text displayed.
|
||
// If there is not enough space to display the ellipsis, it is clipped.
|
||
TextOverflowEllipsis = 1
|
||
|
||
// DefaultSemantics - default value of the view Semantic property
|
||
DefaultSemantics = 0
|
||
|
||
// ArticleSemantics - value of the view Semantic property: view represents a self-contained
|
||
// composition in a document, page, application, or site, which is intended to be
|
||
// independently distributable or reusable (e.g., in syndication)
|
||
ArticleSemantics = 1
|
||
|
||
// SectionSemantics - value of the view Semantic property: view represents
|
||
// a generic standalone section of a document, which doesn't have a more specific
|
||
// semantic element to represent it.
|
||
SectionSemantics = 2
|
||
|
||
// AsideSemantics - value of the view Semantic property: view represents a portion
|
||
// of a document whose content is only indirectly related to the document's main content.
|
||
// Asides are frequently presented as sidebars or call-out boxes.
|
||
AsideSemantics = 3
|
||
|
||
// HeaderSemantics - value of the view Semantic property: view represents introductory
|
||
// content, typically a group of introductory or navigational aids. It may contain
|
||
// some heading elements but also a logo, a search form, an author name, and other elements.
|
||
HeaderSemantics = 4
|
||
|
||
// MainSemantics - value of the view Semantic property: view represents the dominant content
|
||
// of the application. The main content area consists of content that is directly related
|
||
// to or expands upon the central topic of a document, or the central functionality of an application.
|
||
MainSemantics = 5
|
||
|
||
// FooterSemantics - value of the view Semantic property: view represents a footer for its
|
||
// nearest sectioning content or sectioning root element. A footer view typically contains
|
||
// information about the author of the section, copyright data or links to related documents.
|
||
FooterSemantics = 6
|
||
|
||
// NavigationSemantics - value of the view Semantic property: view represents a section of
|
||
// a page whose purpose is to provide navigation links, either within the current document
|
||
// or to other documents. Common examples of navigation sections are menus, tables of contents,
|
||
// and indexes.
|
||
NavigationSemantics = 7
|
||
|
||
// FigureSemantics - value of the view Semantic property: view represents self-contained content,
|
||
// potentially with an optional caption, which is specified using the FigureCaptionSemantics view.
|
||
FigureSemantics = 8
|
||
|
||
// FigureCaptionSemantics - value of the view Semantic property: view represents a caption or
|
||
// legend describing the rest of the contents of its parent FigureSemantics view.
|
||
FigureCaptionSemantics = 9
|
||
|
||
// ButtonSemantics - value of the view Semantic property: view a clickable button
|
||
ButtonSemantics = 10
|
||
|
||
// ParagraphSemantics - value of the view Semantic property: view represents a paragraph.
|
||
// Paragraphs are usually represented in visual media as blocks of text separated
|
||
// from adjacent blocks by blank lines and/or first-line indentation
|
||
ParagraphSemantics = 11
|
||
|
||
// H1Semantics - value of the view Semantic property: view represent of first level section headings.
|
||
// H1Semantics is the highest section level and H6Semantics is the lowest.
|
||
H1Semantics = 12
|
||
|
||
// H2Semantics - value of the view Semantic property: view represent of second level section headings.
|
||
// H1Semantics is the highest section level and H6Semantics is the lowest.
|
||
H2Semantics = 13
|
||
|
||
// H3Semantics - value of the view Semantic property: view represent of third level section headings.
|
||
// H1Semantics is the highest section level and H6Semantics is the lowest.
|
||
H3Semantics = 14
|
||
|
||
// H4Semantics - value of the view Semantic property: view represent of fourth level section headings.
|
||
// H1Semantics is the highest section level and H6Semantics is the lowest.
|
||
H4Semantics = 15
|
||
|
||
// H5Semantics - value of the view Semantic property: view represent of fifth level section headings.
|
||
// H1Semantics is the highest section level and H6Semantics is the lowest.
|
||
H5Semantics = 16
|
||
|
||
// H6Semantics - value of the view Semantic property: view represent of sixth level section headings.
|
||
// H1Semantics is the highest section level and H6Semantics is the lowest.
|
||
H6Semantics = 17
|
||
|
||
// BlockquoteSemantics - value of the view Semantic property: view indicates that
|
||
// the enclosed text is an extended quotation.
|
||
BlockquoteSemantics = 18
|
||
|
||
// CodeSemantics - value of the view Semantic property: view displays its contents styled
|
||
// in a fashion intended to indicate that the text is a short fragment of computer code
|
||
CodeSemantics = 19
|
||
|
||
// NoneFloat - value of the view "float" property: the View must not float.
|
||
NoneFloat = 0
|
||
|
||
// LeftFloat - value of the view "float" property: the View must float on the left side of its containing block.
|
||
LeftFloat = 1
|
||
|
||
// RightFloat - value of the view "float" property: the View must float on the right side of its containing block.
|
||
RightFloat = 2
|
||
|
||
// NoneResize - value of the view "resize" property: the View The offers no user-controllable method for resizing it.
|
||
NoneResize = 0
|
||
|
||
// BothResize - value of the view "resize" property: the View displays a mechanism for allowing
|
||
// the user to resize it, which may be resized both horizontally and vertically.
|
||
BothResize = 1
|
||
|
||
// HorizontalResize - value of the view "resize" property: the View displays a mechanism for allowing
|
||
// the user to resize it in the horizontal direction.
|
||
HorizontalResize = 2
|
||
|
||
// VerticalResize - value of the view "resize" property: the View displays a mechanism for allowing
|
||
// the user to resize it in the vertical direction.
|
||
VerticalResize = 3
|
||
|
||
// RowAutoFlow - value of the "grid-auto-flow" property of the GridLayout:
|
||
// Views are placed by filling each row in turn, adding new rows as necessary.
|
||
RowAutoFlow = 0
|
||
|
||
// ColumnAutoFlow - value of the "grid-auto-flow" property of the GridLayout:
|
||
// Views are placed by filling each column in turn, adding new columns as necessary.
|
||
ColumnAutoFlow = 1
|
||
|
||
// RowDenseAutoFlow - value of the "grid-auto-flow" property of the GridLayout:
|
||
// Views are placed by filling each row, adding new rows as necessary.
|
||
// "dense" packing algorithm attempts to fill in holes earlier in the grid, if smaller items come up later.
|
||
// This may cause views to appear out-of-order, when doing so would fill in holes left by larger views.
|
||
RowDenseAutoFlow = 2
|
||
|
||
// ColumnDenseAutoFlow - value of the "grid-auto-flow" property of the GridLayout:
|
||
// Views are placed by filling each column, adding new columns as necessary.
|
||
// "dense" packing algorithm attempts to fill in holes earlier in the grid, if smaller items come up later.
|
||
// This may cause views to appear out-of-order, when doing so would fill in holes left by larger views.
|
||
ColumnDenseAutoFlow = 3
|
||
|
||
// BlendNormal - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the top color, regardless of what the bottom color is.
|
||
// The effect is like two opaque pieces of paper overlapping.
|
||
BlendNormal = 0
|
||
|
||
// BlendMultiply - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of multiplying the top and bottom colors.
|
||
// A black layer leads to a black final layer, and a white layer leads to no change.
|
||
// The effect is like two images printed on transparent film overlapping.
|
||
BlendMultiply = 1
|
||
|
||
// BlendScreen - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of inverting the colors, multiplying them, and inverting that value.
|
||
// A black layer leads to no change, and a white layer leads to a white final layer.
|
||
// The effect is like two images shone onto a projection screen.
|
||
BlendScreen = 2
|
||
|
||
// BlendOverlay - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of multiply if the bottom color is darker, or screen if the bottom color is lighter.
|
||
// This blend mode is equivalent to hard-light but with the layers swapped.
|
||
BlendOverlay = 3
|
||
|
||
// BlendDarken - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is composed of the darkest values of each color channel.
|
||
BlendDarken = 4
|
||
|
||
// BlendLighten - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is composed of the lightest values of each color channel.
|
||
BlendLighten = 5
|
||
|
||
// BlendColorDodge - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of dividing the bottom color by the inverse of the top color.
|
||
// A black foreground leads to no change. A foreground with the inverse color of the backdrop leads to a fully lit color.
|
||
// This blend mode is similar to screen, but the foreground need only be as light as the inverse of the backdrop to create a fully lit color.
|
||
BlendColorDodge = 6
|
||
|
||
// BlendColorBurn - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of inverting the bottom color, dividing the value by the top color, and inverting that value.
|
||
// A white foreground leads to no change. A foreground with the inverse color of the backdrop leads to a black final image.
|
||
// This blend mode is similar to multiply, but the foreground need only be as dark as the inverse of the backdrop to make the final image black.
|
||
BlendColorBurn = 7
|
||
|
||
// BlendHardLight - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of multiply if the top color is darker, or screen if the top color is lighter.
|
||
// This blend mode is equivalent to overlay but with the layers swapped. The effect is similar to shining a harsh spotlight on the backdrop.
|
||
BlendHardLight = 8
|
||
|
||
// BlendSoftLight - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is similar to hard-light, but softer. This blend mode behaves similar to hard-light.
|
||
// The effect is similar to shining a diffused spotlight on the backdrop*.*
|
||
BlendSoftLight = 9
|
||
|
||
// BlendDifference - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is the result of subtracting the darker of the two colors from the lighter one.
|
||
// A black layer has no effect, while a white layer inverts the other layer's color.
|
||
BlendDifference = 10
|
||
|
||
// BlendExclusion - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color is similar to difference, but with less contrast.
|
||
// As with difference, a black layer has no effect, while a white layer inverts the other layer's color.
|
||
BlendExclusion = 11
|
||
|
||
// BlendHue - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color has the hue of the top color, while using the saturation and luminosity of the bottom color.
|
||
BlendHue = 12
|
||
|
||
// BlendSaturation - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color has the saturation of the top color, while using the hue and luminosity of the bottom color.
|
||
// A pure gray backdrop, having no saturation, will have no effect.
|
||
BlendSaturation = 13
|
||
|
||
// BlendColor - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color has the hue and saturation of the top color, while using the luminosity of the bottom color.
|
||
// The effect preserves gray levels and can be used to colorize the foreground.
|
||
BlendColor = 14
|
||
|
||
// BlendLuminosity - value of the "mix-blend-mode" and "background-blend-mode" property:
|
||
// The final color has the luminosity of the top color, while using the hue and saturation of the bottom color.
|
||
// This blend mode is equivalent to BlendColor, but with the layers swapped.
|
||
BlendLuminosity = 15
|
||
|
||
// ColumnFillBalance - value of the "column-fill" property: content is equally divided between columns.
|
||
ColumnFillBalance = 0
|
||
|
||
// ColumnFillAuto - value of the "column-fill" property:
|
||
// Columns are filled sequentially. Content takes up only the room it needs, possibly resulting in some columns remaining empty.
|
||
ColumnFillAuto = 1
|
||
|
||
// TextWrapOn - value of the "text-wrap" property:
|
||
// text is wrapped across lines at appropriate characters (for example spaces,
|
||
// in languages like English that use space separators) to minimize overflow.
|
||
TextWrapOn = 0
|
||
|
||
// TextWrapOff - value of the "text-wrap" property: text does not wrap across lines.
|
||
// It will overflow its containing element rather than breaking onto a new line.
|
||
TextWrapOff = 1
|
||
|
||
// TextWrapBalance - value of the "text-wrap" property: text is wrapped in a way
|
||
// that best balances the number of characters on each line, enhancing layout quality
|
||
// and legibility. Because counting characters and balancing them across multiple lines
|
||
// is computationally expensive, this value is only supported for blocks of text
|
||
// spanning a limited number of lines (six or less for Chromium and ten or less for Firefox).
|
||
TextWrapBalance = 2
|
||
)
|