mirror of https://github.com/anoshenko/rui.git
				
				
				
			Updated tabs styles
This commit is contained in:
		
							parent
							
								
									59acf03260
								
							
						
					
					
						commit
						3e93ea4bb9
					
				
							
								
								
									
										19
									
								
								README-ru.md
								
								
								
								
							
							
						
						
									
										19
									
								
								README-ru.md
								
								
								
								
							|  | @ -2488,26 +2488,15 @@ Cвойства "tab-close-button" может быть задано как дл | |||
| Что позволяет легко реализовать вкладки с помощью ListView. Именно в этом случаи и применяется значение HiddenTabs. | ||||
| 
 | ||||
| При отображении текущей (выбранной) вкладки типа TopTabs, BottomTabs, LeftListTabs и RightListTabs используется  | ||||
| стиль "ruiActiveTab", а для вкладки типа LeftTabs и RightTabs используется стиль "ruiActiveVerticalTab". | ||||
| стиль "ruiCurrentTab", а для вкладки типа LeftTabs и RightTabs используется стиль "ruiCurrentVerticalTab". | ||||
| Если вы хотите кастомизировать отображение вкладок, то вы можите либо переопределить данные стили, либо | ||||
| назначить свой стиль с помощью свойства "current-tab-style" (константа CurrentTabStyle). | ||||
| 
 | ||||
| Соответственно, для неактивной вкладки используются стили "ruiInactiveTab" и "ruiInactiveVerticalTab", а  | ||||
| Соответственно, для неактивной вкладки используются стили "ruiTab" и "ruiVerticalTab", а  | ||||
| назначить свой стиль можно с помощью свойства "tab-style" (константа TabStyle). | ||||
| 
 | ||||
| Также при отображении вкладок используется следующие константы и стили: | ||||
| 
 | ||||
| * "ruiTabHeight" - SizeUnit константа задает высоту панели вкладок; | ||||
| 
 | ||||
| * "ruiTabSpace" - SizeUnit константа задает расстояние между вкладками; | ||||
| 
 | ||||
| * "ruiTabsPadding" - SizeUnit или BoundsProperty константа задает отступ от внутри панели вкладок; | ||||
| 
 | ||||
| * "ruiTabsBackgroundColor" - цвет фона панели закладок; | ||||
| 
 | ||||
| * "ruiTabCloseButton" - стиль кнопки закрытия вкладки. | ||||
| 
 | ||||
| Вы можете переопределять данные константы и стили для кастимизации панели вкладок | ||||
| Для отображения панели вкладок используется стиль "ruiTabBar", а  | ||||
| назначить свой стиль можно с помощью свойства "tab-bar-style" (константа TabBarStyle). | ||||
| 
 | ||||
| ## AbsoluteLayout | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										21
									
								
								README.md
								
								
								
								
							
							
						
						
									
										21
									
								
								README.md
								
								
								
								
							|  | @ -2455,27 +2455,16 @@ the "tabs" integer property (the Tabs constant). This property can take on the f | |||
| Why do I need the value HiddenTabs. The point is that TabsLayout implements the ListAdapter interface. | ||||
| Which makes it easy to implement tabs with a ListView. This is where the HiddenTabs value comes in. | ||||
| 
 | ||||
| When displaying the current (selected) tabs of type TopTabs, BottomTabs, LeftListTabs and RightListTabs,  | ||||
| the style is "ruiActiveTab", and for tabs of type LeftTabs and RightTabs, the style is "ruiActiveVerticalTab". | ||||
| For displaying the current (selected) tab of type TopTabs, BottomTabs, LeftListTabs and RightListTabs,  | ||||
| the "ruiCurrentTab" style is used, and for tab of type LeftTabs and RightTabs, the "ruiCurrentVerticalTab" style is used. | ||||
| If you want to customize the display of tabs, you can either override these styles, or assign your own style using  | ||||
| the "current-tab-style" property (constant CurrentTabStyle). | ||||
| 
 | ||||
| Accordingly, for an inactive tab, the "ruiInactiveTab" and "ruiInactiveVerticalTab" styles are used,  | ||||
| Accordingly, for an inactive tab, the "ruiTab" and "ruiVerticalTab" styles are used,  | ||||
| and you can assign your own style using the "tab-style" property (constant TabStyle). | ||||
| 
 | ||||
| Also, when displaying tabs, the following constants and styles are used: | ||||
| 
 | ||||
| * "ruiTabHeight" - the SizeUnit constant sets the height of the tab bar; | ||||
| 
 | ||||
