2021-09-07 17:36:50 +03:00
|
|
|
package rui
|
|
|
|
|
|
|
|
import "strings"
|
|
|
|
|
|
|
|
// CustomView defines a custom view interface
|
|
|
|
type CustomView interface {
|
|
|
|
ViewsContainer
|
2024-09-12 14:05:11 +03:00
|
|
|
|
|
|
|
// CreateSuperView must be implemented to create a base view from which custom control has been built
|
2021-09-07 17:36:50 +03:00
|
|
|
CreateSuperView(session Session) View
|
2024-09-12 14:05:11 +03:00
|
|
|
|
|
|
|
// SuperView must be implemented to return a base view from which custom control has been built
|
2021-09-07 17:36:50 +03:00
|
|
|
SuperView() View
|
2024-09-12 14:05:11 +03:00
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
setSuperView(view View)
|
|
|
|
setTag(tag string)
|
|
|
|
}
|
|
|
|
|
|
|
|
// CustomViewData defines a data of a basic custom view
|
|
|
|
type CustomViewData struct {
|
2024-05-02 15:07:57 +03:00
|
|
|
tag string
|
|
|
|
superView View
|
|
|
|
defaultParams Params
|
2021-09-07 17:36:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// InitCustomView initializes fields of CustomView by default values
|
|
|
|
func InitCustomView(customView CustomView, tag string, session Session, params Params) bool {
|
|
|
|
customView.setTag(tag)
|
|
|
|
if view := customView.CreateSuperView(session); view != nil {
|
|
|
|
customView.setSuperView(view)
|
|
|
|
setInitParams(customView, params)
|
|
|
|
} else {
|
|
|
|
ErrorLog(`nil SuperView of "` + tag + `" view`)
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) init(session Session) {
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
// SuperView returns a super view
|
|
|
|
func (customView *CustomViewData) SuperView() View {
|
|
|
|
return customView.superView
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) setSuperView(view View) {
|
|
|
|
customView.superView = view
|
2024-05-02 15:07:57 +03:00
|
|
|
customView.defaultParams = Params{}
|
|
|
|
for _, tag := range view.AllTags() {
|
|
|
|
if value := view.getRaw(tag); value != nil {
|
|
|
|
customView.defaultParams[tag] = value
|
|
|
|
}
|
|
|
|
}
|
2021-09-07 17:36:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) setTag(tag string) {
|
|
|
|
customView.tag = tag
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get returns a value of the property with name defined by the argument.
|
|
|
|
// The type of return value depends on the property. If the property is not set then nil is returned.
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) Get(tag PropertyName) any {
|
2021-09-07 17:36:50 +03:00
|
|
|
return customView.superView.Get(tag)
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) getRaw(tag PropertyName) any {
|
2021-09-07 17:36:50 +03:00
|
|
|
return customView.superView.getRaw(tag)
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) setRaw(tag PropertyName, value any) {
|
2021-09-07 17:36:50 +03:00
|
|
|
customView.superView.setRaw(tag, value)
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) setContent(value any) bool {
|
|
|
|
if container, ok := customView.superView.(ViewsContainer); ok {
|
|
|
|
return container.setContent(value)
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
// Set sets the value (second argument) of the property with name defined by the first argument.
|
|
|
|
// Return "true" if the value has been set, in the opposite case "false" are returned and
|
|
|
|
// a description of the error is written to the log
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) Set(tag PropertyName, value any) bool {
|
2021-09-07 17:36:50 +03:00
|
|
|
return customView.superView.Set(tag, value)
|
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// SetAnimated sets the value (second argument) of the property with name defined by the first argument.
|
|
|
|
// Return "true" if the value has been set, in the opposite case "false" are returned and
|
|
|
|
// a description of the error is written to the log
|
2024-12-06 19:15:23 +03:00
|
|
|
func (customView *CustomViewData) SetAnimated(tag PropertyName, value any, animation AnimationProperty) bool {
|
2021-09-07 17:36:50 +03:00
|
|
|
return customView.superView.SetAnimated(tag, value, animation)
|
|
|
|
}
|
|
|
|
|
2024-09-25 13:45:47 +03:00
|
|
|
func (customView *CustomViewData) SetParams(params Params) bool {
|
|
|
|
return customView.superView.SetParams(params)
|
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// SetChangeListener set the function to track the change of the View property
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) SetChangeListener(tag PropertyName, listener func(View, PropertyName)) {
|
2021-11-20 11:15:28 +03:00
|
|
|
customView.superView.SetChangeListener(tag, listener)
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
// Remove removes the property with name defined by the argument
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) Remove(tag PropertyName) {
|
2021-09-07 17:36:50 +03:00
|
|
|
customView.superView.Remove(tag)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AllTags returns an array of the set properties
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) AllTags() []PropertyName {
|
2021-09-07 17:36:50 +03:00
|
|
|
return customView.superView.AllTags()
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) empty() bool {
|
|
|
|
return customView.superView.empty()
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
// Clear removes all properties
|
|
|
|
func (customView *CustomViewData) Clear() {
|
|
|
|
customView.superView.Clear()
|
|
|
|
}
|
|
|
|
|
2022-05-22 12:54:02 +03:00
|
|
|
func (customView *CustomViewData) cssViewStyle(buffer cssBuilder, session Session) {
|
|
|
|
customView.superView.cssViewStyle(buffer, session)
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
// Session returns a current Session interface
|
|
|
|
func (customView *CustomViewData) Session() Session {
|
|
|
|
return customView.superView.Session()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Parent returns a parent view
|
|
|
|
func (customView *CustomViewData) Parent() View {
|
|
|
|
return customView.superView.Parent()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) parentHTMLID() string {
|
|
|
|
return customView.superView.parentHTMLID()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) setParentID(parentID string) {
|
|
|
|
customView.superView.setParentID(parentID)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tag returns a tag of View interface
|
|
|
|
func (customView *CustomViewData) Tag() string {
|
|
|
|
if customView.tag != "" {
|
|
|
|
return customView.tag
|
|
|
|
}
|
|
|
|
return customView.superView.Tag()
|
|
|
|
}
|
|
|
|
|
|
|
|
// ID returns a id of the view
|
|
|
|
func (customView *CustomViewData) ID() string {
|
|
|
|
return customView.superView.ID()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Focusable returns true if the view receives the focus
|
|
|
|
func (customView *CustomViewData) Focusable() bool {
|
|
|
|
return customView.superView.Focusable()
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
// SetTransitionEndListener sets the new listener of the transition end event
|
|
|
|
func (customView *CustomViewData) SetTransitionEndListener(property string, listener TransitionEndListener) {
|
|
|
|
customView.superView.SetTransitionEndListener(property, listener)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetTransitionEndFunc sets the new listener function of the transition end event
|
|
|
|
func (customView *CustomViewData) SetTransitionEndFunc(property string, listenerFunc func(View, string)) {
|
|
|
|
customView.superView.SetTransitionEndFunc(property, listenerFunc)
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Frame returns a location and size of the view in pixels
|
|
|
|
func (customView *CustomViewData) Frame() Frame {
|
|
|
|
return customView.superView.Frame()
|
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// Scroll returns a location and size of a scrollable view in pixels
|
2021-09-07 17:36:50 +03:00
|
|
|
func (customView *CustomViewData) Scroll() Frame {
|
|
|
|
return customView.superView.Scroll()
|
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// HasFocus returns "true" if the view has focus
|
2022-01-15 01:20:04 +03:00
|
|
|
func (customView *CustomViewData) HasFocus() bool {
|
|
|
|
return customView.superView.HasFocus()
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
func (customView *CustomViewData) onResize(self View, x, y, width, height float64) {
|
|
|
|
customView.superView.onResize(customView.superView, x, y, width, height)
|
|
|
|
}
|
|
|
|
|
2022-01-15 01:20:04 +03:00
|
|
|
func (customView *CustomViewData) onItemResize(self View, index string, x, y, width, height float64) {
|
2021-09-07 17:36:50 +03:00
|
|
|
customView.superView.onItemResize(customView.superView, index, x, y, width, height)
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) handleCommand(self View, command PropertyName, data DataObject) bool {
|
2021-09-07 17:36:50 +03:00
|
|
|
return customView.superView.handleCommand(customView.superView, command, data)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) htmlClass(disabled bool) string {
|
|
|
|
return customView.superView.htmlClass(disabled)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) htmlTag() string {
|
|
|
|
return customView.superView.htmlTag()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) closeHTMLTag() bool {
|
|
|
|
return customView.superView.closeHTMLTag()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) htmlID() string {
|
|
|
|
return customView.superView.htmlID()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) htmlSubviews(self View, buffer *strings.Builder) {
|
|
|
|
customView.superView.htmlSubviews(customView.superView, buffer)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) htmlProperties(self View, buffer *strings.Builder) {
|
|
|
|
customView.superView.htmlProperties(customView.superView, buffer)
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) htmlDisabledProperty() bool {
|
|
|
|
return customView.superView.htmlDisabledProperty()
|
|
|
|
}
|
|
|
|
|
2021-09-07 17:36:50 +03:00
|
|
|
func (customView *CustomViewData) cssStyle(self View, builder cssBuilder) {
|
|
|
|
customView.superView.cssStyle(customView.superView, builder)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) addToCSSStyle(addCSS map[string]string) {
|
|
|
|
customView.superView.addToCSSStyle(addCSS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) setNoResizeEvent() {
|
|
|
|
customView.superView.setNoResizeEvent()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) isNoResizeEvent() bool {
|
|
|
|
return customView.superView.isNoResizeEvent()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Views return a list of child views
|
|
|
|
func (customView *CustomViewData) Views() []View {
|
|
|
|
if customView.superView != nil {
|
|
|
|
if container, ok := customView.superView.(ViewsContainer); ok {
|
|
|
|
return container.Views()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return []View{}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Append appends a view to the end of the list of a view children
|
|
|
|
func (customView *CustomViewData) Append(view View) {
|
|
|
|
if customView.superView != nil {
|
|
|
|
if container, ok := customView.superView.(ViewsContainer); ok {
|
|
|
|
container.Append(view)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Insert inserts a view to the "index" position in the list of a view children
|
2021-11-20 14:22:00 +03:00
|
|
|
func (customView *CustomViewData) Insert(view View, index int) {
|
2021-09-07 17:36:50 +03:00
|
|
|
if customView.superView != nil {
|
|
|
|
if container, ok := customView.superView.(ViewsContainer); ok {
|
|
|
|
container.Insert(view, index)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove removes a view from the list of a view children and return it
|
2021-11-20 14:22:00 +03:00
|
|
|
func (customView *CustomViewData) RemoveView(index int) View {
|
2021-09-07 17:36:50 +03:00
|
|
|
if customView.superView != nil {
|
|
|
|
if container, ok := customView.superView.(ViewsContainer); ok {
|
|
|
|
return container.RemoveView(index)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-04-24 21:13:45 +03:00
|
|
|
// Remove removes a view from the list of a view children and return it
|
|
|
|
func (customView *CustomViewData) ViewIndex(view View) int {
|
|
|
|
if customView.superView != nil {
|
|
|
|
if container, ok := customView.superView.(ViewsContainer); ok {
|
|
|
|
return container.ViewIndex(view)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1
|
|
|
|
}
|
|
|
|
|
2024-11-13 12:56:39 +03:00
|
|
|
func (customView *CustomViewData) exscludeTags() []PropertyName {
|
2024-05-02 15:07:57 +03:00
|
|
|
if customView.superView != nil {
|
2024-11-13 12:56:39 +03:00
|
|
|
exsclude := []PropertyName{}
|
2024-05-02 15:07:57 +03:00
|
|
|
for tag, value := range customView.defaultParams {
|
|
|
|
if value == customView.superView.getRaw(tag) {
|
|
|
|
exsclude = append(exsclude, tag)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return exsclude
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// String convert internal representation of a [CustomViewData] into a string.
|
2021-09-07 17:36:50 +03:00
|
|
|
func (customView *CustomViewData) String() string {
|
|
|
|
if customView.superView != nil {
|
2024-11-13 12:56:39 +03:00
|
|
|
buffer := allocStringBuilder()
|
|
|
|
defer freeStringBuilder(buffer)
|
|
|
|
writeViewStyle(customView.tag, customView, buffer, "", customView.exscludeTags())
|
|
|
|
return buffer.String()
|
2021-09-07 17:36:50 +03:00
|
|
|
}
|
|
|
|
return customView.tag + " { }"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (customView *CustomViewData) setScroll(x, y, width, height float64) {
|
|
|
|
if customView.superView != nil {
|
|
|
|
customView.superView.setScroll(x, y, width, height)
|
|
|
|
}
|
|
|
|
}
|
2021-10-04 17:58:17 +03:00
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// Transition returns the transition animation of the property(tag). Returns nil is there is no transition animation.
|
2024-12-06 19:15:23 +03:00
|
|
|
func (customView *CustomViewData) Transition(tag PropertyName) AnimationProperty {
|
2021-10-04 17:58:17 +03:00
|
|
|
if customView.superView != nil {
|
2022-08-10 15:36:38 +03:00
|
|
|
return customView.superView.Transition(tag)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// Transitions returns a map of transition animations. The result is always non-nil.
|
2024-12-06 19:15:23 +03:00
|
|
|
func (customView *CustomViewData) Transitions() map[PropertyName]AnimationProperty {
|
2022-08-10 15:36:38 +03:00
|
|
|
if customView.superView != nil {
|
|
|
|
return customView.superView.Transitions()
|
|
|
|
}
|
2024-12-06 19:15:23 +03:00
|
|
|
return map[PropertyName]AnimationProperty{}
|
2022-08-10 15:36:38 +03:00
|
|
|
}
|
|
|
|
|
2024-09-12 14:05:11 +03:00
|
|
|
// SetTransition sets the transition animation for the property if "animation" argument is not nil, and
|
|
|
|
// removes the transition animation of the property if "animation" argument is nil.
|
|
|
|
// The "tag" argument is the property name.
|
2024-12-06 19:15:23 +03:00
|
|
|
func (customView *CustomViewData) SetTransition(tag PropertyName, animation AnimationProperty) {
|
2022-08-10 15:36:38 +03:00
|
|
|
if customView.superView != nil {
|
|
|
|
customView.superView.SetTransition(tag, animation)
|
2021-10-04 17:58:17 +03:00
|
|
|
}
|
|
|
|
}
|