1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
#------------------------------------------------------------------------------
# Copyright (c) 2013-2025, Nucleic Development Team.
#
# Distributed under the terms of the Modified BSD License.
#
# The full license is in the file LICENSE, distributed with this software.
#------------------------------------------------------------------------------
""" An example of using chained Enaml aliases.
This example is functionally equivalent to 'chained_widget_alias.enaml',
but it shows how the developer can exert more control over a widget by
exposing individual attributes instead of entire widgets.
<< autodoc-me >>
"""
from enaml.widgets.api import Window, Container, Slider, Field, GroupBox
enamldef InternalBox(GroupBox):
""" The internal content box.
The slider is aliased via 'slider'.
"""
alias slider
title = 'Inner Box'
Slider: slider:
pass
enamldef OuterBox(GroupBox):
""" The outer content box.
The internal slider value is aliased via 'slider_value'.
"""
alias slider_value: internal.slider.value
title = 'Outer Box'
InternalBox: internal:
pass
enamldef Main(Window):
""" The main application window.
This window uses a chained alias to bind the inner slider of the
group boxes to the other slider in the main window. It also uses
a subscription on the chained alias to update a read only field.
"""
title = 'Chained Attribute Alias'
Container:
OuterBox: outer:
slider_value := slider.value
Slider: slider:
value = 50
Field:
read_only = True
text << str(outer.slider_value)
|