2023-05-25 13:59:13 +00:00
<div>
<layout:Container>
<h1>Input</h1>
<p>Clickable components support the <view:CodeInline>EventClick</view:CodeInline> event that handlers can be registered to with <view:CodeInline>@Click="c.handleButton(event)"</view:CodeInline></p>
<view:Code>
<pre vg-content='"func (c *PageInput) handleButton(event input.ClickEvent) {\n" +
" c.button1Counter++\n" +
"}"' style="margin: 0;"></pre>
</view:Code>
<p>Data binding...</p>
<h2>Button</h2>
<p>Simple example with click handler:</p>
<view:Code>
<pre vg-content='"<input:Button @Click=\"c.button1Counter++\"><div vg-content=\"fmt.Sprintf(`Button pressed %d times`, c.button1Counter)\"></div></input:Button>"' style="margin: 0;"></pre>
</view:Code>
<input:Button @Click="c.button1Counter++"><div vg-content='fmt.Sprintf("Button pressed %d times", c.button1Counter)'></div></input:Button>
<p>Symbols can be attached to buttons:</p>
<view:Code>
<pre vg-content='"<input:Button>\n" +
" <vg-slot name=\"IconSlot\"><icons:LDocument></icons:LDocument></vg-slot>\n" +
" <vg-slot name=\"DefaultSlot\"><div>Some text</div></vg-slot>\n" +
"</input:Button>"' style="margin: 0;"></pre>
</view:Code>
<input:Button>
<vg-slot name="IconSlot"><icons:LDocument></icons:LDocument></vg-slot>
<vg-slot name="DefaultSlot"><div>Some text</div></vg-slot>
</input:Button>
<p>Use the <view:CodeInline>d3c-button-vertical</view:CodeInline> CSS class to align the button content vertically:</p>
<view:Code>
<pre vg-content='"<input:Button class=\"d3c-button-vertical\">\n" +
" <vg-slot name=\"IconSlot\"><icons:LGlobe style=\"font-size: 2em;\"></icons:LGlobe></vg-slot>\n" +
" <vg-slot name=\"DefaultSlot\"><div>Something</div></vg-slot>\n" +
"</input:Button>"' style="margin: 0;"></pre>
</view:Code>
<input:Button class="d3c-button-vertical">
<vg-slot name="IconSlot"><icons:LGlobe style="font-size: 2em;"></icons:LGlobe></vg-slot>
<vg-slot name="DefaultSlot">Something</vg-slot>
</input:Button>
2023-05-25 14:37:46 +00:00
<p>Buttons can be bound to boolean variables, in this case they will function as a toggle:</p>
<view:Code>
<pre vg-content='"<input:Button :Bind=\"&c.button4Bool\">Toggle me!</input:Button>"' style="margin: 0;"></pre>
</view:Code>
<input:Button :Bind="&c.button4Bool">Toggle me!</input:Button>
<span vg-content="fmt.Sprintf(`Boolean is set to %v.`, c.button4Bool)"></span>
2023-05-25 13:59:13 +00:00
2023-06-23 18:41:04 +00:00
<h2>Radio buttons</h2>
<view:Code>
2023-07-02 22:18:58 +00:00
<pre vg-content='"<input:RadioButton id=\"page-radio-button-1-a\" :Bind=\"input.ValueBindAny{&c.radioButton1}\" Key=\"A\"></input:RadioButton>\n" +
2023-06-23 18:41:04 +00:00
"<label for=\"page-radio-button-1-a\">Option A</label>"' style="margin: 0;"></pre>
</view:Code>
2023-07-02 22:18:58 +00:00
<input:RadioButton id="page-radio-button-1-a" :Bind="input.ValueBindAny{&c.radioButton1}" Key="A"></input:RadioButton>
2023-06-23 18:41:04 +00:00
<label for="page-radio-button-1-a">Option A</label>
<br>
2023-07-02 22:18:58 +00:00
<input:RadioButton id="page-radio-button-1-b" :Bind="input.ValueBindAny{&c.radioButton1}" Key="B"></input:RadioButton>
2023-06-23 18:41:04 +00:00
<label for="page-radio-button-1-b">Option B</label>
<br>
2023-07-02 22:18:58 +00:00
<input:RadioButton id="page-radio-button-1-c" :Bind="input.ValueBindAny{&c.radioButton1}" Key="C"></input:RadioButton>
2023-06-23 18:41:04 +00:00
<label for="page-radio-button-1-c">Option C</label>
<div vg-content="fmt.Sprintf(`Selected option is %q.`, c.radioButton1)"></div>
<h2>Checkboxes</h2>
<view:Code>
<pre vg-content='"<input:CheckBox id=\"page-checkBox-1\" :Bind=\"&c.checkBox1\"></input:CheckBox>\n" +
"<label for=\"page-checkBox-1\">Click this to toggle the checkBox</label>"' style="margin: 0;"></pre>
</view:Code>
<input:CheckBox id="page-checkBox-1" :Bind="&c.checkBox1"></input:CheckBox>
<label for="page-checkBox-1">Click this to toggle the checkbox</label>
<div vg-content="fmt.Sprintf(`Boolean is set to %v.`, c.checkBox1)"></div>
<input:CheckBox id="page-checkBox-2" :Bind="&c.checkBox2"></input:CheckBox>
<label for="page-checkBox-2">Click this to toggle the pre-checked checkbox</label>
2023-05-25 13:59:13 +00:00
<h2>Input fields</h2>
<p>Input fields can be bound to data. They will automatically change their type based on the bound data type.</p>
2023-06-04 15:45:27 +00:00
<p>To make labels work correctly, you have to use the <view:CodeInline>ID="some-id"</view:CodeInline> tag (uppercase ID), which will set the ID of the embedded input element!</p>
2023-05-25 13:59:13 +00:00
<view:Code>
<pre vg-content='"<label for=\"page-input-1\">Some input field</label>\n" +
2023-07-02 22:18:58 +00:00
"<input:Field ID=\"page-input-1\" :Bind=\"input.ValueBindAny{&c.inputField1String}\"></input:Field>"' style="margin: 0;"></pre>
2023-05-25 13:59:13 +00:00
</view:Code>
<label for="page-input-1">Some input field bound to string value</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-1" :Bind="input.ValueBindAny{&c.inputField1String}"></input:Field>
2023-05-25 15:44:44 +00:00
<span vg-content='fmt.Sprintf("Current value is %q.", c.inputField1String)'></span>
2023-05-25 13:59:13 +00:00
<br>
<label for="page-input-2">Some input field bound to integer value</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-2" :Bind="input.ValueBindAny{&c.inputField2Int}"></input:Field>
2023-05-25 15:44:44 +00:00
<span vg-content='fmt.Sprintf("Current value is %v.", c.inputField2Int)'></span>
2023-05-25 13:59:13 +00:00
<br>
<label for="page-input-3">Some input field bound to float value</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-3" :Bind="input.ValueBindAny{&c.inputField3Float}"></input:Field>
2023-05-25 15:44:44 +00:00
<span vg-content='fmt.Sprintf("Current value is %v.", c.inputField3Float)'></span>
2023-06-23 18:41:04 +00:00
<br>
<label for="page-input-6">Some input field bound to bool value</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-6" :Bind="input.ValueBindAny{&c.inputField6Bool}"></input:Field>
2023-06-23 18:41:04 +00:00
<span vg-content='fmt.Sprintf("Current state is %v.", c.inputField6Bool)'></span>
2023-06-23 19:10:35 +00:00
<p>For passwords you have to set the <view:CodeInline>Type="password"</view:CodeInline> field of the component:</p>
2023-05-25 15:20:12 +00:00
<label for="page-input-4">Some input field bound to password string</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-4" :Bind="input.ValueBindAny{&c.inputField4String}" Type="password"></input:Field>
2023-05-25 15:44:44 +00:00
<span vg-content='fmt.Sprintf("Secret password is %q.", c.inputField4String)'></span>
<p>You can add additional buttons to the input field:</p>
<label for="page-input-5">Some input field with some extra button</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-5" :Bind="input.ValueBindAny{&c.inputField5String}">
2023-05-25 15:44:44 +00:00
<input:Button :Bind="&c.inputField5Bool">
<icons:LLockOpened vg-if="!c.inputField5Bool" class="d3c-button-borderless"></icons:LLockOpened>
<icons:LLockClosed vg-if="c.inputField5Bool" class="d3c-button-borderless"></icons:LLockClosed>
</input:Button>
<input:Button>
<icons:LGlobe></icons:LGlobe>
</input:Button>
</input:Field>
2023-06-23 19:10:35 +00:00
<p>time.Time is also supported:</p>
<label for="page-input-7">Some input field bound to a time.Time value</label>
2023-07-02 22:18:58 +00:00
<input:Field ID="page-input-7" :Bind="input.ValueBindAny{&c.inputField7Time}"></input:Field>
2023-06-23 19:10:35 +00:00
<span vg-content='fmt.Sprintf("Selected date and time is %v.", c.inputField7Time)'></span>
2023-05-25 15:20:12 +00:00
2023-05-27 11:37:40 +00:00
<h2>Drop-down</h2>
<label for="page-dropdown-1">Select a slice entry</label>
2023-07-02 22:18:58 +00:00
<input:Dropdown id="page-dropdown-1" :Bind="input.ValueBindAny{Value: &c.dropdown1Index}" :BindList="input.ListBindGenericSlice[string]{Slice: &c.dropdown1Slice}"></input:Dropdown>
2023-05-27 11:37:40 +00:00
<span vg-content='fmt.Sprintf("The selected index is %d.", c.dropdown1Index)'></span>
2023-06-02 09:17:22 +00:00
<h2>Tags</h2>
<p>Select or change the list of tags</p>
<input:Tags :Bind="input.ListBindGenericSlice[string]{Slice: &c.tags1Slice}" id="page-tags-1"></input:Tags>
2023-06-26 22:23:07 +00:00
<h2>Text-area</h2>
2024-12-30 12:54:41 +00:00
<input:TextArea :Bind="input.ValueBindAny{&c.textArea1}" id="page-text-area-1" rows="10" style="width:100%; resize:none; box-sizing:border-box;"></input:TextArea>
2023-06-26 22:23:07 +00:00
<pre vg-content='fmt.Sprintf("Your entered text: %s", c.textArea1)'></pre>
2023-05-25 13:59:13 +00:00
</layout:Container>
</div>
<style>
</style>
<script type="application/x-go">
import (
"git.d3nexus.de/Dadido3/D3vugu-components/components/input"
"git.d3nexus.de/Dadido3/D3vugu-components/components/layout"
//"git.d3nexus.de/Dadido3/D3vugu-components/components/navigation"
"git.d3nexus.de/Dadido3/D3vugu-components/components/view"
"git.d3nexus.de/Dadido3/D3vugu-components/icons"
)
</script>