| * "ruiTabSpace" - the SizeUnit constant sets the distance between tabs; | ||||
| 
 | ||||
| * "ruiTabsPadding" - the SizeUnit or BoundsProperty constant sets the indentation from the inside of the tab bar; | ||||
| 
 | ||||
| * "ruiTabsBackgroundColor" - background color of the tabs bar; | ||||
| 
 | ||||
| * "ruiTabCloseButton" - style of the button for closing the tab. | ||||
| 
 | ||||
| You can override these constants and styles to customize the tab bar | ||||
| The "ruiTabBar" style is used to display the tab bar, and you can assign your own style  | ||||
| using the "tab-bar-style" property (constant TabBarStyle). | ||||
| 
 | ||||
| ## AbsoluteLayout | ||||
| 
 | ||||
|  |  | |||
|  | @ -17,11 +17,11 @@ theme { | |||
| 		ruiPopupTitleColor = #FF0000FF, | ||||
| 		ruiPopupTitleTextColor = #FFFFFFFF, | ||||
| 
 | ||||
| 		ruiTabsBackgroundColor = #FFEEEEEE, | ||||
| 		ruiInactiveTabColor = #FFD0D0D0, | ||||
| 		ruiInactiveTabTextColor = #FF202020, | ||||
| 		ruiActiveTabColor = #FFFFFFFF, | ||||
| 		ruiActiveTabTextColor = #FF000000, | ||||
| 		ruiTabBarBackgroundColor = #FFEEEEEE, | ||||
| 		ruiTabColor = #FFD0D0D0, | ||||
| 		ruiTabTextColor = #FF202020, | ||||
| 		ruiCurrentTabColor = #FFFFFFFF, | ||||
| 		ruiCurrentTabTextColor = #FF000000, | ||||
| 	}, | ||||
| 	colors:dark = _{ | ||||
| 		ruiTextColor = #FFE0E0E0, | ||||
|  | @ -34,11 +34,11 @@ theme { | |||
| 		ruiHighlightColor = #FF1A74E8, | ||||
| 		ruiHighlightTextColor = #FFFFFFFF, | ||||
| 
 | ||||
| 		ruiTabsBackgroundColor = #FF303030, | ||||
| 		ruiInactiveTabColor = #FF606060, | ||||
| 		ruiInactiveTabTextColor = #FFE0E0E0, | ||||
| 		ruiActiveTabColor = #FF000000, | ||||
| 		ruiActiveTabTextColor = #FFFFFFFF, | ||||
| 		ruiTabBarBackgroundColor = #FF303030, | ||||
| 		ruiTabColor = #FF606060, | ||||
| 		ruiTabTextColor = #FFE0E0E0, | ||||
| 		ruiCurrentTabColor = #FF000000, | ||||
| 		ruiCurrentTabTextColor = #FFFFFFFF, | ||||
| 	}, | ||||
| 	constants = _{ | ||||
| 		ruiButtonHorizontalPadding = 16px, | ||||
|  | @ -53,9 +53,9 @@ theme { | |||
| 		ruiPopupTitleHeight = 32px, | ||||
| 		ruiPopupTitlePadding = 8px, | ||||
| 		ruiPopupButtonGap = 4px, | ||||
| 		ruiTabSpace = 2px, | ||||
| 		ruiTabMargin = 1px, | ||||
| 		ruiTabHeight = 32px, | ||||
| 		ruiTabsPadding = 2px, | ||||
| 		ruiTabBarPadding = 2px, | ||||
| 		ruiTabRadius = 2px, | ||||
| 	}, | ||||
| 	constants:touch = _{ | ||||
|  | @ -118,32 +118,43 @@ theme { | |||
| 			background-color=@ruiHighlightColor, | ||||
| 			text-color=@ruiHighlightTextColor, | ||||
| 		}, | ||||
| 		ruiActiveTab { | ||||
| 			background-color = @ruiActiveTabColor, | ||||
| 			text-color = @ruiActiveTabTextColor, | ||||
| 		ruiTabBar { | ||||
| 			background-color = @ruiTabBarBackgroundColor, | ||||
| 		} | ||||
| 		ruiCurrentTab { | ||||
| 			min-height = @ruiTabHeight, | ||||
| 			background-color = @ruiCurrentTabColor, | ||||
| 			text-color = @ruiCurrentTabTextColor, | ||||
| 			padding-left = 4px, | ||||
| 			padding-right = 4px, | ||||
| 			margin = @ruiTabMargin, | ||||
| 			radius = @ruiTabRadius, | ||||
| 		}, | ||||
| 		ruiInactiveTab { | ||||
| 			background-color = @ruiInactiveTabColor, | ||||
| 			text-color = @ruiInactiveTabTextColor, | ||||
| 		ruiTab { | ||||
| 			min-height = @ruiTabHeight, | ||||
| 			background-color = @ruiTabColor, | ||||
| 			text-color = @ruiTabTextColor, | ||||
| 			padding-left = 4px, | ||||
| 			padding-right = 4px, | ||||
| 			margin = @ruiTabMargin, | ||||
| 			radius = @ruiTabRadius, | ||||
| 		}, | ||||
| 		ruiActiveVerticalTab { | ||||
| 			background-color = @ruiActiveTabColor, | ||||
| 			text-color = @ruiActiveTabTextColor, | ||||
| 		ruiCurrentVerticalTab { | ||||
| 			min-width = @ruiTabHeight, | ||||
| 			background-color = @ruiCurrentTabColor, | ||||
| 			text-color = @ruiCurrentTabTextColor, | ||||
| 			padding-top = 4px, | ||||
| 			padding-bottom = 4px, | ||||
| 			margin = @ruiTabMargin, | ||||
| 			radius = @ruiTabRadius, | ||||
| 		}, | ||||
| 		ruiInactiveVerticalTab { | ||||
| 			background-color = @ruiInactiveTabColor, | ||||
| 			text-color = @ruiInactiveTabTextColor, | ||||
| 		ruiVerticalTab { | ||||
| 			min-width = @ruiTabHeight, | ||||
| 			background-color = @ruiTabColor, | ||||
| 			text-color = @ruiTabTextColor, | ||||
| 			padding-top = 4px, | ||||
| 			padding-bottom = 4px, | ||||
| 			margin = @ruiTabMargin, | ||||
| 			radius = @ruiTabRadius, | ||||
| 		}, | ||||
| 		ruiTabCloseButton { | ||||
|  | @ -155,7 +166,7 @@ theme { | |||
| 			text-size = 16px, | ||||
| 		}, | ||||
| 		ruiTabCloseButton:hover { | ||||
| 			background-color = @ruiTabsBackgroundColor, | ||||
| 			background-color = @ruiTabBarBackgroundColor, | ||||
| 			radius = 3px, | ||||
| 		}, | ||||
| 		ruiPopup { | ||||
|  |  | |||
|  | @ -395,12 +395,6 @@ const ( | |||
| 	Anchor = "anchor" | ||||
| 	// Gap is the constant for the "gap" property tag.
 | ||||
| 	Gap = "gap" | ||||
| 	// Tabs is the constant for the "tabs" property tag.
 | ||||
| 	Tabs = "tabs" | ||||
| 	// TabStyle is the constant for the "tab-style" property tag.
 | ||||
| 	TabStyle = "tab-style" | ||||
| 	// CurrentTabStyle is the constant for the "current-tab-style" property tag.
 | ||||
| 	CurrentTabStyle = "current-tab-style" | ||||
| 	// Text is the constant for the "text" property tag.
 | ||||
| 	Text = "text" | ||||
| 	// VerticalAlign is the constant for the "vertical-align" property tag.
 | ||||
|  |  | |||
							
								
								
									
										101
									
								
								tabsLayout.go
								
								
								
								
							
							
						
						
									
										101
									
								
								tabsLayout.go
								
								
								
								
							|  | @ -27,6 +27,26 @@ const ( | |||
| 	// The main listener format: func(TabsLayout, int), where the second argument is the index of the tab.
 | ||||
| 	TabCloseEvent = "tab-close-event" | ||||
| 
 | ||||
| 	// Tabs is the constant for the "tabs" property tag.
 | ||||
| 	// The "tabs" is the int property that sets where the tabs are located.
 | ||||
| 	// Valid values: TopTabs (0), BottomTabs (1), LeftTabs (2), RightTabs (3), LeftListTabs (4), RightListTabs (5), and HiddenTabs (6).
 | ||||
| 	Tabs = "tabs" | ||||
| 
 | ||||
| 	// TabBarStyle is the constant for the "tab-bar-style" property tag.
 | ||||
| 	// The "tab-bar-style" is the string property that sets the style for the display of the tab bar.
 | ||||
| 	// The default value is "ruiTabBar".
 | ||||
| 	TabBarStyle = "tab-bar-style" | ||||
| 
 | ||||
| 	// TabStyle is the constant for the "tab-style" property tag.
 | ||||
| 	// The "tab-style" is the string property that sets the style for the display of the tab.
 | ||||
| 	// The default value is "ruiTab" or "ruiVerticalTab".
 | ||||
| 	TabStyle = "tab-style" | ||||
| 
 | ||||
| 	// CurrentTabStyle is the constant for the "current-tab-style" property tag.
 | ||||
| 	// The "current-tab-style" is the string property that sets the style for the display of the current (selected) tab.
 | ||||
| 	// The default value is "ruiCurrentTab" or "ruiCurrentVerticalTab".
 | ||||
| 	CurrentTabStyle = "current-tab-style" | ||||
| 
 | ||||
| 	// TopTabs - tabs of TabsLayout are on the top
 | ||||
| 	TopTabs = 0 | ||||
| 	// BottomTabs - tabs of TabsLayout are on the bottom
 | ||||
|  | @ -463,15 +483,22 @@ func (tabsLayout *tabsLayoutData) tabsLocation() int { | |||
| 	return tabs | ||||
| } | ||||
| 
 | ||||
| func (tabsLayout *tabsLayoutData) tabBarStyle() string { | ||||
| 	if style, ok := stringProperty(tabsLayout, TabBarStyle, tabsLayout.session); ok { | ||||
| 		return style | ||||
| 	} | ||||
| 	return "ruiTabBar" | ||||
| } | ||||
| 
 | ||||
| func (tabsLayout *tabsLayoutData) inactiveTabStyle() string { | ||||
| 	if style, ok := stringProperty(tabsLayout, TabStyle, tabsLayout.session); ok { | ||||
| 		return style | ||||
| 	} | ||||
| 	switch tabsLayout.tabsLocation() { | ||||
| 	case LeftTabs, RightTabs: | ||||
| 		return "ruiInactiveVerticalTab" | ||||
| 		return "ruiVerticalTab" | ||||
| 	} | ||||
| 	return "ruiInactiveTab" | ||||
| 	return "ruiTab" | ||||
| } | ||||
| 
 | ||||
| func (tabsLayout *tabsLayoutData) activeTabStyle() string { | ||||
|  | @ -480,9 +507,9 @@ func (tabsLayout *tabsLayoutData) activeTabStyle() string { | |||
| 	} | ||||
| 	switch tabsLayout.tabsLocation() { | ||||
| 	case LeftTabs, RightTabs: | ||||
| 		return "ruiActiveVerticalTab" | ||||
| 		return "ruiCurrentVerticalTab" | ||||
| 	} | ||||
| 	return "ruiActiveTab" | ||||
| 	return "ruiCurrentTab" | ||||
| } | ||||
| 
 | ||||
| func (tabsLayout *tabsLayoutData) ListSize() int { | ||||
|  | @ -685,10 +712,10 @@ func (tabsLayout *tabsLayoutData) htmlSubviews(self View, buffer *strings.Builde | |||
| 	tabsLayoutID := tabsLayout.htmlID() | ||||
| 
 | ||||
| 	if location != HiddenTabs { | ||||
| 		tabsHeight, _ := sizeConstant(tabsLayout.session, "ruiTabHeight") | ||||
| 		tabsSpace, _ := sizeConstant(tabsLayout.session, "ruiTabSpace") | ||||
| 		rowLayout := false | ||||
| 		buffer.WriteString(`<div style="display: flex;`) | ||||
| 
 | ||||
| 		buffer.WriteString(`<div class="`) | ||||
| 		buffer.WriteString(tabsLayout.tabBarStyle()) | ||||
| 		buffer.WriteString(`" style="display: flex;`) | ||||
| 
 | ||||
| 		switch location { | ||||
| 		case LeftTabs, LeftListTabs, TopTabs: | ||||
|  | @ -708,40 +735,6 @@ func (tabsLayout *tabsLayoutData) htmlSubviews(self View, buffer *strings.Builde | |||
| 
 | ||||
| 		default: | ||||
| 			buffer.WriteString(`row nowrap; justify-content: flex-start; align-items: stretch;`) | ||||
| 			if tabsHeight.Type != Auto { | ||||
| 				buffer.WriteString(` height: `) | ||||
| 				buffer.WriteString(tabsHeight.cssString("")) | ||||
| 				buffer.WriteByte(';') | ||||
| 			} | ||||
| 			rowLayout = true | ||||
| 		} | ||||
| 
 | ||||
| 		switch location { | ||||
| 		case LeftTabs, RightTabs: | ||||
| 			if tabsHeight.Type != Auto { | ||||
| 				buffer.WriteString(` width: `) | ||||
| 				buffer.WriteString(tabsHeight.cssString("")) | ||||
| 				buffer.WriteByte(';') | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		var tabsPadding Bounds | ||||
| 		if value, ok := tabsLayout.session.Constant("ruiTabsPadding"); ok { | ||||
| 			if tabsPadding.parse(value, tabsLayout.session) { | ||||
| 				if !tabsPadding.allFieldsAuto() { | ||||
| 					buffer.WriteByte(' ') | ||||
| 					buffer.WriteString(Padding) | ||||
| 					buffer.WriteString(`: `) | ||||
| 					tabsPadding.writeCSSString(buffer, "0") | ||||
| 					buffer.WriteByte(';') | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if tabsBackground, ok := tabsLayout.session.Color("ruiTabsBackgroundColor"); ok { | ||||
| 			buffer.WriteString(` background-color: `) | ||||
| 			buffer.WriteString(tabsBackground.cssString()) | ||||
| 			buffer.WriteByte(';') | ||||
| 		} | ||||
| 
 | ||||
| 		buffer.WriteString(`">`) | ||||
|  | @ -752,34 +745,18 @@ func (tabsLayout *tabsLayoutData) htmlSubviews(self View, buffer *strings.Builde | |||
| 		notTranslate := GetNotTranslate(tabsLayout, "") | ||||
| 		closeButton, _ := boolProperty(tabsLayout, TabCloseButton, tabsLayout.session) | ||||
| 
 | ||||
| 		tabMargin := "" | ||||
| 		if tabsSpace.Type != Auto && tabsSpace.Value > 0 { | ||||
| 			if rowLayout { | ||||
| 				tabMargin = ` margin-right: ` + tabsSpace.cssString("") + ";" | ||||
| 			} else { | ||||
| 				tabMargin = ` margin-bottom: ` + tabsSpace.cssString("") + ";" | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		var tabStyle, titleDiv string | ||||
| 		switch location { | ||||
| 		case LeftTabs, RightTabs: | ||||
| 			tabStyle = `display: grid; grid-template-rows: auto 1fr auto; align-items: center; justify-items: center; grid-row-gap: 8px;` | ||||
| 
 | ||||
| 		case LeftListTabs, RightListTabs: | ||||
| 			tabStyle = `display: grid; grid-template-columns: auto 1fr auto; align-items: start; justify-items: center; grid-column-gap: 8px;` | ||||
| 			tabStyle = `display: grid; grid-template-columns: auto 1fr auto; align-items: center; justify-items: start; grid-column-gap: 8px;` | ||||
| 
 | ||||
| 		default: | ||||
| 			tabStyle = `display: grid; grid-template-columns: auto 1fr auto; align-items: center; justify-items: center; grid-column-gap: 8px;` | ||||
| 		} | ||||
| 
 | ||||
| 		switch location { | ||||
| 		case LeftListTabs, RightListTabs: | ||||
| 			if tabsHeight.Type != Auto { | ||||
| 				tabStyle += ` height: ` + tabsHeight.cssString("") + ";" | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		switch location { | ||||
| 		case LeftTabs: | ||||
| 			titleDiv = `<div style="writing-mode: vertical-lr; transform: rotate(180deg); grid-row-start: 2; grid-row-end: 3; grid-column-start: 1; grid-column-end: 2;">` | ||||
|  | @ -791,7 +768,6 @@ func (tabsLayout *tabsLayoutData) htmlSubviews(self View, buffer *strings.Builde | |||
| 			titleDiv = `<div style="grid-row-start: 1; grid-row-end: 2; grid-column-start: 2; grid-column-end: 3;">` | ||||
| 		} | ||||
| 
 | ||||
| 		last := len(tabsLayout.views) - 1 | ||||
| 		for n, view := range tabsLayout.views { | ||||
| 			icon, _ := stringProperty(view, Icon, tabsLayout.session) | ||||
| 			title, _ := stringProperty(view, Title, tabsLayout.session) | ||||
|  | @ -819,11 +795,6 @@ func (tabsLayout *tabsLayoutData) htmlSubviews(self View, buffer *strings.Builde | |||
| 			buffer.WriteString(strconv.Itoa(n)) | ||||
| 			buffer.WriteString(`, event)" style="`) | ||||
| 			buffer.WriteString(tabStyle) | ||||
| 
 | ||||
| 			if n != last { | ||||
| 				buffer.WriteString(tabMargin) | ||||
| 			} | ||||
| 
 | ||||
| 			buffer.WriteString(`" data-container="`) | ||||
| 			buffer.WriteString(tabsLayoutID) | ||||
| 			buffer.WriteString(`" data-view="`) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue